Installed-header hygiene (BZ#20366): conditionally defined structures.
authorZack Weinberg <zackw@panix.com>
Wed, 13 Jul 2016 19:20:29 +0000 (15:20 -0400)
committerZack Weinberg <zackw@panix.com>
Fri, 23 Sep 2016 12:43:56 +0000 (08:43 -0400)
Several network-related structures are defined conditionally under
__USE_MISC, but unconditionally used by other headers.  The path of
least resistance is usually to condition the uses on __USE_MISC as
well.

* sysdeps/mach/hurd/net/if_ppp.h
* sysdeps/unix/sysv/linux/net/if_ppp.h:
        Only define struct ifpppstatsreq and struct ifpppcstatsreq
        if __USE_MISC is defined, to ensure struct ifreq is declared.

* inet/netinet/ether.h: Condition all function prototypes
        on __USE_MISC, to ensure struct ether_addr is declared.

sys/socket.h defines struct osockaddr only under __USE_MISC, whereas
protocols/talkd.h requires it unconditionally.  Here it doesn't make
sense to condition the entire body of protocols/talkd.h on __USE_MISC.
Rather than complicate sys/socket.h with a __need macro or duplicate
the definition, I am introducing a new concept: tiny headers named
bits/types/TYPE.h that define TYPE and nothing else.  This can, I hope,
ultimately replace *all* the __need macros.  The guard macro for such
headers will be __TYPE_defined, just in case application or third-party
library code is looking at them.

* socket/bits/types/struct_osockaddr.h: New header.
* include/bits/types/struct_osockaddr.h: New wrapper.
* socket/Makefile: Install the new header.
* socket/sys/socket.h,  inet/protocols/talkd.h:
Refer to bits/types/struct_osockaddr.h for the definition of
struct osockaddr.

ChangeLog
include/bits/types/struct_osockaddr.h [new file with mode: 0644]
inet/netinet/ether.h
inet/protocols/talkd.h
socket/Makefile
socket/bits/types/struct_osockaddr.h [new file with mode: 0644]
socket/sys/socket.h
sysdeps/mach/hurd/net/if_ppp.h
sysdeps/unix/sysv/linux/net/if_ppp.h

index 81456f8..60500b4 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,22 @@
 2016-09-23  Zack Weinberg  <zackw@panix.com>
 
+       * sysdeps/mach/hurd/net/if_ppp.h
+       * sysdeps/unix/sysv/linux/net/if_ppp.h:
+       Only define struct ifpppstatsreq and struct ifpppcstatsreq
+       if __USE_MISC is defined, to ensure struct ifreq is declared.
+
+       * inet/netinet/ether.h: Condition all function prototypes
+       on __USE_MISC, to ensure struct ether_addr is declared.
+
+       * socket/bits/types/struct_osockaddr.h: New header.
+       * include/bits/types/struct_osockaddr.h: New wrapper.
+       * socket/Makefile: Install the new header.
+       * socket/sys/socket.h, inet/protocols/talkd.h:
+       Refer to bits/types/struct_osockaddr.h for the definition of
+       struct osockaddr.
+
+2016-09-23  Zack Weinberg  <zackw@panix.com>
+
        * bits/in.h, gmon/sys/gmon.h, inet/netinet/igmp.h
        * inet/protocols/routed.h, inet/protocols/talkd.h
        * inet/protocols/timed.h, io/fts.h, nptl_db/thread_db.h
diff --git a/include/bits/types/struct_osockaddr.h b/include/bits/types/struct_osockaddr.h
new file mode 100644 (file)
index 0000000..78f3188
--- /dev/null
@@ -0,0 +1 @@
+#include "../../socket/bits/types/struct_osockaddr.h"
index 3dff523..0952b23 100644 (file)
@@ -24,6 +24,7 @@
 /* Get definition of `struct ether_addr'.  */
 #include <netinet/if_ether.h>
 
+#ifdef __USE_MISC
 __BEGIN_DECLS
 
 /* Convert 48 bit Ethernet ADDRess to ASCII.  */
@@ -49,5 +50,6 @@ extern int ether_line (const char *__line, struct ether_addr *__addr,
                       char *__hostname) __THROW;
 
 __END_DECLS
+#endif /* Use misc.  */
 
 #endif /* netinet/ether.h */
index 34e2654..09bd8a9 100644 (file)
@@ -53,6 +53,7 @@
 #include <sys/types.h>
 #include <sys/socket.h>
 #include <stdint.h>
+#include <bits/types/struct_osockaddr.h>
 
 /*
  * Client->server request message format.
index 92450e8..6be5ec7 100644 (file)
@@ -23,7 +23,8 @@ subdir        := socket
 include ../Makeconfig
 
 headers        := sys/socket.h sys/un.h bits/sockaddr.h bits/socket.h \
-          bits/socket2.h sys/socketvar.h net/if.h
+          bits/socket2.h bits/types/struct_osockaddr.h \
+          sys/socketvar.h net/if.h
 
 routines := accept bind connect getpeername getsockname getsockopt     \
            listen recv recvfrom recvmsg send sendmsg sendto            \
diff --git a/socket/bits/types/struct_osockaddr.h b/socket/bits/types/struct_osockaddr.h
new file mode 100644 (file)
index 0000000..e0bf59d
--- /dev/null
@@ -0,0 +1,12 @@
+#ifndef __osockaddr_defined
+#define __osockaddr_defined 1
+
+/* This is the 4.3 BSD `struct sockaddr' format, which is used as wire
+   format in the grotty old 4.3 `talk' protocol.  */
+struct osockaddr
+{
+  unsigned short int sa_family;
+  unsigned char sa_data[14];
+};
+
+#endif
index c9f0f50..5be1b91 100644 (file)
@@ -38,13 +38,7 @@ __BEGIN_DECLS
 #include <bits/socket.h>
 
 #ifdef __USE_MISC
-/* This is the 4.3 BSD `struct sockaddr' format, which is used as wire
-   format in the grotty old 4.3 `talk' protocol.  */
-struct osockaddr
-  {
-    unsigned short int sa_family;
-    unsigned char sa_data[14];
-  };
+# include <bits/types/struct_osockaddr.h>
 #endif
 
 /* The following constants should be used for the second parameter of
index b210d7f..8ee620b 100644 (file)
@@ -119,6 +119,8 @@ struct ppp_option_data {
        int       transmit;
 };
 
+/* 'struct ifreq' is only available from net/if.h under __USE_MISC.  */
+#ifdef __USE_MISC
 struct ifpppstatsreq {
   struct ifreq    b;
   struct ppp_stats stats;                      /* statistic information */
@@ -131,6 +133,7 @@ struct ifpppcstatsreq {
 
 #define ifr__name       b.ifr_ifrn.ifrn_name
 #define stats_ptr       b.ifr_ifru.ifru_data
+#endif
 
 /*
  * Ioctl definitions.
index 9994982..31a2076 100644 (file)
@@ -118,6 +118,8 @@ struct ppp_option_data {
        int      transmit;
 };
 
+/* 'struct ifreq' is only available from net/if.h under __USE_MISC.  */
+#ifdef __USE_MISC
 struct ifpppstatsreq {
   struct ifreq    b;
   struct ppp_stats stats;                      /* statistic information */
@@ -130,6 +132,7 @@ struct ifpppcstatsreq {
 
 #define ifr__name       b.ifr_ifrn.ifrn_name
 #define stats_ptr       b.ifr_ifru.ifru_data
+#endif
 
 /*
  * Ioctl definitions.