]> git.apps.os.sepia.ceph.com Git - ceph-ci.git/commit
ceph.spec.in: cull _FORTIFY_SOURCE macro from CXXFLAGS for seastar
authorKefu Chai <kchai@redhat.com>
Thu, 23 Jul 2020 08:03:06 +0000 (16:03 +0800)
committerKefu Chai <kchai@redhat.com>
Thu, 23 Jul 2020 08:19:56 +0000 (16:19 +0800)
commitdb20cfd095229b79d97337e60ff4154c3c986970
treef9edb832a187613d6c3b1a2f74cb12fa95c4c49a
parent2c7daf6d12c762fe80cea700da2a635d7e1e3366
ceph.spec.in: cull _FORTIFY_SOURCE macro from CXXFLAGS for seastar

seastar uses setjmp() and longjmp() to implement coroutine, but
longjmp() is defined as ____longjmp_chk() by GCC if _FORTIFY_SOURC is
defined. ____longjmp_chk() simply bails out with an error message if
the dest stack pointer is higher than the src stack pointer, or the dest
stack pointer is not in the sigaltstack. in the case of seastar, the dst
%sp is not necessarily higher than src stack pointer, and it's not
handling a signal for switching the thread context. that's why we have
the "longjmp causes uninitialized stack frame" error when running
crimson-osd on RHEL/CentOS 8 using the prebuilt rpm packages.

the optflags rpm macro adds -D_FORTIFY_SOURCE=2 to CFLAGS and CXXFLAGS,
so even seastar tries to pass -U_FORTIFY_SOURCE to GCC, there is chance
that cmake append CXXFLAGS at the end of the option list passed to GCC.
and this renders seastar's attempt to undefine _FORTIFY_SOURCE useless.

another way to address this issue is to undefine this macro in
seastar:src/core/thread.cc. but since seastar tries neutralize the macro
in its cmake script instead of source file, i assume they have their
considerations. let's drop it in the rpm recipe instead.

Signed-off-by: Kefu Chai <kchai@redhat.com>
ceph.spec.in