Replace unnecessary ARM uses of <sys/linux-syscalls.h> with <asm/unistd.h>.
For some reason, socketcalls.c was only being compiled for ARM, where it makes no sense. For x86 we generate stubs for the socket functions that use __NR_socketcall directly. Change-Id: I84181e6183fae2314ae3ed862276eba82ad21e8e
This commit is contained in:
parent
3323628d63
commit
8794ece296
6 changed files with 3 additions and 264 deletions
|
@ -366,7 +366,6 @@ libc_upstream_netbsd_src_files := \
|
|||
ifeq ($(TARGET_ARCH),arm)
|
||||
libc_common_src_files += \
|
||||
bionic/memmove.c.arm \
|
||||
bionic/socketcalls.c \
|
||||
string/bcopy.c \
|
||||
string/strncmp.c \
|
||||
|
||||
|
|
|
@ -27,7 +27,7 @@
|
|||
*/
|
||||
|
||||
#include <machine/asm.h>
|
||||
#include <sys/linux-syscalls.h>
|
||||
#include <asm/unistd.h>
|
||||
|
||||
// void _exit_with_stack_teardown(void* stackBase, int stackSize, int retCode)
|
||||
ENTRY(_exit_with_stack_teardown)
|
||||
|
|
|
@ -28,7 +28,7 @@
|
|||
|
||||
#include <linux/err.h>
|
||||
#include <machine/asm.h>
|
||||
#include <sys/linux-syscalls.h>
|
||||
#include <asm/unistd.h>
|
||||
|
||||
// int __pthread_clone(void* (*fn)(void*), void* child_stack, int flags, void* arg);
|
||||
ENTRY(__pthread_clone)
|
||||
|
|
|
@ -26,7 +26,7 @@
|
|||
* SUCH DAMAGE.
|
||||
*/
|
||||
|
||||
#include <sys/linux-syscalls.h>
|
||||
#include <asm/unistd.h>
|
||||
#include <machine/asm.h>
|
||||
|
||||
#define FUTEX_WAIT 0
|
||||
|
|
|
@ -28,7 +28,6 @@
|
|||
|
||||
#include <linux/err.h>
|
||||
#include <machine/asm.h>
|
||||
#include <sys/linux-syscalls.h>
|
||||
|
||||
ENTRY(syscall)
|
||||
mov ip, sp
|
||||
|
|
|
@ -1,259 +0,0 @@
|
|||
/*
|
||||
* Copyright (C) 2008 The Android Open Source Project
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
* * Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in
|
||||
* the documentation and/or other materials provided with the
|
||||
* distribution.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
||||
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
||||
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
||||
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
||||
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
||||
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
|
||||
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
|
||||
* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||
* SUCH DAMAGE.
|
||||
*/
|
||||
#include <unistd.h>
|
||||
#include <sys/socket.h>
|
||||
#include <sys/linux-syscalls.h>
|
||||
|
||||
enum
|
||||
{
|
||||
SYS_SOCKET = 1,
|
||||
SYS_BIND,
|
||||
SYS_CONNECT,
|
||||
SYS_LISTEN,
|
||||
SYS_ACCEPT,
|
||||
SYS_GETSOCKNAME,
|
||||
SYS_GETPEERNAME,
|
||||
SYS_SOCKETPAIR,
|
||||
SYS_SEND,
|
||||
SYS_RECV,
|
||||
SYS_SENDTO,
|
||||
SYS_RECVFROM,
|
||||
SYS_SHUTDOWN,
|
||||
SYS_SETSOCKOPT,
|
||||
SYS_GETSOCKOPT,
|
||||
SYS_SENDMSG,
|
||||
SYS_RECVMSG
|
||||
};
|
||||
|
||||
#ifndef __NR_socket
|
||||
int socket(int domain, int type, int protocol)
|
||||
{
|
||||
unsigned long t[3];
|
||||
|
||||
t[0] = (unsigned long) domain;
|
||||
t[1] = (unsigned long) type;
|
||||
t[2] = (unsigned long) protocol;
|
||||
|
||||
return (int) __socketcall( SYS_SOCKET, t );
|
||||
}
|
||||
#endif /* !__NR_socket */
|
||||
|
||||
|
||||
#ifndef __NR_bind
|
||||
int bind(int sockfd, const struct sockaddr *my_addr, socklen_t addrlen)
|
||||
{
|
||||
unsigned long t[3];
|
||||
|
||||
t[0] = (unsigned long) sockfd;
|
||||
t[1] = (unsigned long) my_addr;
|
||||
t[2] = (unsigned long) addrlen;
|
||||
|
||||
return (int) __socketcall( SYS_BIND, t );
|
||||
}
|
||||
#endif /* !__NR_bind */
|
||||
|
||||
#ifndef __NR_connect
|
||||
int connect(int sockfd, const struct sockaddr *serv_addr, socklen_t addrlen )
|
||||
{
|
||||
unsigned long t[3];
|
||||
|
||||
t[0] = (unsigned long) sockfd;
|
||||
t[1] = (unsigned long) serv_addr;
|
||||
t[2] = (unsigned long) addrlen;
|
||||
|
||||
return (int) __socketcall( SYS_CONNECT, t );
|
||||
}
|
||||
#endif /* !__NR_connect */
|
||||
|
||||
#ifndef __NR_listen
|
||||
int listen(int s, int backlog)
|
||||
{
|
||||
unsigned long t[2];
|
||||
|
||||
t[0] = (unsigned long) s;
|
||||
t[1] = (unsigned long) backlog;
|
||||
|
||||
return (int) __socketcall( SYS_LISTEN, t );
|
||||
}
|
||||
#endif /* __NR_listen */
|
||||
|
||||
#ifndef __NR_accept
|
||||
int accept(int sock, struct sockaddr *adresse, socklen_t *longueur)
|
||||
{
|
||||
unsigned long t[3];
|
||||
|
||||
t[0] = (unsigned long) sock;
|
||||
t[1] = (unsigned long) adresse;
|
||||
t[2] = (unsigned long) longueur;
|
||||
|
||||
return (int) __socketcall( SYS_ACCEPT, t );
|
||||
}
|
||||
#endif /* __NR_accept */
|
||||
|
||||
#ifndef __NR_getsockname
|
||||
int getsockname(int s, struct sockaddr * name, socklen_t * namelen )
|
||||
{
|
||||
unsigned long t[3];
|
||||
|
||||
t[0] = (unsigned long) s;
|
||||
t[1] = (unsigned long) name;
|
||||
t[2] = (unsigned long) namelen;
|
||||
|
||||
return (int) __socketcall( SYS_GETSOCKNAME, t );
|
||||
}
|
||||
#endif /* __NR_getsockname */
|
||||
|
||||
#ifndef __NR_getpeername
|
||||
int getpeername(int s, struct sockaddr *name, socklen_t *namelen)
|
||||
{
|
||||
unsigned long t[3];
|
||||
|
||||
t[0] = (unsigned long) s;
|
||||
t[1] = (unsigned long) name;
|
||||
t[2] = (unsigned long) namelen;
|
||||
|
||||
return (int) __socketcall( SYS_GETPEERNAME, t );
|
||||
}
|
||||
#endif /* !__NR_getpeername */
|
||||
|
||||
#ifndef __NR_socketpair
|
||||
int socketpair(int d, int type, int protocol, int sv[2])
|
||||
{
|
||||
unsigned long t[4];
|
||||
|
||||
t[0] = (unsigned long) d;
|
||||
t[1] = (unsigned long) type;
|
||||
t[2] = (unsigned long) protocol;
|
||||
t[3] = (unsigned long) sv;
|
||||
|
||||
return (int) __socketcall( SYS_SOCKETPAIR, t );
|
||||
}
|
||||
#endif /* __NR_socketpair */
|
||||
|
||||
#ifndef __NR_sendto
|
||||
ssize_t sendto(int socket, const void *message, size_t length, int flags,
|
||||
const struct sockaddr *dest_addr, socklen_t dest_len)
|
||||
{
|
||||
unsigned long t[6];
|
||||
|
||||
t[0] = (unsigned long) socket;
|
||||
t[1] = (unsigned long) message;
|
||||
t[2] = (unsigned long) length;
|
||||
t[3] = (unsigned long) flags;
|
||||
t[4] = (unsigned long) dest_addr;
|
||||
t[5] = (unsigned long) dest_len;
|
||||
|
||||
return __socketcall( SYS_SENDTO, t );
|
||||
}
|
||||
#endif /* !__NR_sendto */
|
||||
|
||||
#ifndef __NR_recvfrom
|
||||
ssize_t recvfrom(int socket, void *buffer, size_t length, unsigned int flags,
|
||||
const struct sockaddr *address, socklen_t *address_len)
|
||||
{
|
||||
unsigned long t[6];
|
||||
|
||||
t[0] = (unsigned long) socket;
|
||||
t[1] = (unsigned long) buffer;
|
||||
t[2] = (unsigned long) length;
|
||||
t[3] = (unsigned long) flags;
|
||||
t[4] = (unsigned long) address;
|
||||
t[5] = (unsigned long) address_len;
|
||||
|
||||
return __socketcall( SYS_RECVFROM, t );
|
||||
}
|
||||
#endif /* !__NR_recvfrom */
|
||||
|
||||
#ifndef __NR_shutdown
|
||||
int shutdown(int socket, int how)
|
||||
{
|
||||
unsigned long t[2];
|
||||
|
||||
t[0] = (unsigned long) socket;
|
||||
t[1] = (unsigned long) how;
|
||||
|
||||
return (int) __socketcall( SYS_SHUTDOWN, t );
|
||||
}
|
||||
#endif /* !__NR_shutdown */
|
||||
|
||||
#ifndef __NR_setsockopt
|
||||
int setsockopt( int s, int level, int optname, const void* optval, socklen_t optlen )
|
||||
{
|
||||
unsigned long t[5];
|
||||
|
||||
t[0] = (unsigned long) s;
|
||||
t[1] = (unsigned long) level;
|
||||
t[2] = (unsigned long) optname;
|
||||
t[3] = (unsigned long) optval;
|
||||
t[4] = (unsigned long) optlen;
|
||||
|
||||
return (int) __socketcall( SYS_SETSOCKOPT, t );
|
||||
}
|
||||
#endif /* !__NR_setsockopt */
|
||||
|
||||
#ifndef __NR_getsockopt
|
||||
int getsockopt(int s, int level, int optname, void *optval, socklen_t *optlen)
|
||||
{
|
||||
unsigned long t[5];
|
||||
|
||||
t[0] = (unsigned long) s;
|
||||
t[1] = (unsigned long) level;
|
||||
t[2] = (unsigned long) optname;
|
||||
t[3] = (unsigned long) optval;
|
||||
t[4] = (unsigned long) optlen;
|
||||
|
||||
return (int) __socketcall( SYS_GETSOCKOPT, t );
|
||||
}
|
||||
#endif /* !__NR_getsockopt */
|
||||
|
||||
#ifndef __NR_sendmsg
|
||||
int sendmsg (int socket, const struct msghdr *message, unsigned int flags)
|
||||
{
|
||||
unsigned long t[3];
|
||||
|
||||
t[0] = (unsigned long) socket;
|
||||
t[1] = (unsigned long) message;
|
||||
t[2] = (unsigned long) flags;
|
||||
|
||||
return __socketcall( SYS_SENDMSG, t );
|
||||
}
|
||||
#endif /* __NR_sendmsg */
|
||||
|
||||
#ifndef __NR_recvmsg
|
||||
int recvmsg(int socket, struct msghdr *message, unsigned int flags)
|
||||
{
|
||||
unsigned long t[3];
|
||||
|
||||
t[0] = (unsigned long) socket;
|
||||
t[1] = (unsigned long) message;
|
||||
t[2] = (unsigned long) flags;
|
||||
|
||||
return __socketcall( SYS_RECVMSG, t );
|
||||
}
|
||||
#endif /* __NR_recvmsg */
|
||||
|
Loading…
Reference in a new issue