mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-25 10:27:04 +00:00 
			
		
		
		
	per a suggestion by Frits van Bommel, mark all MBlaze Pseudo
instructions as isCodeGenOnly in the parent class instead of sprinkling it throughout the .td files. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@118125 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		| @@ -124,7 +124,7 @@ let isAsCheapAsAMove = 1 in { | ||||
| } | ||||
|  | ||||
|  | ||||
| let usesCustomInserter = 1, isCodeGenOnly = 1 in { | ||||
| let usesCustomInserter = 1 in { | ||||
|   def Select_FCC : MBlazePseudo<(outs GPR:$dst), | ||||
|     (ins GPR:$T, GPR:$F, GPR:$CMP, i32imm:$CC), | ||||
|     "; SELECT_FCC PSEUDO!", | ||||
|   | ||||
| @@ -49,8 +49,7 @@ def FC      : Format<18>; // NOP | ||||
|  | ||||
| // Generic MBlaze Format | ||||
| class MBlazeInst<bits<6> op, Format form, dag outs, dag ins, string asmstr,  | ||||
|                  list<dag> pattern, InstrItinClass itin> : Instruction  | ||||
| { | ||||
|                  list<dag> pattern, InstrItinClass itin> : Instruction { | ||||
|   let Namespace = "MBlaze"; | ||||
|   field bits<32> Inst; | ||||
|  | ||||
| @@ -61,6 +60,10 @@ class MBlazeInst<bits<6> op, Format form, dag outs, dag ins, string asmstr, | ||||
|   // Top 6 bits are the 'opcode' field | ||||
|   let Inst{0-5} = opcode;    | ||||
|    | ||||
|   // If the instruction is marked as a pseudo, set isCodeGenOnly so that the | ||||
|   // assembler and disassmbler ignore it. | ||||
|   let isCodeGenOnly = !eq(!cast<string>(form), "FPseudo"); | ||||
|    | ||||
|   dag OutOperandList = outs; | ||||
|   dag InOperandList  = ins; | ||||
|  | ||||
|   | ||||
| @@ -125,7 +125,7 @@ def xaddr : ComplexPattern<i32, 2, "SelectAddrRegReg", [], []>; | ||||
| //===----------------------------------------------------------------------===// | ||||
|  | ||||
| // As stack alignment is always done with addiu, we need a 16-bit immediate | ||||
| let Defs = [R1], Uses = [R1], isCodeGenOnly = 1 in { | ||||
| let Defs = [R1], Uses = [R1] in { | ||||
| def ADJCALLSTACKDOWN : MBlazePseudo<(outs), (ins simm16:$amt), | ||||
|                                   "#ADJCALLSTACKDOWN $amt", | ||||
|                                   [(callseq_start timm:$amt)]>; | ||||
| @@ -526,7 +526,7 @@ let neverHasSideEffects = 1 in { | ||||
|   def NOP :  MBlazeInst< 0x20, FC, (outs), (ins), "nop    ", [], IIAlu>; | ||||
| } | ||||
|  | ||||
| let usesCustomInserter = 1, isCodeGenOnly = 1 in { | ||||
| let usesCustomInserter = 1 in { | ||||
|   def Select_CC : MBlazePseudo<(outs GPR:$dst), | ||||
|     (ins GPR:$T, GPR:$F, GPR:$CMP, i32imm:$CC), | ||||
|     "; SELECT_CC PSEUDO!", | ||||
|   | ||||
		Reference in New Issue
	
	Block a user