//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 ptr [[C:%[a-z0-9]+]] to ptr addrspace(4) //CHECK: call spir_func void @_ZNU3AS41C6AssignE1E(ptr addrspace(4) {{[^,]*}} [[A1]], i32 noundef 0) c.Assign(a); //CHECK: [[A2:%[.a-z0-9]+]] ={{.*}} addrspacecast ptr [[C]] to ptr addrspace(4) //CHECK: call spir_func void @_ZNU3AS41C8OrAssignE1E(ptr addrspace(4) {{[^,]*}} [[A2]], i32 noundef 0) c.OrAssign(a); E e; //CHECK: store i32 1, ptr %e e = b; //CHECK: store i32 0, ptr addrspace(1) @globE globE = a; //CHECK: store i32 %or, ptr addrspace(1) @globI globI |= b; //CHECK: store i32 %add, ptr addrspace(1) @globI globI += a; //CHECK: [[GVIV1:%[0-9]+]] = load volatile i32, ptr addrspace(1) @globVI //CHECK: [[AND:%[a-z0-9]+]] = and i32 [[GVIV1]], 1 //CHECK: store volatile i32 [[AND]], ptr addrspace(1) @globVI globVI &= b; //CHECK: [[GVIV2:%[0-9]+]] = load volatile i32, ptr addrspace(1) @globVI //CHECK: [[SUB:%[a-z0-9]+]] = sub nsw i32 [[GVIV2]], 0 //CHECK: store volatile i32 [[SUB]], ptr addrspace(1) @globVI globVI -= a; } //CHECK: define linkonce_odr spir_func void @_ZNU3AS41C6AssignE1E(ptr addrspace(4) {{[^,]*}} {{[ %a-z0-9]*}}, i32{{[ %a-z0-9]*}}) //CHECK: [[THIS_ADDR:%[.a-z0-9]+]] = alloca ptr addrspace(4) //CHECK: [[E_ADDR:%[.a-z0-9]+]] = alloca i32 //CHECK: store ptr addrspace(4) {{%[a-z0-9]+}}, ptr [[THIS_ADDR]] //CHECK: store i32 {{%[a-z0-9]+}}, ptr [[E_ADDR]] //CHECK: [[THIS1:%[.a-z0-9]+]] = load ptr addrspace(4), ptr [[THIS_ADDR]] //CHECK: [[E:%[0-9]+]] = load i32, ptr [[E_ADDR]] //CHECK: [[ME:%[a-z0-9]+]] = getelementptr inbounds %class.C, ptr addrspace(4) [[THIS1]], i32 0, i32 0 //CHECK: store i32 [[E]], ptr addrspace(4) [[ME]] //CHECK: define linkonce_odr spir_func void @_ZNU3AS41C8OrAssignE1E(ptr addrspace(4) {{[^,]*}} {{[ %a-z0-9]*}}, i32{{[ %a-z0-9]*}}) //CHECK: [[THIS_ADDR:%[.a-z0-9]+]] = alloca ptr addrspace(4) //CHECK: [[E_ADDR:%[.a-z0-9]+]] = alloca i32 //CHECK: store ptr addrspace(4) {{%[a-z0-9]+}}, ptr [[THIS_ADDR]] //CHECK: store i32 {{%[a-z0-9]+}}, ptr [[E_ADDR]] //CHECK: [[THIS1:%[.a-z0-9]+]] = load ptr addrspace(4), ptr [[THIS_ADDR]] //CHECK: [[E:%[0-9]+]] = load i32, ptr [[E_ADDR]] //CHECK: [[MI_GEP:%[a-z0-9]+]] = getelementptr inbounds %class.C, ptr addrspace(4) [[THIS1]], i32 0, i32 1 //CHECK: [[MI:%[0-9]+]] = load i32, ptr addrspace(4) [[MI_GEP]] //CHECK: %or = or i32 [[MI]], [[E]]