mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-13 20:32:21 +00:00
b7eb78409c
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@175905 91177308-0d34-0410-b5e6-96231b3b80d8
25 lines
644 B
LLVM
25 lines
644 B
LLVM
; RUN: llc < %s -march=x86-64 -O0 | FileCheck %s
|
|
; Make sure fast-isel doesn't reset the materialised constant map
|
|
; across an intrinsic call.
|
|
|
|
; CHECK: movl $100000
|
|
; CHECK-NOT: movl $100000
|
|
define i1 @test1(i32 %v1, i32 %v2, i32* %X) nounwind {
|
|
entry:
|
|
%a = shl i32 100000, %v1
|
|
%t = call {i32, i1} @llvm.sadd.with.overflow.i32(i32 %a, i32 %v2)
|
|
%ext = extractvalue {i32, i1} %t, 0
|
|
%sum = shl i32 100000, %ext
|
|
%obit = extractvalue {i32, i1} %t, 1
|
|
br i1 %obit, label %overflow, label %normal
|
|
|
|
normal:
|
|
store i32 %sum, i32* %X
|
|
br label %overflow
|
|
|
|
overflow:
|
|
ret i1 false
|
|
}
|
|
|
|
declare {i32, i1} @llvm.sadd.with.overflow.i32(i32, i32)
|