xref: /llvm-project/llvm/test/CodeGen/SPIRV/opencl/basic/progvar_prog_scope_init.ll (revision ec7baca17e78d47c1571d1c06b95f920562293da)
1*ec7baca1SMichal Paszkowski; RUN: llc -O0 -mtriple=spirv64-unknown-unknown %s -o - | FileCheck %s
28468e674SAndrey Tretyakov
38468e674SAndrey Tretyakov; CHECK:     OpEntryPoint Kernel %[[#f1:]] "writer"
48468e674SAndrey Tretyakov; CHECK:     OpEntryPoint Kernel %[[#f2:]] "reader"
58468e674SAndrey Tretyakov; CHECK-DAG: OpName %[[#a_var:]] "a_var"
68468e674SAndrey Tretyakov; CHECK-DAG: OpName %[[#p_var:]] "p_var"
78468e674SAndrey Tretyakov; CHECK-DAG: %[[#uchar:]] = OpTypeInt 8 0
88468e674SAndrey Tretyakov; CHECK-DAG: %[[#pt1:]] = OpTypePointer CrossWorkgroup %[[#uchar]]
98468e674SAndrey Tretyakov; CHECK-DAG: %[[#arr2:]] = OpTypeArray %[[#uchar]]
108468e674SAndrey Tretyakov; CHECK-DAG: %[[#pt2:]] = OpTypePointer CrossWorkgroup %[[#arr2]]
118468e674SAndrey Tretyakov; CHECK-DAG: %[[#pt3:]] = OpTypePointer CrossWorkgroup %[[#pt1]]
128468e674SAndrey Tretyakov; CHECK-DAG: %[[#a_var]] = OpVariable %[[#pt2]] CrossWorkgroup
138468e674SAndrey Tretyakov; CHECK-DAG: %[[#const:]] = OpSpecConstantOp %[[#pt1]] 70 %[[#a_var]]
148468e674SAndrey Tretyakov; CHECK-DAG: %[[#p_var]] = OpVariable %[[#pt3]] CrossWorkgroup %[[#const]]
158468e674SAndrey Tretyakov@var = addrspace(1) global i8 0, align 1
168468e674SAndrey Tretyakov@g_var = addrspace(1) global i8 1, align 1
178468e674SAndrey Tretyakov@a_var = addrspace(1) global [2 x i8] c"\01\01", align 1
188468e674SAndrey Tretyakov@p_var = addrspace(1) global i8 addrspace(1)* getelementptr inbounds ([2 x i8], [2 x i8] addrspace(1)* @a_var, i32 0, i64 1), align 8
198468e674SAndrey Tretyakov
208468e674SAndrey Tretyakovdefine spir_func zeroext i8 @from_buf(i8 zeroext %a) {
218468e674SAndrey Tretyakoventry:
228468e674SAndrey Tretyakov  %tobool = icmp ne i8 %a, 0
238468e674SAndrey Tretyakov  %i1promo = zext i1 %tobool to i8
248468e674SAndrey Tretyakov  ret i8 %i1promo
258468e674SAndrey Tretyakov}
268468e674SAndrey Tretyakov
278468e674SAndrey Tretyakovdefine spir_func zeroext i8 @to_buf(i8 zeroext %a) {
288468e674SAndrey Tretyakoventry:
298468e674SAndrey Tretyakov  %i1trunc = trunc i8 %a to i1
308468e674SAndrey Tretyakov  %frombool = select i1 %i1trunc, i8 1, i8 0
318468e674SAndrey Tretyakov  %0 = and i8 %frombool, 1
328468e674SAndrey Tretyakov  %tobool = icmp ne i8 %0, 0
338468e674SAndrey Tretyakov  %conv = select i1 %tobool, i8 1, i8 0
348468e674SAndrey Tretyakov  ret i8 %conv
358468e674SAndrey Tretyakov}
368468e674SAndrey Tretyakov
378468e674SAndrey Tretyakovdefine spir_kernel void @writer(i8 addrspace(1)* %src, i32 %idx) {
388468e674SAndrey Tretyakoventry:
398468e674SAndrey Tretyakov  %arrayidx = getelementptr inbounds i8, i8 addrspace(1)* %src, i64 0
408468e674SAndrey Tretyakov  %0 = load i8, i8 addrspace(1)* %arrayidx, align 1
418468e674SAndrey Tretyakov  %call = call spir_func zeroext i8 @from_buf(i8 zeroext %0)
428468e674SAndrey Tretyakov  %i1trunc = trunc i8 %call to i1
438468e674SAndrey Tretyakov  %frombool = select i1 %i1trunc, i8 1, i8 0
448468e674SAndrey Tretyakov  store i8 %frombool, i8 addrspace(1)* @var, align 1
458468e674SAndrey Tretyakov  %arrayidx1 = getelementptr inbounds i8, i8 addrspace(1)* %src, i64 1
468468e674SAndrey Tretyakov  %1 = load i8, i8 addrspace(1)* %arrayidx1, align 1
478468e674SAndrey Tretyakov  %call2 = call spir_func zeroext i8 @from_buf(i8 zeroext %1)
488468e674SAndrey Tretyakov  %i1trunc1 = trunc i8 %call2 to i1
498468e674SAndrey Tretyakov  %frombool3 = select i1 %i1trunc1, i8 1, i8 0
508468e674SAndrey Tretyakov  store i8 %frombool3, i8 addrspace(1)* @g_var, align 1
518468e674SAndrey Tretyakov  %arrayidx4 = getelementptr inbounds i8, i8 addrspace(1)* %src, i64 2
528468e674SAndrey Tretyakov  %2 = load i8, i8 addrspace(1)* %arrayidx4, align 1
538468e674SAndrey Tretyakov  %call5 = call spir_func zeroext i8 @from_buf(i8 zeroext %2)
548468e674SAndrey Tretyakov  %i1trunc2 = trunc i8 %call5 to i1
558468e674SAndrey Tretyakov  %frombool6 = select i1 %i1trunc2, i8 1, i8 0
568468e674SAndrey Tretyakov  %3 = getelementptr inbounds [2 x i8], [2 x i8] addrspace(1)* @a_var, i64 0, i64 0
578468e674SAndrey Tretyakov  store i8 %frombool6, i8 addrspace(1)* %3, align 1
588468e674SAndrey Tretyakov  %arrayidx7 = getelementptr inbounds i8, i8 addrspace(1)* %src, i64 3
598468e674SAndrey Tretyakov  %4 = load i8, i8 addrspace(1)* %arrayidx7, align 1
608468e674SAndrey Tretyakov  %call8 = call spir_func zeroext i8 @from_buf(i8 zeroext %4)
618468e674SAndrey Tretyakov  %i1trunc3 = trunc i8 %call8 to i1
628468e674SAndrey Tretyakov  %frombool9 = select i1 %i1trunc3, i8 1, i8 0
638468e674SAndrey Tretyakov  %5 = getelementptr inbounds [2 x i8], [2 x i8] addrspace(1)* @a_var, i64 0, i64 1
648468e674SAndrey Tretyakov  store i8 %frombool9, i8 addrspace(1)* %5, align 1
658468e674SAndrey Tretyakov  %idx.ext = zext i32 %idx to i64
668468e674SAndrey Tretyakov  %add.ptr = getelementptr inbounds i8, i8 addrspace(1)* %3, i64 %idx.ext
678468e674SAndrey Tretyakov  store i8 addrspace(1)* %add.ptr, i8 addrspace(1)* addrspace(1)* @p_var, align 8
688468e674SAndrey Tretyakov  ret void
698468e674SAndrey Tretyakov}
708468e674SAndrey Tretyakov
718468e674SAndrey Tretyakovdefine spir_kernel void @reader(i8 addrspace(1)* %dest, i8 zeroext %ptr_write_val) {
728468e674SAndrey Tretyakoventry:
738468e674SAndrey Tretyakov  %call = call spir_func zeroext i8 @from_buf(i8 zeroext %ptr_write_val)
748468e674SAndrey Tretyakov  %i1trunc = trunc i8 %call to i1
758468e674SAndrey Tretyakov  %0 = load i8 addrspace(1)*, i8 addrspace(1)* addrspace(1)* @p_var, align 8
768468e674SAndrey Tretyakov  %frombool = select i1 %i1trunc, i8 1, i8 0
778468e674SAndrey Tretyakov  store volatile i8 %frombool, i8 addrspace(1)* %0, align 1
788468e674SAndrey Tretyakov  %1 = load i8, i8 addrspace(1)* @var, align 1
798468e674SAndrey Tretyakov  %2 = and i8 %1, 1
808468e674SAndrey Tretyakov  %tobool = icmp ne i8 %2, 0
818468e674SAndrey Tretyakov  %i1promo = zext i1 %tobool to i8
828468e674SAndrey Tretyakov  %call1 = call spir_func zeroext i8 @to_buf(i8 zeroext %i1promo)
838468e674SAndrey Tretyakov  %arrayidx = getelementptr inbounds i8, i8 addrspace(1)* %dest, i64 0
848468e674SAndrey Tretyakov  store i8 %call1, i8 addrspace(1)* %arrayidx, align 1
858468e674SAndrey Tretyakov  %3 = load i8, i8 addrspace(1)* @g_var, align 1
868468e674SAndrey Tretyakov  %4 = and i8 %3, 1
878468e674SAndrey Tretyakov  %tobool2 = icmp ne i8 %4, 0
888468e674SAndrey Tretyakov  %i1promo1 = zext i1 %tobool2 to i8
898468e674SAndrey Tretyakov  %call3 = call spir_func zeroext i8 @to_buf(i8 zeroext %i1promo1)
908468e674SAndrey Tretyakov  %arrayidx4 = getelementptr inbounds i8, i8 addrspace(1)* %dest, i64 1
918468e674SAndrey Tretyakov  store i8 %call3, i8 addrspace(1)* %arrayidx4, align 1
928468e674SAndrey Tretyakov  %5 = getelementptr inbounds [2 x i8], [2 x i8] addrspace(1)* @a_var, i64 0, i64 0
938468e674SAndrey Tretyakov  %6 = load i8, i8 addrspace(1)* %5, align 1
948468e674SAndrey Tretyakov  %7 = and i8 %6, 1
958468e674SAndrey Tretyakov  %tobool5 = icmp ne i8 %7, 0
968468e674SAndrey Tretyakov  %i1promo2 = zext i1 %tobool5 to i8
978468e674SAndrey Tretyakov  %call6 = call spir_func zeroext i8 @to_buf(i8 zeroext %i1promo2)
988468e674SAndrey Tretyakov  %arrayidx7 = getelementptr inbounds i8, i8 addrspace(1)* %dest, i64 2
998468e674SAndrey Tretyakov  store i8 %call6, i8 addrspace(1)* %arrayidx7, align 1
1008468e674SAndrey Tretyakov  %8 = getelementptr inbounds [2 x i8], [2 x i8] addrspace(1)* @a_var, i64 0, i64 1
1018468e674SAndrey Tretyakov  %9 = load i8, i8 addrspace(1)* %8, align 1
1028468e674SAndrey Tretyakov  %10 = and i8 %9, 1
1038468e674SAndrey Tretyakov  %tobool8 = icmp ne i8 %10, 0
1048468e674SAndrey Tretyakov  %i1promo3 = zext i1 %tobool8 to i8
1058468e674SAndrey Tretyakov  %call9 = call spir_func zeroext i8 @to_buf(i8 zeroext %i1promo3)
1068468e674SAndrey Tretyakov  %arrayidx10 = getelementptr inbounds i8, i8 addrspace(1)* %dest, i64 3
1078468e674SAndrey Tretyakov  store i8 %call9, i8 addrspace(1)* %arrayidx10, align 1
1088468e674SAndrey Tretyakov  ret void
1098468e674SAndrey Tretyakov}
110