From owner-freebsd-hackers Wed Sep 18 20: 0:38 2002 Delivered-To: freebsd-hackers@freebsd.org Received: from mx1.FreeBSD.org (mx1.FreeBSD.org [216.136.204.125]) by hub.freebsd.org (Postfix) with ESMTP id 48A4737B401; Wed, 18 Sep 2002 20:00:36 -0700 (PDT) Received: from avocet.mail.pas.earthlink.net (avocet.mail.pas.earthlink.net [207.217.120.50]) by mx1.FreeBSD.org (Postfix) with ESMTP id D410443E75; Wed, 18 Sep 2002 20:00:35 -0700 (PDT) (envelope-from tlambert2@mindspring.com) Received: from pool0424.cvx21-bradley.dialup.earthlink.net ([209.179.193.169] helo=mindspring.com) by avocet.mail.pas.earthlink.net with esmtp (Exim 3.33 #1) id 17rrYO-0005gF-00; Wed, 18 Sep 2002 20:00:32 -0700 Message-ID: <3D893D14.E06E3BA8@mindspring.com> Date: Wed, 18 Sep 2002 19:57:24 -0700 From: Terry Lambert X-Mailer: Mozilla 4.79 [en] (Win98; U) X-Accept-Language: en MIME-Version: 1.0 To: Daniel Eischen Cc: Alfred Perlstein , hackers@FreeBSD.org, deischen@FreeBSD.org, Garrett Wollman Subject: Re: sem_init help? References: Content-Type: text/plain; charset=us-ascii Content-Transfer-Encoding: 7bit Sender: owner-freebsd-hackers@FreeBSD.ORG Precedence: bulk List-ID: List-Archive: (Web Archive) List-Help: (List Instructions) List-Subscribe: List-Unsubscribe: X-Loop: FreeBSD.ORG Daniel Eischen wrote: > Yes, but it doesn't change what the spec says above. It's > implying that any process can perform sem_destroy() on it and > the spec also says for sem_init() that "This semaphore shall > remain usable until the semaphore is destroyed.". The key point is "that can access". It restricts the scope to processes that can access the shared resource. > So the sem_init()'ing process can exit and leave the destroying > to one of the other processes that have access to it. Here's my argument against that, from the sem_destroy() man page: It is safe to destroy an initialised semaphore upon which no threads are currently blocked. The effect of destroying a semaphore upon which other threads are currently blocked is undefined. By itself, "undefined" here isn't very damning. But if you look at the return codes that a caller should expect to have to handle EBUSY; the text is thus: The sem_destroy() function will fail if: [EINVAL] The sem argument is not a valid semaphore. [ENOSYS] The function sem_destroy() is not supported by this implementation. The sem_destroy() function may fail if: [EBUSY] There are currently processes blocked on the semaphore. ...the implication here is clear: the sem_destroy() function may or may not know enough to be able to return an EBUSY error, based on how it was implemented. What this implies is that the implementation can optionally do what you say: > The semaphore remains active until it is destroyed. ...i.e. doing this is permissable, but... it would be a hairy problem to track shared memory and mmap'ed region deletions to track deletion of shared regions containing blocked semaphores. 8-(. > If you don't want to track its page, can you hook it into ipcrm(1)? Ugh, please, no! 8-) 8-). If people want persistent semaphore objects using the POSIX semaphores interface, they are supposed to used named instead of unnamed semaphores. -- Terry To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-hackers" in the body of the message