Date: Wed, 14 Oct 1998 08:12:03 -0600 (MDT) From: Darren Whittaker <djw@sage1.sagecorp.com> To: Mike Smith <mike@smith.net.au> Cc: freebsd-current@FreeBSD.ORG, john.young@openmarket.com Subject: Re: problem in 3.0 Message-ID: <Pine.SOL.3.93.981014080742.8720A-100000@sage1.sagecorp.com> In-Reply-To: <199810080530.WAA01135@dingo.cdrom.com>
next in thread | previous in thread | raw e-mail | index | archive | help
Thank you for your email. I have taken your code and modified it to run as
a cgi:
#include <stdio.h>
#include <err.h>
#include <errno.h>
int main(int argc, char *argv[])
{
int i, j;
char buf[256];
FILE *p;
/* output the head */
printf("Content-type: text/html\n");
fflush(stdout);
printf("\n<html><head><title>TESTING</title></head>");
printf("<CENTER><H1>TESTING</CENTER></H1><HR>\n");
printf("<body bgcolor=#ffffff><p><pre>\n");
fflush(stdout);
/* loop using popen */
for (i = 0; i < 10; i++)
{
buf[0] = '\0';
if ((p = popen("/bin/date", "r")) == NULL)
{
printf("popen error: %s\n",strerror(errno));
continue;
}
fgets(buf, sizeof(buf) - 1, p);
printf(buf);
if ((j = pclose(p)) != 0)
printf("pclose error: %s [%d]\n",strerror(j),j);
}
/* output the tail */
fflush(stdout);
printf("</pre><HR><center><small>Copyright © 1998 Open Market, Inc.
All
Rights Reserved.\n");
printf("</small></center></body></html>\n");
fflush(stdout);
}
Here is some of the output when I run it from the web browser:
Wed Oct 14 07:00:13 PDT 1998
pclose error: No child processes [10]
pclose error: No child processes [10]
pclose error: No child processes [10]
pclose error: No child processes [10]
pclose error: No child processes [10]
pclose error: No child processes [10]
pclose error: No child processes [10]
pclose error: No child processes [10]
pclose error: No child processes [10]
What do you think the problem might be?
-Darren
------------------
Darren Whittaker
Senior Software Engineer
Small Enterprise Group
Open Market, Inc.
On Wed, 7 Oct 1998, Mike Smith wrote:
> > We have found a problem with popen. The first popen is executed just fine
> > with a good pclose. The second popen appears to work (though nothing
> > happens) and the pclose returns a 138. This also applies to the system
> > call. The first one works but any after sustem call after the first
> > one fails. We even forked the process but in the child only the first
> > popen work.
>
> I'm not sure that I can follow your problem here. Have you reduced the
> program to its simplest form, eg:
>
> dingo:/tmp>cat p.c
> #include <stdio.h>
> #include <err.h>
>
> void main(void)
> {
> int i, j;
> char buf[256];
> FILE *p;
>
> for (i = 0; i < 10; i++) {
> if ((p = popen("/bin/date", "r")) == NULL)
> err(1, "popen");
> fgets(buf, sizeof(buf) - 1, p);
> printf(buf);
> if ((j = pclose(p)) != 0)
> errx(1, "pclose %d", j);
> }
> }
> dingo:/tmp>gcc -o p p.c
> dingo:/tmp>./p
> Wed Oct 7 22:28:04 PDT 1998
> Wed Oct 7 22:28:04 PDT 1998
> Wed Oct 7 22:28:04 PDT 1998
> Wed Oct 7 22:28:04 PDT 1998
> Wed Oct 7 22:28:04 PDT 1998
> Wed Oct 7 22:28:04 PDT 1998
> Wed Oct 7 22:28:04 PDT 1998
> Wed Oct 7 22:28:04 PDT 1998
> Wed Oct 7 22:28:04 PDT 1998
> Wed Oct 7 22:28:04 PDT 1998
> dingo:/tmp>uname -a
> FreeBSD dingo.cdrom.com 3.0-CURRENT FreeBSD 3.0-CURRENT #2: Wed Sep 16 16:38:28 PDT 1998 mike@dingo.cdrom.com:/local0/src/sys/compile/DINGO i386
>
> What do you mean by "this also applies to the system call"? Which
> system call?
>
> > Now our program is running as a cgi under Apache and works on your 2.x
> > versions just fine.
>
> I'm afraid you're going to have to supply some more detail before we
> can help you further here.
> --
> \\ Sometimes you're ahead, \\ Mike Smith
> \\ sometimes you're behind. \\ mike@smith.net.au
> \\ The race is long, and in the \\ msmith@freebsd.org
> \\ end it's only with yourself. \\ msmith@cdrom.com
>
>
>
To Unsubscribe: send mail to majordomo@FreeBSD.org
with "unsubscribe freebsd-current" in the body of the message
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?Pine.SOL.3.93.981014080742.8720A-100000>
