From owner-freebsd-hackers Wed Feb 10 18:29:57 1999 Return-Path: Received: (from majordom@localhost) by hub.freebsd.org (8.8.8/8.8.8) id SAA02588 for freebsd-hackers-outgoing; Wed, 10 Feb 1999 18:29:57 -0800 (PST) (envelope-from owner-freebsd-hackers@FreeBSD.ORG) Received: from smtp02.primenet.com (smtp02.primenet.com [206.165.6.132]) by hub.freebsd.org (8.8.8/8.8.8) with ESMTP id SAA02581 for ; Wed, 10 Feb 1999 18:29:55 -0800 (PST) (envelope-from tlambert@usr06.primenet.com) Received: (from daemon@localhost) by smtp02.primenet.com (8.8.8/8.8.8) id TAA08483; Wed, 10 Feb 1999 19:29:54 -0700 (MST) Received: from usr06.primenet.com(206.165.6.206) via SMTP by smtp02.primenet.com, id smtpd008384; Wed Feb 10 19:29:51 1999 Received: (from tlambert@localhost) by usr06.primenet.com (8.8.5/8.8.5) id TAA09779; Wed, 10 Feb 1999 19:29:34 -0700 (MST) From: Terry Lambert Message-Id: <199902110229.TAA09779@usr06.primenet.com> Subject: Re: portability of shm, mmap, pipes and socket IPC To: peter.jeremy@auss2.alcatel.com.au (Peter Jeremy) Date: Thu, 11 Feb 1999 02:29:33 +0000 (GMT) Cc: dillon@apollo.backplane.com, tlambert@primenet.com, hackers@FreeBSD.ORG In-Reply-To: <99Feb11.122748est.40371@border.alcanet.com.au> from "Peter Jeremy" at Feb 11, 99 12:38:12 pm X-Mailer: ELM [version 2.4 PL25] MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: owner-freebsd-hackers@FreeBSD.ORG Precedence: bulk X-Loop: FreeBSD.ORG > >FreeBSD semaphores are inadequately resource tracked in _exit(). > > > All semaphores are inadequately resource tracked in _exit(), it's a > > problem inherited from the SYSV implementation. > > Could someone please describe what the problem(s) are and what impact > they have on applications using SysV semaphores. > > I have an application (running on 3.0-RELEASE) that relies on the > kernel correctly tracking SEM_UNDO's. (Basically I have a wrapper > that seizes a semaphore with sem_op = -1, sem_flg = SEM_UNDO and then > execs a process that knows nothing about the semaphores.) I was > seeing some wierd behaviour, but I thought that was a (now fixed) bug > in the kernel handling of SEMUME and SEMUSZ (see PR kern/9068). If the sem_op is a negative integer, and the absolute value of the sem_op is larger than the current value of the semaphore, and the value of (sem_flg&IPC_NOWAIT) is false, then the operation is ignored. The operation is *supposed* to increment the sem_cnt, and suspend the calling process. Apparently, this isn't done because of the need to tie it into the signal code (see the tsleep at ~ line 758 of kern/sysv_sem.c). Oh yeah; while I'm at having to prove someone else's bug report is a valid bug report, it's supposed to return EIDRM instead of EINVAL; contrary to the comments at ~ line 770, BSD *does* define this value. I'm pretty sure no one has bug reported that, though... Terry Lambert terry@lambert.org --- Any opinions in this posting are my own and not those of my present or previous employers. To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-hackers" in the body of the message