about summary refs log tree commit diff
path: root/bits/socket.h
diff options
context:
space:
mode:
authorFlorian Weimer <fweimer@redhat.com>2024-05-18 09:33:19 +0200
committerFlorian Weimer <fweimer@redhat.com>2024-05-27 17:25:13 +0200
commit26e7005728f0eea2972474e6be2905c467661237 (patch)
treecc9b1d51cd6805f7f7caaf6310152cac6c43971b /bits/socket.h
parent9f2b100d6705b9bbb25206b53e80d7759644e06e (diff)
downloadglibc-26e7005728f0eea2972474e6be2905c467661237.tar.gz
glibc-26e7005728f0eea2972474e6be2905c467661237.tar.xz
glibc-26e7005728f0eea2972474e6be2905c467661237.zip
socket: Use may_alias on sockaddr structs (bug 19622)
This supports common coding patterns.  The GCC C front end before
version 7 rejects the may_alias attribute on a struct definition
if it was not present in a previous forward declaration, so this
attribute can only be conditionally applied.

This implements the spirit of the change in Austin Group issue 1641.

Suggested-by: Marek Polacek <polacek@redhat.com>
Suggested-by: Jakub Jelinek <jakub@redhat.com>
Reviewed-by: Sam James <sam@gentoo.org>
Reviewed-by: Carlos O'Donell <carlos@redhat.com>
(cherry picked from commit 8d7b6b4cb27d4dec1dd5f7960298c1699275f962)
Diffstat (limited to 'bits/socket.h')
-rw-r--r--bits/socket.h4
1 files changed, 2 insertions, 2 deletions
diff --git a/bits/socket.h b/bits/socket.h
index 13de124bac..772074d52a 100644
--- a/bits/socket.h
+++ b/bits/socket.h
@@ -149,7 +149,7 @@ enum __socket_type
 #include <bits/sockaddr.h>
 
 /* Structure describing a generic socket address.  */
-struct sockaddr
+struct __attribute_struct_may_alias__ sockaddr
   {
     __SOCKADDR_COMMON (sa_);	/* Common data: address family and length.  */
     char sa_data[14];		/* Address data.  */
@@ -166,7 +166,7 @@ struct sockaddr
 #define _SS_PADSIZE \
   (_SS_SIZE - __SOCKADDR_COMMON_SIZE - sizeof (__ss_aligntype))
 
-struct sockaddr_storage
+struct __attribute_struct_may_alias__ sockaddr_storage
   {
     __SOCKADDR_COMMON (ss_);	/* Address family, etc.  */
     char __ss_padding[_SS_PADSIZE];