mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-02-25 19:29:53 +00:00
Fix linking of constant expr casts due to type resolution changes. With
this and the other patches 253.perlbmk links again. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@12565 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
4b2f08a3a9
commit
1438102576
@ -325,6 +325,14 @@ static Value *RemapOperand(const Value *In,
|
||||
assert(CE->getOpcode() == Instruction::Cast);
|
||||
Value *V = RemapOperand(CE->getOperand(0), LocalMap, GlobalMap);
|
||||
Result = ConstantExpr::getCast(cast<Constant>(V), CE->getType());
|
||||
} else if (CE->getNumOperands() == 3) {
|
||||
// Select instruction
|
||||
assert(CE->getOpcode() == Instruction::Select);
|
||||
Value *V1 = RemapOperand(CE->getOperand(0), LocalMap, GlobalMap);
|
||||
Value *V2 = RemapOperand(CE->getOperand(1), LocalMap, GlobalMap);
|
||||
Value *V3 = RemapOperand(CE->getOperand(2), LocalMap, GlobalMap);
|
||||
Result = ConstantExpr::getSelect(cast<Constant>(V1), cast<Constant>(V2),
|
||||
cast<Constant>(V3));
|
||||
} else if (CE->getNumOperands() == 2) {
|
||||
// Binary operator...
|
||||
Value *V1 = RemapOperand(CE->getOperand(0), LocalMap, GlobalMap);
|
||||
|
@ -325,6 +325,14 @@ static Value *RemapOperand(const Value *In,
|
||||
assert(CE->getOpcode() == Instruction::Cast);
|
||||
Value *V = RemapOperand(CE->getOperand(0), LocalMap, GlobalMap);
|
||||
Result = ConstantExpr::getCast(cast<Constant>(V), CE->getType());
|
||||
} else if (CE->getNumOperands() == 3) {
|
||||
// Select instruction
|
||||
assert(CE->getOpcode() == Instruction::Select);
|
||||
Value *V1 = RemapOperand(CE->getOperand(0), LocalMap, GlobalMap);
|
||||
Value *V2 = RemapOperand(CE->getOperand(1), LocalMap, GlobalMap);
|
||||
Value *V3 = RemapOperand(CE->getOperand(2), LocalMap, GlobalMap);
|
||||
Result = ConstantExpr::getSelect(cast<Constant>(V1), cast<Constant>(V2),
|
||||
cast<Constant>(V3));
|
||||
} else if (CE->getNumOperands() == 2) {
|
||||
// Binary operator...
|
||||
Value *V1 = RemapOperand(CE->getOperand(0), LocalMap, GlobalMap);
|
||||
|
@ -325,6 +325,14 @@ static Value *RemapOperand(const Value *In,
|
||||
assert(CE->getOpcode() == Instruction::Cast);
|
||||
Value *V = RemapOperand(CE->getOperand(0), LocalMap, GlobalMap);
|
||||
Result = ConstantExpr::getCast(cast<Constant>(V), CE->getType());
|
||||
} else if (CE->getNumOperands() == 3) {
|
||||
// Select instruction
|
||||
assert(CE->getOpcode() == Instruction::Select);
|
||||
Value *V1 = RemapOperand(CE->getOperand(0), LocalMap, GlobalMap);
|
||||
Value *V2 = RemapOperand(CE->getOperand(1), LocalMap, GlobalMap);
|
||||
Value *V3 = RemapOperand(CE->getOperand(2), LocalMap, GlobalMap);
|
||||
Result = ConstantExpr::getSelect(cast<Constant>(V1), cast<Constant>(V2),
|
||||
cast<Constant>(V3));
|
||||
} else if (CE->getNumOperands() == 2) {
|
||||
// Binary operator...
|
||||
Value *V1 = RemapOperand(CE->getOperand(0), LocalMap, GlobalMap);
|
||||
|
Loading…
x
Reference in New Issue
Block a user