Skip site navigation (1)Skip section navigation (2)
Date:      Mon, 31 Mar 2008 05:49:33 +0200
From:      =?utf-8?Q?Dag-Erling_Sm=C3=B8rgrav?= <des@des.no>
To:        Mel <fbsd.hackers@rachie.is-a-geek.net>
Cc:        freebsd-hackers@freebsd.org
Subject:   Re: Popen and EVFILT_WRITE question
Message-ID:  <86ve33wo1e.fsf@ds4.des.no>
In-Reply-To: <200803301220.39921.fbsd.hackers@rachie.is-a-geek.net> (Mel's message of "Sun\, 30 Mar 2008 12\:20\:38 %2B0200")
References:  <200803301220.39921.fbsd.hackers@rachie.is-a-geek.net>

next in thread | previous in thread | raw e-mail | index | archive | help
Mel <fbsd.hackers@rachie.is-a-geek.net> writes:

> Hi,
>
> from reading the manpage on EVFILT_WRITE I thought it would be an easy to=
 use=20
> interface to detect when a program wants input.
> So far, that doesn't seem to be the case. Ultimately what I want to do is=
 pipe=20
> all the popen(3)'d output to a logfile and act on any input it wants.
>
> Could anyone explain to me why I'm never getting the EVFILT_WRITE event i=
n=20
> below testcode?
> (It doesn't matter if I open the pipe with w+ or r+).
>
> test.c:
> #include <sys/types.h>
> #include <sys/event.h>
> #include <sys/time.h>
> #include <sysexits.h>
> #include <err.h>
> #include <stdio.h>
>
> int main(int argc, char **argv)
> {
> 	FILE *proc;
> 	int kq;
> 	struct kevent changes[2], events[2];
>
> 	proc =3D popen("./test.sh", "w+");
> 	if( -1 =3D=3D (kq =3D kqueue()) )
> 		err(EX_OSERR, "Cannot get a kqueue");
>
> 	EV_SET(&changes[0], fileno(proc), EVFILT_WRITE, EV_ADD|EV_ENABLE, 0,
> 			0, 0);
> 	EV_SET(&changes[1], fileno(proc), EVFILT_READ, EV_ADD|EV_ENABLE, 0,
> 			0, 0);

This is never going to work.

First, the second kevent overrides the first, because they both have the
same ident.

Second, you're going to run into buffering issues.

Third, an EVFILT_WRITE event will trigger as long as there is space in
the pipe buffer.  There is no such thing as "when a program wants input"
in Unix; it will either read input or it won't, and what happens when it
reads depends entirely on what the fd it reads from is connected to,
whether it's a slow or fast device, blocking or non-blocking, etc.

DES
--=20
Dag-Erling Sm=C3=B8rgrav - des@des.no



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?86ve33wo1e.fsf>