GNU bug report logs -
#18222
24.3.92; fork handlers in gmalloc.c can lead to deadlock
Previous Next
Reported by: Ken Brown <kbrown <at> cornell.edu>
Date: Fri, 8 Aug 2014 13:11:01 UTC
Severity: normal
Found in version 24.3.92
Fixed in version 25.1
Done: Ken Brown <kbrown <at> cornell.edu>
Bug is archived. No further changes may be made.
Full log
View this message in rfc822 format
>>>>> On Mon, 25 Aug 2014 05:39:58 +0300, Eli Zaretskii <eliz <at> gnu.org> said:
>> Date: Mon, 25 Aug 2014 08:28:59 +0900 From: YAMAMOTO Mitsuharu
>> <mituharu <at> math.s.chiba-u.ac.jp> Cc: Peter Hull
>> <peterhull90 <at> gmail.com>, 18222 <at> debbugs.gnu.org
>>
>> I think it's worth trying also on other platforms that use gmalloc.
> The problem is how to write the DUMPED and ALLOCATED_BEFORE_DUMPING
> macros. For Cygwin, they use some intimate knowledge about Cygwin
> runtime internals; the question is, do other platforms have similar
> facilities and features.
If the system malloc always returns a 16-byte aligned address (I'm not
sure if that is the case for *BSDs), and if we actually only need
8-byte alignment for memory allocated before dumping, then we can
determine whether the address has been allocated before dumping or not
by tweaking the address returned by malloc before dumping so it always
returns a value p such that (p & 8) == 8. Actually this is how
unexec_malloc etc. in unexmacosx.c work.
YAMAMOTO Mitsuharu
mituharu <at> math.s.chiba-u.ac.jp
This bug report was last modified 10 years and 288 days ago.
Previous Next
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.