* nscd/connections.c (send_ro_fd): Make sure BUF is aligned correctly.
authorUlrich Drepper <drepper@redhat.com>
Thu, 14 Jul 2005 02:17:58 +0000 (02:17 +0000)
committerUlrich Drepper <drepper@redhat.com>
Thu, 14 Jul 2005 02:17:58 +0000 (02:17 +0000)
ChangeLog
nscd/connections.c

index b6ce28a..3814c07 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,6 @@
 2005-07-13  Ulrich Drepper  <drepper@redhat.com>
 
+       * nscd/connections.c (send_ro_fd): Make sure BUF is aligned correctly.
        * nscd/nscd_helper.c (wait_on_socket): New function.
        (get_mapping): Use wait_on_socket instead of poll.  The former handles
        EINTR of poll correctly.
index 8179cb2..9dc852a 100644 (file)
@@ -604,9 +604,14 @@ send_ro_fd (struct database_dyn *db, char *key, int fd)
   iov[0].iov_len = strlen (key) + 1;
 
   /* Prepare the control message to transfer the descriptor.  */
-  char buf[CMSG_SPACE (sizeof (int))];
+  union
+  {
+    struct cmsghdr hdr;
+    char bytes[CMSG_SPACE (sizeof (int))];
+  } buf;
   struct msghdr msg = { .msg_iov = iov, .msg_iovlen = 1,
-                       .msg_control = buf, .msg_controllen = sizeof (buf) };
+                       .msg_control = buf.bytes,
+                       .msg_controllen = sizeof (buf) };
   struct cmsghdr *cmsg = CMSG_FIRSTHDR (&msg);
 
   cmsg->cmsg_level = SOL_SOCKET;