summaryrefslogtreecommitdiffstats
path: root/package/busybox/patches/420-httpd_sendcgi_fix.patch
blob: f2ed2f3e86ab489dbdb84d90774b9d670194755a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
diff -ur busybox.old/networking/httpd.c busybox.dev/networking/httpd.c
--- busybox.old/networking/httpd.c	2007-02-10 16:36:50.950661000 +0100
+++ busybox.dev/networking/httpd.c	2007-02-11 21:24:52.026742384 +0100
@@ -1211,9 +1211,10 @@
 #if PIPESIZE >= MAX_MEMORY_BUFF
 # error "PIPESIZE >= MAX_MEMORY_BUFF"
 #endif
-			/* NB: was safe_read. If it *has to be* safe_read, */
-			/* please explain why in this comment... */
-			count = full_read(inFd, rbuf, PIPESIZE);
+			/* reverted back to safe_read, otherwise httpd may block if the */
+			/* cgi-script outputs page date before it has fully received all */
+			/* (eg POST) data */
+			count = safe_read(inFd, rbuf, PIPESIZE);
 			if (count == 0)
 				break;  /* closed */
 			if (count < 0)