(sockaddr_storage): change padding so that we have one char[] of pad
and then an unsigned long[] (for alignment and padding). this works much better in practice. git-svn-id: svn://svn.h5l.se/heimdal/trunk/heimdal@7685 ec53bebd-3082-4978-b11e-865c3cabbd6b
This commit is contained in:
@@ -448,27 +448,29 @@ typedef unsigned short sa_family_t;
|
|||||||
|
|
||||||
#if HAVE_STRUCT_SOCKADDR_SA_LEN
|
#if HAVE_STRUCT_SOCKADDR_SA_LEN
|
||||||
|
|
||||||
#define _SS_PAD1SIZE (_SS_ALIGNSIZE - sizeof (sa_family_t) - sizeof(unsigned char))
|
typedef unsigned char roken_sa_family_t;
|
||||||
#define _SS_PAD2SIZE (_SS_MAXSIZE - (sizeof (sa_family_t) + _SS_PAD1SIZE + _SS_ALIGNSIZE))
|
|
||||||
|
#define _SS_PAD1SIZE (_SS_ALIGNSIZE - sizeof (roken_sa_family_t) - sizeof(unsigned char))
|
||||||
|
#define _SS_PAD2SIZE (_SS_MAXSIZE - (sizeof (roken_sa_family_t) + sizeof(unsigned char) + _SS_PAD1SIZE + _SS_ALIGNSIZE))
|
||||||
|
|
||||||
struct sockaddr_storage {
|
struct sockaddr_storage {
|
||||||
unsigned char ss_len;
|
unsigned char ss_len;
|
||||||
sa_family_t ss_family;
|
roken_sa_family_t ss_family;
|
||||||
char __ss_pad1[_SS_PAD1SIZE];
|
char __ss_pad1[_SS_PAD1SIZE];
|
||||||
unsigned long __ss_align;
|
unsigned long __ss_align[_SS_PAD2SIZE / sizeof(unsigned long) + 1];
|
||||||
char __ss_pad2[_SS_PAD2SIZE];
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#else /* !HAVE_STRUCT_SOCKADDR_SA_LEN */
|
#else /* !HAVE_STRUCT_SOCKADDR_SA_LEN */
|
||||||
|
|
||||||
#define _SS_PAD1SIZE (_SS_ALIGNSIZE - sizeof (sa_family_t))
|
typedef unsigned short roken_sa_family_t;
|
||||||
#define _SS_PAD2SIZE (_SS_MAXSIZE - (sizeof (sa_family_t) + _SS_PAD1SIZE + _SS_ALIGNSIZE))
|
|
||||||
|
#define _SS_PAD1SIZE (_SS_ALIGNSIZE - sizeof (roken_sa_family_t))
|
||||||
|
#define _SS_PAD2SIZE (_SS_MAXSIZE - (sizeof (roken_sa_family_t) + _SS_PAD1SIZE + _SS_ALIGNSIZE))
|
||||||
|
|
||||||
struct sockaddr_storage {
|
struct sockaddr_storage {
|
||||||
sa_family_t ss_family;
|
roken_sa_family_t ss_family;
|
||||||
char __ss_pad1[_SS_PAD1SIZE];
|
char __ss_pad1[_SS_PAD1SIZE];
|
||||||
unsigned long __ss_align;
|
unsigned long __ss_align[_SS_PAD2SIZE / sizeof(unsigned long) + 1];
|
||||||
char __ss_pad2[_SS_PAD2SIZE];
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif /* HAVE_STRUCT_SOCKADDR_SA_LEN */
|
#endif /* HAVE_STRUCT_SOCKADDR_SA_LEN */
|
||||||
|
Reference in New Issue
Block a user