diff options
| author | Tim Northover <tnorthover@apple.com> | 2016-08-23 21:01:20 +0000 |
|---|---|---|
| committer | Tim Northover <tnorthover@apple.com> | 2016-08-23 21:01:20 +0000 |
| commit | b3a0be4d38ab08456aa4406e86d1b6c76581245a (patch) | |
| tree | 90e8ec3f034084c4cb4a751d82888924d728cc89 /llvm/lib/Target | |
| parent | 4c1f1f120c9da460a7b1d1f24936499d8caeae11 (diff) | |
| download | bcm5719-llvm-b3a0be4d38ab08456aa4406e86d1b6c76581245a.tar.gz bcm5719-llvm-b3a0be4d38ab08456aa4406e86d1b6c76581245a.zip | |
GlobalISel: legalize conditional branches on AArch64.
llvm-svn: 279565
Diffstat (limited to 'llvm/lib/Target')
| -rw-r--r-- | llvm/lib/Target/AArch64/AArch64MachineLegalizer.cpp | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/llvm/lib/Target/AArch64/AArch64MachineLegalizer.cpp b/llvm/lib/Target/AArch64/AArch64MachineLegalizer.cpp index 901bbf1b9b9..9d9f0b38b18 100644 --- a/llvm/lib/Target/AArch64/AArch64MachineLegalizer.cpp +++ b/llvm/lib/Target/AArch64/AArch64MachineLegalizer.cpp @@ -62,6 +62,7 @@ AArch64MachineLegalizer::AArch64MachineLegalizer() { setAction({MemOp, 1, p0}, Legal); } + // Constants for (auto Ty : {s32, s64}) { setAction({TargetOpcode::G_CONSTANT, Ty}, Legal); setAction({TargetOpcode::G_FCONSTANT, Ty}, Legal); @@ -72,8 +73,13 @@ AArch64MachineLegalizer::AArch64MachineLegalizer() { setAction({TargetOpcode::G_FCONSTANT, s16}, WidenScalar); + // Control-flow setAction({G_BR, LLT::unsized()}, Legal); + setAction({G_BRCOND, s32}, Legal); + for (auto Ty : {s1, s8, s16}) + setAction({G_BRCOND, Ty}, WidenScalar); + // Pointer-handling setAction({G_FRAME_INDEX, p0}, Legal); setAction({G_PTRTOINT, 0, s64}, Legal); |

