• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1; ModuleID = 'bitcast.bc'
2target datalayout = "e-i64:64-v16:16-v24:32-v32:32-v48:64-v96:128-v192:256-v256:256-v512:512-v1024:1024"
3target triple = "spir64-unknown-unknown"
4
5; RUN: llvm-as %s -o %t.bc
6; RUN: llvm-spirv %t.bc -o %t.spv
7; RUN: llvm-spirv -r %t.spv -o %t.bc
8; RUN: llvm-dis < %t.bc | FileCheck %s
9
10; Check the bitcast is translated back to bitcast
11
12; CHECK: bitcast
13
14; Function Attrs: nounwind
15define spir_kernel void @test_fn(<2 x i8> addrspace(1)* nocapture readonly %src, i16 addrspace(1)* nocapture %dst) #0 {
16entry:
17  %call = tail call spir_func i64 @_Z13get_global_idj(i32 0) #2
18  %sext = shl i64 %call, 32
19  %idxprom = ashr exact i64 %sext, 32
20  %arrayidx = getelementptr inbounds <2 x i8>,  <2 x i8> addrspace(1)* %src, i64 %idxprom
21  %0 = load <2 x i8>, <2 x i8> addrspace(1)* %arrayidx, align 2, !tbaa !9
22  %astype = bitcast <2 x i8> %0 to i16
23  %arrayidx2 = getelementptr inbounds i16, i16 addrspace(1)* %dst, i64 %idxprom
24  store i16 %astype, i16 addrspace(1)* %arrayidx2, align 2, !tbaa !12
25  ret void
26}
27
28; Function Attrs: nounwind readnone
29declare spir_func i64 @_Z13get_global_idj(i32) #1
30
31attributes #0 = { nounwind "less-precise-fpmad"="false" "no-frame-pointer-elim"="false" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "no-realign-stack" "stack-protector-buffer-size"="8" "unsafe-fp-math"="false" "use-soft-float"="false" }
32attributes #1 = { nounwind readnone "less-precise-fpmad"="false" "no-frame-pointer-elim"="false" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "no-realign-stack" "stack-protector-buffer-size"="8" "unsafe-fp-math"="false" "use-soft-float"="false" }
33attributes #2 = { nounwind readnone }
34
35!opencl.kernels = !{!0}
36!opencl.enable.FP_CONTRACT = !{}
37!opencl.spir.version = !{!6}
38!opencl.ocl.version = !{!6}
39!opencl.used.extensions = !{!7}
40!opencl.used.optional.core.features = !{!7}
41!opencl.compiler.options = !{!7}
42!llvm.ident = !{!8}
43
44!0 = !{void (<2 x i8> addrspace(1)*, i16 addrspace(1)*)* @test_fn, !1, !2, !3, !4, !5}
45!1 = !{!"kernel_arg_addr_space", i32 1, i32 1}
46!2 = !{!"kernel_arg_access_qual", !"none", !"none"}
47!3 = !{!"kernel_arg_type", !"char2*", !"short*"}
48!4 = !{!"kernel_arg_type_qual", !"", !""}
49!5 = !{!"kernel_arg_base_type", !"char2*", !"short*"}
50!6 = !{i32 2, i32 0}
51!7 = !{}
52!8 = !{!"clang version 3.4 "}
53!9 = !{!10, !10, i64 0}
54!10 = !{!"omnipotent char", !11, i64 0}
55!11 = !{!"Simple C/C++ TBAA"}
56!12 = !{!13, !13, i64 0}
57!13 = !{!"short", !10, i64 0}
58