diff options
-rw-r--r-- | src/responder/common/responder_common.c | 10 | ||||
-rw-r--r-- | src/sss_client/common.c | 14 |
2 files changed, 16 insertions, 8 deletions
diff --git a/src/responder/common/responder_common.c b/src/responder/common/responder_common.c index f4de3a79e..156f0c84a 100644 --- a/src/responder/common/responder_common.c +++ b/src/responder/common/responder_common.c @@ -157,7 +157,11 @@ static void cred_handler(struct cli_ctx *cctx, char action) struct iovec iov; struct cmsghdr *cmsg; struct ucred *creds; - char buf[CMSG_SPACE(sizeof(struct ucred))]; + /* buf must be aligned on some architectures. */ + union ubuf { + int align; + char buf[CMSG_SPACE(sizeof(struct ucred))]; + } u; char dummy='s'; int enable=1; @@ -178,8 +182,8 @@ static void cred_handler(struct cli_ctx *cctx, char action) msg.msg_iov = &iov; msg.msg_iovlen = 1; - msg.msg_control = buf; - msg.msg_controllen = sizeof(buf); + msg.msg_control = u.buf; + msg.msg_controllen = sizeof(u.buf); switch (action) { case 'r': diff --git a/src/sss_client/common.c b/src/sss_client/common.c index f1c8d1853..07b9d0d95 100644 --- a/src/sss_client/common.c +++ b/src/sss_client/common.c @@ -63,7 +63,11 @@ static int exchange_credentials(void) struct cmsghdr *cmsg; struct iovec iov; char dummy='a'; - char buf[CMSG_SPACE(sizeof(struct ucred))]; + /* buf must be aligned on some architectures. */ + union ubuf { + int align; + char buf[CMSG_SPACE(sizeof(struct ucred))]; + } u; struct ucred *creds; int enable = 1; struct pollfd pfd; @@ -83,8 +87,8 @@ static int exchange_credentials(void) msg.msg_iov = &iov; msg.msg_iovlen = 1; - msg.msg_control = buf; - msg.msg_controllen = sizeof(buf); + msg.msg_control = u.buf; + msg.msg_controllen = sizeof(u.buf); cmsg = CMSG_FIRSTHDR(&msg); cmsg->cmsg_level = SOL_SOCKET; @@ -118,8 +122,8 @@ static int exchange_credentials(void) msg.msg_iov = &iov; msg.msg_iovlen = 1; - msg.msg_control = buf; - msg.msg_controllen = sizeof(buf); + msg.msg_control = u.buf; + msg.msg_controllen = sizeof(u.buf); pfd.fd = sss_cli_sd; pfd.events = POLLIN; |