Use hybrid malloc for FreeBSD (Bug#28308)
FreeBSD aarch64 does not provide sbrk, so gmalloc cannot be used; when using system malloc dumping does not work correctly (allocated data is invalid after dumping). * configure.ac: Set hybrid_malloc for freebsd. * src/gmalloc.c (gdefault_morecore) [!HAVE_SBRK]: Don't call sbrk.
This commit is contained in:
parent
725ab635d9
commit
918a2dda07
2 changed files with 7 additions and 6 deletions
|
@ -2218,7 +2218,7 @@ test "$CANNOT_DUMP" = yes ||
|
|||
case "$opsys" in
|
||||
## darwin ld insists on the use of malloc routines in the System framework.
|
||||
darwin | mingw32 | nacl | sol2-10) ;;
|
||||
cygwin | qnxto)
|
||||
cygwin | qnxto | freebsd)
|
||||
hybrid_malloc=yes
|
||||
system_malloc= ;;
|
||||
*) test "$ac_cv_func_sbrk" = yes && system_malloc=$emacs_cv_sanitize_address;;
|
||||
|
|
|
@ -1502,17 +1502,18 @@ extern void *__sbrk (ptrdiff_t increment);
|
|||
static void *
|
||||
gdefault_morecore (ptrdiff_t increment)
|
||||
{
|
||||
void *result;
|
||||
#ifdef HYBRID_MALLOC
|
||||
if (!DUMPED)
|
||||
{
|
||||
return bss_sbrk (increment);
|
||||
}
|
||||
#endif
|
||||
result = (void *) __sbrk (increment);
|
||||
if (result == (void *) -1)
|
||||
return NULL;
|
||||
#ifdef HAVE_SBRK
|
||||
void *result = (void *) __sbrk (increment);
|
||||
if (result != (void *) -1)
|
||||
return result;
|
||||
#endif
|
||||
return NULL;
|
||||
}
|
||||
|
||||
void *(*__morecore) (ptrdiff_t) = gdefault_morecore;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue