summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTed Unangst <tedu@cvs.openbsd.org>2003-07-24 01:31:37 +0000
committerTed Unangst <tedu@cvs.openbsd.org>2003-07-24 01:31:37 +0000
commitf0489087865cdd17b940931b64d446996e889eb2 (patch)
tree3737f16dc530f4e61f2222877fd004a5723a28e3
parent4c921dd7a04fb366e8891a7d593feb4485f95ed2 (diff)
after sys_sendmsg, change control message level back in case somebody looks
at it. we don't use stackgap because control messages can be larger than the gap, and it's just easier this way. ok deraadt@
-rw-r--r--sys/compat/linux/linux_socket.c18
1 files changed, 15 insertions, 3 deletions
diff --git a/sys/compat/linux/linux_socket.c b/sys/compat/linux/linux_socket.c
index f6e5cbf3356..0d458e32a01 100644
--- a/sys/compat/linux/linux_socket.c
+++ b/sys/compat/linux/linux_socket.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: linux_socket.c,v 1.29 2003/01/21 08:05:11 niklas Exp $ */
+/* $OpenBSD: linux_socket.c,v 1.30 2003/07/24 01:31:36 tedu Exp $ */
/* $NetBSD: linux_socket.c,v 1.14 1996/04/05 00:01:50 christos Exp $ */
/*
@@ -1068,6 +1068,7 @@ linux_sendmsg(p, v, retval)
msg.msg_name = (struct sockaddr *)sa;
if ((error = copyout(&msg, nmsg, sizeof(struct msghdr))))
return (error);
+ lla.msg = nmsg;
}
SCARG(&bla, s) = lla.s;
@@ -1089,14 +1090,25 @@ linux_sendmsg(p, v, retval)
* 0xffff, of course.
*/
level = SOL_SOCKET;
- /* XXX should use stack gap! */
+ /*
+ * XXX should use stack gap!
+ * We don't because the control header is variable length
+ * up to 2048 bytes, and there's only 512 bytes of gap.
+ */
error = copyout(&level, &((struct cmsghdr *)control)->
cmsg_level, sizeof(int));
if (error)
return error;
}
done:
- return sys_sendmsg(p, &bla, retval);
+ error = sys_sendmsg(p, &bla, retval);
+ /* replace level, just in case somebody cares. */
+ if (level == SOL_SOCKET) {
+ level = 1;
+ copyout(&level, &((struct cmsghdr *)control)->cmsg_level,
+ sizeof(int));
+ }
+ return (error);
}
/*