1.0.46.26: mach-exception-handler improvement: current_mach_task
authorCyrus Harmon <ch-sbcl@bobobeach.com>
Mon, 7 Mar 2011 23:41:24 +0000 (23:41 +0000)
committerCyrus Harmon <ch-sbcl@bobobeach.com>
Mon, 7 Mar 2011 23:41:24 +0000 (23:41 +0000)
 * define current_mach_task variable, squirrel away the value of
   mach_task_self there and use that instead of calling mach_task_self
   so that we don't leak send rights all over the place

src/runtime/darwin-os.c
src/runtime/darwin-os.h
src/runtime/thread.c
version.lisp-expr

index 63fc6e6..f15e11b 100644 (file)
@@ -67,6 +67,7 @@ mach_exception_handler(void *port)
    signal handlers run in the relevant thread directly. */
 
 mach_port_t mach_exception_handler_port_set = MACH_PORT_NULL;
+mach_port_t current_mach_task = MACH_PORT_NULL;
 
 pthread_t
 setup_mach_exception_handling_thread()
@@ -75,8 +76,10 @@ setup_mach_exception_handling_thread()
     pthread_t mach_exception_handling_thread = NULL;
     pthread_attr_t attr;
 
+    current_mach_task = mach_task_self();
+
     /* allocate a mach_port for this process */
-    ret = mach_port_allocate(mach_task_self(),
+    ret = mach_port_allocate(current_mach_task,
                              MACH_PORT_RIGHT_PORT_SET,
                              &mach_exception_handler_port_set);
 
@@ -105,7 +108,7 @@ mach_thread_init(mach_port_t thread_exception_port)
 
     FSHOW((stderr, "Allocating mach port %x\n", thread_exception_port));
 
-    ret = mach_port_allocate_name(mach_task_self(),
+    ret = mach_port_allocate_name(current_mach_task,
                                   MACH_PORT_RIGHT_RECEIVE,
                                   thread_exception_port);
     if (ret) {
@@ -113,7 +116,7 @@ mach_thread_init(mach_port_t thread_exception_port)
     }
 
     /* establish the right for the thread_exception_port to send messages */
-    ret = mach_port_insert_right(mach_task_self(),
+    ret = mach_port_insert_right(current_mach_task,
                                  thread_exception_port,
                                  thread_exception_port,
                                  MACH_MSG_TYPE_MAKE_SEND);
@@ -130,7 +133,7 @@ mach_thread_init(mach_port_t thread_exception_port)
         lose("thread_set_exception_port failed with return_code %d\n", ret);
     }
 
-    ret = mach_port_move_member(mach_task_self(),
+    ret = mach_port_move_member(current_mach_task,
                                 thread_exception_port,
                                 mach_exception_handler_port_set);
     if (ret) {
index 9228d1b..be8640d 100644 (file)
@@ -34,4 +34,8 @@ typedef ucontext_t os_context_t;
 
 #define SIG_STOP_FOR_GC (SIGUSR2)
 
+#ifdef LISP_FEATURE_MACH_EXCEPTION_HANDLER
+extern mach_port_t current_mach_task;
+#endif
+
 #endif /* _DARWIN_OS_H */
index 535263a..ee11e0f 100644 (file)
@@ -318,12 +318,12 @@ new_thread_trampoline(struct thread *th)
 
 #ifdef LISP_FEATURE_MACH_EXCEPTION_HANDLER
     FSHOW((stderr, "Deallocating mach port %x\n", THREAD_STRUCT_TO_EXCEPTION_PORT(th)));
-    mach_port_move_member(mach_task_self(),
+    mach_port_move_member(current_mach_task,
                           THREAD_STRUCT_TO_EXCEPTION_PORT(th),
                           MACH_PORT_NULL);
-    mach_port_deallocate(mach_task_self(),
+    mach_port_deallocate(current_mach_task,
                          THREAD_STRUCT_TO_EXCEPTION_PORT(th));
-    mach_port_destroy(mach_task_self(),
+    mach_port_destroy(current_mach_task,
                       THREAD_STRUCT_TO_EXCEPTION_PORT(th));
 #endif
 
index ab530cc..2126bc0 100644 (file)
@@ -20,4 +20,4 @@
 ;;; checkins which aren't released. (And occasionally for internal
 ;;; versions, especially for internal versions off the main CVS
 ;;; branch, it gets hairier, e.g. "0.pre7.14.flaky4.13".)
-"1.0.46.25"
+"1.0.46.26"