[InstCombine] Signed saturation patterns
[llvm-core.git] / test / Assembler / call-nonzero-program-addrspace-2.ll
blob6ec1fd0e2abab855a63153afccb1e538b85c9a81
1 ; RUN: not llvm-as %s -o /dev/null 2>&1 | FileCheck %s
2 ; RUN: llvm-as %s -data-layout=P42 -o - | llvm-dis - -o - | FileCheck %s -check-prefix PROGAS42
4 ; Check that numbered variables in a nonzero program address space 200 can be used in a call instruction
6 define i8 @test_unnamed(i8(i32)*, i8(i32) addrspace(42)* %0) {
7   ; Calls with explicit address spaces are fine:
8   call addrspace(0) i8 %0(i32 0)
9   call addrspace(42) i8 %1(i32 0)
10   ; this call is fine if the program address space is 42
11   call i8 %1(i32 0)
12   ; CHECK: call-nonzero-program-addrspace-2.ll:[[@LINE-1]]:11: error: '%1' defined with type 'i8 (i32) addrspace(42)*' but expected 'i8 (i32)*'
13   ret i8 0
16 ; PROGAS42:       target datalayout = "P42"
17 ; PROGAS42:       define i8 @test_unnamed(i8 (i32)* %0, i8 (i32) addrspace(42)* %1) addrspace(42) {
18 ; PROGAS42-NEXT:    %3 = call addrspace(0) i8 %0(i32 0)
19 ; PROGAS42-NEXT:    %4 = call addrspace(42) i8 %1(i32 0)
20 ; PROGAS42-NEXT:    %5 = call addrspace(42) i8 %1(i32 0)
21 ; PROGAS42-NEXT:    ret i8 0
22 ; PROGAS42-NEXT:  }