From 75c2961b764bcd54a1563a9a4f5cf3da66e815da Mon Sep 17 00:00:00 2001 From: Roman Lebedev Date: Fri, 31 Aug 2018 08:52:03 +0000 Subject: [PATCH] [NFC][X86][AArch64] A few more patterns for [lack of] signed truncation check pattern.[NFC][X86][AArch64] A few more patterns for [lack of] signed truncation check pattern. llvm-svn: 341188 --- .../lack-of-signed-truncation-check.ll | 16 +++++++++++- .../AArch64/signed-truncation-check.ll | 16 +++++++++++- .../X86/lack-of-signed-truncation-check.ll | 25 ++++++++++++++++++- .../CodeGen/X86/signed-truncation-check.ll | 25 ++++++++++++++++++- 4 files changed, 78 insertions(+), 4 deletions(-) diff --git a/llvm/test/CodeGen/AArch64/lack-of-signed-truncation-check.ll b/llvm/test/CodeGen/AArch64/lack-of-signed-truncation-check.ll index be2dffde8243..f5537c796b76 100644 --- a/llvm/test/CodeGen/AArch64/lack-of-signed-truncation-check.ll +++ b/llvm/test/CodeGen/AArch64/lack-of-signed-truncation-check.ll @@ -10,7 +10,7 @@ ; This can be expressed in a several ways in IR: ; trunc + sext + icmp ne <- not canonical ; shl + ashr + icmp ne -; add + icmp ult +; add + icmp ult/ule ; add + icmp uge/ugt ; However only the simplest form (with two shifts) gets lowered best. @@ -176,6 +176,20 @@ define i1 @add_ultcmp_i64_i8(i64 %x) nounwind { ret i1 %tmp1 } +; Slightly more canonical variant +define i1 @add_ulecmp_i16_i8(i16 %x) nounwind { +; CHECK-LABEL: add_ulecmp_i16_i8: +; CHECK: // %bb.0: +; CHECK-NEXT: sub w8, w0, #128 // =128 +; CHECK-NEXT: ubfx w8, w8, #8, #8 +; CHECK-NEXT: cmp w8, #255 // =255 +; CHECK-NEXT: cset w0, lo +; CHECK-NEXT: ret + %tmp0 = add i16 %x, -128 ; ~0U << (8-1) + %tmp1 = icmp ule i16 %tmp0, -257 ; ~0U << 8 - 1 + ret i1 %tmp1 +} + ; ---------------------------------------------------------------------------- ; ; add + icmp uge ; ---------------------------------------------------------------------------- ; diff --git a/llvm/test/CodeGen/AArch64/signed-truncation-check.ll b/llvm/test/CodeGen/AArch64/signed-truncation-check.ll index 6b5fffefe367..be468e74b828 100644 --- a/llvm/test/CodeGen/AArch64/signed-truncation-check.ll +++ b/llvm/test/CodeGen/AArch64/signed-truncation-check.ll @@ -10,7 +10,7 @@ ; This can be expressed in a several ways in IR: ; trunc + sext + icmp eq <- not canonical ; shl + ashr + icmp eq -; add + icmp uge +; add + icmp uge/ugt ; add + icmp ult/ule ; However only the simplest form (with two shifts) gets lowered best. @@ -178,6 +178,20 @@ define i1 @add_ugecmp_i64_i8(i64 %x) nounwind { ret i1 %tmp1 } +; Slightly more canonical variant +define i1 @add_ugtcmp_i16_i8(i16 %x) nounwind { +; CHECK-LABEL: add_ugtcmp_i16_i8: +; CHECK: // %bb.0: +; CHECK-NEXT: sub w8, w0, #128 // =128 +; CHECK-NEXT: ubfx w8, w8, #8, #8 +; CHECK-NEXT: cmp w8, #254 // =254 +; CHECK-NEXT: cset w0, hi +; CHECK-NEXT: ret + %tmp0 = add i16 %x, -128 ; ~0U << (8-1) + %tmp1 = icmp ugt i16 %tmp0, -257 ; ~0U << 8 - 1 + ret i1 %tmp1 +} + ; ---------------------------------------------------------------------------- ; ; add + icmp ult ; ---------------------------------------------------------------------------- ; diff --git a/llvm/test/CodeGen/X86/lack-of-signed-truncation-check.ll b/llvm/test/CodeGen/X86/lack-of-signed-truncation-check.ll index ac36087d0022..343a5ab953a5 100644 --- a/llvm/test/CodeGen/X86/lack-of-signed-truncation-check.ll +++ b/llvm/test/CodeGen/X86/lack-of-signed-truncation-check.ll @@ -11,7 +11,7 @@ ; This can be expressed in a several ways in IR: ; trunc + sext + icmp ne <- not canonical ; shl + ashr + icmp ne -; add + icmp ult +; add + icmp ult/ule ; add + icmp uge/ugt ; However only the simplest form (with two shifts) gets lowered best. @@ -288,6 +288,29 @@ define i1 @add_ultcmp_i64_i8(i64 %x) nounwind { ret i1 %tmp1 } +; Slightly more canonical variant +define i1 @add_ulecmp_i16_i8(i16 %x) nounwind { +; X86-LABEL: add_ulecmp_i16_i8: +; X86: # %bb.0: +; X86-NEXT: movl {{[0-9]+}}(%esp), %eax +; X86-NEXT: addl $-128, %eax +; X86-NEXT: movzwl %ax, %eax +; X86-NEXT: cmpl $65280, %eax # imm = 0xFF00 +; X86-NEXT: setb %al +; X86-NEXT: retl +; +; X64-LABEL: add_ulecmp_i16_i8: +; X64: # %bb.0: +; X64-NEXT: addl $-128, %edi +; X64-NEXT: movzwl %di, %eax +; X64-NEXT: cmpl $65280, %eax # imm = 0xFF00 +; X64-NEXT: setb %al +; X64-NEXT: retq + %tmp0 = add i16 %x, -128 ; ~0U << (8-1) + %tmp1 = icmp ule i16 %tmp0, -257 ; ~0U << 8 - 1 + ret i1 %tmp1 +} + ; ---------------------------------------------------------------------------- ; ; add + icmp uge ; ---------------------------------------------------------------------------- ; diff --git a/llvm/test/CodeGen/X86/signed-truncation-check.ll b/llvm/test/CodeGen/X86/signed-truncation-check.ll index c41b4e681edf..4684770f09a7 100644 --- a/llvm/test/CodeGen/X86/signed-truncation-check.ll +++ b/llvm/test/CodeGen/X86/signed-truncation-check.ll @@ -11,7 +11,7 @@ ; This can be expressed in a several ways in IR: ; trunc + sext + icmp eq <- not canonical ; shl + ashr + icmp eq -; add + icmp uge +; add + icmp uge/ugt ; add + icmp ult/ule ; However only the simplest form (with two shifts) gets lowered best. @@ -292,6 +292,29 @@ define i1 @add_ugecmp_i64_i8(i64 %x) nounwind { ret i1 %tmp1 } +; Slightly more canonical variant +define i1 @add_ugtcmp_i16_i8(i16 %x) nounwind { +; X86-LABEL: add_ugtcmp_i16_i8: +; X86: # %bb.0: +; X86-NEXT: movl {{[0-9]+}}(%esp), %eax +; X86-NEXT: addl $-128, %eax +; X86-NEXT: movzwl %ax, %eax +; X86-NEXT: cmpl $65279, %eax # imm = 0xFEFF +; X86-NEXT: seta %al +; X86-NEXT: retl +; +; X64-LABEL: add_ugtcmp_i16_i8: +; X64: # %bb.0: +; X64-NEXT: addl $-128, %edi +; X64-NEXT: movzwl %di, %eax +; X64-NEXT: cmpl $65279, %eax # imm = 0xFEFF +; X64-NEXT: seta %al +; X64-NEXT: retq + %tmp0 = add i16 %x, -128 ; ~0U << (8-1) + %tmp1 = icmp ugt i16 %tmp0, -257 ; ~0U << 8 - 1 + ret i1 %tmp1 +} + ; ---------------------------------------------------------------------------- ; ; add + icmp ult ; ---------------------------------------------------------------------------- ;