[LLVMdev] Example for usage of LLVM/Clang/libclc
Ahmed ElTantawy
ahmede at ece.ubc.ca
Wed Feb 4 22:09:02 PST 2015
Just as an update, I figured out that Clang was not properly linked to the
libclc library and I used a slightly modified version of the script in
libclc/compile-test.sh,
" clang -target nvptx-unknown-nvcl -S -emit-llvm -O4
-Iptx-nvidiacl/include -Igeneric/include -include clc/clc.h -Xclang
-mlink-bitcode-file -Xclang nvptx--nvidiacl/lib/builtins.opt.bc
-Dcl_clang_storage_class_specifiers -Dcl_khr_fp64 "$@" "
which works but it produces LLVM IR code for all OpenCL intrinsics
implemented by libclc along with the kernel I am interested in, is their a
possibility to avoid this ? and only produce the llvm code for the kernel
required ?
On Tue, Feb 3, 2015 at 3:35 PM, Ahmed ElTantawy <ahmede at ece.ubc.ca> wrote:
> Hi,
>
> My goal is to use Clang/LLVM/libclc to compile an OpenCL kernel and
> eventually generate a PTX code. I already did this but I am not sure if the
> PTX code I am generating is correct (is the one that is supposed to be
> generated).
>
> For example, currently,
>
> In OpenCL : get_global_id(0) translates to
> In LLVM : %call = tail call i32 @get_global_id(i32 0) which
> translates to
> In PTX:
>
> // .globl blur2d
> .func (.param .b32 func_retval0) get_global_id
> (
> .param .b32 get_global_id_param_0
> )
> ;
>
> mov.u32 %r2, 0;
> .param .b32 param0;
> st.param.b32 [param0+0], %r2;
> .param .b32 retval0;
> call.uni (retval0),
> get_global_id,
> (
> param0
> );
>
>
>
>
> Is this what is supposed to happen ? or there is something wrong ? I am
> saying this because the get_global_id implementation does not make much
> sense to me and I am not sure if it used the libclc definitions at all ?
>
> If it is not, any idea how the correct conversion will look like ?
>
> Thanks,
>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20150204/332ff711/attachment.html>
More information about the llvm-dev
mailing list