diff options
author | Tim Northover <tnorthover@apple.com> | 2016-08-26 17:46:13 +0000 |
---|---|---|
committer | Tim Northover <tnorthover@apple.com> | 2016-08-26 17:46:13 +0000 |
commit | cecee56abb688cd98f0dc9334acdfec8831f7ddd (patch) | |
tree | 17e1fa4c89a21a4b8041b088bd8d3d7a35e96bfd /llvm/lib/Target/AArch64/AArch64MachineLegalizer.cpp | |
parent | 7a753d9bec529698c16475c72cf1de386b63381f (diff) | |
download | llvm-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.cpp | 4 |
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); |