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