1 #include "codegen/nv50_ir_target_nvc0.h" 2 3 namespace nv50_ir { 4 5 class TargetGM107 : public TargetNVC0 6 { 7 public: TargetGM107(unsigned int chipset)8 TargetGM107(unsigned int chipset) : TargetNVC0(chipset) {} 9 10 virtual CodeEmitter *getCodeEmitter(Program::Type); 11 CodeEmitter *createCodeEmitterGM107(Program::Type); 12 13 virtual bool runLegalizePass(Program *, CGStage) const; 14 15 virtual void getBuiltinCode(const uint32_t **, uint32_t *) const; 16 virtual uint32_t getBuiltinOffset(int) const; 17 18 virtual bool isOpSupported(operation, DataType) const; 19 virtual bool isReuseSupported(const Instruction *) const; 20 21 virtual bool isBarrierRequired(const Instruction *) const; 22 23 virtual bool canDualIssue(const Instruction *, const Instruction *) const; 24 virtual int getLatency(const Instruction *) const; 25 virtual int getReadLatency(const Instruction *) const; 26 27 virtual bool isCS2RSV(SVSemantic) const; 28 }; 29 30 } // namespace nv50_ir 31