1
0
mirror of https://sourceware.org/git/glibc.git synced 2025-07-29 11:41:21 +03:00
2008-01-16  Ulrich Drepper  <drepper@redhat.com>
	[BZ #5607]
	* conform/data/fcntl.h-data: Fix posix_fadvise and posix_fallocate
	prototypes.
	* conform/data/limits.h-data: Adjust limits changed in v6 and add
	additional suffixes.
	* conform/data/mqueue.h-data: Fix typo in mq_curmsgs entry.
	Add optional functions mq_timedreceive and mq_timedsend.
	* conform/data/netdb.h-data: Add more AI_* and EAI_* constants.
	* conform/data/pthread.h-data: Fix prototype of
	pthread_condattr_setclock.  pthread_sigmask is not required in v6.
	* conform/data/semaphore.h-data: Allow time.h definitions.
	* conform/data/signal.h-data: Likewise.
	* conform/data/stdio.h-data: getw and putw are not required in v6.
	* conform/data/stdlib.h-data: Change setstate prototype.
	* conform/data/string.h-data: Fix strerror_r prototype.
	* conform/data/time.h-data: Fix typo in TIMER_ABSTIME definition.
	* conform/data/unistd.h-data: pthread_atfork not required in v6.
	Fix readlink prototype.
	* conform/data/netinet/in.h-data: Add const to in6addr_any and
	in6addr_loopback.
	* inet/netinet/in.h: Cleanup namespace.
	* posix/regex.h: Likewise.
	* resolv/netdb.h: Likewise.
	* sysdeps/unix/sysv/linux/bits/in.h: Likewise.
	* sysdeps/unix/sysv/linux/bits/socket.h: Likewise.
	* sysdeps/unix/sysv/linux/x86_64/bits/stat.h: Likewise.
This commit is contained in:
Ulrich Drepper
2008-01-16 10:11:18 +00:00
parent fbe90cd5c7
commit a53d3f8295
20 changed files with 255 additions and 99 deletions

View File

@ -1,3 +1,32 @@
2008-01-16 Ulrich Drepper <drepper@redhat.com>
[BZ #5607]
* conform/data/fcntl.h-data: Fix posix_fadvise and posix_fallocate
prototypes.
* conform/data/limits.h-data: Adjust limits changed in v6 and add
additional suffixes.
* conform/data/mqueue.h-data: Fix typo in mq_curmsgs entry.
Add optional functions mq_timedreceive and mq_timedsend.
* conform/data/netdb.h-data: Add more AI_* and EAI_* constants.
* conform/data/pthread.h-data: Fix prototype of
pthread_condattr_setclock. pthread_sigmask is not required in v6.
* conform/data/semaphore.h-data: Allow time.h definitions.
* conform/data/signal.h-data: Likewise.
* conform/data/stdio.h-data: getw and putw are not required in v6.
* conform/data/stdlib.h-data: Change setstate prototype.
* conform/data/string.h-data: Fix strerror_r prototype.
* conform/data/time.h-data: Fix typo in TIMER_ABSTIME definition.
* conform/data/unistd.h-data: pthread_atfork not required in v6.
Fix readlink prototype.
* conform/data/netinet/in.h-data: Add const to in6addr_any and
in6addr_loopback.
* inet/netinet/in.h: Cleanup namespace.
* posix/regex.h: Likewise.
* resolv/netdb.h: Likewise.
* sysdeps/unix/sysv/linux/bits/in.h: Likewise.
* sysdeps/unix/sysv/linux/bits/socket.h: Likewise.
* sysdeps/unix/sysv/linux/x86_64/bits/stat.h: Likewise.
2008-01-15 Ulrich Drepper <drepper@redhat.com> 2008-01-15 Ulrich Drepper <drepper@redhat.com>
* conform/data/fmtmsg.h-data: Add missing allows. * conform/data/fmtmsg.h-data: Add missing allows.

View File

@ -87,8 +87,8 @@ function int creat (const char*, mode_t)
function int fcntl (int, int, ...) function int fcntl (int, int, ...)
function int open (const char*, int, ...) function int open (const char*, int, ...)
#ifdef XOPEN2K #ifdef XOPEN2K
function int posix_fadvise (int, off_t, size_t, int) function int posix_fadvise (int, off_t, off_t, int)
function int posix_fallocate (int, off_t, size_t) function int posix_fallocate (int, off_t, off_t)
#endif #endif
allow-header sys/stat.h allow-header sys/stat.h

View File

@ -57,7 +57,11 @@ constant _POSIX_CLOCKRES_MIN <= 20000000
optional-constant _POSIX_AIO_LISTIO_MAX 2 optional-constant _POSIX_AIO_LISTIO_MAX 2
optional-constant _POSIX_AIO_MAX 1 optional-constant _POSIX_AIO_MAX 1
optional-constant _POSIX_ARG_MAX 4096 optional-constant _POSIX_ARG_MAX 4096
#ifdef XOPEN2K
optional-constant _POSIX_CHILD_MAX 25
#else
optional-constant _POSIX_CHILD_MAX 6 optional-constant _POSIX_CHILD_MAX 6
#endif
optional-constant _POSIX_DELAYTIMER_MAX 32 optional-constant _POSIX_DELAYTIMER_MAX 32
optional-constant _POSIX_LINK_MAX 8 optional-constant _POSIX_LINK_MAX 8
optional-constant _POSIX_LOGIN_NAME_MAX 9 optional-constant _POSIX_LOGIN_NAME_MAX 9
@ -66,8 +70,16 @@ optional-constant _POSIX_MAX_INPUT 255
optional-constant _POSIX_MQ_OPEN_MAX 8 optional-constant _POSIX_MQ_OPEN_MAX 8
optional-constant _POSIX_MQ_PRIO_MAX 32 optional-constant _POSIX_MQ_PRIO_MAX 32
optional-constant _POSIX_NAME_MAX 14 optional-constant _POSIX_NAME_MAX 14
#ifdef XOPEN2K
optional-constant _POSIX_NGROUPS_MAX 8
#else
optional-constant _POSIX_NGROUPS_MAX 0 optional-constant _POSIX_NGROUPS_MAX 0
#endif
#ifdef XOPEN2K
optional-constant _POSIX_OPEN_MAX 20
#else
optional-constant _POSIX_OPEN_MAX 16 optional-constant _POSIX_OPEN_MAX 16
#endif
optional-constant _POSIX_PATH_MAX 256 optional-constant _POSIX_PATH_MAX 256
optional-constant _POSIX_PIPE_BUF 512 optional-constant _POSIX_PIPE_BUF 512
optional-constant _POSIX2_RE_DUP_MAX 255 optional-constant _POSIX2_RE_DUP_MAX 255
@ -126,3 +138,6 @@ optional-constant NL_SETMAX >= 255
optional-constant NL_TEXTMAX optional-constant NL_TEXTMAX
optional-constant NZERO >= 20 optional-constant NZERO >= 20
optional-constant TMP_MAX >= 10000 optional-constant TMP_MAX >= 10000
allow *_MAX
allow *_MIN

View File

@ -8,7 +8,7 @@ type {struct mq_attr}
element {struct mq_attr} long mq_flags element {struct mq_attr} long mq_flags
element {struct mq_attr} long mq_maxmsg element {struct mq_attr} long mq_maxmsg
element {struct mq_attr} long mq_msgsize element {struct mq_attr} long mq_msgsize
element {struct mq_attr} long mq_curmsg element {struct mq_attr} long mq_curmsgs
function int mq_close (mqd_t) function int mq_close (mqd_t)
function int mq_getattr (mqd_t, struct mq_attr*) function int mq_getattr (mqd_t, struct mq_attr*)
@ -18,6 +18,10 @@ function ssize_t mq_receive (mqd_t, char*, size_t, unsigned int*)
function int mq_send (mqd_t, const char*, size_t, unsigned int) function int mq_send (mqd_t, const char*, size_t, unsigned int)
function int mq_setattr (mqd_t, const struct mq_attr*, struct mq_attr*) function int mq_setattr (mqd_t, const struct mq_attr*, struct mq_attr*)
function int mq_unlink (const char*) function int mq_unlink (const char*)
#ifdef XOPEN2K
optional-function ssize_t mq_timedreceive (mqd_t, char*, size_t, unsigned int*, const struct timespec*)
optional-function int mq_timedsend (mqd_t, const char*, size_t, unsigned int, const struct timespec*)
#endif
allow-header fcntl.h allow-header fcntl.h
allow-header signal.h allow-header signal.h

View File

@ -55,6 +55,10 @@ element {struct addrinfo} {struct addrinfo*} ai_next
macro AI_PASSIVE macro AI_PASSIVE
macro AI_CANONNAME macro AI_CANONNAME
macro AI_NUMERICHOST macro AI_NUMERICHOST
macro AI_V4MAPPED
macro AI_ALL
macro AI_ADDRCONFIG
macro AI_NUMERICSERV
macro NI_NOFQDN macro NI_NOFQDN
macro NI_NUMERICHOST macro NI_NUMERICHOST
@ -71,6 +75,7 @@ macro EAI_NONAME
macro EAI_SERVICE macro EAI_SERVICE
macro EAI_SOCKTYPE macro EAI_SOCKTYPE
macro EAI_SYSTEM macro EAI_SYSTEM
macro EAI_OVERFLOW
function void endhostent (void) function void endhostent (void)
function void endnetent (void) function void endnetent (void)

View File

@ -27,12 +27,12 @@ element {struct sockaddr_in6} uint32_t sin6_flowinfo
element {struct sockaddr_in6} {struct in6_addr} sin6_addr element {struct sockaddr_in6} {struct in6_addr} sin6_addr
element {struct sockaddr_in6} uint32_t sin6_scope_id element {struct sockaddr_in6} uint32_t sin6_scope_id
variable {struct in6_addr} in6addr_any variable {const struct in6_addr} in6addr_any
// constant IN6ADDR_ANY_INIT // constant IN6ADDR_ANY_INIT
macro IN6ADDR_ANY_INIT macro IN6ADDR_ANY_INIT
variable {struct in6_addr} in6addr_loopback variable {const struct in6_addr} in6addr_loopback
// constant IN6ADDR_LOOPBACK_INIT // constant IN6ADDR_LOOPBACK_INIT
macro IN6ADDR_LOOPBACK_INIT macro IN6ADDR_LOOPBACK_INIT

View File

@ -84,7 +84,7 @@ function int pthread_condattr_destroy (pthread_condattr_t*)
optional-function int pthread_condattr_getclock (const pthread_condattr_t*, clockid_t*) optional-function int pthread_condattr_getclock (const pthread_condattr_t*, clockid_t*)
function int pthread_condattr_getpshared (const pthread_condattr_t*, int*) function int pthread_condattr_getpshared (const pthread_condattr_t*, int*)
function int pthread_condattr_init (pthread_condattr_t*) function int pthread_condattr_init (pthread_condattr_t*)
optional-function int pthread_condattr_setclock (const pthread_condattr_t*, clockid_t*) optional-function int pthread_condattr_setclock (pthread_condattr_t*, clockid_t)
function int pthread_condattr_setpshared (pthread_condattr_t*, int) function int pthread_condattr_setpshared (pthread_condattr_t*, int)
function int pthread_create (pthread_t*, const pthread_attr_t*, void *(*) (void*), void*) function int pthread_create (pthread_t*, const pthread_attr_t*, void *(*) (void*), void*)
function int pthread_detach (pthread_t) function int pthread_detach (pthread_t)
@ -140,7 +140,9 @@ function int pthread_setconcurrency (int)
# endif # endif
function int pthread_setschedparam (pthread_t, int, const struct sched_param*) function int pthread_setschedparam (pthread_t, int, const struct sched_param*)
function int pthread_setspecific (pthread_key_t, const void*) function int pthread_setspecific (pthread_key_t, const void*)
#ifndef XOPEN2K
function int pthread_sigmask (int, const sigset_t*, sigset_t*) function int pthread_sigmask (int, const sigset_t*, sigset_t*)
#endif
function int pthread_spin_destroy (pthread_spinlock_t*) function int pthread_spin_destroy (pthread_spinlock_t*)
function int pthread_spin_init (pthread_spinlock_t*, int) function int pthread_spin_init (pthread_spinlock_t*, int)
function int pthread_spin_lock (pthread_spinlock_t*) function int pthread_spin_lock (pthread_spinlock_t*)

View File

@ -18,6 +18,7 @@ function int sem_wait (sem_t*)
allow-header fcntl.h allow-header fcntl.h
allow-header sys/types.h allow-header sys/types.h
# endif # endif
allow-header time.h
allow sem_* allow sem_*
allow SEM_* allow SEM_*

View File

@ -203,3 +203,5 @@ allow SS_*
allow SV_* allow SV_*
allow TRAP_* allow TRAP_*
allow *_t allow *_t
allow-header time.h

View File

@ -67,7 +67,9 @@ function int getchar_unlocked ()
function int getopt (int, char *const[], const char *) function int getopt (int, char *const[], const char *)
#endif #endif
function {char*} gets (char*) function {char*} gets (char*)
#ifndef XOPEN2K
function int getw (FILE*) function int getw (FILE*)
#endif
function int pclose (FILE*) function int pclose (FILE*)
function void perror (const char*) function void perror (const char*)
function {FILE*} popen (const char*, const char*) function {FILE*} popen (const char*, const char*)
@ -77,7 +79,9 @@ function int putchar (int)
function int putc_unlocked (int, FILE*) function int putc_unlocked (int, FILE*)
function int putchar_unlocked (int) function int putchar_unlocked (int)
function int puts (const char*) function int puts (const char*)
#ifndef XOPEN2K
function int putw (int, FILE*) function int putw (int, FILE*)
#endif
function int remove (const char*) function int remove (const char*)
function int rename (const char*, const char*) function int rename (const char*, const char*)
function void rewind (FILE*) function void rewind (FILE*)

View File

@ -86,7 +86,7 @@ function {char*} realpath (const char*, char*)
function {unsigned short int*} seed48 (unsigned short int[3]) function {unsigned short int*} seed48 (unsigned short int[3])
function int setenv (const char*, const char*, int) function int setenv (const char*, const char*, int)
function void setkey (const char*) function void setkey (const char*)
function {char*} setstate (const char*) function {char*} setstate (char*)
function void srand (unsigned int) function void srand (unsigned int)
function void srand48 (long int) function void srand48 (long int)
function void srandom (unsigned) function void srandom (unsigned)

View File

@ -17,7 +17,7 @@ function size_t strcspn (const char*, const char*)
function {char*} strdup (const char*) function {char*} strdup (const char*)
function {char*} strerror (int) function {char*} strerror (int)
#ifdef XOPEN2K #ifdef XOPEN2K
function {char*} strerror_r (int, char*, size_t) function int strerror_r (int, char*, size_t)
#endif #endif
function size_t strlen (const char*) function size_t strlen (const char*)
function {char*} strncat (char*, const char*, size_t) function {char*} strncat (char*, const char*, size_t)

View File

@ -29,7 +29,7 @@ element {struct itimerspec} {struct timespec} it_interval
element {struct itimerspec} {struct timespec} it_value element {struct itimerspec} {struct timespec} it_value
constant CLOCK_REALTIME constant CLOCK_REALTIME
constant TIME_ABSTIME constant TIMER_ABSTIME
constant CLOCK_MONOTONIC constant CLOCK_MONOTONIC
type clock_t type clock_t

View File

@ -337,10 +337,12 @@ function {long int} pathconf (const char*, int)
function int pause (void) function int pause (void)
function int pipe (int[2]) function int pipe (int[2])
function ssize_t pread (int, void*, size_t, off_t) function ssize_t pread (int, void*, size_t, off_t)
#ifndef XOPEN2K
function int pthread_atfork (void(*)(void), void(*)(void), void(*)(void)) function int pthread_atfork (void(*)(void), void(*)(void), void(*)(void))
#endif
function ssize_t pwrite (int, const void*, size_t, off_t) function ssize_t pwrite (int, const void*, size_t, off_t)
function ssize_t read (int, void*, size_t) function ssize_t read (int, void*, size_t)
function int readlink (const char*, char*, size_t) function ssize_t readlink (const char*, char*, size_t)
function int rmdir (const char*) function int rmdir (const char*)
function {void*} sbrk (intptr_t) function {void*} sbrk (intptr_t)
function int setegid (gid_t) function int setegid (gid_t)

View File

@ -195,13 +195,17 @@ struct in6_addr
{ {
union union
{ {
uint8_t u6_addr8[16]; uint8_t __u6_addr8[16];
uint16_t u6_addr16[8]; #if defined __USE_MISC || defined __USE_GNU
uint32_t u6_addr32[4]; uint16_t __u6_addr16[8];
} in6_u; uint32_t __u6_addr32[4];
#define s6_addr in6_u.u6_addr8 #endif
#define s6_addr16 in6_u.u6_addr16 } __in6_u;
#define s6_addr32 in6_u.u6_addr32 #define s6_addr __in6_u.__u6_addr8
#if defined __USE_MISC || defined __USE_GNU
# define s6_addr16 __in6_u.__u6_addr16
# define s6_addr32 __in6_u.__u6_addr32
#endif
}; };
extern const struct in6_addr in6addr_any; /* :: */ extern const struct in6_addr in6addr_any; /* :: */
@ -238,6 +242,7 @@ struct sockaddr_in6
}; };
#if defined __USE_MISC || defined __USE_GNU
/* IPv4 multicast request. */ /* IPv4 multicast request. */
struct ip_mreq struct ip_mreq
{ {
@ -259,6 +264,8 @@ struct ip_mreq_source
/* IP address of interface. */ /* IP address of interface. */
struct in_addr imr_sourceaddr; struct in_addr imr_sourceaddr;
}; };
#endif
/* Likewise, for IPv6. */ /* Likewise, for IPv6. */
struct ipv6_mreq struct ipv6_mreq
@ -271,6 +278,7 @@ struct ipv6_mreq
}; };
#if defined __USE_MISC || defined __USE_GNU
/* Multicast group request. */ /* Multicast group request. */
struct group_req struct group_req
{ {
@ -337,6 +345,7 @@ struct group_filter
- sizeof (struct sockaddr_storage) \ - sizeof (struct sockaddr_storage) \
+ ((numsrc) \ + ((numsrc) \
* sizeof (struct sockaddr_storage))) * sizeof (struct sockaddr_storage)))
#endif
/* Get system-specific definitions. */ /* Get system-specific definitions. */
@ -422,12 +431,14 @@ extern uint16_t htons (uint16_t __hostshort)
&& (((__const uint32_t *) (a))[2] == ((__const uint32_t *) (b))[2]) \ && (((__const uint32_t *) (a))[2] == ((__const uint32_t *) (b))[2]) \
&& (((__const uint32_t *) (a))[3] == ((__const uint32_t *) (b))[3])) && (((__const uint32_t *) (a))[3] == ((__const uint32_t *) (b))[3]))
#if defined __USE_MISC || defined __USE_GNU
/* Bind socket to a privileged IP port. */ /* Bind socket to a privileged IP port. */
extern int bindresvport (int __sockfd, struct sockaddr_in *__sock_in) __THROW; extern int bindresvport (int __sockfd, struct sockaddr_in *__sock_in) __THROW;
/* The IPv6 version of this function. */ /* The IPv6 version of this function. */
extern int bindresvport6 (int __sockfd, struct sockaddr_in6 *__sock_in) extern int bindresvport6 (int __sockfd, struct sockaddr_in6 *__sock_in)
__THROW; __THROW;
#endif
#define IN6_IS_ADDR_MC_NODELOCAL(a) \ #define IN6_IS_ADDR_MC_NODELOCAL(a) \
@ -450,6 +461,8 @@ extern int bindresvport6 (int __sockfd, struct sockaddr_in6 *__sock_in)
(IN6_IS_ADDR_MULTICAST(a) \ (IN6_IS_ADDR_MULTICAST(a) \
&& ((((__const uint8_t *) (a))[1] & 0xf) == 0xe)) && ((((__const uint8_t *) (a))[1] & 0xf) == 0xe))
#ifdef __USE_GNU
/* IPv6 packet information. */ /* IPv6 packet information. */
struct in6_pktinfo struct in6_pktinfo
{ {
@ -465,7 +478,6 @@ struct ip6_mtuinfo
}; };
#ifdef __USE_GNU
/* Obsolete hop-by-hop and Destination Options Processing (RFC 2292). */ /* Obsolete hop-by-hop and Destination Options Processing (RFC 2292). */
extern int inet6_option_space (int __nbytes) extern int inet6_option_space (int __nbytes)
__THROW __attribute_deprecated__; __THROW __attribute_deprecated__;

View File

@ -1,6 +1,6 @@
/* Definitions for data structures and routines for the regular /* Definitions for data structures and routines for the regular
expression library. expression library.
Copyright (C) 1985,1989-93,1995-98,2000,2001,2002,2003,2005,2006 Copyright (C) 1985,1989-93,1995-98,2000,2001,2002,2003,2005,2006,2008
Free Software Foundation, Inc. Free Software Foundation, Inc.
This file is part of the GNU C Library. This file is part of the GNU C Library.
@ -43,6 +43,7 @@ typedef unsigned long int active_reg_t;
add or remove a bit, only one other definition need change. */ add or remove a bit, only one other definition need change. */
typedef unsigned long int reg_syntax_t; typedef unsigned long int reg_syntax_t;
#ifdef __USE_GNU
/* If this bit is not set, then \ inside a bracket expression is literal. /* If this bit is not set, then \ inside a bracket expression is literal.
If set, then such a \ quotes the following character. */ If set, then such a \ quotes the following character. */
# define RE_BACKSLASH_ESCAPE_IN_LISTS ((unsigned long int) 1) # define RE_BACKSLASH_ESCAPE_IN_LISTS ((unsigned long int) 1)
@ -173,6 +174,7 @@ typedef unsigned long int reg_syntax_t;
/* If this bit is set, then no_sub will be set to 1 during /* If this bit is set, then no_sub will be set to 1 during
re_compile_pattern. */ re_compile_pattern. */
# define RE_NO_SUB (RE_CONTEXT_INVALID_DUP << 1) # define RE_NO_SUB (RE_CONTEXT_INVALID_DUP << 1)
#endif
/* This global variable defines the particular regexp syntax to use (for /* This global variable defines the particular regexp syntax to use (for
some interfaces). When a regexp is compiled, the syntax used is some interfaces). When a regexp is compiled, the syntax used is
@ -180,6 +182,7 @@ typedef unsigned long int reg_syntax_t;
already-compiled regexps. */ already-compiled regexps. */
extern reg_syntax_t re_syntax_options; extern reg_syntax_t re_syntax_options;
#ifdef __USE_GNU
/* Define combinations of the above bits for the standard possibilities. /* Define combinations of the above bits for the standard possibilities.
(The [[[ comments delimit what gets put into the Texinfo file, so (The [[[ comments delimit what gets put into the Texinfo file, so
don't delete them!) */ don't delete them!) */
@ -259,6 +262,7 @@ extern reg_syntax_t re_syntax_options;
# endif # endif
/* If sizeof(int) == 2, then ((1 << 15) - 1) overflows. */ /* If sizeof(int) == 2, then ((1 << 15) - 1) overflows. */
# define RE_DUP_MAX (0x7fff) # define RE_DUP_MAX (0x7fff)
#endif
/* POSIX `cflags' bits (i.e., information for `regcomp'). */ /* POSIX `cflags' bits (i.e., information for `regcomp'). */
@ -337,7 +341,16 @@ typedef enum
private to the regex routines. */ private to the regex routines. */
#ifndef RE_TRANSLATE_TYPE #ifndef RE_TRANSLATE_TYPE
# define RE_TRANSLATE_TYPE unsigned char * # define __RE_TRANSLATE_TYPE unsigned char *
# ifdef __USE_GNU
# define RE_TRANSLATE_TYPE __RE_TRANSLATE_TYPE
# endif
#endif
#ifdef __USE_GNU
# define __REPB_PREFIX(name) name
#else
# define __REPB_PREFIX(name) __##name
#endif #endif
struct re_pattern_buffer struct re_pattern_buffer
@ -345,27 +358,27 @@ struct re_pattern_buffer
/* Space that holds the compiled pattern. It is declared as /* Space that holds the compiled pattern. It is declared as
`unsigned char *' because its elements are sometimes used as `unsigned char *' because its elements are sometimes used as
array indexes. */ array indexes. */
unsigned char *buffer; unsigned char *__REPB_PREFIX(buffer);
/* Number of bytes to which `buffer' points. */ /* Number of bytes to which `buffer' points. */
unsigned long int allocated; unsigned long int __REPB_PREFIX(allocated);
/* Number of bytes actually used in `buffer'. */ /* Number of bytes actually used in `buffer'. */
unsigned long int used; unsigned long int __REPB_PREFIX(used);
/* Syntax setting with which the pattern was compiled. */ /* Syntax setting with which the pattern was compiled. */
reg_syntax_t syntax; reg_syntax_t __REPB_PREFIX(syntax);
/* Pointer to a fastmap, if any, otherwise zero. re_search uses the /* Pointer to a fastmap, if any, otherwise zero. re_search uses the
fastmap, if there is one, to skip over impossible starting points fastmap, if there is one, to skip over impossible starting points
for matches. */ for matches. */
char *fastmap; char *__REPB_PREFIX(fastmap);
/* Either a translate table to apply to all characters before /* Either a translate table to apply to all characters before
comparing them, or zero for no translation. The translation is comparing them, or zero for no translation. The translation is
applied to a pattern when it is compiled and to a string when it applied to a pattern when it is compiled and to a string when it
is matched. */ is matched. */
RE_TRANSLATE_TYPE translate; __RE_TRANSLATE_TYPE __REPB_PREFIX(translate);
/* Number of subexpressions found by the compiler. */ /* Number of subexpressions found by the compiler. */
size_t re_nsub; size_t re_nsub;
@ -374,34 +387,36 @@ struct re_pattern_buffer
Well, in truth it's used only in `re_search_2', to see whether or Well, in truth it's used only in `re_search_2', to see whether or
not we should use the fastmap, so we don't set this absolutely not we should use the fastmap, so we don't set this absolutely
perfectly; see `re_compile_fastmap' (the `duplicate' case). */ perfectly; see `re_compile_fastmap' (the `duplicate' case). */
unsigned can_be_null : 1; unsigned __REPB_PREFIX(can_be_null) : 1;
/* If REGS_UNALLOCATED, allocate space in the `regs' structure /* If REGS_UNALLOCATED, allocate space in the `regs' structure
for `max (RE_NREGS, re_nsub + 1)' groups. for `max (RE_NREGS, re_nsub + 1)' groups.
If REGS_REALLOCATE, reallocate space if necessary. If REGS_REALLOCATE, reallocate space if necessary.
If REGS_FIXED, use what's there. */ If REGS_FIXED, use what's there. */
#ifdef __USE_GNU
# define REGS_UNALLOCATED 0 # define REGS_UNALLOCATED 0
# define REGS_REALLOCATE 1 # define REGS_REALLOCATE 1
# define REGS_FIXED 2 # define REGS_FIXED 2
unsigned regs_allocated : 2; #endif
unsigned __REPB_PREFIX(regs_allocated) : 2;
/* Set to zero when `regex_compile' compiles a pattern; set to one /* Set to zero when `regex_compile' compiles a pattern; set to one
by `re_compile_fastmap' if it updates the fastmap. */ by `re_compile_fastmap' if it updates the fastmap. */
unsigned fastmap_accurate : 1; unsigned __REPB_PREFIX(fastmap_accurate) : 1;
/* If set, `re_match_2' does not return information about /* If set, `re_match_2' does not return information about
subexpressions. */ subexpressions. */
unsigned no_sub : 1; unsigned __REPB_PREFIX(no_sub) : 1;
/* If set, a beginning-of-line anchor doesn't match at the beginning /* If set, a beginning-of-line anchor doesn't match at the beginning
of the string. */ of the string. */
unsigned not_bol : 1; unsigned __REPB_PREFIX(not_bol) : 1;
/* Similarly for an end-of-line anchor. */ /* Similarly for an end-of-line anchor. */
unsigned not_eol : 1; unsigned __REPB_PREFIX(not_eol) : 1;
/* If true, an anchor at a newline matches. */ /* If true, an anchor at a newline matches. */
unsigned newline_anchor : 1; unsigned __REPB_PREFIX(newline_anchor) : 1;
}; };
typedef struct re_pattern_buffer regex_t; typedef struct re_pattern_buffer regex_t;
@ -410,6 +425,7 @@ typedef struct re_pattern_buffer regex_t;
typedef int regoff_t; typedef int regoff_t;
#ifdef __USE_GNU
/* This is the structure we store register match data in. See /* This is the structure we store register match data in. See
regex.texinfo for a full description of what registers match. */ regex.texinfo for a full description of what registers match. */
struct re_registers struct re_registers
@ -426,6 +442,7 @@ struct re_registers
# ifndef RE_NREGS # ifndef RE_NREGS
# define RE_NREGS 30 # define RE_NREGS 30
# endif # endif
#endif
/* POSIX specification for registers. Aside from the different names than /* POSIX specification for registers. Aside from the different names than
@ -439,6 +456,7 @@ typedef struct
/* Declarations for routines. */ /* Declarations for routines. */
#ifdef __USE_GNU
/* Sets the current default syntax to SYNTAX, and return the old syntax. /* Sets the current default syntax to SYNTAX, and return the old syntax.
You can also simply assign to the `re_syntax_options' variable. */ You can also simply assign to the `re_syntax_options' variable. */
extern reg_syntax_t re_set_syntax (reg_syntax_t __syntax); extern reg_syntax_t re_set_syntax (reg_syntax_t __syntax);
@ -503,8 +521,9 @@ extern void re_set_registers (struct re_pattern_buffer *__buffer,
struct re_registers *__regs, struct re_registers *__regs,
unsigned int __num_regs, unsigned int __num_regs,
regoff_t *__starts, regoff_t *__ends); regoff_t *__starts, regoff_t *__ends);
#endif /* Use GNU */
#if defined _REGEX_RE_COMP || defined _LIBC #if defined _REGEX_RE_COMP || (defined _LIBC && defined __USE_BSD)
# ifndef _CRAY # ifndef _CRAY
/* 4.2 bsd compatibility. */ /* 4.2 bsd compatibility. */
extern char *re_comp (const char *); extern char *re_comp (const char *);

View File

@ -62,8 +62,6 @@ extern int *__h_errno_location (void) __THROW __attribute__ ((__const__));
/* Possible values left in `h_errno'. */ /* Possible values left in `h_errno'. */
#define NETDB_INTERNAL -1 /* See errno. */
#define NETDB_SUCCESS 0 /* No problem. */
#define HOST_NOT_FOUND 1 /* Authoritative Answer Host not found. */ #define HOST_NOT_FOUND 1 /* Authoritative Answer Host not found. */
#define TRY_AGAIN 2 /* Non-Authoritative Host not found, #define TRY_AGAIN 2 /* Non-Authoritative Host not found,
or SERVERFAIL. */ or SERVERFAIL. */
@ -71,7 +69,11 @@ extern int *__h_errno_location (void) __THROW __attribute__ ((__const__));
NOTIMP. */ NOTIMP. */
#define NO_DATA 4 /* Valid name, no data record of requested #define NO_DATA 4 /* Valid name, no data record of requested
type. */ type. */
#if defined __USE_MISC || defined __USE_GNU
# define NETDB_INTERNAL -1 /* See errno. */
# define NETDB_SUCCESS 0 /* No problem. */
# define NO_ADDRESS NO_DATA /* No address, look for MX record. */ # define NO_ADDRESS NO_DATA /* No address, look for MX record. */
#endif
#ifdef __USE_XOPEN2K #ifdef __USE_XOPEN2K
/* Highest reserved Internet port number. */ /* Highest reserved Internet port number. */
@ -83,13 +85,14 @@ extern int *__h_errno_location (void) __THROW __attribute__ ((__const__));
# define SCOPE_DELIMITER '%' # define SCOPE_DELIMITER '%'
#endif #endif
#if defined __USE_MISC || defined __USE_GNU
/* Print error indicated by `h_errno' variable on standard error. STR /* Print error indicated by `h_errno' variable on standard error. STR
if non-null is printed before the error string. */ if non-null is printed before the error string. */
extern void herror (__const char *__str) __THROW; extern void herror (__const char *__str) __THROW;
/* Return string associated with error ERR_NUM. */ /* Return string associated with error ERR_NUM. */
extern __const char *hstrerror (int __err_num) __THROW; extern __const char *hstrerror (int __err_num) __THROW;
#endif
/* Description of data base entry for a single host. */ /* Description of data base entry for a single host. */
@ -100,7 +103,9 @@ struct hostent
int h_addrtype; /* Host address type. */ int h_addrtype; /* Host address type. */
int h_length; /* Length of address. */ int h_length; /* Length of address. */
char **h_addr_list; /* List of addresses from name server. */ char **h_addr_list; /* List of addresses from name server. */
#if defined __USE_MISC || defined __USE_GNU
# define h_addr h_addr_list[0] /* Address, for backward compatibility.*/ # define h_addr h_addr_list[0] /* Address, for backward compatibility.*/
#endif
}; };
/* Open host data base files and mark them as staying open even after /* Open host data base files and mark them as staying open even after
@ -590,15 +595,15 @@ struct gaicb
# define EAI_NONAME -2 /* NAME or SERVICE is unknown. */ # define EAI_NONAME -2 /* NAME or SERVICE is unknown. */
# define EAI_AGAIN -3 /* Temporary failure in name resolution. */ # define EAI_AGAIN -3 /* Temporary failure in name resolution. */
# define EAI_FAIL -4 /* Non-recoverable failure in name res. */ # define EAI_FAIL -4 /* Non-recoverable failure in name res. */
# define EAI_NODATA -5 /* No address associated with NAME. */
# define EAI_FAMILY -6 /* `ai_family' not supported. */ # define EAI_FAMILY -6 /* `ai_family' not supported. */
# define EAI_SOCKTYPE -7 /* `ai_socktype' not supported. */ # define EAI_SOCKTYPE -7 /* `ai_socktype' not supported. */
# define EAI_SERVICE -8 /* SERVICE not supported for `ai_socktype'. */ # define EAI_SERVICE -8 /* SERVICE not supported for `ai_socktype'. */
# define EAI_ADDRFAMILY -9 /* Address family for NAME not supported. */
# define EAI_MEMORY -10 /* Memory allocation failure. */ # define EAI_MEMORY -10 /* Memory allocation failure. */
# define EAI_SYSTEM -11 /* System error returned in `errno'. */ # define EAI_SYSTEM -11 /* System error returned in `errno'. */
# define EAI_OVERFLOW -12 /* Argument buffer overflow. */ # define EAI_OVERFLOW -12 /* Argument buffer overflow. */
# ifdef __USE_GNU # ifdef __USE_GNU
# define EAI_NODATA -5 /* No address associated with NAME. */
# define EAI_ADDRFAMILY -9 /* Address family for NAME not supported. */
# define EAI_INPROGRESS -100 /* Processing request in progress. */ # define EAI_INPROGRESS -100 /* Processing request in progress. */
# define EAI_CANCELED -101 /* Request canceled. */ # define EAI_CANCELED -101 /* Request canceled. */
# define EAI_NOTCANCELED -102 /* Request not canceled. */ # define EAI_NOTCANCELED -102 /* Request not canceled. */
@ -607,8 +612,10 @@ struct gaicb
# define EAI_IDN_ENCODE -105 /* IDN encoding failed. */ # define EAI_IDN_ENCODE -105 /* IDN encoding failed. */
# endif # endif
# ifdef __USE_GNU
# define NI_MAXHOST 1025 # define NI_MAXHOST 1025
# define NI_MAXSERV 32 # define NI_MAXSERV 32
# endif
# define NI_NUMERICHOST 1 /* Don't try to look up hostname. */ # define NI_NUMERICHOST 1 /* Don't try to look up hostname. */
# define NI_NUMERICSERV 2 /* Don't convert port number to name. */ # define NI_NUMERICSERV 2 /* Don't convert port number to name. */

View File

@ -1,4 +1,4 @@
/* Copyright (C) 1991-1999, 2000, 2004 Free Software Foundation, Inc. /* Copyright (C) 1991-1999, 2000, 2004, 2008 Free Software Foundation, Inc.
This file is part of the GNU C Library. This file is part of the GNU C Library.
The GNU C Library is free software; you can redistribute it and/or The GNU C Library is free software; you can redistribute it and/or
@ -43,6 +43,7 @@
#define IP_ADD_SOURCE_MEMBERSHIP 39 /* ip_mreq_source: join source group */ #define IP_ADD_SOURCE_MEMBERSHIP 39 /* ip_mreq_source: join source group */
#define IP_DROP_SOURCE_MEMBERSHIP 40 /* ip_mreq_source: leave source group */ #define IP_DROP_SOURCE_MEMBERSHIP 40 /* ip_mreq_source: leave source group */
#define IP_MSFILTER 41 #define IP_MSFILTER 41
#if defined __USE_MISC || defined __USE_GNU
# define MCAST_JOIN_GROUP 42 /* group_req: join any-source group */ # define MCAST_JOIN_GROUP 42 /* group_req: join any-source group */
# define MCAST_BLOCK_SOURCE 43 /* group_source_req: block from given group */ # define MCAST_BLOCK_SOURCE 43 /* group_source_req: block from given group */
# define MCAST_UNBLOCK_SOURCE 44 /* group_source_req: unblock from given group*/ # define MCAST_UNBLOCK_SOURCE 44 /* group_source_req: unblock from given group*/
@ -53,6 +54,7 @@
# define MCAST_EXCLUDE 0 # define MCAST_EXCLUDE 0
# define MCAST_INCLUDE 1 # define MCAST_INCLUDE 1
#endif
#define IP_ROUTER_ALERT 5 /* bool */ #define IP_ROUTER_ALERT 5 /* bool */
#define IP_PKTINFO 8 /* bool */ #define IP_PKTINFO 8 /* bool */
@ -76,6 +78,7 @@
#define IP_DEFAULT_MULTICAST_LOOP 1 #define IP_DEFAULT_MULTICAST_LOOP 1
#define IP_MAX_MEMBERSHIPS 20 #define IP_MAX_MEMBERSHIPS 20
#if defined __USE_MISC || defined __USE_GNU
/* Structure used to describe IP options for IP_OPTIONS and IP_RETOPTS. /* Structure used to describe IP options for IP_OPTIONS and IP_RETOPTS.
The `ip_dst' field is used for the first-hop gateway when using a The `ip_dst' field is used for the first-hop gateway when using a
source route (this gets put into the header proper). */ source route (this gets put into the header proper). */
@ -100,6 +103,7 @@ struct in_pktinfo
struct in_addr ipi_spec_dst; /* Routing destination address */ struct in_addr ipi_spec_dst; /* Routing destination address */
struct in_addr ipi_addr; /* Header destination address */ struct in_addr ipi_addr; /* Header destination address */
}; };
#endif
/* Options for use with `getsockopt' and `setsockopt' at the IPv6 level. /* Options for use with `getsockopt' and `setsockopt' at the IPv6 level.
The first word in the comment at the right is the data type used; The first word in the comment at the right is the data type used;

View File

@ -26,10 +26,8 @@
#endif #endif
#define __need_size_t #define __need_size_t
#define __need_NULL
#include <stddef.h> #include <stddef.h>
#include <limits.h>
#include <sys/types.h> #include <sys/types.h>
/* Type for length arguments in socket calls. */ /* Type for length arguments in socket calls. */
@ -156,11 +154,7 @@ struct sockaddr
/* Structure large enough to hold any socket address (with the historical /* Structure large enough to hold any socket address (with the historical
exception of AF_UNIX). We reserve 128 bytes. */ exception of AF_UNIX). We reserve 128 bytes. */
#if ULONG_MAX > 0xffffffff #define __ss_aligntype unsigned long int
# define __ss_aligntype __uint64_t
#else
# define __ss_aligntype __uint32_t
#endif
#define _SS_SIZE 128 #define _SS_SIZE 128
#define _SS_PADSIZE (_SS_SIZE - (2 * sizeof (__ss_aligntype))) #define _SS_PADSIZE (_SS_SIZE - (2 * sizeof (__ss_aligntype)))
@ -263,7 +257,7 @@ struct cmsghdr
#define CMSG_NXTHDR(mhdr, cmsg) __cmsg_nxthdr (mhdr, cmsg) #define CMSG_NXTHDR(mhdr, cmsg) __cmsg_nxthdr (mhdr, cmsg)
#define CMSG_FIRSTHDR(mhdr) \ #define CMSG_FIRSTHDR(mhdr) \
((size_t) (mhdr)->msg_controllen >= sizeof (struct cmsghdr) \ ((size_t) (mhdr)->msg_controllen >= sizeof (struct cmsghdr) \
? (struct cmsghdr *) (mhdr)->msg_control : (struct cmsghdr *) NULL) ? (struct cmsghdr *) (mhdr)->msg_control : (struct cmsghdr *) 0)
#define CMSG_ALIGN(len) (((len) + sizeof (size_t) - 1) \ #define CMSG_ALIGN(len) (((len) + sizeof (size_t) - 1) \
& (size_t) ~(sizeof (size_t) - 1)) & (size_t) ~(sizeof (size_t) - 1))
#define CMSG_SPACE(len) (CMSG_ALIGN (len) \ #define CMSG_SPACE(len) (CMSG_ALIGN (len) \
@ -307,18 +301,74 @@ enum
#endif #endif
}; };
#ifdef __USE_GNU
/* User visible structure for SCM_CREDENTIALS message */ /* User visible structure for SCM_CREDENTIALS message */
struct ucred struct ucred
{ {
pid_t pid; /* PID of sending process. */ pid_t pid; /* PID of sending process. */
uid_t uid; /* UID of sending process. */ uid_t uid; /* UID of sending process. */
gid_t gid; /* GID of sending process. */ gid_t gid; /* GID of sending process. */
}; };
#endif
/* Ugly workaround for unclean kernel headers. */
#if !defined __USE_MISC && !defined __USE_GNU
# ifndef FIOGETOWN
# define __SYS_SOCKET_H_undef_FIOGETOWN
# endif
# ifndef FIOSETOWN
# define __SYS_SOCKET_H_undef_FIOSETOWN
# endif
# ifndef SIOCATMARK
# define __SYS_SOCKET_H_undef_SIOCATMARK
# endif
# ifndef SIOCGPGRP
# define __SYS_SOCKET_H_undef_SIOCGPGRP
# endif
# ifndef SIOCGSTAMP
# define __SYS_SOCKET_H_undef_SIOCGSTAMP
# endif
# ifndef SIOCGSTAMPNS
# define __SYS_SOCKET_H_undef_SIOCGSTAMPNS
# endif
# ifndef SIOCSPGRP
# define __SYS_SOCKET_H_undef_SIOCSPGRP
# endif
#endif
/* Get socket manipulation related informations from kernel headers. */ /* Get socket manipulation related informations from kernel headers. */
#include <asm/socket.h> #include <asm/socket.h>
#if !defined __USE_MISC && !defined __USE_GNU
# ifdef __SYS_SOCKET_H_undef_FIOGETOWN
# undef __SYS_SOCKET_H_undef_FIOGETOWN
# undef FIOGETOWN
# endif
# ifdef __SYS_SOCKET_H_undef_FIOSETOWN
# undef __SYS_SOCKET_H_undef_FIOSETOWN
# undef FIOSETOWN
# endif
# ifdef __SYS_SOCKET_H_undef_SIOCATMARK
# undef __SYS_SOCKET_H_undef_SIOCATMARK
# undef SIOCATMARK
# endif
# ifdef __SYS_SOCKET_H_undef_SIOCGPGRP
# undef __SYS_SOCKET_H_undef_SIOCGPGRP
# undef SIOCGPGRP
# endif
# ifdef __SYS_SOCKET_H_undef_SIOCGSTAMP
# undef __SYS_SOCKET_H_undef_SIOCGSTAMP
# undef SIOCGSTAMP
# endif
# ifdef __SYS_SOCKET_H_undef_SIOCGSTAMPNS
# undef __SYS_SOCKET_H_undef_SIOCGSTAMPNS
# undef SIOCGSTAMPNS
# endif
# ifdef __SYS_SOCKET_H_undef_SIOCSPGRP
# undef __SYS_SOCKET_H_undef_SIOCSPGRP
# undef SIOCSPGRP
# endif
#endif
/* Structure used to manipulate the SO_LINGER option. */ /* Structure used to manipulate the SO_LINGER option. */
struct linger struct linger

View File

@ -61,7 +61,7 @@ struct stat
__uid_t st_uid; /* User ID of the file's owner. */ __uid_t st_uid; /* User ID of the file's owner. */
__gid_t st_gid; /* Group ID of the file's group.*/ __gid_t st_gid; /* Group ID of the file's group.*/
#if __WORDSIZE == 64 #if __WORDSIZE == 64
int pad0; int __pad0;
#endif #endif
__dev_t st_rdev; /* Device number, if device. */ __dev_t st_rdev; /* Device number, if device. */
#if __WORDSIZE == 32 #if __WORDSIZE == 32
@ -129,7 +129,7 @@ struct stat64
__uid_t st_uid; /* User ID of the file's owner. */ __uid_t st_uid; /* User ID of the file's owner. */
__gid_t st_gid; /* Group ID of the file's group.*/ __gid_t st_gid; /* Group ID of the file's group.*/
#if __WORDSIZE == 64 #if __WORDSIZE == 64
int pad0; int __pad0;
__dev_t st_rdev; /* Device number, if device. */ __dev_t st_rdev; /* Device number, if device. */
__off_t st_size; /* Size of file, in bytes. */ __off_t st_size; /* Size of file, in bytes. */
#else #else