PERFORCE change 89531 for review

Todd Miller millert at FreeBSD.org
Wed Jan 11 14:41:51 PST 2006


http://perforce.freebsd.org/chv.cgi?CH=89531

Change 89531 by millert at millert_ibook on 2006/01/11 22:40:55

	Fix the order of the message checks; we need to do the port
	check before the rights check (it was the other way around).
	To do this we must move mac_check_port_send() out of
	ipc_kmsg_send() and into ipc_kmsg_copyin_header().  It is
	too late to deny in ipc_kmsg_send() since the rights have
	already have been copied into the kmsg at that point.

Affected files ...

.. //depot/projects/trustedbsd/sedarwin7/src/darwin/xnu/osfmk/ipc/ipc_kmsg.c#6 edit

Differences ...

==== //depot/projects/trustedbsd/sedarwin7/src/darwin/xnu/osfmk/ipc/ipc_kmsg.c#6 (text+ko) ====

@@ -848,20 +848,11 @@
 	port = (ipc_port_t) kmsg->ikm_header.msgh_remote_port;
 	assert(IP_VALID(port));
 
+	if ((option & ~(MACH_SEND_TIMEOUT|MACH_SEND_ALWAYS)) != 0)
+		printf("ipc_kmsg_send: bad option 0x%x\n", option);
+
 	ip_lock(port);
 
-#ifdef MAC
-	task_t self = current_task();
-	tasklabel_lock(self);
-
-	int rc = mac_check_port_send(&self->maclabel, &port->ip_label);
-	tasklabel_unlock(self);
-	if (rc) {
-		ip_unlock (port);
-		return KERN_NO_ACCESS;
-	}
-#endif	
-
 	if (port->ip_receiver == ipc_space_kernel) {
 
 		/*
@@ -1727,7 +1718,46 @@
 	mach_port_name_t	notify)
 {
     mach_msg_return_t 		mr;
-    
+#ifdef MAC
+    mach_port_name_t dest_name;
+    ipc_entry_t entry;
+    ipc_port_t port;
+    task_t self;
+    int error = 0;
+
+    /*
+     * We do the port send check here instead of in ipc_kmsg_send()
+     * because copying the header involves copying the port rights too
+     * and we need to do the send check before anything is actually copied.
+     * We don't currently try to mediate kernel-resident servers.
+     */
+    self = current_task();
+    if (self != kernel_task) {
+	is_read_lock(space);
+	if (space->is_active) {
+	    dest_name = (mach_port_name_t) kmsg->ikm_header.msgh_remote_port;
+	    if (MACH_PORT_VALID(dest_name)) {
+		entry = ipc_entry_lookup(space, dest_name);
+		if (entry != IE_NULL) {
+		    port = (ipc_port_t) entry->ie_object;
+		    assert(port != IP_NULL);
+		    ip_lock(port);
+		    if (ip_active(port)) {
+			tasklabel_lock(self);
+			error = mac_check_port_send(&self->maclabel,
+			    &port->ip_label);
+			tasklabel_unlock(self);
+		    }
+		    ip_unlock(port);
+		}
+	    }
+	}
+	is_read_unlock(space);
+	if (error != 0)
+	    return MACH_SEND_INVALID_DEST;
+    }
+#endif
+
     mr = ipc_kmsg_copyin_header(&kmsg->ikm_header, space, notify);
     if (mr != MACH_MSG_SUCCESS)
 	return mr;


More information about the p4-projects mailing list