| //RUN: %clang_cc1 %s -triple spir -emit-llvm -O0 -o - | FileCheck %s |
| |
| enum E { |
| a, |
| b, |
| }; |
| |
| class C { |
| public: |
| void Assign(E e) { me = e; } |
| void OrAssign(E e) { mi |= e; } |
| E me; |
| int mi; |
| }; |
| |
| __global E globE; |
| volatile __global int globVI; |
| __global int globI; |
| //CHECK-LABEL: define{{.*}} spir_func void @_Z3barv() |
| void bar() { |
| C c; |
| //CHECK: [[A1:%[.a-z0-9]+]] ={{.*}} addrspacecast %class.C* [[C:%[a-z0-9]+]] to %class.C addrspace(4)* |
| //CHECK: call spir_func void @_ZNU3AS41C6AssignE1E(%class.C addrspace(4)* {{[^,]*}} [[A1]], i32 0) |
| c.Assign(a); |
| //CHECK: [[A2:%[.a-z0-9]+]] ={{.*}} addrspacecast %class.C* [[C]] to %class.C addrspace(4)* |
| //CHECK: call spir_func void @_ZNU3AS41C8OrAssignE1E(%class.C addrspace(4)* {{[^,]*}} [[A2]], i32 0) |
| c.OrAssign(a); |
| |
| E e; |
| //CHECK: store i32 1, i32* %e |
| e = b; |
| //CHECK: store i32 0, i32 addrspace(1)* @globE |
| globE = a; |
| //CHECK: store i32 %or, i32 addrspace(1)* @globI |
| globI |= b; |
| //CHECK: store i32 %add, i32 addrspace(1)* @globI |
| globI += a; |
| //CHECK: [[GVIV1:%[0-9]+]] = load volatile i32, i32 addrspace(1)* @globVI |
| //CHECK: [[AND:%[a-z0-9]+]] = and i32 [[GVIV1]], 1 |
| //CHECK: store volatile i32 [[AND]], i32 addrspace(1)* @globVI |
| globVI &= b; |
| //CHECK: [[GVIV2:%[0-9]+]] = load volatile i32, i32 addrspace(1)* @globVI |
| //CHECK: [[SUB:%[a-z0-9]+]] = sub nsw i32 [[GVIV2]], 0 |
| //CHECK: store volatile i32 [[SUB]], i32 addrspace(1)* @globVI |
| globVI -= a; |
| } |
| |
| //CHECK: define linkonce_odr spir_func void @_ZNU3AS41C6AssignE1E(%class.C addrspace(4)* {{[^,]*}} {{[ %a-z0-9]*}}, i32{{[ %a-z0-9]*}}) |
| //CHECK: [[THIS_ADDR:%[.a-z0-9]+]] = alloca %class.C addrspace(4) |
| //CHECK: [[E_ADDR:%[.a-z0-9]+]] = alloca i32 |
| //CHECK: store %class.C addrspace(4)* {{%[a-z0-9]+}}, %class.C addrspace(4)** [[THIS_ADDR]] |
| //CHECK: store i32 {{%[a-z0-9]+}}, i32* [[E_ADDR]] |
| //CHECK: [[THIS1:%[.a-z0-9]+]] = load %class.C addrspace(4)*, %class.C addrspace(4)** [[THIS_ADDR]] |
| //CHECK: [[E:%[0-9]+]] = load i32, i32* [[E_ADDR]] |
| //CHECK: [[ME:%[a-z0-9]+]] = getelementptr inbounds %class.C, %class.C addrspace(4)* [[THIS1]], i32 0, i32 0 |
| //CHECK: store i32 [[E]], i32 addrspace(4)* [[ME]] |
| |
| //CHECK: define linkonce_odr spir_func void @_ZNU3AS41C8OrAssignE1E(%class.C addrspace(4)* {{[^,]*}} {{[ %a-z0-9]*}}, i32{{[ %a-z0-9]*}}) |
| //CHECK: [[THIS_ADDR:%[.a-z0-9]+]] = alloca %class.C addrspace(4) |
| //CHECK: [[E_ADDR:%[.a-z0-9]+]] = alloca i32 |
| //CHECK: store %class.C addrspace(4)* {{%[a-z0-9]+}}, %class.C addrspace(4)** [[THIS_ADDR]] |
| //CHECK: store i32 {{%[a-z0-9]+}}, i32* [[E_ADDR]] |
| //CHECK: [[THIS1:%[.a-z0-9]+]] = load %class.C addrspace(4)*, %class.C addrspace(4)** [[THIS_ADDR]] |
| //CHECK: [[E:%[0-9]+]] = load i32, i32* [[E_ADDR]] |
| //CHECK: [[MI_GEP:%[a-z0-9]+]] = getelementptr inbounds %class.C, %class.C addrspace(4)* [[THIS1]], i32 0, i32 1 |
| //CHECK: [[MI:%[0-9]+]] = load i32, i32 addrspace(4)* [[MI_GEP]] |
| //CHECK: %or = or i32 [[MI]], [[E]] |