Change select(2) to kevent(2) on script(1)...

Ed Schouten ed at 80386.nl
Sun Dec 21 21:19:52 UTC 2008


* Norikatsu Shigemura <nork at FreeBSD.org> wrote:
> I inspired by your 'kqueue()-support to pseudo-terminal master
> devices' (svn commit: r185942).  So I'm trying to use kevent(2)
> on script(1). (SEE ALSO following patch)
> 
> But it doesn't work.  Because 'master' file descriptor (from
> openpty(3)) doesn't return last 0 byte data readable when shell
> exit.  In this case of select(2), 'master' file descriptor
> gets 0 byte data and exit script(1).
> 
> Do you have any idea?

I sure have. It turns out there is a small bug in the pts(4) driver.
Inside ptsdrv_close() (called when the TTY is being closed), we set a
flag to mark the pseudo-terminal as `finished' (which causes it to
return EOF's).

A difference between select() and kqueue() is that the knote handlers
are executed syncrhonously, while select() calls ptsdev_poll() later on.
This should be fixed as of r186382. Thanks for reporting this issue!

Are you planning to commit the patch for script(1) to SVN? I'm not sure
if we should port applications to kqueue(). Right now script(1) should
almost cleanly compile/work on other versions of FreeBSD and other
Unix-like operating systems.

-- 
 Ed Schouten <ed at 80386.nl>
 WWW: http://80386.nl/
-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: application/pgp-signature
Size: 195 bytes
Desc: not available
Url : http://lists.freebsd.org/pipermail/freebsd-current/attachments/20081221/08a862c0/attachment.pgp


More information about the freebsd-current mailing list