diff options
author | Tim Northover <tnorthover@apple.com> | 2016-08-26 17:46:06 +0000 |
---|---|---|
committer | Tim Northover <tnorthover@apple.com> | 2016-08-26 17:46:06 +0000 |
commit | 7a753d9bec529698c16475c72cf1de386b63381f (patch) | |
tree | bd0f2ee6bfa04c1e7d4788f14bfbefcb130e85fb /llvm/lib/Target/AArch64/AArch64MachineLegalizer.cpp | |
parent | 1d18a99a53a3a37ccffdf36341da2d46c8f6c201 (diff) | |
download | bcm5719-llvm-7a753d9bec529698c16475c72cf1de386b63381f.tar.gz bcm5719-llvm-7a753d9bec529698c16475c72cf1de386b63381f.zip |
GlobalISel: legalize under-width divisions.
llvm-svn: 279841
Diffstat (limited to 'llvm/lib/Target/AArch64/AArch64MachineLegalizer.cpp')
-rw-r--r-- | llvm/lib/Target/AArch64/AArch64MachineLegalizer.cpp | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/llvm/lib/Target/AArch64/AArch64MachineLegalizer.cpp b/llvm/lib/Target/AArch64/AArch64MachineLegalizer.cpp index 1a329361dab..0c9addf83ba 100644 --- a/llvm/lib/Target/AArch64/AArch64MachineLegalizer.cpp +++ b/llvm/lib/Target/AArch64/AArch64MachineLegalizer.cpp @@ -36,17 +36,21 @@ AArch64MachineLegalizer::AArch64MachineLegalizer() { const LLT v4s32 = LLT::vector(4, 32); const LLT v2s64 = LLT::vector(2, 64); - for (auto BinOp : {G_ADD, G_SUB, G_MUL, G_AND, G_OR, G_XOR}) { + for (auto BinOp : {G_ADD, G_SUB, G_MUL, G_AND, G_OR, G_XOR, G_SHL}) { // These operations naturally get the right answer when used on // GPR32, even if the actual type is narrower. for (auto Ty : {s1, s8, s16, s32, s64, v2s32, v4s32, v2s64}) setAction({BinOp, Ty}, Legal); } - for (auto BinOp : {G_SHL, G_LSHR, G_ASHR, G_SDIV, G_UDIV}) + for (auto BinOp : {G_LSHR, G_ASHR, G_SDIV, G_UDIV}) { for (auto Ty : {s32, s64}) setAction({BinOp, Ty}, Legal); + for (auto Ty : {s1, s8, s16}) + setAction({BinOp, Ty}, WidenScalar); + } + for (auto Op : { G_UADDE, G_USUBE, G_SADDO, G_SSUBO, G_SMULO, G_UMULO }) { for (auto Ty : { s32, s64 }) setAction({Op, Ty}, Legal); |