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