diff options
| author | Davide Italiano <davide@freebsd.org> | 2017-07-19 18:09:46 +0000 |
|---|---|---|
| committer | Davide Italiano <davide@freebsd.org> | 2017-07-19 18:09:46 +0000 |
| commit | 5fc5d0a4069e304597b04adb0ecc79a009684b75 (patch) | |
| tree | 765eed5f4a4ec7df7e43316de0150d95059abe73 /llvm/test | |
| parent | 3fce9d9c4929a1218b9119b237bfe1b64c463113 (diff) | |
| download | bcm5719-llvm-5fc5d0a4069e304597b04adb0ecc79a009684b75.tar.gz bcm5719-llvm-5fc5d0a4069e304597b04adb0ecc79a009684b75.zip | |
[X86] Don't try to scale down if that exceeds the bitwidth.
Fixes the crash reported in PR33844.
llvm-svn: 308503
Diffstat (limited to 'llvm/test')
| -rw-r--r-- | llvm/test/CodeGen/X86/pr33844.ll | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/llvm/test/CodeGen/X86/pr33844.ll b/llvm/test/CodeGen/X86/pr33844.ll new file mode 100644 index 00000000000..2585945aa10 --- /dev/null +++ b/llvm/test/CodeGen/X86/pr33844.ll @@ -0,0 +1,38 @@ +; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py +; RUN: llc -o - %s | FileCheck %s + +target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128" +target triple = "x86_64-unknown-linux-gnu" + +@global = external global i32 +@global.1 = external global i64 + +define void @patatino() { +; CHECK-LABEL: patatino: +; CHECK: # BB#0: # %bb +; CHECK-NEXT: movl {{.*}}(%rip), %eax +; CHECK-NEXT: movl %eax, %ecx +; CHECK-NEXT: shrl $31, %ecx +; CHECK-NEXT: addl $2147483647, %ecx # imm = 0x7FFFFFFF +; CHECK-NEXT: shrl $31, %ecx +; CHECK-NEXT: andl $62, %ecx +; CHECK-NEXT: andl $-536870912, %eax # imm = 0xE0000000 +; CHECK-NEXT: orl %ecx, %eax +; CHECK-NEXT: movl %eax, {{.*}}(%rip) +; CHECK-NEXT: retq +bb: + %tmp = load i32, i32* @global + %tmp1 = lshr i32 %tmp, 31 + %tmp2 = add nuw nsw i32 %tmp1, 2147483647 + %tmp3 = load i64, i64* @global.1 + %tmp4 = shl i64 %tmp3, 23 + %tmp5 = add nsw i64 %tmp4, 8388639 + %tmp6 = trunc i64 %tmp5 to i32 + %tmp7 = lshr i32 %tmp2, %tmp6 + %tmp8 = load i32, i32* @global + %tmp9 = and i32 %tmp7, 62 + %tmp10 = and i32 %tmp8, -536870912 + %tmp11 = or i32 %tmp9, %tmp10 + store i32 %tmp11, i32* @global + ret void +} |

