summaryrefslogtreecommitdiffstats
path: root/llvm/lib/CodeGen
diff options
context:
space:
mode:
authorAditya Nandakumar <aditya_nandakumar@apple.com>2017-03-22 01:16:39 +0000
committerAditya Nandakumar <aditya_nandakumar@apple.com>2017-03-22 01:16:39 +0000
commitbc389badbc45288b0050c4b323374f1c0243fdf3 (patch)
tree022ea822ad366dcf7a29c77c1442691ffbec0700 /llvm/lib/CodeGen
parent0498baa4bea05471f7e683e460e20fd7c5cd6293 (diff)
downloadbcm5719-llvm-bc389badbc45288b0050c4b323374f1c0243fdf3.tar.gz
bcm5719-llvm-bc389badbc45288b0050c4b323374f1c0243fdf3.zip
[GlobalISel]: Create VREGs for ConstantInt args
This patch changes the behavior of IRTranslating intrinsics where we now create VREG + G_CONSTANT for ConstantInt values. We already do this for FloatingPoint values. This makes it easier for the backends to select code and it won't have to de-duplicate creation+selection of constants. Reviewed by: ab llvm-svn: 298473
Diffstat (limited to 'llvm/lib/CodeGen')
-rw-r--r--llvm/lib/CodeGen/GlobalISel/IRTranslator.cpp5
1 files changed, 1 insertions, 4 deletions
diff --git a/llvm/lib/CodeGen/GlobalISel/IRTranslator.cpp b/llvm/lib/CodeGen/GlobalISel/IRTranslator.cpp
index b3f131b5eeb..76618737844 100644
--- a/llvm/lib/CodeGen/GlobalISel/IRTranslator.cpp
+++ b/llvm/lib/CodeGen/GlobalISel/IRTranslator.cpp
@@ -772,10 +772,7 @@ bool IRTranslator::translateCall(const User &U, MachineIRBuilder &MIRBuilder) {
// Some intrinsics take metadata parameters. Reject them.
if (isa<MetadataAsValue>(Arg))
return false;
- if (ConstantInt *CI = dyn_cast<ConstantInt>(Arg))
- MIB.addImm(CI->getSExtValue());
- else
- MIB.addUse(getOrCreateVReg(*Arg));
+ MIB.addUse(getOrCreateVReg(*Arg));
}
return true;
}
OpenPOWER on IntegriCloud