From 78343e97c68fda079c66f2443bab6d1ee16f0b67 Mon Sep 17 00:00:00 2001 From: Justus Winter <4winter@informatik.uni-hamburg.de> Date: Sat, 3 May 2014 01:02:35 +0200 Subject: libports: lock-less reference counting for port_info objects * libports/ports.h (struct port_info): Use the new type. * libports/lookup-port.c: No need to lock _ports_lock anymore. * libports/bucket-iterate.c: Likewise. * libports/complete-deallocate.c: Check if someone reacquired a reference through a hash table lookup. * libports/create-internal.c: Use the new reference counting primitives. * libports/get-right.c: Likewise. * libports/import-port.c: Likewise. * libports/port-deref-weak.c: Likewise. * libports/port-deref.c: Likewise. * libports/port-ref-weak.c: Likewise. * libports/port-ref.c: Likewise. * libports/reallocate-from-external.c: Likewise. * libports/transfer-right.c: Likewise. * utils/rpctrace.c: Likewise. --- libports/get-right.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'libports/get-right.c') diff --git a/libports/get-right.c b/libports/get-right.c index 89050c6b..8681f465 100644 --- a/libports/get-right.c +++ b/libports/get-right.c @@ -41,7 +41,7 @@ ports_get_right (void *port) if ((pi->flags & PORT_HAS_SENDRIGHTS) == 0) { pi->flags |= PORT_HAS_SENDRIGHTS; - pi->refcnt++; + refcounts_ref (&pi->refcounts, NULL); err = mach_port_request_notification (mach_task_self (), pi->port_right, MACH_NOTIFY_NO_SENDERS, -- cgit v1.2.3