Bug#595403: perl: POSIX::sigaction breakage on armel
Niko Tyni
ntyni at debian.org
Fri Sep 24 15:28:21 UTC 2010
reassign 595403 libc6 2.11.2-5
retitle 595403 libc6: sigaction + SA_RESTORER problems on armel
thanks
On Tue, Sep 14, 2010 at 11:20:25PM +0300, Niko Tyni wrote:
> On Fri, Sep 10, 2010 at 02:35:54PM +0300, Niko Tyni wrote:
> > On Fri, Sep 03, 2010 at 09:01:27PM +0300, Niko Tyni wrote:
> >
> > > > As Sys::SigAction is a pure perl module, I agree the bug is most probably
> > > > in POSIX::sigaction in the perl package.
> Further inspection shows the stack corruption somehow happens between
> the signal delivery and the signal handler invocation. See the gdb
> session below. Returning from the sighandler makes the program crash
> as the return address is smashed.
I've finally got to the bottom of this. It's not stack corruption after
all, it's about the obsolete and non-POSIX SA_RESTORER functionality
in sigaction(2).
The crash in the libsys-sigaction-perl test suite on armel is the result
of three things:
A. sigaction(2) in the C library "leaks" the SA_RESTORER flag
(0x4000000) into the oldact struct on at least armel and amd64.
This flag is undocumented, not defined in a public header, and the
manual page explicitly discourages using the corresponding sa_restorer()
struct member. See the attached sa-leak.c test.
B. on armel only(?) sigaction(2) in the C library actually honors the
SA_RESTORER flag: it will pass the sa_restorer() pointer through to
the kernel syscall when the flag is set. See the attached sa-restorer.c
test, which crashes on armel.
C. POSIX::sigaction() in the perl package uses a separate Perl side data
structure for passing the sigaction information in and out. This data
structure contains fields for the handler, mask and flags, and their
values are copied to the actual C side sigaction structs. If the flags
contain the SA_RESTORER bit (0x4000000), it will be passed through
but the corresponding sa_restorer() member will not be set. See the
attached sa-perl.c test, which is a C translation of the original problem.
I'm reassigning this to libc6. I think just fixing the leak in the above
item "A" should fix this. I expect the item "B" is a feature and not
a bug.
As for the item "C": I can see perl could work around this by either
- carrying the sa_restorer() pointer over to the Perl side, or
- zeroing out all non-POSIX flag bits on input and/or output
Neither of these seem very inviting or easily justifiable upstream. The
sa_restorer() pointer is explicitly documented not to be used at all,
and zeroing out any unknown bits seems like a risky thing that might
cause breakage on other systems.
Just clearing the SA_RESTORER flag cannot be done portably AFAICS as
it's not defined in a public header file.
@eglibc maintainers: please let me know if I should consider implementing
a workaround anyway; this is blocking the RC bug #595397.
--
Niko Tyni ntyni at debian.org
-------------- next part --------------
A non-text attachment was scrubbed...
Name: sa-leak.c
Type: text/x-csrc
Size: 659 bytes
Desc: not available
URL: <http://lists.alioth.debian.org/pipermail/perl-maintainers/attachments/20100924/45efd5fd/attachment.c>
-------------- next part --------------
A non-text attachment was scrubbed...
Name: sa-restorer.c
Type: text/x-csrc
Size: 595 bytes
Desc: not available
URL: <http://lists.alioth.debian.org/pipermail/perl-maintainers/attachments/20100924/45efd5fd/attachment-0001.c>
-------------- next part --------------
A non-text attachment was scrubbed...
Name: sa-perl.c
Type: text/x-csrc
Size: 1164 bytes
Desc: not available
URL: <http://lists.alioth.debian.org/pipermail/perl-maintainers/attachments/20100924/45efd5fd/attachment-0002.c>
More information about the Perl-maintainers
mailing list