aboutsummaryrefslogtreecommitdiff
path: root/llvm/lib/Target/AArch64/AArch64MachineLegalizer.cpp
diff options
context:
space:
mode:
authorTim Northover <tnorthover@apple.com>2016-08-26 17:46:13 +0000
committerTim Northover <tnorthover@apple.com>2016-08-26 17:46:13 +0000
commitcecee56abb688cd98f0dc9334acdfec8831f7ddd (patch)
tree17e1fa4c89a21a4b8041b088bd8d3d7a35e96bfd /llvm/lib/Target/AArch64/AArch64MachineLegalizer.cpp
parent7a753d9bec529698c16475c72cf1de386b63381f (diff)
downloadllvm-cecee56abb688cd98f0dc9334acdfec8831f7ddd.zip
llvm-cecee56abb688cd98f0dc9334acdfec8831f7ddd.tar.gz
llvm-cecee56abb688cd98f0dc9334acdfec8831f7ddd.tar.bz2
GlobalISel: legalize sdiv and srem operations.
llvm-svn: 279842
Diffstat (limited to 'llvm/lib/Target/AArch64/AArch64MachineLegalizer.cpp')
-rw-r--r--llvm/lib/Target/AArch64/AArch64MachineLegalizer.cpp4
1 files changed, 4 insertions, 0 deletions
diff --git a/llvm/lib/Target/AArch64/AArch64MachineLegalizer.cpp b/llvm/lib/Target/AArch64/AArch64MachineLegalizer.cpp
index 0c9addf..681d137 100644
--- a/llvm/lib/Target/AArch64/AArch64MachineLegalizer.cpp
+++ b/llvm/lib/Target/AArch64/AArch64MachineLegalizer.cpp
@@ -51,6 +51,10 @@ AArch64MachineLegalizer::AArch64MachineLegalizer() {
setAction({BinOp, Ty}, WidenScalar);
}
+ for (auto BinOp : { G_SREM, G_UREM })
+ for (auto Ty : { s1, s8, s16, s32, s64 })
+ setAction({BinOp, Ty}, Lower);
+
for (auto Op : { G_UADDE, G_USUBE, G_SADDO, G_SSUBO, G_SMULO, G_UMULO }) {
for (auto Ty : { s32, s64 })
setAction({Op, Ty}, Legal);