summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/responder/common/responder_common.c10
-rw-r--r--src/sss_client/common.c14
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;