mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-25 10:27:04 +00:00 
			
		
		
		
	Clean up LEApcrel instuction(s) a bit. It's not really a Pseudo, so don't mark
it as such. Add some encoding information. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@119588 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		| @@ -455,6 +455,14 @@ void ARMCodeEmitter::emitInstruction(const MachineInstr &MI) { | ||||
|     llvm_unreachable("Unhandled instruction encoding format!"); | ||||
|     break; | ||||
|   } | ||||
|   case ARMII::MiscFrm: | ||||
|     if (MI.getOpcode() == ARM::LEApcrelJT) { | ||||
|       // Materialize jumptable address. | ||||
|       emitLEApcrelJTInstruction(MI); | ||||
|       break; | ||||
|     } | ||||
|     llvm_unreachable("Unhandled instruction encoding!"); | ||||
|     break; | ||||
|   case ARMII::Pseudo: | ||||
|     emitPseudoInstruction(MI); | ||||
|     break; | ||||
|   | ||||
| @@ -1168,21 +1168,27 @@ def PICSTRB : AXI2stb<(outs), (ins GPR:$src, addrmodepc:$addr, pred:$p), | ||||
|  | ||||
| // LEApcrel - Load a pc-relative address into a register without offending the | ||||
| // assembler. | ||||
| // FIXME: These are marked as pseudos, but they're really not(?). They're just | ||||
| // the ADR instruction. Is this the right way to handle that? They need | ||||
| // encoding information regardless. | ||||
| let neverHasSideEffects = 1 in { | ||||
| let isReMaterializable = 1 in | ||||
| def LEApcrel : AXI1<0x0, (outs GPR:$dst), (ins i32imm:$label, pred:$p), | ||||
|                     Pseudo, IIC_iALUi, | ||||
|                     "adr$p\t$dst, #$label", []>; | ||||
| // FIXME: We want one cannonical LEApcrel instruction and to express one or | ||||
| // both of these as pseudo-instructions that get expanded to it. | ||||
| def LEApcrel : AXI1<0, (outs GPR:$Rd), (ins i32imm:$label, pred:$p), | ||||
|                     MiscFrm, IIC_iALUi, | ||||
|                     "adr$p\t$Rd, #$label", []>; | ||||
|  | ||||
| } // neverHasSideEffects | ||||
| def LEApcrelJT : AXI1<0x0, (outs GPR:$dst), | ||||
| def LEApcrelJT : AXI1<0b0100, (outs GPR:$Rd), | ||||
|                            (ins i32imm:$label, nohash_imm:$id, pred:$p), | ||||
|                       Pseudo, IIC_iALUi, | ||||
|                       "adr$p\t$dst, #${label}_${id}", []> { | ||||
|     let Inst{25} = 1; | ||||
|                       MiscFrm, IIC_iALUi, | ||||
|                       "adr$p\t$Rd, #${label}_${id}", []> { | ||||
|   bits<4> p; | ||||
|   bits<4> Rd; | ||||
|   let Inst{31-28} = p; | ||||
|   let Inst{27-25} = 0b001; | ||||
|   let Inst{20} = 0; | ||||
|   let Inst{19-16} = 0b1111; | ||||
|   let Inst{15-12} = Rd; | ||||
|   // FIXME: Add label encoding/fixup | ||||
| } | ||||
|  | ||||
| //===----------------------------------------------------------------------===// | ||||
|   | ||||
		Reference in New Issue
	
	Block a user