brk.c 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. /* brk system call for Linux/i386.
  2. Copyright (C) 1995, 1996, 2000 Free Software Foundation, Inc.
  3. This file is part of the GNU C Library.
  4. The GNU C Library is free software; you can redistribute it and/or
  5. modify it under the terms of the GNU Lesser General Public
  6. License as published by the Free Software Foundation; either
  7. version 2.1 of the License, or (at your option) any later version.
  8. The GNU C Library is distributed in the hope that it will be useful,
  9. but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  11. Lesser General Public License for more details.
  12. You should have received a copy of the GNU Lesser General Public
  13. License along with the GNU C Library; if not, write to the Free
  14. Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
  15. 02111-1307 USA. */
  16. #include <errno.h>
  17. #include <unistd.h>
  18. #include <sys/syscall.h>
  19. /* This must be initialized data because commons can't have aliases. */
  20. void *___brk_addr = 0;
  21. int brk (void *addr)
  22. {
  23. void *__unbounded newbrk, *__unbounded scratch;
  24. asm ("movl %%ebx, %1\n" /* Save %ebx in scratch register. */
  25. "movl %3, %%ebx\n" /* Put ADDR in %ebx to be syscall arg. */
  26. "int $0x80 # %2\n" /* Perform the system call. */
  27. "movl %1, %%ebx\n" /* Restore %ebx from scratch register. */
  28. : "=a" (newbrk), "=r" (scratch)
  29. : "0" (__NR_brk), "g" (__ptrvalue (addr)));
  30. ___brk_addr = newbrk;
  31. if (newbrk < addr)
  32. {
  33. __set_errno (ENOMEM);
  34. return -1;
  35. }
  36. return 0;
  37. }