aboutsummaryrefslogtreecommitdiffstats
path: root/package/uhttpd/src/uhttpd-cgi.c
diff options
context:
space:
mode:
authorJo-Philipp Wich <jow@openwrt.org>2010-03-29 09:26:02 +0000
committerJo-Philipp Wich <jow@openwrt.org>2010-03-29 09:26:02 +0000
commit33f40d767770b339e1a36ae6953fb3162cf43346 (patch)
treefbf808afb2e1365824bd7e5436a775bc00fb5534 /package/uhttpd/src/uhttpd-cgi.c
parentf5144821ed6cb3ba0333f8fde7184dbead85a9c8 (diff)
downloadupstream-33f40d767770b339e1a36ae6953fb3162cf43346.tar.gz
upstream-33f40d767770b339e1a36ae6953fb3162cf43346.tar.bz2
upstream-33f40d767770b339e1a36ae6953fb3162cf43346.zip
[package] uhttpd: fix a signal related race condition exposed by LuCI on fast machines
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@20573 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'package/uhttpd/src/uhttpd-cgi.c')
-rw-r--r--package/uhttpd/src/uhttpd-cgi.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/package/uhttpd/src/uhttpd-cgi.c b/package/uhttpd/src/uhttpd-cgi.c
index 28686b47e2..1a6c6ad4fe 100644
--- a/package/uhttpd/src/uhttpd-cgi.c
+++ b/package/uhttpd/src/uhttpd-cgi.c
@@ -562,7 +562,10 @@ void uh_cgi_request(struct client *cl, struct http_request *req, struct path_inf
close(wfd[1]);
if( !kill(child, 0) )
+ {
kill(child, SIGTERM);
+ waitpid(child, NULL, 0);
+ }
break;
}