aboutsummaryrefslogtreecommitdiffstats
path: root/lib/Target/ARM/ARMMCCodeEmitter.cpp
diff options
context:
space:
mode:
authorJim Grosbach <grosbach@apple.com>2010-10-12 18:09:12 +0000
committerJim Grosbach <grosbach@apple.com>2010-10-12 18:09:12 +0000
commitf59818b81ad75e43727bf8143b64386c82b77fe9 (patch)
treef86790e2c9db5fc6f36fe9293db7f47f1e15732b /lib/Target/ARM/ARMMCCodeEmitter.cpp
parent320afb8c818b5cd5b9d4fcd0dba83ba3384ed4b4 (diff)
downloadexternal_llvm-f59818b81ad75e43727bf8143b64386c82b77fe9.zip
external_llvm-f59818b81ad75e43727bf8143b64386c82b77fe9.tar.gz
external_llvm-f59818b81ad75e43727bf8143b64386c82b77fe9.tar.bz2
Add MOVi ARM encoding.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@116321 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/ARM/ARMMCCodeEmitter.cpp')
-rw-r--r--lib/Target/ARM/ARMMCCodeEmitter.cpp7
1 files changed, 7 insertions, 0 deletions
diff --git a/lib/Target/ARM/ARMMCCodeEmitter.cpp b/lib/Target/ARM/ARMMCCodeEmitter.cpp
index 1c4ad26..b2584f9 100644
--- a/lib/Target/ARM/ARMMCCodeEmitter.cpp
+++ b/lib/Target/ARM/ARMMCCodeEmitter.cpp
@@ -150,6 +150,13 @@ EncodeInstruction(const MCInst &MI, raw_ostream &OS,
unsigned Value = getBinaryCodeForInstr(MI);
switch (Opcode) {
default: break;
+ case ARM::MOVi:
+ // The 's' bit.
+ if (MI.getOperand(4).getReg() == ARM::CPSR)
+ Value |= 1 << ARMII::S_BitShift;
+ // The shifted immediate value.
+ Value |= getMachineSoImmOpValue((unsigned)MI.getOperand(1).getImm());
+ break;
case ARM::ADDri:
case ARM::ANDri:
case ARM::BICri: