diff options
| author | jow <jow@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2010-09-09 20:15:02 +0000 | 
|---|---|---|
| committer | jow <jow@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2010-09-09 20:15:02 +0000 | 
| commit | 8c59fddb365bcd9a8ab6ce8ecc0c27b8026c0fd4 (patch) | |
| tree | 8f411598966424ee49349f5da6ac769006dcb592 | |
| parent | 9d4993c5b6517becf40cd41a00063020b2f4b594 (diff) | |
[package] uhttpd: break tight loop when receiving eof during header reading (#7904)
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@22988 3c298f89-4303-0410-b956-a3cf2f4a3e73
| -rw-r--r-- | package/uhttpd/Makefile | 2 | ||||
| -rw-r--r-- | package/uhttpd/src/uhttpd.c | 4 | 
2 files changed, 5 insertions, 1 deletions
| diff --git a/package/uhttpd/Makefile b/package/uhttpd/Makefile index 086c29458..e37fa90ec 100644 --- a/package/uhttpd/Makefile +++ b/package/uhttpd/Makefile @@ -8,7 +8,7 @@  include $(TOPDIR)/rules.mk  PKG_NAME:=uhttpd -PKG_RELEASE:=17 +PKG_RELEASE:=18  PKG_BUILD_DIR := $(BUILD_DIR)/$(PKG_NAME)  PKG_BUILD_DEPENDS := libcyassl liblua diff --git a/package/uhttpd/src/uhttpd.c b/package/uhttpd/src/uhttpd.c index 6f5e61634..a818e1c45 100644 --- a/package/uhttpd/src/uhttpd.c +++ b/package/uhttpd/src/uhttpd.c @@ -401,6 +401,10 @@ static struct http_request * uh_http_header_recv(struct client *cl)  			{  				ensure_out(rlen = uh_tcp_recv(cl, bufptr, rlen)); +				/* unexpected eof - #7904 */ +				if( rlen == 0 ) +					return NULL; +  				blen -= rlen;  				bufptr += rlen;  			} | 
