1; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --function-signature
2; Test that update_test_checks.py can run pre-processing commands.
3; RUN: opt < %s -passes=instsimplify -S | FileCheck %s --check-prefix=CHECK-AS200
4; RUN: sed -e 's/addrspace(200)/addrspace(0)/g' -e 's/-A200-P200-G200//g' %s \
5; RUN:   | opt -passes=instsimplify -S | FileCheck %s --check-prefix=CHECK-AS0
6; Check that multiple pre-processing commands are handled
7; RUN: sed 's/addrspace(200)/addrspace(1)/g' %s | sed 's/-A1-P1-G1//g' \
8; RUN:   | opt -passes=instsimplify -S | FileCheck %s --check-prefix=CHECK-AS1
9; More than two commands should also be fine
10; RUN: cat %s | cat | cat | cat | opt < %s -passes=instsimplify -S \
11; RUN:   | FileCheck %s --check-prefix=CHECK-AS200-NOOP-PRE-PROCESS
12
13target datalayout = "e-m:e-p200:128:128:128:64-p:64:64-A200-P200-G200"
14
15define i8 addrspace(200)* @test_zerogep_in_different_as(i8 addrspace(200)* %arg) addrspace(200) nounwind {
16; CHECK-AS200-LABEL: define {{[^@]+}}@test_zerogep_in_different_as
17; CHECK-AS200-SAME: (i8 addrspace(200)* [[ARG:%.*]]) addrspace(200) #[[ATTR0:[0-9]+]] {
18; CHECK-AS200-NEXT:  entry:
19; CHECK-AS200-NEXT:    ret i8 addrspace(200)* [[ARG]]
20;
21; CHECK-AS0-LABEL: define {{[^@]+}}@test_zerogep_in_different_as
22; CHECK-AS0-SAME: (i8* [[ARG:%.*]]) #[[ATTR0:[0-9]+]] {
23; CHECK-AS0-NEXT:  entry:
24; CHECK-AS0-NEXT:    ret i8* [[ARG]]
25;
26; CHECK-AS1-LABEL: define {{[^@]+}}@test_zerogep_in_different_as
27; CHECK-AS1-SAME: (i8 addrspace(1)* [[ARG:%.*]]) addrspace(1) #[[ATTR0:[0-9]+]] {
28; CHECK-AS1-NEXT:  entry:
29; CHECK-AS1-NEXT:    ret i8 addrspace(1)* [[ARG]]
30;
31; CHECK-AS200-NOOP-PRE-PROCESS-LABEL: define {{[^@]+}}@test_zerogep_in_different_as
32; CHECK-AS200-NOOP-PRE-PROCESS-SAME: (i8 addrspace(200)* [[ARG:%.*]]) addrspace(200) #[[ATTR0:[0-9]+]] {
33; CHECK-AS200-NOOP-PRE-PROCESS-NEXT:  entry:
34; CHECK-AS200-NOOP-PRE-PROCESS-NEXT:    ret i8 addrspace(200)* [[ARG]]
35;
36entry:
37  %ret = getelementptr inbounds i8, i8 addrspace(200)* %arg, i64 0
38  ret i8 addrspace(200)* %ret
39}
40