xref: /aosp_15_r20/external/llvm/test/Verifier/bitcast-address-space-through-gep-2.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: not llvm-as -disable-output %s 2>&1 | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker
3*9880d681SAndroid Build Coastguard Worker; CHECK: error: invalid cast opcode for cast from 'i32 addrspace(2)*' to 'i32 addrspace(3)*'
4*9880d681SAndroid Build Coastguard Worker
5*9880d681SAndroid Build Coastguard Workertarget datalayout = "e-p:32:32:32-p1:16:16:16-p2:8:8:8-p3:8:8:8-i1:8:32-i8:8:32-i16:16:32-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:32:64-v128:32:128-a0:0:32-n8:16:32"
6*9880d681SAndroid Build Coastguard Worker
7*9880d681SAndroid Build Coastguard Worker
8*9880d681SAndroid Build Coastguard Worker%struct.Foo1 = type { i32 addrspace(1)* }
9*9880d681SAndroid Build Coastguard Worker
10*9880d681SAndroid Build Coastguard Worker@as2_array = addrspace(2) global [32 x i32] zeroinitializer
11*9880d681SAndroid Build Coastguard Worker
12*9880d681SAndroid Build Coastguard Worker; gep -> legal bitcast (2 -> 3) -> gep -> illegal bitcast (3 -> 1)
13*9880d681SAndroid Build Coastguard Worker@bitcast_after_gep_bitcast_gep =
14*9880d681SAndroid Build Coastguard Worker         global %struct.Foo1 { i32 addrspace(1)* bitcast
15*9880d681SAndroid Build Coastguard Worker                                    (i32 addrspace(3)* getelementptr
16*9880d681SAndroid Build Coastguard Worker                                         (i32, i32 addrspace(3)* bitcast
17*9880d681SAndroid Build Coastguard Worker                                              (i32 addrspace(2)* getelementptr
18*9880d681SAndroid Build Coastguard Worker                                                   ([32 x i32], [32 x i32] addrspace(2)* @as2_array, i32 0, i32 8) to i32 addrspace(3)*), i32 3) to i32 addrspace(1)*) }
19*9880d681SAndroid Build Coastguard Worker
20