diff options
-rw-r--r-- | lib/CodeGen/InstrSelection/InstrSelectionSupport.cpp | 7 | ||||
-rw-r--r-- | lib/Target/SparcV9/InstrSelection/InstrSelectionSupport.cpp | 7 |
2 files changed, 8 insertions, 6 deletions
diff --git a/lib/CodeGen/InstrSelection/InstrSelectionSupport.cpp b/lib/CodeGen/InstrSelection/InstrSelectionSupport.cpp index 8f35be8a07..ff214500db 100644 --- a/lib/CodeGen/InstrSelection/InstrSelectionSupport.cpp +++ b/lib/CodeGen/InstrSelection/InstrSelectionSupport.cpp @@ -91,9 +91,10 @@ ChooseRegOrImmed(Value* val, // To use reg or immed, constant needs to be integer, bool, or a NULL pointer Constant *CPV = dyn_cast<Constant>(val); - if (CPV == NULL || - (! CPV->getType()->isIntegral() && - ! (isa<PointerType>(CPV->getType()) && CPV->isNullValue()))) + if (CPV == NULL + || CPV->isConstantExpr() + || (! CPV->getType()->isIntegral() && + ! (isa<PointerType>(CPV->getType()) && CPV->isNullValue()))) return MachineOperand::MO_VirtualRegister; // Now get the constant value and check if it fits in the IMMED field. diff --git a/lib/Target/SparcV9/InstrSelection/InstrSelectionSupport.cpp b/lib/Target/SparcV9/InstrSelection/InstrSelectionSupport.cpp index 8f35be8a07..ff214500db 100644 --- a/lib/Target/SparcV9/InstrSelection/InstrSelectionSupport.cpp +++ b/lib/Target/SparcV9/InstrSelection/InstrSelectionSupport.cpp @@ -91,9 +91,10 @@ ChooseRegOrImmed(Value* val, // To use reg or immed, constant needs to be integer, bool, or a NULL pointer Constant *CPV = dyn_cast<Constant>(val); - if (CPV == NULL || - (! CPV->getType()->isIntegral() && - ! (isa<PointerType>(CPV->getType()) && CPV->isNullValue()))) + if (CPV == NULL + || CPV->isConstantExpr() + || (! CPV->getType()->isIntegral() && + ! (isa<PointerType>(CPV->getType()) && CPV->isNullValue()))) return MachineOperand::MO_VirtualRegister; // Now get the constant value and check if it fits in the IMMED field. |