Date: Sun, 19 Aug 2007 10:44:09 -0400 (EDT) From: Daniel Eischen <deischen@freebsd.org> To: Robert Watson <rwatson@freebsd.org> Cc: wine-freebsd@hub.org, src-committers@freebsd.org, cvs-src@freebsd.org, cvs-all@freebsd.org, "Marc G. Fournier" <scrappy@hub.org>, David Xu <davidxu@freebsd.org>, Tijl Coosemans <tijl@ulyssis.org>, Xin LI <delphij@delphij.net> Subject: Re: cvs commit: src/sys/kern kern_thr.c syscalls.master src/sys/sys Message-ID: <Pine.GSO.4.64.0708191027350.16079@sea.ntplx.net> In-Reply-To: <20070819092923.X65240@fledge.watson.org> References: <200708160526.l7G5Qg0b008022@repoman.freebsd.org> <46C4FD02.3090708@freebsd.org> <Pine.GSO.4.64.0708162216530.1396@sea.ntplx.net> <200708182118.37998.tijl@ulyssis.org> <20070818204223.D1234@fledge.watson.org> <Pine.GSO.4.64.0708182050070.13363@sea.ntplx.net> <250D8A54B98F12158C71D8FE@ganymede.hub.org> <Pine.GSO.4.64.0708182250550.13824@sea.ntplx.net> <20070819092923.X65240@fledge.watson.org>
next in thread | previous in thread | raw e-mail | index | archive | help
On Sun, 19 Aug 2007, Robert Watson wrote: > On Sat, 18 Aug 2007, Daniel Eischen wrote: > >>> Stupid question, but ... why not? >>> >>> First off, do you know for a fact that Wine is the only app out there that >>> needs the ability to kill off a thread in a seperate process, or has >>> nobody in the past cared enough to see other apps ported from Linux -> >>> FreeBSD to push for this sort of thing? >> >> FreeBSD as well as Solaris and Linux (it looks like Linux only allows a >> thread group to be signaled) have gotten along without this API, and Wine >> seems to be the only target for this syscall. > > While I'm not familiar with the newer pthread code on Linux, I can say with > reasonable authority that the older implementation used the same ID space for > pids and thread IDs, since threads were tasks, and therefore Linux has always > supported directly signalling threads in other processes. Thread id's (as visible to an application) are not required to be something that is known by the kernel. They certainly are not in libkse and libc_r, and I don't think they are in libthr either. This API won't work with libkse (or libc_r if we care) and isn't guaranteed to work with any future libthreadX. POSIX has well defined behavior with regard to signaling, and this certainly bypasses that. If we want to add a more well thought out set of APIs for thread groups that can (in the future) support CPU binding and scheduling, then that's OK. But the API as committed is a hack that solves one particular problem that can be solved in other (more portable) ways. sigqueue() was mentioned as a possible solution earlier. -- DE
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?Pine.GSO.4.64.0708191027350.16079>