r1636 - trunk/varnish-cache/bin/varnishd
phk at projects.linpro.no
phk at projects.linpro.no
Tue Jul 3 23:38:32 CEST 2007
Author: phk
Date: 2007-07-03 23:38:32 +0200 (Tue, 03 Jul 2007)
New Revision: 1636
Modified:
trunk/varnish-cache/bin/varnishd/cache_http.c
trunk/varnish-cache/bin/varnishd/cache_ws.c
Log:
Do correct LostHeader processing on WS_Alloc() failure
Modified: trunk/varnish-cache/bin/varnishd/cache_http.c
===================================================================
--- trunk/varnish-cache/bin/varnishd/cache_http.c 2007-07-03 21:31:25 UTC (rev 1635)
+++ trunk/varnish-cache/bin/varnishd/cache_http.c 2007-07-03 21:38:32 UTC (rev 1636)
@@ -801,6 +801,7 @@
http_CopyHome(struct worker *w, int fd, struct http *hp)
{
unsigned u, l;
+ enum httptag htt;
char *p;
for (u = 0; u < hp->nhd; u++) {
@@ -808,25 +809,34 @@
continue;
switch (u) {
case HTTP_HDR_PROTO:
- WSLH(w, HTTP_T_Protocol, fd, hp, u);
+ htt = HTTP_T_Protocol;
break;
case HTTP_HDR_STATUS:
- WSLH(w, HTTP_T_Status, fd, hp, u);
+ htt = HTTP_T_Status;
break;
case HTTP_HDR_RESPONSE:
- WSLH(w, HTTP_T_Response, fd, hp, u);
+ htt = HTTP_T_Response;
break;
default:
- WSLH(w, HTTP_T_Header, fd, hp, u);
+ htt = HTTP_T_Header;
break;
}
- if (hp->hd[u].b >= hp->ws->s && hp->hd[u].e <= hp->ws->e)
+ if (hp->hd[u].b >= hp->ws->s && hp->hd[u].e <= hp->ws->e) {
+ WSLH(w, htt, fd, hp, u);
continue;
+ }
l = hp->hd[u].e - hp->hd[u].b;
p = WS_Alloc(hp->ws, l + 1);
- memcpy(p, hp->hd[u].b, l + 1);
- hp->hd[u].b = p;
- hp->hd[u].e = p + l;
+ if (p != NULL) {
+ WSLH(w, htt, fd, hp, u);
+ memcpy(p, hp->hd[u].b, l + 1);
+ hp->hd[u].b = p;
+ hp->hd[u].e = p + l;
+ } else {
+ WSLH(w, HTTP_T_LostHeader, fd, hp, u);
+ hp->hd[u].b = NULL;
+ hp->hd[u].e = NULL;
+ }
}
}
@@ -860,7 +870,7 @@
/*--------------------------------------------------------------------*/
static void
-http_PutField(struct http *to, int field, const char *string)
+http_PutField(struct worker *w, int fd, struct http *to, int field, const char *string)
{
const char *e;
char *p;
@@ -870,18 +880,22 @@
e = strchr(string, '\0');
l = (e - string);
p = WS_Alloc(to->ws, l + 1);
- memcpy(p, string, l + 1);
- to->hd[field].b = p;
- to->hd[field].e = p + l;
+ if (p == NULL) {
+ WSL(w, http2shmlog(to, HTTP_T_LostHeader), fd, "%s", string);
+ to->hd[field].b = NULL;
+ to->hd[field].e = NULL;
+ } else {
+ memcpy(p, string, l + 1);
+ to->hd[field].b = p;
+ to->hd[field].e = p + l;
+ }
}
void
http_PutProtocol(struct worker *w, int fd, struct http *to, const char *protocol)
{
- (void)w; /* should be used to report losthdr */
- (void)fd; /* should be used to report losthdr */
- http_PutField(to, HTTP_HDR_PROTO, protocol);
+ http_PutField(w, fd, to, HTTP_HDR_PROTO, protocol);
}
void
@@ -889,20 +903,16 @@
{
char stat[4];
- (void)w; /* should be used to report losthdr */
- (void)fd; /* should be used to report losthdr */
assert(status >= 0 && status <= 999);
sprintf(stat, "%d", status);
- http_PutField(to, HTTP_HDR_STATUS, stat);
+ http_PutField(w, fd, to, HTTP_HDR_STATUS, stat);
}
void
http_PutResponse(struct worker *w, int fd, struct http *to, const char *response)
{
- (void)w; /* should be used to report losthdr */
- (void)fd; /* should be used to report losthdr */
- http_PutField(to, HTTP_HDR_RESPONSE, response);
+ http_PutField(w, fd, to, HTTP_HDR_RESPONSE, response);
}
void
Modified: trunk/varnish-cache/bin/varnishd/cache_ws.c
===================================================================
--- trunk/varnish-cache/bin/varnishd/cache_ws.c 2007-07-03 21:31:25 UTC (rev 1635)
+++ trunk/varnish-cache/bin/varnishd/cache_ws.c 2007-07-03 21:38:32 UTC (rev 1636)
@@ -89,7 +89,8 @@
WS_Assert(ws);
assert(ws->r == NULL);
- xxxassert(ws->f + bytes <= ws->e);
+ if (ws->f + bytes > ws->e)
+ return(NULL);
r = ws->f;
ws->f += bytes;
return (r);
More information about the varnish-commit
mailing list