mirror of
https://sourceware.org/git/glibc.git
synced 2025-07-30 22:43:12 +03:00
[BZ #227]
2004-08-15 Roland McGrath <roland@redhat.com> [BZ #227] * sysdeps/unix/sysv/linux/kernel-features.h (__ASSUME_BRK_PAGE_ROUNDED): New macro. * sysdeps/unix/sysv/linux/dl-sysdep.c (frob_brk) [! __ASSUME_BRK_PAGE_ROUNDED]: Adjust the break up if it falls within the partial page after the dynamic linker's own data segment.
This commit is contained in:
@ -1,5 +1,5 @@
|
|||||||
/* Dynamic linker system dependencies for Linux.
|
/* Dynamic linker system dependencies for Linux.
|
||||||
Copyright (C) 1995, 1997, 2001 Free Software Foundation, Inc.
|
Copyright (C) 1995, 1997, 2001, 2004 Free Software Foundation, Inc.
|
||||||
This file is part of the GNU C Library.
|
This file is part of the GNU C Library.
|
||||||
|
|
||||||
The GNU C Library is free software; you can redistribute it and/or
|
The GNU C Library is free software; you can redistribute it and/or
|
||||||
@ -21,6 +21,8 @@
|
|||||||
the generic dynamic linker system interface code. */
|
the generic dynamic linker system interface code. */
|
||||||
|
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
#include <ldsodefs.h>
|
||||||
|
#include "kernel-features.h"
|
||||||
|
|
||||||
#define DL_SYSDEP_INIT frob_brk ()
|
#define DL_SYSDEP_INIT frob_brk ()
|
||||||
|
|
||||||
@ -28,6 +30,27 @@ static inline void
|
|||||||
frob_brk (void)
|
frob_brk (void)
|
||||||
{
|
{
|
||||||
__brk (0); /* Initialize the break. */
|
__brk (0); /* Initialize the break. */
|
||||||
|
|
||||||
|
#if ! __ASSUME_BRK_PAGE_ROUNDED
|
||||||
|
/* If the dynamic linker was executed as a program, then the break may
|
||||||
|
start immediately after our data segment. However, dl-minimal.c has
|
||||||
|
already stolen the remainder of the page for internal allocations.
|
||||||
|
If we don't adjust the break location recorded by the kernel, the
|
||||||
|
normal program startup will inquire, find the value at our &_end,
|
||||||
|
and start allocating its own data there, clobbering dynamic linker
|
||||||
|
data structures allocated there during startup.
|
||||||
|
|
||||||
|
Later Linux kernels have changed this behavior so that the initial
|
||||||
|
break value is rounded up to the page boundary before we start. */
|
||||||
|
|
||||||
|
extern void *__curbrk attribute_hidden;
|
||||||
|
extern void _end attribute_hidden;
|
||||||
|
void *const endpage = (void *) 0 + (((__curbrk - (void *) 0)
|
||||||
|
+ GLRO(dl_pagesize) - 1)
|
||||||
|
& -GLRO(dl_pagesize));
|
||||||
|
if (__builtin_expect (__curbrk >= &_end && __curbrk < endpage, 0))
|
||||||
|
__brk (endpage);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
#include <sysdeps/generic/dl-sysdep.c>
|
#include <sysdeps/generic/dl-sysdep.c>
|
||||||
|
@ -400,3 +400,9 @@
|
|||||||
#if __LINUX_KERNEL_VERSION >= 132612
|
#if __LINUX_KERNEL_VERSION >= 132612
|
||||||
# define __ASSUME_GETDENTS32_D_TYPE 1
|
# define __ASSUME_GETDENTS32_D_TYPE 1
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* Starting with version 2.5.3, the initial location returned by `brk'
|
||||||
|
after exec is always rounded up to the next page. */
|
||||||
|
#if __LINUX_KERNEL_VERSION >= 132355
|
||||||
|
# define __ASSUME_BRK_PAGE_ROUNDED 1
|
||||||
|
#endif
|
||||||
|
Reference in New Issue
Block a user