glibc/sysdeps/unix/sysv/linux/tile/tilegx/ioctl.S
H.J. Lu 9e5ee8b839 Hide internal __ioctl function [BZ #18822]
Hide internal __ioctl function to allow direct access within libc.so and
libc.a without using GOT nor PLT.

__GI___ioctl is defined when sysdeps/unix/syscalls.list is used to
generate ioctl.  Otherwise libc_hidden_def is needed explicitly.

	[BZ #18822]
	* include/sys/ioctl.h (__ioctl): Add libc_hidden_proto.
	* misc/ioctl.c (__ioctl): Add libc_hidden_def.
	* sysdeps/mach/hurd/ioctl.c (__ioctl): Likewise.
	* sysdeps/unix/sysv/linux/aarch64/ioctl.S (__ioctl): Likewise.
	* sysdeps/unix/sysv/linux/mips/mips64/n64/ioctl.S (__ioctl):
	Likewise.
	* sysdeps/unix/sysv/linux/powerpc/ioctl.c (__ioctl): Likewise.
	* sysdeps/unix/sysv/linux/tile/tilegx/ioctl.S (__ioctl): Likewise.
2017-10-01 15:59:06 -07:00

43 lines
1.5 KiB
ArmAsm

/* Copyright (C) 2011-2017 Free Software Foundation, Inc.
This file is part of the GNU C Library.
Contributed by Chris Metcalf <cmetcalf@tilera.com>, 2011.
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, see
<http://www.gnu.org/licenses/>. */
/* TILE-Gx specifies that "unsigned int" is sign extended in the high
32 bits. But since the userspace API claims to be "unsigned long",
calls into __ioctl() will not be sign extended, but rather pass all
64 bits of the argument. Therefore, when we pass the "request"
value to the kernel, we must explicitly sign-extend it to match the
kernel's internal use of "unsigned int" as the second argument,
which we do by casting to "unsigned int". */
#include <sysdep.h>
.text
ENTRY (__ioctl)
FEEDBACK_ENTER(__ioctl)
{
addxi r1, r1, 0
moveli TREG_SYSCALL_NR_NAME, __NR_ioctl
}
swint1
BNEZ r1, 0f
jrp lr
PSEUDO_END (__ioctl)
libc_hidden_def (__ioctl)
weak_alias (__ioctl, ioctl)