Trouble killing processes in SysV/AT

Chris Torek chris at mimsy.UUCP
Sun May 1 02:32:24 AEST 1988


In article <51443 at sun.uucp> limes at sun.uucp (Greg Limes) writes:
>If the sleep priority is above PZERO, the [signalled] sleep() will return
>an error corresponding to "I was interrupted!".

Unless Sun has made some big kernel changes recently, this is not the
case.  See /sys/sys/kern_synch.c, at the label `psig' in sleep().

Returning an error from sleep would be a viable alternative to `catch'
and `throw' routines, although it would entail more work.  Every driver
that now sleeps interruptably might read

	while ((foo->status & READY) == 0) {
		if (sleep((caddr_t)foo, PFOO))
			return (EINTR);
	}

and one would be safe in ignoring the (new) return value from sleep
iff the sleep is uninterruptable.
-- 
In-Real-Life: Chris Torek, Univ of MD Comp Sci Dept (+1 301 454 7163)
Domain:	chris at mimsy.umd.edu	Path:	uunet!mimsy!chris



More information about the Comp.unix.questions mailing list