__libc_system.
(__libc_system): Call it, putting just the line == NULL test here.
* include/libc-symbols.h (__hidden_proto): Add extern keywords so
variables work right.
* elf/dl-open.c (dl_open_worker): Use _ macro instead of gettext.
* elf/dl-close.c (_dl_close): Likewise.
* include/netinet/in.h: Use libc_hidden_proto for bindresvport,
in6addr_any, in6addr_loopback. Remove decls for
bindresvport_internal, in6addr_any_internal, in6addr_loopback_internal.
* sunrpc/svc_udp.c (svcudp_bufcreate): Nix INTUSE for bindresvport.
* sunrpc/svc_tcp.c (svctcp_create): Likewise.
* sunrpc/clnt_udp.c (clntudp_bufcreate): Likewise.
* sunrpc/bindrsvprt.c: Change INTDEF to libc_hidden_def.
* inet/in6_addr.c: Change INTVARDEF to libc_hidden_def.
* sysdeps/posix/getaddrinfo.c (gaih_inet): Nix INTUSE for
in6addr_loopback.
* inet/gethstbyad_r.c (PREPROCESS): Nix INTUSE for in6addr_any.
* include/netinet/ether.h: Use libc_hidden_proto for ether_ntoa_r,
ether_aton_r.
* inet/ether_aton_r.c: Add libc_hidden_def.
* inet/ether_ntoa_r.c: Likewise.
* include/rpc/auth.h: Use libc_hidden_proto for getnetname,
netname2user, host2netname.
* sunrpc/netname.c: Add libc_hidden_def.
* include/netdb.h: Use libc_hidden_proto for innetgr, rcmd_af,
rexec_af, rresvport_af, ruserok_af.
* inet/rcmd.c: Add libc_hidden_def.
* inet/getnetgrent_r.c: Likewise.
2002-08-05 Roland McGrath <roland@redhat.com>
+ * sysdeps/posix/system.c (do_system): New function, guts broken out of
+ __libc_system.
+ (__libc_system): Call it, putting just the line == NULL test here.
+
+ * include/libc-symbols.h (__hidden_proto): Add extern keywords so
+ variables work right.
+
+ * elf/dl-open.c (dl_open_worker): Use _ macro instead of gettext.
+ * elf/dl-close.c (_dl_close): Likewise.
+
+ * include/netinet/in.h: Use libc_hidden_proto for bindresvport,
+ in6addr_any, in6addr_loopback. Remove decls for
+ bindresvport_internal, in6addr_any_internal, in6addr_loopback_internal.
+ * sunrpc/svc_udp.c (svcudp_bufcreate): Nix INTUSE for bindresvport.
+ * sunrpc/svc_tcp.c (svctcp_create): Likewise.
+ * sunrpc/clnt_udp.c (clntudp_bufcreate): Likewise.
+ * sunrpc/bindrsvprt.c: Change INTDEF to libc_hidden_def.
+ * inet/in6_addr.c: Change INTVARDEF to libc_hidden_def.
+ * sysdeps/posix/getaddrinfo.c (gaih_inet): Nix INTUSE for
+ in6addr_loopback.
+ * inet/gethstbyad_r.c (PREPROCESS): Nix INTUSE for in6addr_any.
+
+ * include/netinet/ether.h: Use libc_hidden_proto for ether_ntoa_r,
+ ether_aton_r.
+ * inet/ether_aton_r.c: Add libc_hidden_def.
+ * inet/ether_ntoa_r.c: Likewise.
+
+ * include/rpc/auth.h: Use libc_hidden_proto for getnetname,
+ netname2user, host2netname.
+ * sunrpc/netname.c: Add libc_hidden_def.
+
+ * include/netdb.h: Use libc_hidden_proto for innetgr, rcmd_af,
+ rexec_af, rresvport_af, ruserok_af.
+ * inet/rcmd.c: Add libc_hidden_def.
+ * inet/getnetgrent_r.c: Likewise.
+
* include/rpc/svc.h: Use libc_hidden_proto for xprt_register,
xprt_unregister.
* sunrpc/svc.c: Add libc_hidden_def.
counter. */
if (any_tls)
if (__builtin_expect (++GL(dl_tls_generation) == 0, 0))
- __libc_fatal (gettext ("TLS generation counter wrapped! Please send report with the 'glibcbug' script."));
+ __libc_fatal (_("TLS generation counter wrapped! Please send report with the 'glibcbug' script."));
#endif
/* Notify the debugger those objects are finalized and gone. */
/* Bump the generation number if necessary. */
if (any_tls)
if (__builtin_expect (++GL(dl_tls_generation) == 0, 0))
- __libc_fatal (gettext ("TLS generation counter wrapped! Please send report with the 'glibcbug' script."));
+ __libc_fatal (_("TLS generation counter wrapped! Please send report with the 'glibcbug' script."));
#endif
/* Run the initializer functions of new objects. */
# endif
# define hidden_proto(name) __hidden_proto (name, __GI_##name)
# define __hidden_proto(name, internal) \
- __typeof (name) internal; \
- __typeof (name) name __asm__ (__hidden_asmname (#internal)) \
+ extern __typeof (name) internal; \
+ extern __typeof (name) name __asm__ (__hidden_asmname (#internal)) \
__hidden_proto_hiddenattr;
# define __hidden_asmname(name) \
__hidden_asmname1 (__USER_LABEL_PREFIX__, name)
# define __set_h_errno(x) (h_errno = (x))
# endif /* _LIBC_REENTRANT */
+libc_hidden_proto (innetgr)
+libc_hidden_proto (rcmd_af)
+libc_hidden_proto (rexec_af)
+libc_hidden_proto (rresvport_af)
+libc_hidden_proto (ruserok_af)
+
/* Document internal interfaces. */
extern int __gethostent_r (struct hostent *__restrict __result_buf,
char *__restrict __buf, size_t __buflen,
#ifndef _NETINET_ETHER_H
#include <inet/netinet/ether.h>
+libc_hidden_proto (ether_aton_r)
+libc_hidden_proto (ether_ntoa_r)
+
/* Because the `ethers' lookup does not fit so well in the scheme we
define a dummy struct here which helps us to use the available
functions. */
struct parser_data *data,
size_t datalen, int *errnop);
-#define DECLARE_NSS_PROTOTYPES(service) \
-extern enum nss_status _nss_ ## service ## _setetherent (int __stayopen); \
-extern enum nss_status _nss_ ## service ## _endetherent (void); \
-extern enum nss_status _nss_ ## service ## _getetherent_r \
- (struct etherent *result, char *buffer, \
- size_t buflen, int *errnop); \
-extern enum nss_status _nss_ ## service ## _gethostton_r \
- (const char *name, struct etherent *eth, \
- char *buffer, size_t buflen, int *errnop); \
-extern enum nss_status _nss_ ## service ## _getntohost_r \
- (const struct ether_addr *addr, \
- struct etherent *eth, \
+#define DECLARE_NSS_PROTOTYPES(service) \
+extern enum nss_status _nss_ ## service ## _setetherent (int __stayopen); \
+extern enum nss_status _nss_ ## service ## _endetherent (void); \
+extern enum nss_status _nss_ ## service ## _getetherent_r \
+ (struct etherent *result, char *buffer, \
+ size_t buflen, int *errnop); \
+extern enum nss_status _nss_ ## service ## _gethostton_r \
+ (const char *name, struct etherent *eth, \
+ char *buffer, size_t buflen, int *errnop); \
+extern enum nss_status _nss_ ## service ## _getntohost_r \
+ (const struct ether_addr *addr, \
+ struct etherent *eth, \
char *buffer, size_t buflen, int *errnop);
DECLARE_NSS_PROTOTYPES (files)
+#ifndef _NETINET_IN_H
+
#include <inet/netinet/in.h>
-extern const struct in6_addr in6addr_any_internal attribute_hidden;
-extern const struct in6_addr in6addr_loopback_internal attribute_hidden;
+libc_hidden_proto (bindresvport)
+libc_hidden_proto (in6addr_loopback)
+libc_hidden_proto (in6addr_any)
-/* Bind socket to a privileged IP port. */
-extern int bindresvport_internal (int __sockfd,
- struct sockaddr_in *__sock_in) attribute_hidden;
+#endif
#ifndef _RPC_AUTH_H
#include <sunrpc/rpc/auth.h>
+libc_hidden_proto (getnetname)
+libc_hidden_proto (netname2user)
+libc_hidden_proto (host2netname)
+
/* Now define the internal interfaces. */
struct key_netstarg;
extern int key_setnet (struct key_netstarg *arg);
-/* Copyright (C) 1996, 1997, 1998, 1999 Free Software Foundation, Inc.
+/* Copyright (C) 1996,97,98,99,2002 Free Software Foundation, Inc.
This file is part of the GNU C Library.
Contributed by Ulrich Drepper <drepper@cygnus.com>, 1996.
return addr;
}
+libc_hidden_def (ether_aton_r)
-/* Copyright (C) 1996, 1997 Free Software Foundation, Inc.
+/* Copyright (C) 1996,97,2002 Free Software Foundation, Inc.
This file is part of the GNU C Library.
Contributed by Ulrich Drepper <drepper@cygnus.com>, 1996.
addr->ether_addr_octet[4], addr->ether_addr_octet[5]);
return buf;
}
+libc_hidden_def (ether_ntoa_r)
be performed. */
#define PREPROCESS \
if (len == sizeof (struct in6_addr) \
- && __builtin_expect (memcmp (&INTUSE(in6addr_any), addr, \
+ && __builtin_expect (memcmp (&in6addr_any, addr, \
sizeof (struct in6_addr)), 1) == 0) \
{ \
*h_errnop = HOST_NOT_FOUND; \
return result == 1;
}
+libc_hidden_def (innetgr)
const struct in6_addr in6addr_any =
{ { { 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0 } } };
-INTVARDEF(in6addr_any)
+libc_hidden_def (in6addr_any)
const struct in6_addr in6addr_loopback =
{ { { 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1 } } };
-INTVARDEF(in6addr_loopback)
+libc_hidden_def (in6addr_loopback)
freeaddrinfo(res);
return -1;
}
+libc_hidden_def (rcmd_af)
int
rcmd(ahost, rport, locuser, remuser, cmd, fd2p)
__set_errno (EAGAIN);
return -1;
}
+libc_hidden_def (rresvport_af)
int
rresvport(alport)
freeaddrinfo(res0);
return (ret);
}
+libc_hidden_def (ruserok_af)
+
int
ruserok(rhost, superuser, ruser, luser)
const char *rhost, *ruser, *luser;
return res;
}
-INTDEF (bindresvport)
+libc_hidden_def (bindresvport)
goto fooy;
}
/* attempt to bind to prov port */
- (void) INTUSE(bindresvport) (*sockp, (struct sockaddr_in *) 0);
+ (void) bindresvport (*sockp, (struct sockaddr_in *) 0);
/* the sockets rpc controls are non-blocking */
(void) __ioctl (*sockp, FIONBIO, (char *) &dontblock);
#ifdef IP_RECVERR
sprintf (netname, "%s.%s@%s", OPSYS, hostname, domainname);
return 1;
}
+libc_hidden_def (host2netname)
int
getnetname (char name[MAXNETNAMELEN + 1])
dummy = user2netname (name, uid, NULL);
return (dummy);
}
+libc_hidden_def (getnetname)
/* Type of the lookup function for netname2user. */
typedef int (*netname2user_function) (const char netname[MAXNETNAMELEN + 1],
return status == NSS_STATUS_SUCCESS;
}
+libc_hidden_def (netname2user)
int
netname2host (const char netname[MAXNETNAMELEN + 1], char *hostname,
}
__bzero ((char *) &addr, sizeof (addr));
addr.sin_family = AF_INET;
- if (INTUSE(bindresvport) (sock, &addr))
+ if (bindresvport (sock, &addr))
{
addr.sin_port = 0;
(void) __bind (sock, (struct sockaddr *) &addr, len);
}
__bzero ((char *) &addr, sizeof (addr));
addr.sin_family = AF_INET;
- if (INTUSE(bindresvport) (sock, &addr))
+ if (bindresvport (sock, &addr))
{
addr.sin_port = 0;
(void) __bind (sock, (struct sockaddr *) &addr, len);
{
at->family = AF_INET6;
if ((req->ai_flags & AI_PASSIVE) == 0)
- memcpy (at->addr, &INTUSE(in6addr_loopback),
- sizeof (struct in6_addr));
+ memcpy (at->addr, &in6addr_loopback, sizeof (struct in6_addr));
atr = at->next;
}
-/* Copyright (C) 1991-1999, 2000 Free Software Foundation, Inc.
+/* Copyright (C) 1991-99,2000,02 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
#define SHELL_NAME "sh" /* Name to give it. */
/* Execute LINE as a shell command, returning its status. */
-int
-__libc_system (const char *line)
+static int
+do_system (const char *line)
{
int status, save;
pid_t pid;
sigset_t block, omask;
#endif
- if (line == NULL)
- /* Check that we have a command processor available. It might
- not be available after a chroot(), for example. */
- return __libc_system ("exit 0") == 0;
-
sa.sa_handler = SIG_IGN;
sa.sa_flags = 0;
__sigemptyset (&sa.sa_mask);
return status;
}
+
+int
+__libc_system (const char *line)
+{
+ if (line == NULL)
+ /* Check that we have a command processor available. It might
+ not be available after a chroot(), for example. */
+ return do_system ("exit 0") == 0;
+
+ return do_system (line);
+}
weak_alias (__libc_system, system)