You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
68 lines
2.8 KiB
68 lines
2.8 KiB
//RUN: %clang_cc1 %s -triple spir -cl-std=clc++ -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]]
|