about summary refs log tree commit diff
diff options
context:
space:
mode:
-rw-r--r--mach/Makefile30
-rw-r--r--mach/bootprivport.c64
2 files changed, 18 insertions, 76 deletions
diff --git a/mach/Makefile b/mach/Makefile
index f13c285fd9..674250c9ad 100644
--- a/mach/Makefile
+++ b/mach/Makefile
@@ -36,29 +36,34 @@ routines = $(mach-syscalls) $(mach-shortcuts) \
 	   mig-alloc mig-dealloc mig-reply \
 	   msg-destroy msgserver \
 	   mach_error errstring error_compat errsystems \
-	   devstream bootprivport setup-thread $(lock)
+	   devstream setup-thread $(lock)
+
 # The RPC interfaces go in a separate library.
 interface-library := libmachuser
-user-interfaces := $(addprefix mach/,mach_interface mach_port mach_host	\
-				     memory_object_user			\
-				     memory_object_default		\
-				     exc mach4				\
-				     default_pager			\
-	            )\
-		   $(addprefix device/,device device_request)
+
 # We produce mach_interface.h from mach.defs because there is already a
 # <mach/mach.h> that is not the interface header (thanks CMU).
+mach-interface-list := $(patsubst mach,mach_interface,$(mach-interface-list))
 mach/mach_interface.defs = mach/mach.defs
+
 # Similarly for memory_object_user vs. memory_object
+mach-interface-list := $(patsubst memory_object,memory_object_user,\
+				  $(mach-interface-list))
 mach/memory_object_user.defs = mach/memory_object.defs
+
+user-interfaces := $(addprefix mach/,$(mach-interface-list)	\
+			       	     mach_port mach_host exc	\
+	            )\
+		   $(addprefix device/,device device_request)
+
 server-interfaces := mach/exc
+
 # It is important that we do not use the wildcard function to expand
 # `err_*.sub'.  Leaving the wildcard allows Make-dist to find all matching
 # files in all sysdep directories.
 distribute += Machrules syscalls.awk shortcut.awk \
 	      errorlib.h err_*.sub errsystems.awk
 
-
 # Clear any environment	value.
 generated =
 
@@ -103,7 +108,7 @@ ifndef mach-shortcuts
 # Forget about mach_interface.defs for this run.  On the next run,
 # $(mach-shortcuts) will be set, and that will change how
 # mach_interface.defs is processed: it will get the -D flags below.
-user-interfaces := $(filter-out mach/mach_interface \
+user-interfaces := $(filter-out $(mach-interface-list:%=mach/%) \
 				mach/mach_port mach/mach_host mach/mach4 \
 				device/device_request,\
 				$(user-interfaces))
@@ -114,7 +119,8 @@ MIGFLAGS-mach/mach4=-DMACH_PCSAMPLE
 
 # Make the MiG stubs for $(mach-shortcuts) be CALL_rpc.
 migdefines += $(foreach call,$(mach-shortcuts),-D$(call)=$(call)_rpc)
-mach/mach_interface.uh mach/mach_host.uh mach/mach_port.uh: $(objpfx)mach-syscalls.mk
+$(mach-interface-list:%=mach/%.uh) \
+  mach/mach_host.uh mach/mach_port.uh: $(objpfx)mach-syscalls.mk
 
 ifdef mach-shortcuts
 $(mach-shortcuts:%=$(objpfx)%.c): $(objpfx)%.c: shortcut.awk \
@@ -127,7 +133,7 @@ endif	# mach-shortcuts
 
 # Generate mach-shortcuts.h, which will contain the prototypes for the
 # shortcutted kernel RPC functions.
-$(objpfx)mach-shortcuts.h: $(objpfx)mach/mach_interface.h \
+$(objpfx)mach-shortcuts.h: $(mach-interface-list:%=$(objpfx)mach/%.h) \
 			   $(objpfx)mach/mach_host.h \
 			   $(objpfx)mach/mach_port.h
 # The first line gets us one paragraph per line, with @s separating real lines.
diff --git a/mach/bootprivport.c b/mach/bootprivport.c
deleted file mode 100644
index 7114caa95f..0000000000
--- a/mach/bootprivport.c
+++ /dev/null
@@ -1,64 +0,0 @@
-/* Copyright (C) 1993, 1997 Free Software Foundation, Inc.
-   This file is part of the GNU C Library.
-
-   The GNU C Library is free software; you can redistribute it and/or
-   modify it under the terms of the GNU Lesser General Public
-   License as published by the Free Software Foundation; either
-   version 2.1 of the License, or (at your option) any later version.
-
-   The GNU C Library is distributed in the hope that it will be useful,
-   but WITHOUT ANY WARRANTY; without even the implied warranty of
-   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
-   Lesser General Public License for more details.
-
-   You should have received a copy of the GNU Lesser General Public
-   License along with the GNU C Library; if not, write to the Free
-   Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
-   02111-1307 USA.  */
-
-#include <mach.h>
-
-kern_return_t
-__mach_get_priv_ports (mach_port_t *host_priv_ptr,
-		       mach_port_t *device_master_ptr)
-{
-  kern_return_t err;
-  mach_port_t bootstrap, reply;
-
-  struct
-    {
-      mach_msg_header_t hdr;
-      mach_msg_type_t host_priv_type;
-      mach_port_t host_priv;
-      mach_msg_type_t dev_master_type;
-      mach_port_t dev_master;
-    } msg;
-
-  if (err = task_get_bootstrap_port (mach_task_self (), &bootstrap))
-    return err;
-
-  /* We cannot simply use a MiG-generated user stub to do this,
-     because the return message does not contain a return code datum.  */
-  reply = __mach_reply_port ();
-  msg.hdr.msgh_bits = MACH_MSGH_BITS (MACH_MSG_TYPE_COPY_SEND,
-				      MACH_MSG_TYPE_MAKE_SEND_ONCE);
-  msg.hdr.msgh_size = 0;
-  msg.hdr.msgh_remote_port = bootstrap;
-  msg.hdr.msgh_local_port = reply;
-  msg.hdr.msgh_kind = MACH_MSGH_KIND_NORMAL;
-  msg.hdr.msgh_id = 999999;
-  err = __mach_msg (&msg.hdr,
-		    MACH_SEND_MSG|MACH_RCV_MSG|MACH_RCV_TIMEOUT,
-		    sizeof (msg.hdr), sizeof (msg), reply,
-		    500, MACH_PORT_NULL); /* XXX timeout is arbitrary */
-  mach_port_deallocate (mach_task_self (), bootstrap);
-  mach_port_deallocate (mach_task_self (), reply);
-
-  if (err == KERN_SUCCESS)
-    {
-      *host_priv_ptr = msg.host_priv;
-      *device_master_ptr = msg.dev_master;
-    }
-
-  return err;
-}