mirror of
http://git.haproxy.org/git/haproxy.git/
synced 2025-04-01 22:48:25 +00:00
BUG/MEDIUM: mux-h1: Fix the zero-copy on output for chunked messages
The commit 3815b227f
("MEDIUM: mux-h1: implement true zero-copy of DATA blocks")
broke the output of chunked messages. When the zero-copy was performed on such
messages, no chunk size was emitted nor ending CRLF.
Now, the chunked envelope is added when necessary. We have at least the size of
the struct htx to emit it. So 40 bytes for now. It should be enough.
This commit is contained in:
parent
256bf0d37b
commit
adb2220041
38
src/mux_h1.c
38
src/mux_h1.c
@ -839,6 +839,34 @@ static void h1_capture_bad_message(struct h1c *h1c, struct h1s *h1s,
|
||||
&ctx, h1_show_error_snapshot);
|
||||
}
|
||||
|
||||
/* Emit the chunksize followed by a CRLF in front of data of the buffer
|
||||
* <buf>. It goes backwards and starts with the byte before the buffer's
|
||||
* head. The caller is responsible for ensuring there is enough room left before
|
||||
* the buffer's head for the string.
|
||||
*/
|
||||
static void h1_emit_chunk_size(struct buffer *buf, size_t chksz)
|
||||
{
|
||||
char *beg, *end;
|
||||
|
||||
beg = end = b_head(buf);
|
||||
*--beg = '\n';
|
||||
*--beg = '\r';
|
||||
do {
|
||||
*--beg = hextab[chksz & 0xF];
|
||||
} while (chksz >>= 4);
|
||||
buf->head -= (end - beg);
|
||||
b_add(buf, end - beg);
|
||||
}
|
||||
|
||||
/* Emit a CRLF after the data of the buffer <buf>. The caller is responsible for
|
||||
* ensuring there is enough room left in the buffer for the string. */
|
||||
static void h1_emit_chunk_crlf(struct buffer *buf)
|
||||
{
|
||||
*(b_peek(buf, b_data(buf))) = '\r';
|
||||
*(b_peek(buf, b_data(buf) + 1)) = '\n';
|
||||
b_add(buf, 2);
|
||||
}
|
||||
|
||||
/*
|
||||
* Parse HTTP/1 headers. It returns the number of bytes parsed if > 0, or 0 if
|
||||
* it couldn't proceed. Parsing errors are reported by setting H1S_F_*_ERROR
|
||||
@ -1389,6 +1417,16 @@ static size_t h1_process_output(struct h1c *h1c, struct buffer *buf, size_t coun
|
||||
|
||||
buf->area = old_area;
|
||||
buf->data = buf->head = 0;
|
||||
|
||||
/* The message is chunked. We need to emit the chunk
|
||||
* size. We have at least the size of the struct htx to
|
||||
* write the chunk envelope. It should be enough.
|
||||
*/
|
||||
if (h1m->flags & H1_MF_CHNK) {
|
||||
h1_emit_chunk_size(&h1c->obuf, count);
|
||||
h1_emit_chunk_crlf(&h1c->obuf);
|
||||
}
|
||||
|
||||
total += count;
|
||||
goto out;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user