<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/90239>90239</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
llvm-spirv crashes on C++ for OpenCL using printf
</td>
</tr>
<tr>
<th>Labels</th>
<td>
new issue
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
Calandracas606
</td>
</tr>
</table>
<pre>
I am trying to offline compile an OpenCL program to SPIRV, but the compilation is crashing.
I can reproduce with llvm from two different systems:
- Ubuntu 22.04
- llvm installed using: https://apt.llvm.org/
- Ubuntu clang version 18.1.3 (++20240322073153+ef6d1ec07c69-1~exp1~20240322193300.86)
- llvm-spirv built from: https://github.com/KhronosGroup/SPIRV-LLVM-Translator/tree/llvm_release_180
- llvm version 17.0.6 obtained from my distribution void linux
Both of these can reproduce the issue, but the attached logs are from the binaries in void linux (since they have debug symbols)
**LOGS** [logs.tar.gz](https://github.com/llvm/llvm-project/files/15133744/logs.tar.gz)
Here is a simple reproducer:
`clang -c -target spirv64 -o sample.spv kernel.clcpp`
`kernel.clcpp`:
``` c++
__kernel void my_kernel(const int number) {
const int col = get_global_id(0);
const int row = get_global_id(1);
if (col == 0 && row == 0) {
// if i remove the printf(...) statement the compilation succeedss
printf("number = %i\n", number);
}
// do more stuff ...
};
```
Notes:
- If I remove the `printf(...)` statement, the compilation succeeds
- Only happens when compiling as C++ for OpenCL
- renaming `kernel.clcpp` -> `kernel.cl` and running `clang -c -target spirv64 -o sample.spv kernel.cl` succeeds
- the simple test case doesn't use any C++ for OpenCL features, however the application I'm developing does need them
- I have much more complicated programs which use `printf(...)` and they compile successfully
```
PLEASE submit a bug report to https://github.com/llvm/llvm-project/issues/ and include the crash backtrace.
Stack dump:
0. Program arguments: /usr/bin/llvm-spirv /tmp/kernel-073d5b.bc -o sample.spv
#0 0x00007f79f9f6cb5e llvm::sys::PrintStackTrace(llvm::raw_ostream&, int) ./../lib/Support/Unix/Signals.inc:602:22
#1 0x00007f79f9f6a28b llvm::sys::RunSignalHandlers() ./../lib/Support/Signals.cpp:104:20
#2 0x00007f79f9f6a28b SignalHandler ./../lib/Support/Unix/Signals.inc:403:31
#3 0x00007f79f8f768c0 __restore_rt libc_sigaction.c:0:0
#4 0x00007f7a01c95f4b llvm::CastInfo<llvm::TypedPointerType, llvm::Type*, void>::doCastIfPossible(llvm::Type* const&) /usr/include/llvm/Support/Casting.h:493:5
#5 0x00007f7a01c95f4b decltype(auto) llvm::dyn_cast<llvm::TypedPointerType, llvm::Type>(llvm::Type*) /usr/include/llvm/Support/Casting.h:663:48
#6 0x00007f7a01c95f4b SPIRV::BuiltinCallMutator::doConversion() ./../lib/SPIRV/SPIRVBuiltinHelper.cpp:94:35
#7 0x00007f7a01c66d3f llvm::IRBuilder<llvm::ConstantFolder, llvm::IRBuilderDefaultInserter>::~IRBuilder() /usr/include/llvm/IR/IRBuilder.h:2595:7
#8 0x00007f7a01c66d3f SPIRV::BuiltinCallMutator::~BuiltinCallMutator() ./../lib/SPIRV/SPIRVBuiltinHelper.h:101:3
#9 0x00007f7a01c6d272 SPIRV::OCLToSPIRVBase::transBuiltin(llvm::CallInst*, OCLUtil::OCLBuiltinTransInfo&) ./../lib/SPIRV/OCLToSPIRV.cpp:929:1
#10 0x00007f7a01c6d9e5 std::_Function_base::~_Function_base() /usr/include/c++/13.2/bits/std_function.h:243:11
#11 0x00007f7a01c6d9e5 std::function<void (SPIRV::BuiltinCallMutator&)>::~function() /usr/include/c++/13.2/bits/std_function.h:334:11
#12 0x00007f7a01c6d9e5 OCLUtil::OCLBuiltinTransInfo::~OCLBuiltinTransInfo() ./../lib/SPIRV/OCLUtil.h:156:8
#13 0x00007f7a01c6d9e5 SPIRV::OCLToSPIRVBase::visitCallBuiltinSimple(llvm::CallInst*, llvm::StringRef, llvm::StringRef) ./../lib/SPIRV/OCLToSPIRV.cpp:1075:1
#14 0x00007f7a01c75588 SPIRV::OCLToSPIRVBase::visitCallInst(llvm::CallInst&) ./../lib/SPIRV/OCLToSPIRV.cpp:420:25
#15 0x00007f7a01c75986 void llvm::InstVisitor<SPIRV::OCLToSPIRVBase, void>::visit<llvm::ilist_iterator<llvm::ilist_detail::node_options<llvm::Instruction, false, false, void>, false, false>>(llvm::ilist_iterator<llvm::ilist_detail::node_options<llvm::Instruction, false, false, void>, false, false>, llvm::ilist_iterator<llvm::ilist_detail::node_options<llvm::Instruction, false, false, void>, false, false>) /usr/include/llvm/IR/InstVisitor.h:88:18
#16 0x00007f7a01c75986 llvm::InstVisitor<SPIRV::OCLToSPIRVBase, void>::visit(llvm::BasicBlock&) /usr/include/llvm/IR/InstVisitor.h:104:10
#17 0x00007f7a01c75986 void llvm::InstVisitor<SPIRV::OCLToSPIRVBase, void>::visit<llvm::ilist_iterator<llvm::ilist_detail::node_options<llvm::BasicBlock, false, false, void>, false, false>>(llvm::ilist_iterator<llvm::ilist_detail::node_options<llvm::BasicBlock, false, false, void>, false, false>, llvm::ilist_iterator<llvm::ilist_detail::node_options<llvm::BasicBlock, false, false, void>, false, false>) /usr/include/llvm/IR/InstVisitor.h:89:42
#18 0x00007f7a01c75986 llvm::InstVisitor<SPIRV::OCLToSPIRVBase, void>::visit(llvm::Function&) /usr/include/llvm/IR/InstVisitor.h:100:10
#19 0x00007f7a01c75986 void llvm::InstVisitor<SPIRV::OCLToSPIRVBase, void>::visit<llvm::ilist_iterator<llvm::ilist_detail::node_options<llvm::Function, false, false, void>, false, false>>(llvm::ilist_iterator<llvm::ilist_detail::node_options<llvm::Function, false, false, void>, false, false>, llvm::ilist_iterator<llvm::ilist_detail::node_options<llvm::Function, false, false, void>, false, false>) /usr/include/llvm/IR/InstVisitor.h:89:42
#20 0x00007f7a01c75986 llvm::InstVisitor<SPIRV::OCLToSPIRVBase, void>::visit(llvm::Module&) /usr/include/llvm/IR/InstVisitor.h:96:10
#21 0x00007f7a01c75986 SPIRV::OCLToSPIRVBase::runOCLToSPIRV(llvm::Module&) ./../lib/SPIRV/OCLToSPIRV.cpp:177:8
#22 0x00007f7a01c75a82 SPIRV::OCLToSPIRVPass::run(llvm::Module&, llvm::AnalysisManager<llvm::Module>&) ./../lib/SPIRV/OCLToSPIRV.cpp:113:27
#23 0x00007f7a01d352d1 llvm::detail::PassModel<llvm::Module, SPIRV::OCLToSPIRVPass, llvm::PreservedAnalyses, llvm::AnalysisManager<llvm::Module>>::run(llvm::Module&, llvm::AnalysisManager<llvm::Module>&) /usr/include/llvm/IR/PassManagerInternal.h:90:3
#24 0x00007f7a01d69631 llvm::PassManager<llvm::Module, llvm::AnalysisManager<llvm::Module>>::run(llvm::Module&, llvm::AnalysisManager<llvm::Module>&) /usr/include/llvm/IR/PassManager.h:521:20
#25 0x00007f7a01d69631 runSpirvWriterPasses ./../lib/SPIRV/SPIRVWriter.cpp:6000:14
#26 0x000055f5ef291e57 convertLLVMToSPIRV ./../tools/llvm-spirv/llvm-spirv.cpp:366:3
#27 0x000055f5ef291e57 main ./../tools/llvm-spirv/llvm-spirv.cpp:807:30
#28 0x00007f79f8f60c4c __libc_start_call_main ./csu/../sysdeps/nptl/libc_start_call_main.h:74:3
#29 0x00007f79f8f60d05 call_init ./csu/../csu/libc-start.c:128:20
#30 0x00007f79f8f60d05 __libc_start_main@GLIBC_2.2.5 ./csu/../csu/libc-start.c:347:5
#31 0x000055f5ef292141 _start /builddir/glibc-2.38/csu/../sysdeps/x86_64/start.S:117:0
clang: error: unable to execute command: Segmentation fault
clang: error: llvm-spirv command failed due to signal (use -v to see invocation)
clang version 17.0.6
Target: spirv64
Thread model: posix
InstalledDir: /usr/bin
clang: note: diagnostic msg:
********************
PLEASE ATTACH THE FOLLOWING FILES TO THE BUG REPORT:
Preprocessed source(s) and associated run script(s) are located at:
clang: note: diagnostic msg: /tmp/kernel-027ba7.clcpp
clang: note: diagnostic msg: /tmp/kernel-027ba7.sh
clang: note: diagnostic msg:
********************
```
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJzUWl9z26gW_zTk5Yw9Evr_kAfHiVvPTTeZJu0-epCEbG4l0ABK6_vQz34HkC3JddKm3d3pzqSujeCc3_mdPyCAKMW2nNJLFF2h6PqCdHon5OWS1ISXkhRExV58kYtyf7kG0oCWe8a3oAWIqqoZp1CIpmU1BcLhrqV8eQutFFtp-gp4uF-__4jwEvJOg94dehPNBAemoJBE7RjfzpF3jbyF-1xDQThI2kpRdgWFz0zvoK6fGqikaEB_FlCyqqKScg1qrzRtFAr6wTCDD3nHdQcYz72wbwSYOQmMK03qmpbQKca3KFjATuvWjscrhFek1XPTcy7k1rQM43uxRU34Fp6oVMYGP5378wAQThG-QvgKezj0Aoy9JPCjAOErWsWlTwsvKeJs5n-lX1r_66GTnwWB583TGOHsBOhMtUw-Qd6xWluzv0W6ZXrX5fNCNAiv_rOTggv1RoquRXhleZ_d3n58N3uUhKuaaCERXmlJKcIro2EjaU2Johs_9Y7UWY6OtiVzbx6DyDVhnJaO_WYPJVNasryzTnwSrISa8e7L2IVXQu9AVMblip6404QBU6qj47ggWpNiR0uoxVYBkbT39Y5CzjiRjCpgY22GcsW4k7eHHXmiUNK824LaN7mo1ZHT_hObv9u7Nw_uG6DoyuiaayLn2_-h6Brh9AWCDTP9f7NWiv_SQiO8qlhNFcIrP_KDIAlD02MkdArhLZXGciCgWNPWdOBEHsO3_4w9F2azAmaayC3VYAMiDmEmQBEzfK7aJ_hEJaf1vKiLtkWxdyLk9OkxSY493B8ULnpd82bjxjm2m33_E-G0EFxpYFwD75qcSoQzQMnVWCvA0KkQNaDgGrZUb7a1yEm9YSXCqWeICfpho_5SfD7b3x_3P6hhFVhEVoUZ5QHCMcLxQYxtmyAE51czlIGkjXhy0dhKxnWFcDqfz80ApYmmjaku39Qs1RUFpaVSvcTjUISx48RagHDEULTkCGMT5Ue2BqsBJdcTg3pspYBGSApKd1UFBtDYpcn1CQ9HF7qffwhNh1o4g3UF67GlKPZOjDXeP9prsD5n8UHkHa9NurUt5Qo-7yjve5tpgShYukiCSsh-PjgYPANJOWlMv29DE2YouJm0m0bCS5Ad5_2Y1-aEtW0C36AwBvYJqKnSUBBFoRRUcYQTDZ0yc9n-jCFQUaI7aRJ-CTvxmT5R6YpX29ascHStEU4aKOkTrUVrcBvJwCktTdfm6BhXsZqu2Dl_GxKtEFoeJlBDLyt2FtF5xxl-bPk7TMLWWqWqrq73L4TJ_e3N4uEGVJc3TAMBUzYlbYXUZtJ-dRW01dyUQQuI8aLuShdvdn6HnBSftCQF7YP5QZPiE5Rd0x5D1ZsjL7vvFw5EbjsTjgaEyYtOmbkrZ_yg2k2OZj5rzGznHD7zkqCM8nleTOPhmF-BB94Xz_O8pEqyKqviIo-onfIMjGCh9sp9uTdMW5CPBjXC6dBJks8bobSkpLHlZmkqlykac4RXxjGrmuVmBu5awyfCqw-cfTENbMtJreaMFyhYxB5GwQLjAZx_Ao7gND8H7n3Hnai3hJc1lcoWnxf0HxSbRAsWvhcaxd6gGJ9TPFHxSttCL0DBIvAHFcFYRVolcVp4sNlIqrSQdCM11CwvNoptSWGyaG7EePbfUUY4yCCeX2RRFY75WRKl17wSKFgOjY_7lpb3gnFNpflu3DV9ahcDSzvToeDGtZfCCqvuhVIsr6f-7we5WctGQDaEaB_6Q6IMTBmRZqG7MwRlhqBosC06Z1tJi1pbbSnptDCKBhjlnm8KovRrzQ1uzlnzM0bEsTEiTAcr4nNWuDcAq-zKLGYZX5K6ftdpuyI98C14v-h8Jpjda4T7vxfzltYtlX1UZyaogxGjyRRLHJdBNeJi_d5IKc3Ca8Tf0viUcL0S9tGEveOIa1qRrtZrrqjURkAfNV8Hmc6G5wldv7cffXfLJo6yCAWLZLAgPWfBD7D59cyD15K6s4XCN5wOgLITQCVO8BjQ3fL2UThhRFHXps3LRy97EngG3dpmkM2_u-XtB83qo6B-iH13sVntEu0ZCwbNh3AwK62Ff1j5B753ij2jEShdOoWbVcdt3dnkR-RfTxqf9elh6YxXfjDHdp7SZi5UutxUvQjn4tAkjD9C5b-I6jAYBUu7EEc4fdn9lqMhHo_jfx16EIQn0PE56N_1ogN21r8vRWgv14VlFKNgkQ5IgnNIvhOWT0wxbajrcTzY5eBLATo8eNCS8e17Wj3b_ONx6ntJNA3Uk1kuiaI0_WFrHN6zRrwqfULs2ZI0wIpOYWVp3L-MDxWSK_3RQDGVaPk85tPp1sKf1GFWM6U3TFPpyto3j0qqySHOuCjpRrQmVtWkq8Ejuz4FllCR2ik_fjmg-PahgTadKH8HSJN4-y0AfX-SG2LCZm-amnAfZW98LrD-qpgaO_CKKFZc1aL49N1F21nkbt3sewP05F-YE2MWfo-U-CVEf0NG_Bqe1ydEZuvtEFXpP5UQq-Py4OfSwTtJh-xfmA4DB79HMvwCnr8hFX4FzS8nAvb-qUR4J8rOLP5-Jg2yeJoF2D-H-jvrN9nxofl5aD-8qEySyQoZ41NMJH3mxe2eKHXE9ByScaAtOKn3iql3hJPtydt0P8REw-vw--Y9CSeDAdMlfhlEuPTHeyGjYDYWvBMlrc9BwcsXzJ7YdS-povKJls5Aqn7G7EPI_Q1cfidMLQtOzJprKjlxL0-ZN7zSG2KnbxtlnMXBmNiRmGfo_FdSYqmIsD_aBzVkROfIkB1_aJl8-lOaamqEUPXiRorr2Idy7LlpMhy0HBa8UVRFtMKZT6MECrv_pW9vP77rQ3LQoYU9zBxtfE9-9JqCOJ66NjmnpyGMv1Zy6plyEoyISqe7ubFXhAVsNm4LVxOpNwWp681RWaG6g0q1VyVtjVLe6tox-M0g658knNqTnSotvQjsEMaZPtXjvhrhMyvcbij7OJ26fHogcBA6scTgQaH35nZ9tdzgOZ5HP6QqCJNhh9do8k_cgf3QB6fDRG7esbosmQnfrRWF50H6HHVf0ngTh3afxuh7sDUzGXbL7TEZChZApbS7gtBxktcUtAD6hRadtsdNDeGlefhAtw3l2h1f2b3N58SMzl768VARVtMSys5KV_YcABBOO0Vh9mTbKAXGn4Q7HzseiZ9co7BXDdyTR3u2Z_T1x3t9805SUkLjivsCWqFYf-dgfbjUcc3kN0dGU1u40GbWhZKRLRdKswIaZZ-Mrwn85N_owK0_YVs8Pi6Wb-Hx7Q2s7m5v7_5c__EGVuvbmwd4vLPNVx_ewPub-7v3j8ezsHt7L6CgStESlOikPYJSpsgZyolSomD2oFB2HFQhWauPHSSFWrhjRKKPIn_E_tPTNJzkJOkPaH9RiNq91g1_lTOm557u86K8DMosyMgFvfQTP_SjAEfJxe4yidI8i9MkCOMyz4ok8cI4LKsKxzQKcOpdsEt7dSfEsZ-EXpTMo6okkReQpMiCKMlCFHq0Iaw-XiG6sGejl5mHg-yiJjmtlb1qhTGnnw_XYDCKri_kpU2vvNsqFHpmla4GKZrpml6O808StaMKBD93UG3vNvV3Ey46WV_-_JGuRf7_AAAA__96GX5m">