diff options
Diffstat (limited to 'include')
-rw-r--r-- | include/netinet/in.h | 4 | ||||
-rw-r--r-- | include/rpc/auth.h | 9 | ||||
-rw-r--r-- | include/rpc/clnt.h | 22 | ||||
-rw-r--r-- | include/rpc/svc.h | 17 | ||||
-rw-r--r-- | include/rpc/svc_auth.h | 4 | ||||
-rw-r--r-- | include/sys/socket.h | 54 |
6 files changed, 104 insertions, 6 deletions
diff --git a/include/netinet/in.h b/include/netinet/in.h index b85d938181..2a57aceb5e 100644 --- a/include/netinet/in.h +++ b/include/netinet/in.h @@ -1,3 +1,7 @@ #include <inet/netinet/in.h> extern const struct in6_addr in6addr_any_internal attribute_hidden; + +/* Bind socket to a privileged IP port. */ +extern int bindresvport_internal (int __sockfd, + struct sockaddr_in *__sock_in) attribute_hidden; diff --git a/include/rpc/auth.h b/include/rpc/auth.h index bc19049291..9bfde8331b 100644 --- a/include/rpc/auth.h +++ b/include/rpc/auth.h @@ -19,4 +19,13 @@ DECLARE_NSS_PROTOTYPES (nisplus) extern bool_t xdr_des_block_internal (XDR *__xdrs, des_block *__blkp); extern bool_t xdr_opaque_auth_internal (XDR *, struct opaque_auth *); +extern AUTH *authunix_create_internal (char *__machname, __uid_t __uid, + __gid_t __gid, int __len, + __gid_t *__aup_gids) attribute_hidden; +extern AUTH *authunix_create_default_internal (void) attribute_hidden; +extern AUTH *authnone_create_internal (void) attribute_hidden; +extern AUTH *authdes_pk_create_internal (const char *, netobj *, u_int, + struct sockaddr *, + des_block *) attribute_hidden; + #endif diff --git a/include/rpc/clnt.h b/include/rpc/clnt.h index 071c008eb6..13844962be 100644 --- a/include/rpc/clnt.h +++ b/include/rpc/clnt.h @@ -4,4 +4,26 @@ /* Now define the internal interfaces. */ extern int _openchild (const char *command, FILE **fto, FILE **ffrom); +extern CLIENT *clnt_create_internal (__const char *__host, + __const u_long __prog, + __const u_long __vers, + __const char *__prot) attribute_hidden; +extern CLIENT *clnttcp_create_internal (struct sockaddr_in *__raddr, + u_long __prog, u_long __version, + int *__sockp, u_int __sendsz, + u_int __recvsz) attribute_hidden; +extern CLIENT *clntudp_create_internal (struct sockaddr_in *__raddr, + u_long __program, u_long __version, + struct timeval __wait_resend, + int *__sockp) attribute_hidden; +extern CLIENT *clntudp_bufcreate_internal (struct sockaddr_in *__raddr, + u_long __program, u_long __version, + struct timeval __wait_resend, + int *__sockp, u_int __sendsz, + u_int __recvsz) attribute_hidden; +extern CLIENT *clntunix_create_internal (struct sockaddr_un *__raddr, + u_long __program, u_long __version, + int *__sockp, u_int __sendsz, + u_int __recvsz) attribute_hidden; + #endif diff --git a/include/rpc/svc.h b/include/rpc/svc.h index bf948d51e2..063e6f3976 100644 --- a/include/rpc/svc.h +++ b/include/rpc/svc.h @@ -10,5 +10,22 @@ extern SVCXPRT *svcfd_create (int fd, u_int sendsize, u_int recvsize); extern int svcudp_enablecache (SVCXPRT *transp, u_long size); extern SVCXPRT *svcunixfd_create (int fd, u_int sendsize, u_int recvsize); +extern bool_t svc_sendreply_internal (SVCXPRT *xprt, xdrproc_t __xdr_results, + caddr_t __xdr_location) attribute_hidden; +extern void svcerr_decode_internal (SVCXPRT *__xprt) attribute_hidden; +extern void svc_getreq_internal (int __rdfds) attribute_hidden; +extern void svc_getreq_common_internal (const int __fd) attribute_hidden; +extern void svc_getreqset_internal (fd_set *__readfds) attribute_hidden; +extern void svc_getreq_poll_internal (struct pollfd *, + const int) attribute_hidden; +extern bool_t svc_register_internal (SVCXPRT *__xprt, rpcprog_t __prog, + rpcvers_t __vers, + __dispatch_fn_t __dispatch, + rpcprot_t __protocol) attribute_hidden; +extern void svc_unregister_internal (rpcprog_t __prog, + rpcvers_t __vers) attribute_hidden; +extern SVCXPRT *svcudp_create_internal (int __sock) attribute_hidden; +extern SVCXPRT *svcudp_bufcreate_internal (int __sock, u_int __sendsz, + u_int __recvsz) attribute_hidden; #endif diff --git a/include/rpc/svc_auth.h b/include/rpc/svc_auth.h index 9d2462bacb..bf5ce91b68 100644 --- a/include/rpc/svc_auth.h +++ b/include/rpc/svc_auth.h @@ -6,7 +6,7 @@ extern enum auth_stat _svcauth_unix (struct svc_req *rqst, struct rpc_msg *msg); extern enum auth_stat _svcauth_short (struct svc_req *rqst, struct rpc_msg *msg); - - +extern enum auth_stat _authenticate_internal (struct svc_req *__rqst, + struct rpc_msg *__msg) attribute_hidden; #endif diff --git a/include/sys/socket.h b/include/sys/socket.h index 5a8169ffc8..b97c354276 100644 --- a/include/sys/socket.h +++ b/include/sys/socket.h @@ -2,22 +2,24 @@ #include <socket/sys/socket.h> /* Now define the internal interfaces. */ -extern int __socket (int __domain, int __type, int __protocol); +extern int __socket (int __domain, int __type, + int __protocol) attribute_hidden; /* Create two new sockets, of type TYPE in domain DOMAIN and using protocol PROTOCOL, which are connected to each other, and put file descriptors for them in FDS[0] and FDS[1]. If PROTOCOL is zero, one will be chosen automatically. Returns 0 on success, -1 for errors. */ extern int __socketpair (int __domain, int __type, int __protocol, - int __fds[2]); + int __fds[2]) attribute_hidden; /* Return a socket of any type. The socket can be used in subsequent ioctl calls to talk to the kernel. */ -extern int __opensock (void) internal_function; +extern int __opensock (void) internal_function attribute_hidden; /* Put the address of the peer connected to socket FD into *ADDR (which is *LEN bytes long), and its actual length into *LEN. */ -extern int __getpeername (int __fd, __SOCKADDR_ARG __addr, socklen_t *__len); +extern int __getpeername (int __fd, __SOCKADDR_ARG __addr, + socklen_t *__len) attribute_hidden; /* Send N bytes of BUF to socket FD. Returns the number sent or -1. */ extern ssize_t __send (int __fd, __const void *__buf, size_t __n, int __flags); @@ -30,6 +32,50 @@ extern int __connect (int __fd, __CONST_SOCKADDR_ARG __addr, socklen_t __len); extern int __connect_internal (int __fd, __CONST_SOCKADDR_ARG __addr, socklen_t __len) attribute_hidden; +/* Send N bytes of BUF on socket FD to peer at address ADDR (which is + ADDR_LEN bytes long). Returns the number sent, or -1 for errors. */ +extern ssize_t __sendto (int __fd, __const void *__buf, size_t __n, + int __flags, __CONST_SOCKADDR_ARG __addr, + socklen_t __addr_len) attribute_hidden; + +/* Read N bytes into BUF through socket FD. + If ADDR is not NULL, fill in *ADDR_LEN bytes of it with tha address of + the sender, and store the actual size of the address in *ADDR_LEN. + Returns the number of bytes read or -1 for errors. */ +extern ssize_t __recvfrom (int __fd, void *__restrict __buf, size_t __n, + int __flags, __SOCKADDR_ARG __addr, + socklen_t *__restrict __addr_len) attribute_hidden; + +/* Send a message described MESSAGE on socket FD. + Returns the number of bytes sent, or -1 for errors. */ +extern ssize_t __sendmsg (int __fd, __const struct msghdr *__message, + int __flags) attribute_hidden; + +/* Receive a message as described by MESSAGE from socket FD. + Returns the number of bytes read or -1 for errors. */ +extern ssize_t __recvmsg (int __fd, struct msghdr *__message, + int __flags) attribute_hidden; + +/* Set socket FD's option OPTNAME at protocol level LEVEL + to *OPTVAL (which is OPTLEN bytes long). + Returns 0 on success, -1 for errors. */ +extern int __setsockopt (int __fd, int __level, int __optname, + __const void *__optval, + socklen_t __optlen) attribute_hidden; + +/* Put the local address of FD into *ADDR and its length in *LEN. */ +extern int __getsockname (int __fd, __SOCKADDR_ARG __addr, + socklen_t *__restrict __len) attribute_hidden; + +/* Give the socket FD the local address ADDR (which is LEN bytes long). */ +extern int __bind (int __fd, __CONST_SOCKADDR_ARG __addr, + socklen_t __len) attribute_hidden; + +/* Prepare to accept connections on socket FD. + N connection requests will be queued before further requests are refused. + Returns 0 on success, -1 for errors. */ +extern int __listen (int __fd, int __n) attribute_hidden; + /* Return the length of a `sockaddr' structure. */ #ifdef _HAVE_SA_LEN # define SA_LEN(_x) (_x)->sa_len |