mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-14 11:32:34 +00:00
5738b77176
Compiling the following function with -O0 would crash, since LLVM would hit an assertion in getTestUnderMaskCond: int test(unsigned long x) { return x >= 0 && x <= 15; } Fixed by detecting the case in the caller of getTestUnderMaskCond. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@233541 91177308-0d34-0410-b5e6-96231b3b80d8
31 lines
829 B
LLVM
31 lines
829 B
LLVM
; Verify that we do not crash on always-true conditions
|
|
;
|
|
; RUN: llc < %s -mtriple=s390x-linux-gnu -mcpu=z10 -O0
|
|
;
|
|
; This test was compiled using clang -O0 from the following source code:
|
|
;
|
|
; int test(unsigned long x)
|
|
; {
|
|
; return x >= 0 && x <= 15;
|
|
; }
|
|
|
|
define signext i32 @test(i64 %x) {
|
|
entry:
|
|
%x.addr = alloca i64, align 8
|
|
store i64 %x, i64* %x.addr, align 8
|
|
%0 = load i64, i64* %x.addr, align 8
|
|
%cmp = icmp uge i64 %0, 0
|
|
br i1 %cmp, label %land.rhs, label %land.end
|
|
|
|
land.rhs: ; preds = %entry
|
|
%1 = load i64, i64* %x.addr, align 8
|
|
%cmp1 = icmp ule i64 %1, 15
|
|
br label %land.end
|
|
|
|
land.end: ; preds = %land.rhs, %entry
|
|
%2 = phi i1 [ false, %entry ], [ %cmp1, %land.rhs ]
|
|
%land.ext = zext i1 %2 to i32
|
|
ret i32 %land.ext
|
|
}
|
|
|