mirror of
https://sourceware.org/git/glibc.git
synced 2024-11-05 21:00:05 +00:00
* sysdeps/mach/hurd/brk.c (DATA_SIZE): Bump to 128MB.
(_hurd_set_brk): Try to allocate more space when we run out. * sysdeps/generic/sbrk.c: If __curbrk is zero, call __brk with zero and examine it again. * sysdeps/unix/sysv/linux/i386/brk.c: New file. * sysdeps/unix/sysv/linux/i386/brk.S: File removed. * sysdeps/unix/sysv/linux/i386/sbrk.S: File removed. * sysdeps/unix/sysv/linux/dl-sysdep.c: New file.
This commit is contained in:
parent
0fe4e55291
commit
683158e0c4
@ -1,7 +1,14 @@
|
|||||||
Sat Dec 2 03:47:27 1995 Roland McGrath <roland@churchy.gnu.ai.mit.edu>
|
Sat Dec 2 03:47:27 1995 Roland McGrath <roland@churchy.gnu.ai.mit.edu>
|
||||||
|
|
||||||
* sysdeps/unix/sysv/linux/i386/sbrk.S: File removed.
|
* sysdeps/mach/hurd/brk.c (DATA_SIZE): Bump to 128MB.
|
||||||
|
(_hurd_set_brk): Try to allocate more space when we run out.
|
||||||
|
|
||||||
|
* sysdeps/generic/sbrk.c: If __curbrk is zero, call __brk with
|
||||||
|
zero and examine it again.
|
||||||
|
* sysdeps/unix/sysv/linux/i386/brk.c: New file.
|
||||||
|
* sysdeps/unix/sysv/linux/i386/brk.S: File removed.
|
||||||
|
* sysdeps/unix/sysv/linux/i386/sbrk.S: File removed.
|
||||||
|
* sysdeps/unix/sysv/linux/dl-sysdep.c: New file.
|
||||||
* sysdeps/generic/dl-sysdep.c (_dl_sysdep_start) [DL_SYSDEP_INIT]:
|
* sysdeps/generic/dl-sysdep.c (_dl_sysdep_start) [DL_SYSDEP_INIT]:
|
||||||
Invoke this macro before calling DL_MAIN.
|
Invoke this macro before calling DL_MAIN.
|
||||||
|
|
||||||
|
@ -15,26 +15,30 @@ You should have received a copy of the GNU General Public License
|
|||||||
along with the GNU C Library; see the file COPYING. If not, write to
|
along with the GNU C Library; see the file COPYING. If not, write to
|
||||||
the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */
|
the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */
|
||||||
|
|
||||||
#include <ansidecl.h>
|
#include <unistd.h>
|
||||||
|
#include <errno.h>
|
||||||
|
|
||||||
/* Defined in brk.c. */
|
/* Defined in brk.c. */
|
||||||
extern PTR __curbrk;
|
extern void *__curbrk;
|
||||||
extern int EXFUN(__brk, (PTR addr));
|
extern int __brk (void *addr);
|
||||||
|
|
||||||
/* Extend the process's data space by INCREMENT.
|
/* Extend the process's data space by INCREMENT.
|
||||||
If INCREMENT is negative, shrink data space by - INCREMENT.
|
If INCREMENT is negative, shrink data space by - INCREMENT.
|
||||||
Return start of new space allocated, or -1 for errors. */
|
Return start of new space allocated, or -1 for errors. */
|
||||||
PTR
|
void *
|
||||||
DEFUN(__sbrk, (increment), int increment)
|
__sbrk (int increment)
|
||||||
{
|
{
|
||||||
char *oldbrk;
|
void *oldbrk;
|
||||||
|
|
||||||
|
if (__curbrk == 0 && __brk (0) < 0)
|
||||||
|
return (void *) -1;
|
||||||
|
|
||||||
if (increment == 0)
|
if (increment == 0)
|
||||||
return __curbrk;
|
return __curbrk;
|
||||||
|
|
||||||
oldbrk = __curbrk;
|
oldbrk = __curbrk;
|
||||||
if (__brk(oldbrk + increment) < 0)
|
if (__brk (oldbrk + increment) < 0)
|
||||||
return (PTR) -1;
|
return (void *) -1;
|
||||||
|
|
||||||
return oldbrk;
|
return oldbrk;
|
||||||
}
|
}
|
||||||
|
@ -23,8 +23,8 @@ Cambridge, MA 02139, USA. */
|
|||||||
#include <cthreads.h> /* For `struct mutex'. */
|
#include <cthreads.h> /* For `struct mutex'. */
|
||||||
|
|
||||||
|
|
||||||
/* Initial maximum size of the data segment (32MB, which is arbitrary). */
|
/* Initial maximum size of the data segment (this is arbitrary). */
|
||||||
#define DATA_SIZE (32 * 1024 * 1024)
|
#define DATA_SIZE (128 * 1024 * 1024)
|
||||||
|
|
||||||
|
|
||||||
/* Up to the page including this address is allocated from the kernel.
|
/* Up to the page including this address is allocated from the kernel.
|
||||||
@ -85,13 +85,20 @@ _hurd_set_brk (vm_address_t addr)
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Make the memory accessible. */
|
if (pagend > _hurd_data_end)
|
||||||
if (err = __vm_protect (__mach_task_self (), pagebrk, pagend - pagebrk,
|
|
||||||
0, VM_PROT_READ|VM_PROT_WRITE|VM_PROT_EXECUTE))
|
|
||||||
{
|
{
|
||||||
errno = err;
|
/* We didn't allocate enough space! Hopefully we can get some more! */
|
||||||
return -1;
|
err = __vm_allocate (__mach_task_self (), &pagebrk, pagend - pagebrk, 0);
|
||||||
|
if (! err)
|
||||||
|
_hurd_data_end = pagend;
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
/* Make the memory accessible. */
|
||||||
|
err = __vm_protect (__mach_task_self (), pagebrk, pagend - pagebrk,
|
||||||
|
0, VM_PROT_READ|VM_PROT_WRITE|VM_PROT_EXECUTE);
|
||||||
|
|
||||||
|
if (err)
|
||||||
|
return __hurd_fail (err);
|
||||||
|
|
||||||
_hurd_brk = addr;
|
_hurd_brk = addr;
|
||||||
return 0;
|
return 0;
|
||||||
@ -112,7 +119,7 @@ init_brk (void)
|
|||||||
|
|
||||||
pagend = round_page (_hurd_brk);
|
pagend = round_page (_hurd_brk);
|
||||||
|
|
||||||
_hurd_data_end = (vm_address_t) &__data_start + DATA_SIZE;
|
_hurd_data_end = round_page ((vm_address_t) &__data_start + DATA_SIZE);
|
||||||
|
|
||||||
if (pagend < _hurd_data_end)
|
if (pagend < _hurd_data_end)
|
||||||
{
|
{
|
||||||
|
44
sysdeps/unix/sysv/linux/dl-sysdep.c
Normal file
44
sysdeps/unix/sysv/linux/dl-sysdep.c
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
/* Dynamic linker system dependencies for Linux.
|
||||||
|
Copyright (C) 1995 Free Software Foundation, Inc.
|
||||||
|
This file is part of the GNU C Library.
|
||||||
|
|
||||||
|
The GNU C Library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Library General Public License as
|
||||||
|
published by the Free Software Foundation; either version 2 of the
|
||||||
|
License, or (at your option) any later version.
|
||||||
|
|
||||||
|
The GNU C Library is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public
|
||||||
|
License along with the GNU C Library; see the file COPYING.LIB. If
|
||||||
|
not, write to the Free Software Foundation, Inc., 675 Mass Ave,
|
||||||
|
Cambridge, MA 02139, USA. */
|
||||||
|
|
||||||
|
/* Linux needs some special initialization, but otherwise uses
|
||||||
|
the generic dynamic linker system interface code. */
|
||||||
|
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
|
#define DL_SYSDEP_INIT frob_brk ()
|
||||||
|
|
||||||
|
static inline void
|
||||||
|
frob_brk (void)
|
||||||
|
{
|
||||||
|
extern void _end;
|
||||||
|
__brk (0); /* Initialize the break. */
|
||||||
|
if (__sbrk (0) == &_end)
|
||||||
|
{
|
||||||
|
/* The dynamic linker was run as a program, and so the initial break
|
||||||
|
starts just after our bss, at &_end. The malloc in dl-minimal.c
|
||||||
|
will consume the rest of this page, so tell the kernel to move the
|
||||||
|
break up that far. When the user program examines its break, it
|
||||||
|
will see this new value and not clobber our data. */
|
||||||
|
size_t pg = __getpagesize ();
|
||||||
|
__sbrk (pg - ((&_end - (void *) 0) & pg));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#include <sysdeps/generic/dl-sysdep.c>
|
49
sysdeps/unix/sysv/linux/i386/brk.c
Normal file
49
sysdeps/unix/sysv/linux/i386/brk.c
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
/* brk system call for Linux/i386.
|
||||||
|
Copyright (C) 1995 Free Software Foundation, Inc.
|
||||||
|
This file is part of the GNU C Library.
|
||||||
|
|
||||||
|
The GNU C Library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Library General Public License as
|
||||||
|
published by the Free Software Foundation; either version 2 of the
|
||||||
|
License, or (at your option) any later version.
|
||||||
|
|
||||||
|
The GNU C Library is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public
|
||||||
|
License along with the GNU C Library; see the file COPYING.LIB. If
|
||||||
|
not, write to the Free Software Foundation, Inc., 675 Mass Ave,
|
||||||
|
Cambridge, MA 02139, USA. */
|
||||||
|
|
||||||
|
#include <errno.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <sysdep.h>
|
||||||
|
|
||||||
|
void *__curbrk;
|
||||||
|
|
||||||
|
int
|
||||||
|
__brk (void *addr)
|
||||||
|
{
|
||||||
|
void *newbrk, *scratch;
|
||||||
|
|
||||||
|
asm ("movl %%ebx, %1\n" /* Save %ebx in scratch register. */
|
||||||
|
"movl %3, %%ebx\n" /* Put ADDR in %ebx to be syscall arg. */
|
||||||
|
"int $0x80 # %2\n" /* Perform the system call. */
|
||||||
|
"movl %1, %%ebx\n" /* Restore %ebx from scratch register. */
|
||||||
|
: "=a" (newbrk), "=r" (scratch)
|
||||||
|
: "0" (SYS_ify (brk)), "g" (addr));
|
||||||
|
|
||||||
|
__curbrk = newbrk;
|
||||||
|
|
||||||
|
if (newbrk < addr)
|
||||||
|
{
|
||||||
|
errno = ENOMEM;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
weak_alias (__brk, brk)
|
||||||
|
|
Loading…
Reference in New Issue
Block a user