diff options
| author | Anton Korobeynikov <asl@math.spbu.ru> | 2009-10-08 20:43:22 +0000 |
|---|---|---|
| committer | Anton Korobeynikov <asl@math.spbu.ru> | 2009-10-08 20:43:22 +0000 |
| commit | 222b86cd54e732cf1b9ec66fe103c54211b6e44a (patch) | |
| tree | b25d9fa0e247014a21e4ff88a3e474ffb25d0f79 /llvm/lib | |
| parent | e1969dcd110261be9cd09d28a993d2dc5feadb9f (diff) | |
| download | bcm5719-llvm-222b86cd54e732cf1b9ec66fe103c54211b6e44a.tar.gz bcm5719-llvm-222b86cd54e732cf1b9ec66fe103c54211b6e44a.zip | |
Use lower16 / upper16 imm modifiers to asmprint 32-bit imms splitted via movt/movw pair.
llvm-svn: 83572
Diffstat (limited to 'llvm/lib')
| -rw-r--r-- | llvm/lib/Target/ARM/AsmPrinter/ARMAsmPrinter.cpp | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/llvm/lib/Target/ARM/AsmPrinter/ARMAsmPrinter.cpp b/llvm/lib/Target/ARM/AsmPrinter/ARMAsmPrinter.cpp index bdaae222203..1679e12be0e 100644 --- a/llvm/lib/Target/ARM/AsmPrinter/ARMAsmPrinter.cpp +++ b/llvm/lib/Target/ARM/AsmPrinter/ARMAsmPrinter.cpp @@ -329,13 +329,14 @@ void ARMAsmPrinter::printOperand(const MachineInstr *MI, int OpNum, } case MachineOperand::MO_Immediate: { int64_t Imm = MO.getImm(); + O << '#'; if (Modifier) { if (strcmp(Modifier, "lo16") == 0) - Imm = Imm & 0xffffLL; + O << ":lower16:"; else if (strcmp(Modifier, "hi16") == 0) - Imm = (Imm & 0xffff0000LL) >> 16; + O << ":upper16:"; } - O << '#' << Imm; + O << Imm; break; } case MachineOperand::MO_MachineBasicBlock: |

