mirror of
https://sourceware.org/git/glibc.git
synced 2024-12-12 22:30:12 +00:00
cb765808fb
Some headers did not include all of their prerequisite headers. * rpcsvc/nislib.h: Include rpcsvc/nis.h. * sysdeps/unix/sysv/linux/netrose/rose.h: Include sys/socket.h and netax25/ax25.h. <endian.h> only defines BYTE_ORDER, BIG_ENDIAN, LITTLE_ENDIAN, etc. under __USE_MISC; glibc's headers should use __BYTE_ORDER, __BIG_ENDIAN, __LITTLE_ENDIAN, etc. instead. * inet/netinet/icmp6.h, inet/netinet/ip6.h * resolv/arpa/nameser_compat.h: Use __BYTE_ORDER etc. instead of BYTE_ORDER etc. sys/types.h only conditionally defines caddr_t and clockid_t. * sysdeps/unix/sysv/linux/sys/quota.h: Use __caddr_t instead of caddr_t. * sysdeps/unix/sysv/linux/sys/timerfd.h: Use __clockid_t instead of clockid_t. Remove a #warning that was the sole actual problem with using sys/ipc.h without _GNU_SOURCE/_XOPEN_SOURCE. * sysvipc/sys/ipc.h: Remove unnecessary #warning. _LIBC, __USE_XOPEN2K8, and __STDC_VERSION__ are not always defined. It seems to me that _LIBC should not appear in installed headers, but avoiding that for argp specifically would require more surgery than feels appropriate for this patch set. It's possible that "#ifdef _LIBC" would be sufficient, but I wanted to be conservative. All three versions of bits/socket.h want to know whether __flexarr will produce a real flexible array member -- specifically, one that doesn't alter sizeof(the structure containing it). They were testing for this with a complicated #if condition that did not agree with sys/cdefs.h and that tripped -Wundef warnings under -std=c90. I added a new macro to sys/cdefs.h, __glibc_c99_flexarr_available, which reveals exactly what these headers want to know. I also took the opportunity to flatten the rather messy conditional nest defining __flexarr. * argp/argp.h: Check whether _LIBC is defined before expanding it. * posix/glob.h: Check whether __USE_XOPEN2K8 is defined instead of expanding it. * misc/sys/cdefs.h: Tidy up conditional nest defining __flexarr. Define __glibc_c99_flexarr_available to 1 when the compiler supports C99-compatible flexible array members, 0 otherwise. * sysdeps/unix/sysv/linux/bits/socket.h * sysdeps/mach/hurd/bits/socket.h * bits/socket.h: Use __glibc_c99_flexarr_available in definitions of struct cmsghdr and CMSG_DATA.
119 lines
3.1 KiB
C
119 lines
3.1 KiB
C
/* Definitions for Rose packet radio address family.
|
|
Copyright (C) 1998-2016 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
|
|
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/>. */
|
|
|
|
/* What follows is copied from the 2.1.93 <linux/rose.h>. */
|
|
|
|
#ifndef _NETROSE_ROSE_H
|
|
#define _NETROSE_ROSE_H 1
|
|
|
|
#include <sys/socket.h>
|
|
#include <netax25/ax25.h>
|
|
|
|
/* Socket level values. */
|
|
#define SOL_ROSE 260
|
|
|
|
|
|
/* These are the public elements of the Linux kernel Rose
|
|
implementation. For kernel AX.25 see the file ax25.h. This file
|
|
requires ax25.h for the definition of the ax25_address structure. */
|
|
#define ROSE_MTU 251
|
|
|
|
#define ROSE_MAX_DIGIS 6
|
|
|
|
#define ROSE_DEFER 1
|
|
#define ROSE_T1 2
|
|
#define ROSE_T2 3
|
|
#define ROSE_T3 4
|
|
#define ROSE_IDLE 5
|
|
#define ROSE_QBITINCL 6
|
|
#define ROSE_HOLDBACK 7
|
|
|
|
#define SIOCRSGCAUSE (SIOCPROTOPRIVATE + 0)
|
|
#define SIOCRSSCAUSE (SIOCPROTOPRIVATE + 1)
|
|
#define SIOCRSL2CALL (SIOCPROTOPRIVATE + 2)
|
|
#define SIOCRSSL2CALL (SIOCPROTOPRIVATE + 2)
|
|
#define SIOCRSACCEPT (SIOCPROTOPRIVATE + 3)
|
|
#define SIOCRSCLRRT (SIOCPROTOPRIVATE + 4)
|
|
#define SIOCRSGL2CALL (SIOCPROTOPRIVATE + 5)
|
|
#define SIOCRSGFACILITIES (SIOCPROTOPRIVATE + 6)
|
|
|
|
#define ROSE_DTE_ORIGINATED 0x00
|
|
#define ROSE_NUMBER_BUSY 0x01
|
|
#define ROSE_INVALID_FACILITY 0x03
|
|
#define ROSE_NETWORK_CONGESTION 0x05
|
|
#define ROSE_OUT_OF_ORDER 0x09
|
|
#define ROSE_ACCESS_BARRED 0x0B
|
|
#define ROSE_NOT_OBTAINABLE 0x0D
|
|
#define ROSE_REMOTE_PROCEDURE 0x11
|
|
#define ROSE_LOCAL_PROCEDURE 0x13
|
|
#define ROSE_SHIP_ABSENT 0x39
|
|
|
|
|
|
typedef struct
|
|
{
|
|
char rose_addr[5];
|
|
} rose_address;
|
|
|
|
struct sockaddr_rose
|
|
{
|
|
sa_family_t srose_family;
|
|
rose_address srose_addr;
|
|
ax25_address srose_call;
|
|
int srose_ndigis;
|
|
ax25_address srose_digi;
|
|
};
|
|
|
|
struct full_sockaddr_rose
|
|
{
|
|
sa_family_t srose_family;
|
|
rose_address srose_addr;
|
|
ax25_address srose_call;
|
|
unsigned int srose_ndigis;
|
|
ax25_address srose_digis[ROSE_MAX_DIGIS];
|
|
};
|
|
|
|
struct rose_route_struct
|
|
{
|
|
rose_address address;
|
|
unsigned short int mask;
|
|
ax25_address neighbour;
|
|
char device[16];
|
|
unsigned char ndigis;
|
|
ax25_address digipeaters[AX25_MAX_DIGIS];
|
|
};
|
|
|
|
struct rose_cause_struct
|
|
{
|
|
unsigned char cause;
|
|
unsigned char diagnostic;
|
|
};
|
|
|
|
struct rose_facilities_struct
|
|
{
|
|
rose_address source_addr, dest_addr;
|
|
ax25_address source_call, dest_call;
|
|
unsigned char source_ndigis, dest_ndigis;
|
|
ax25_address source_digis[ROSE_MAX_DIGIS];
|
|
ax25_address dest_digis[ROSE_MAX_DIGIS];
|
|
unsigned int rand;
|
|
rose_address fail_addr;
|
|
ax25_address fail_call;
|
|
};
|
|
|
|
#endif /* netrose/rose.h */
|