978e96
commit 583a27d525ae189bdfaa6784021b92a9a1dae12e
978e96
Author: Florian Weimer <fweimer@redhat.com>
978e96
Date:   Mon Apr 9 10:08:07 2018 +0200
978e96
978e96
    resolv: Fully initialize struct mmsghdr in send_dg [BZ #23037]
978e96
978e96
diff --git a/resolv/res_send.c b/resolv/res_send.c
978e96
index 478d542419566574..05c7ba511b0383c1 100644
978e96
--- a/resolv/res_send.c
978e96
+++ b/resolv/res_send.c
978e96
@@ -1154,25 +1154,27 @@ send_dg(res_state statp,
978e96
 		if (have_sendmmsg >= 0 && nwritten == 0 && buf2 != NULL
978e96
 		    && !single_request)
978e96
 		  {
978e96
-		    struct iovec iov[2];
978e96
-		    struct mmsghdr reqs[2];
978e96
-		    reqs[0].msg_hdr.msg_name = NULL;
978e96
-		    reqs[0].msg_hdr.msg_namelen = 0;
978e96
-		    reqs[0].msg_hdr.msg_iov = &iov[0];
978e96
-		    reqs[0].msg_hdr.msg_iovlen = 1;
978e96
-		    iov[0].iov_base = (void *) buf;
978e96
-		    iov[0].iov_len = buflen;
978e96
-		    reqs[0].msg_hdr.msg_control = NULL;
978e96
-		    reqs[0].msg_hdr.msg_controllen = 0;
978e96
-
978e96
-		    reqs[1].msg_hdr.msg_name = NULL;
978e96
-		    reqs[1].msg_hdr.msg_namelen = 0;
978e96
-		    reqs[1].msg_hdr.msg_iov = &iov[1];
978e96
-		    reqs[1].msg_hdr.msg_iovlen = 1;
978e96
-		    iov[1].iov_base = (void *) buf2;
978e96
-		    iov[1].iov_len = buflen2;
978e96
-		    reqs[1].msg_hdr.msg_control = NULL;
978e96
-		    reqs[1].msg_hdr.msg_controllen = 0;
978e96
+		    struct iovec iov =
978e96
+		      { .iov_base = (void *) buf, .iov_len = buflen };
978e96
+		    struct iovec iov2 =
978e96
+		      { .iov_base = (void *) buf2, .iov_len = buflen2 };
978e96
+		    struct mmsghdr reqs[2] =
978e96
+		      {
978e96
+			{
978e96
+			  .msg_hdr =
978e96
+			    {
978e96
+			      .msg_iov = &iov,
978e96
+			      .msg_iovlen = 1,
978e96
+			    },
978e96
+			},
978e96
+			{
978e96
+			  .msg_hdr =
978e96
+			    {
978e96
+			      .msg_iov = &iov2,
978e96
+			      .msg_iovlen = 1,
978e96
+			    }
978e96
+			},
978e96
+		      };
978e96
 
978e96
 		    int ndg = __sendmmsg (pfd[0].fd, reqs, 2, MSG_NOSIGNAL);
978e96
 		    if (__glibc_likely (ndg == 2))