summaryrefslogtreecommitdiffstats
path: root/llvm
diff options
context:
space:
mode:
authorBill Wendling <isanbard@gmail.com>2010-11-29 22:37:46 +0000
committerBill Wendling <isanbard@gmail.com>2010-11-29 22:37:46 +0000
commitee7c5659d77c0eeb2e74101b0f884f25516d19f5 (patch)
treef376941b897e7ffc6992867061bacf690faa42c6 /llvm
parent7ec3d34553386ea5ea9be792bf7e2b204c7f695a (diff)
downloadbcm5719-llvm-ee7c5659d77c0eeb2e74101b0f884f25516d19f5.tar.gz
bcm5719-llvm-ee7c5659d77c0eeb2e74101b0f884f25516d19f5.zip
Thumb encodings for conditional moves.
llvm-svn: 120334
Diffstat (limited to 'llvm')
-rw-r--r--llvm/lib/Target/ARM/ARMInstrThumb.td16
1 files changed, 14 insertions, 2 deletions
diff --git a/llvm/lib/Target/ARM/ARMInstrThumb.td b/llvm/lib/Target/ARM/ARMInstrThumb.td
index 5ac8b98832a..5dae5bd7a9b 100644
--- a/llvm/lib/Target/ARM/ARMInstrThumb.td
+++ b/llvm/lib/Target/ARM/ARMInstrThumb.td
@@ -1210,12 +1210,24 @@ let usesCustomInserter = 1 in // Expanded after instruction selection.
let neverHasSideEffects = 1 in {
def tMOVCCr : T1pIt<(outs GPR:$dst), (ins GPR:$lhs, GPR:$rhs), IIC_iCMOVr,
"mov", "\t$dst, $rhs", []>,
- T1Special<{1,0,?,?}>;
+ T1Special<{1,0,?,?}> {
+ bits<4> rhs;
+ bits<4> dst;
+ let Inst{7} = dst{3};
+ let Inst{6-3} = rhs;
+ let Inst{2-0} = dst{2-0};
+}
let isMoveImm = 1 in
def tMOVCCi : T1pIt<(outs tGPR:$dst), (ins tGPR:$lhs, i32imm:$rhs), IIC_iCMOVi,
"mov", "\t$dst, $rhs", []>,
- T1General<{1,0,0,?,?}>;
+ T1General<{1,0,0,?,?}> {
+ bits<8> rhs;
+ bits<3> dst;
+ let Inst{10-8} = dst;
+ let Inst{7-0} = rhs;
+}
+
} // neverHasSideEffects
// tLEApcrel - Load a pc-relative address into a register without offending the
OpenPOWER on IntegriCloud