[build] Avoid strict-aliasing warnings when building with gcc 4.4
authorMichael Brown <mcb30@etherboot.org>
Tue, 6 Jan 2009 03:19:23 +0000 (19:19 -0800)
committerMichael Brown <mcb30@etherboot.org>
Tue, 6 Jan 2009 03:20:26 +0000 (19:20 -0800)
Conventional usage of the various struct sockaddr_xxx types involves
liberal use of casting, which tends to trigger strict-aliasing
warnings from gcc.  Avoid these now and in future by marking all the
relevant types with __attribute__((may_alias)).

src/include/gpxe/in.h
src/include/gpxe/open.h
src/include/gpxe/resolv.h
src/include/gpxe/socket.h
src/include/gpxe/tcpip.h
src/include/gpxe/udp.h

index 40e4d40..831a611 100644 (file)
@@ -71,7 +71,7 @@ struct sockaddr_in {
        char pad[ sizeof ( struct sockaddr ) - sizeof ( sa_family_t )
                                             - sizeof ( uint16_t )
                                             - sizeof ( struct in_addr ) ];
-};
+} __attribute__ (( may_alias ));
 
 /**
  * IPv6 socket address
@@ -87,7 +87,7 @@ struct sockaddr_in6 {
         uint32_t        sin6_flowinfo;  /* Flow number */
         struct in6_addr sin6_addr;      /* 128-bit destination address */
         uint32_t        sin6_scope_id;  /* Scope ID */
-};
+} __attribute__ (( may_alias ));
 
 extern int inet_aton ( const char *cp, struct in_addr *inp );
 extern char * inet_ntoa ( struct in_addr in );
index beab0a1..81d5fc2 100644 (file)
@@ -9,10 +9,10 @@
 
 #include <stdarg.h>
 #include <gpxe/tables.h>
+#include <gpxe/socket.h>
 
 struct xfer_interface;
 struct uri;
-struct sockaddr;
 
 /** Location types */
 enum {
index 7c1ee6e..e73c820 100644 (file)
@@ -10,8 +10,8 @@
 #include <gpxe/refcnt.h>
 #include <gpxe/interface.h>
 #include <gpxe/tables.h>
+#include <gpxe/socket.h>
 
-struct sockaddr;
 struct resolv_interface;
 
 /** Name resolution interface operations */
index 582de4e..b683bed 100644 (file)
@@ -94,6 +94,6 @@ struct sockaddr {
         * family.
         */
        char pad[ SA_LEN - sizeof ( sa_family_t ) ];
-};
+} __attribute__ (( may_alias ));
 
 #endif /* _GPXE_SOCKET_H */
index c0fadd2..9bc3cc4 100644 (file)
@@ -40,7 +40,7 @@ struct sockaddr_tcpip {
         */
        char pad[ sizeof ( struct sockaddr ) -
                  ( sizeof ( sa_family_t ) + sizeof ( uint16_t ) ) ];
-};
+} __attribute__ (( may_alias ));
 
 /** 
  * A transport-layer protocol of the TCP/IP stack (eg. UDP, TCP, etc)
index cb0e44e..e515f65 100644 (file)
@@ -15,7 +15,6 @@
 #include <gpxe/if_ether.h>
 
 struct xfer_interface;
-struct sockaddr;
 
 /**
  * UDP constants