summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Target/X86/X86LegalizerInfo.cpp
diff options
context:
space:
mode:
authorIgor Breger <igor.breger@intel.com>2017-09-17 11:34:17 +0000
committerIgor Breger <igor.breger@intel.com>2017-09-17 11:34:17 +0000
commitf1d388a5c5a03696349959def898e4f23bffdbdc (patch)
treecfe8515ded9a47bd49b6825a99c6623afc23dcd6 /llvm/lib/Target/X86/X86LegalizerInfo.cpp
parente57308ecf0fad0f4dae56e43d3c76a3a47dde981 (diff)
downloadbcm5719-llvm-f1d388a5c5a03696349959def898e4f23bffdbdc.tar.gz
bcm5719-llvm-f1d388a5c5a03696349959def898e4f23bffdbdc.zip
[GlobalISel][X86] Legalize i1 G_ADD/G_SUB/G_MUL/G_XOR/G_OR/G_AND instructions.
llvm-svn: 313483
Diffstat (limited to 'llvm/lib/Target/X86/X86LegalizerInfo.cpp')
-rw-r--r--llvm/lib/Target/X86/X86LegalizerInfo.cpp5
1 files changed, 4 insertions, 1 deletions
diff --git a/llvm/lib/Target/X86/X86LegalizerInfo.cpp b/llvm/lib/Target/X86/X86LegalizerInfo.cpp
index 6bbb3f3c7e6..98b4863134e 100644
--- a/llvm/lib/Target/X86/X86LegalizerInfo.cpp
+++ b/llvm/lib/Target/X86/X86LegalizerInfo.cpp
@@ -57,10 +57,13 @@ void X86LegalizerInfo::setLegalizerInfo32bit() {
setAction({G_PHI, s1}, WidenScalar);
- for (unsigned BinOp : {G_ADD, G_SUB, G_MUL, G_AND, G_OR, G_XOR})
+ for (unsigned BinOp : {G_ADD, G_SUB, G_MUL, G_AND, G_OR, G_XOR}) {
for (auto Ty : {s8, s16, s32})
setAction({BinOp, Ty}, Legal);
+ setAction({BinOp, s1}, WidenScalar);
+ }
+
for (unsigned Op : {G_UADDE}) {
setAction({Op, s32}, Legal);
setAction({Op, 1, s1}, Legal);
OpenPOWER on IntegriCloud