aboutsummaryrefslogtreecommitdiff
path: root/lib/CodeGen/TargetMachine/Sparc
diff options
context:
space:
mode:
authorVikram S. Adve <vadve@cs.uiuc.edu>2001-08-06 21:06:10 +0000
committerVikram S. Adve <vadve@cs.uiuc.edu>2001-08-06 21:06:10 +0000
commit98a9c979e271ee24bf5f87baed5050cf9c8b236d (patch)
tree004523860f2e9ad45107f4779b02a7871a859fc1 /lib/CodeGen/TargetMachine/Sparc
parent6a0c6d82a9eb2c136298af38d9bf5fcaf288c676 (diff)
Add CC operand as 4th operand of SUBcc, and mark it as a def.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@348 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/TargetMachine/Sparc')
-rw-r--r--lib/CodeGen/TargetMachine/Sparc/SparcInstrSelection.cpp11
1 files changed, 5 insertions, 6 deletions
diff --git a/lib/CodeGen/TargetMachine/Sparc/SparcInstrSelection.cpp b/lib/CodeGen/TargetMachine/Sparc/SparcInstrSelection.cpp
index 901ad0053f..b472febbdd 100644
--- a/lib/CodeGen/TargetMachine/Sparc/SparcInstrSelection.cpp
+++ b/lib/CodeGen/TargetMachine/Sparc/SparcInstrSelection.cpp
@@ -479,12 +479,11 @@ GetInstructionsByRule(InstructionNode* subtreeRoot,
mvec[0] = new MachineInstr(SUBcc);
Set3OperandsFromInstr(mvec[0], subtreeRoot, target, discardResult);
- if (discardResult)
- {// mark the "result" operand as being a CC register
- mvec[0]->SetMachineOperand(2, MachineOperand::MO_CCRegister,
- subtreeRoot->getValue());
- }
- else
+ // mark the 4th operand as being a CC register, and a "result"
+ mvec[0]->SetMachineOperand(3, MachineOperand::MO_CCRegister,
+ subtreeRoot->getValue(), /*def*/ true);
+
+ if (!discardResult)
{ // recompute bool if needed, using the integer condition codes
if (result->getOpcode() == Instruction::SetNE)
discardResult = true;