mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-10-19 02:52:53 +02:00
add a fastpath to ConstantExpr::getBitCast to handle the case when an obviously
unneeded bitcast is requested. This is common for frontends who just unconditionally cast even if the target is often the right type already. THis prevents going into getFoldedCast which switches on the opcode and does a bunch of other stuff before doing the same opzn. llvm-svn: 67435
This commit is contained in:
parent
047b30aba8
commit
38c6f460d2
@ -1996,6 +1996,11 @@ Constant *ConstantExpr::getBitCast(Constant *C, const Type *DstTy) {
|
||||
unsigned DstBitSize = DstTy->getPrimitiveSizeInBits();
|
||||
#endif
|
||||
assert(SrcBitSize == DstBitSize && "BitCast requires types of same width");
|
||||
|
||||
// It is common to ask for a bitcast of a value to its own type, handle this
|
||||
// speedily.
|
||||
if (C->getType() == DstTy) return C;
|
||||
|
||||
return getFoldedCast(Instruction::BitCast, C, DstTy);
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user