swrap: add stubs for swrap_{sendmsg,recvmsg}_{before,after}_unix()
authorStefan Metzmacher <metze@samba.org>
Mon, 29 Jun 2020 07:27:24 +0000 (09:27 +0200)
committerAndreas Schneider <asn@samba.org>
Tue, 2 Feb 2021 09:23:33 +0000 (10:23 +0100)
In order to implement fd-passing of socket_wrapper simulated sockets
we need to modify the msghdr structures from the callers.

Signed-off-by: Stefan Metzmacher <metze@samba.org>
Reviewed-by: Anoop C S <anoopcs@samba.org>
Reviewed-by: Andreas Schneider <asn@samba.org>
src/socket_wrapper.c

index 089f5d9dcc26ee206ab4946a9ae91a3cba3d047a..a0eef9d7d6dc8de378f804edd190a4441bb52e59 100644 (file)
@@ -5148,6 +5148,34 @@ static int swrap_sendmsg_filter_cmsg_sol_socket(const struct cmsghdr *cmsg,
 
 #endif /* HAVE_STRUCT_MSGHDR_MSG_CONTROL */
 
+static int swrap_sendmsg_before_unix(const struct msghdr *_msg_in,
+                                    struct msghdr *msg_tmp)
+{
+       *msg_tmp = *_msg_in;
+       return 0;
+}
+
+static ssize_t swrap_sendmsg_after_unix(struct msghdr *msg_tmp,
+                                       ssize_t ret)
+{
+       return ret;
+}
+
+static int swrap_recvmsg_before_unix(struct msghdr *msg_in,
+                                    struct msghdr *msg_tmp)
+{
+       *msg_tmp = *msg_in;
+       return 0;
+}
+
+static ssize_t swrap_recvmsg_after_unix(struct msghdr *msg_tmp,
+                                       struct msghdr *msg_out,
+                                       ssize_t ret)
+{
+       *msg_out = *msg_tmp;
+       return ret;
+}
+
 static ssize_t swrap_sendmsg_before(int fd,
                                    struct socket_info *si,
                                    struct msghdr *msg,
@@ -6060,7 +6088,12 @@ static ssize_t swrap_recvmsg(int s, struct msghdr *omsg, int flags)
 
        si = find_socket_info(s);
        if (si == NULL) {
-               return libc_recvmsg(s, omsg, flags);
+               rc = swrap_recvmsg_before_unix(omsg, &msg);
+               if (rc < 0) {
+                       return rc;
+               }
+               ret = libc_recvmsg(s, &msg, flags);
+               return swrap_recvmsg_after_unix(&msg, omsg, ret);
        }
 
        tmp.iov_base = NULL;
@@ -6183,7 +6216,12 @@ static ssize_t swrap_sendmsg(int s, const struct msghdr *omsg, int flags)
        int bcast = 0;
 
        if (!si) {
-               return libc_sendmsg(s, omsg, flags);
+               rc = swrap_sendmsg_before_unix(omsg, &msg);
+               if (rc < 0) {
+                       return rc;
+               }
+               ret = libc_sendmsg(s, &msg, flags);
+               return swrap_sendmsg_after_unix(&msg, ret);
        }
 
        ZERO_STRUCT(un_addr);