mirror of
git://sourceware.org/git/glibc.git
synced 2025-01-12 12:07:12 +08:00
2a051a7d1a
2003-02-07 Kaz Kojima <kkojima@rr.iij4u.or.jp> * elf/tls-macros.h: Add non-PIC TLS macros and fix clobber list for SH. * sysdeps/unix/sysv/linux/sh/brk.c: Add SYSCALL_INST_PAD after the trapa instruction. * sysdeps/unix/sysv/linux/sh/clone.S (__clone): Add additional parameters. * sysdeps/unix/sysv/linux/sh/sh4/sysdep.h: New file. (NEED_SYSCALL_INST_PAD): Define. * sysdeps/unix/sysv/linux/sh/sys/user.h (start_thread): Undef to avoid to use definition for the kernel. * sysdeps/unix/sysv/linux/sh/sysdep.h (SYSCALL_ERROR_HANDLER): Save and restore the frame pointer. (SYSCALL_INST_PAD): Define. (INLINE_SYSCALL): Make use of INTERNAL_SYSCALL. (INTERNAL_SYSCALL): Make use of ERR parameter. Add SYSCALL_INST_PAD after trapa instruction. (INTERNAL_SYSCALL_DECL, INTERNAL_SYSCALL_ERRNO, INTERNAL_SYSCALL_ERROR_P): Adjust accordingly.
49 lines
1.4 KiB
C
49 lines
1.4 KiB
C
/* brk system call for Linux/SH.
|
|
Copyright (C) 1999, 2000, 2003 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 Lesser General Public
|
|
License as published by the Free Software Foundation; either
|
|
version 2.1 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
|
|
Lesser General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Lesser General Public
|
|
License along with the GNU C Library; if not, write to the Free
|
|
Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
|
|
02111-1307 USA. */
|
|
|
|
#include <errno.h>
|
|
#include <unistd.h>
|
|
#include <sysdep.h>
|
|
|
|
/* This must be initialized data because commons can't have aliases. */
|
|
void *__curbrk = 0;
|
|
|
|
int
|
|
__brk (void *addr)
|
|
{
|
|
void *newbrk;
|
|
register long r3 asm ("%r3") = SYS_ify (brk);
|
|
register long r4 asm ("%r4") = (long)addr;
|
|
|
|
asm volatile ("trapa #0x11\n\t" SYSCALL_INST_PAD
|
|
: "=z"(newbrk)
|
|
: "r" (r3), "r" (r4));
|
|
|
|
__curbrk = newbrk;
|
|
|
|
if (newbrk < addr)
|
|
{
|
|
__set_errno (ENOMEM);
|
|
return -1;
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
weak_alias (__brk, brk)
|