mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-29 10:32:47 +00:00
Add ConstantExpr::get(Sign|Zero)Extend methods
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@12648 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
97220b7338
commit
d144f42a5a
@ -544,6 +544,8 @@ public:
|
|||||||
/// Cast constant expr
|
/// Cast constant expr
|
||||||
///
|
///
|
||||||
static Constant *getCast(Constant *C, const Type *Ty);
|
static Constant *getCast(Constant *C, const Type *Ty);
|
||||||
|
static Constant *getSignExtend(Constant *C, const Type *Ty);
|
||||||
|
static Constant *getZeroExtend(Constant *C, const Type *Ty);
|
||||||
|
|
||||||
/// Select constant expr
|
/// Select constant expr
|
||||||
///
|
///
|
||||||
|
@ -1131,6 +1131,22 @@ Constant *ConstantExpr::getCast(Constant *C, const Type *Ty) {
|
|||||||
return ExprConstants.getOrCreate(Ty, Key);
|
return ExprConstants.getOrCreate(Ty, Key);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Constant *ConstantExpr::getSignExtend(Constant *C, const Type *Ty) {
|
||||||
|
assert(C->getType()->isInteger() && Ty->isInteger() &&
|
||||||
|
C->getType()->getPrimitiveSize() <= Ty->getPrimitiveSize() &&
|
||||||
|
"This is an illegal sign extension!");
|
||||||
|
C = ConstantExpr::getCast(C, C->getType()->getSignedVersion());
|
||||||
|
return ConstantExpr::getCast(C, Ty);
|
||||||
|
}
|
||||||
|
|
||||||
|
Constant *ConstantExpr::getZeroExtend(Constant *C, const Type *Ty) {
|
||||||
|
assert(C->getType()->isInteger() && Ty->isInteger() &&
|
||||||
|
C->getType()->getPrimitiveSize() <= Ty->getPrimitiveSize() &&
|
||||||
|
"This is an illegal zero extension!");
|
||||||
|
C = ConstantExpr::getCast(C, C->getType()->getUnsignedVersion());
|
||||||
|
return ConstantExpr::getCast(C, Ty);
|
||||||
|
}
|
||||||
|
|
||||||
Constant *ConstantExpr::getTy(const Type *ReqTy, unsigned Opcode,
|
Constant *ConstantExpr::getTy(const Type *ReqTy, unsigned Opcode,
|
||||||
Constant *C1, Constant *C2) {
|
Constant *C1, Constant *C2) {
|
||||||
if (Opcode == Instruction::Shl || Opcode == Instruction::Shr)
|
if (Opcode == Instruction::Shl || Opcode == Instruction::Shr)
|
||||||
|
Loading…
Reference in New Issue
Block a user