xref: /llvm-project/llvm/test/CodeGen/SPIRV/transcoding/ConvertPtr.ll (revision 0a443f13b49b3f392461a0bb60b0146cfc4607c7)
18468e674SAndrey Tretyakov; RUN: llc -O0 -mtriple=spirv32-unknown-unknown %s -o - | FileCheck %s --check-prefix=CHECK-SPIRV
2*0a443f13SVyacheslav Levytskyy; RUN: %if spirv-tools %{ llc -O0 -mtriple=spirv32-unknown-unknown %s -o - -filetype=obj | spirv-val %}
38468e674SAndrey Tretyakov
48468e674SAndrey Tretyakov;; kernel void testConvertPtrToU(global int *a, global unsigned long *res) {
58468e674SAndrey Tretyakov;;   res[0] = (unsigned long)&a[0];
68468e674SAndrey Tretyakov;; }
78468e674SAndrey Tretyakov
88468e674SAndrey Tretyakov; CHECK-SPIRV: OpConvertPtrToU
98468e674SAndrey Tretyakov
108468e674SAndrey Tretyakovdefine dso_local spir_kernel void @testConvertPtrToU(i32 addrspace(1)* noundef %a, i64 addrspace(1)* nocapture noundef writeonly %res) local_unnamed_addr {
118468e674SAndrey Tretyakoventry:
128468e674SAndrey Tretyakov  %0 = ptrtoint i32 addrspace(1)* %a to i32
138468e674SAndrey Tretyakov  %1 = zext i32 %0 to i64
148468e674SAndrey Tretyakov  store i64 %1, i64 addrspace(1)* %res, align 8
158468e674SAndrey Tretyakov  ret void
168468e674SAndrey Tretyakov}
178468e674SAndrey Tretyakov
188468e674SAndrey Tretyakov;; kernel void testConvertUToPtr(unsigned long a) {
198468e674SAndrey Tretyakov;;   global unsigned int *res = (global unsigned int *)a;
208468e674SAndrey Tretyakov;;   res[0] = 0;
218468e674SAndrey Tretyakov;; }
228468e674SAndrey Tretyakov
238468e674SAndrey Tretyakov; CHECK-SPIRV: OpConvertUToPtr
248468e674SAndrey Tretyakov
258468e674SAndrey Tretyakovdefine dso_local spir_kernel void @testConvertUToPtr(i64 noundef %a) local_unnamed_addr {
268468e674SAndrey Tretyakoventry:
278468e674SAndrey Tretyakov  %conv = trunc i64 %a to i32
288468e674SAndrey Tretyakov  %0 = inttoptr i32 %conv to i32 addrspace(1)*
298468e674SAndrey Tretyakov  store i32 0, i32 addrspace(1)* %0, align 4
308468e674SAndrey Tretyakov  ret void
318468e674SAndrey Tretyakov}
32