Bug #20633
closedcompile error at vm_insnhelper.c when HAVE_DECL_ATOMIC_SIGNAL_FENCE is 0
Description
木村といいます。
最近導入された、vm_insnhelper.c 中での atomic_signal_fence()の呼び出し[1]が
config.hで ”#define HAVE_DECL_ATOMIC_SIGNAL_FENCE 0” のときコンパイルエラーになります。
おそらくコードの意図と異なると思うのでパッチ送ります。
compiling array.c
compiling vm.c
In file included from vm.c:514:
./vm_insnhelper.c:400:5: warning: implicit declaration of function 'atomic_signal_fence' is invalid in C99 [-Wimplicit-function-declaration]
atomic_signal_fence(memory_order_seq_cst);
^
./vm_insnhelper.c:400:25: error: use of undeclared identifier 'memory_order_seq_cst'
atomic_signal_fence(memory_order_seq_cst);
^
1 warning and 1 error generated.
[1] Add explicit compiler fence when pushing frames to ensure safe profiling
https://github.com/ruby/ruby/commit/64fef3b870a8ed8147654531aef4c065d8a730c6
Files
Updated by kimuraw (Wataru Kimura) about 2 months ago
- Status changed from Open to Closed
Applied in changeset git|7472fff7f1b5296fbfcde0e2b7411a1d87781f3f.
[Bug #20633] Fix the condition for atomic_signal_fence
AC_CHECK_DECLS
defines HAVE_DECL_SYMBOL
to 1 if declared, 0
otherwise, not undefined.
Updated by ivoanjo (Ivo Anjo) about 2 months ago
Thanks @kimuraw (Wataru Kimura) for fixing my mistake 😅
I've also opened the PRs to backport your fix to the Ruby 3.3 and 3.2 branches:
Updated by nagachika (Tomoyuki Chikanaga) about 2 months ago
- Backport changed from 3.1: UNKNOWN, 3.2: UNKNOWN, 3.3: UNKNOWN to 3.2: DONE, 3.3: REQUIRED
Thank you for reporting and kindly create backport pull requests!
merged into ruby_3_2.
Updated by k0kubun (Takashi Kokubun) 6 days ago · Edited
- Backport changed from 3.2: DONE, 3.3: REQUIRED to 3.2: DONE, 3.3: DONE
Updated by ivoanjo (Ivo Anjo) 6 days ago
Hey @k0kubun (Takashi Kokubun) I don't think 66312ad913d67bfd3c2c83b174eabf537f5def84 is related to this one? 👀
(Although I think this could be closed, as the fix + both backports have landed)
Updated by k0kubun (Takashi Kokubun) 6 days ago
The message was auto-generated by a script. The script only matches the last commit mentioning the ticket number, and there were two matching commits. Sorry for a delayed reply but I got distracted to fix it first (7d47f3c94f4c38f9b236716c9f98b928895d6b2d b6e7e903a09e1577adc2f17600ca40dee80a0534). I updated the above comment with its new output (and then edited it again with a strikethrough).
And, you're right. Looking at https://github.com/ruby/ruby/pull/11372, I think he meant [Bug #20670]. I'll make sure release notes will include that ticket as well.