summaryrefslogtreecommitdiff
path: root/src/channel.c
diff options
context:
space:
mode:
authorPablo Neira Ayuso <pablo@netfilter.org>2009-09-11 16:19:41 +0200
committerPablo Neira Ayuso <pablo@netfilter.org>2009-09-11 16:19:41 +0200
commit189dbc5853ce73448ca0d2423bbac3aa23712478 (patch)
tree21599062fa75ef75bf360b01072cce8e810f192b /src/channel.c
parent49540362b2a25aadbaf25fd087414776aa5a67a8 (diff)
downloadconntrack-tools-189dbc5853ce73448ca0d2423bbac3aa23712478.tar.gz
conntrack-tools-189dbc5853ce73448ca0d2423bbac3aa23712478.zip
conntrackd: fix MTU for TCP channels
Use the TCP header size (20 bytes) instead of the UDP header size (8 bytes) to calculate the maximum packet size. Reported-by: Samuel Gauthier <samuel.gauthier@6wind.com> Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
Diffstat (limited to 'src/channel.c')
-rw-r--r--src/channel.c9
1 files changed, 4 insertions, 5 deletions
diff --git a/src/channel.c b/src/channel.c
index 76fb057..7374d1b 100644
--- a/src/channel.c
+++ b/src/channel.c
@@ -29,8 +29,6 @@ void channel_init(void)
ops[CHANNEL_TCP] = &channel_tcp;
}
-#define HEADERSIZ 28 /* IP header (20 bytes) + UDP header 8 (bytes) */
-
struct channel_buffer {
char *data;
int size;
@@ -38,7 +36,7 @@ struct channel_buffer {
};
static struct channel_buffer *
-channel_buffer_open(int mtu)
+channel_buffer_open(int mtu, int headersiz)
{
struct channel_buffer *b;
@@ -46,7 +44,7 @@ channel_buffer_open(int mtu)
if (b == NULL)
return NULL;
- b->size = mtu - HEADERSIZ;
+ b->size = mtu - headersiz;
b->data = malloc(b->size);
if (b->data == NULL) {
@@ -108,7 +106,8 @@ channel_open(struct channel_conf *conf)
c->ops = ops[conf->channel_type];
if (conf->channel_flags & CHANNEL_F_BUFFERED) {
- c->buffer = channel_buffer_open(c->channel_ifmtu);
+ c->buffer = channel_buffer_open(c->channel_ifmtu,
+ c->ops->headersiz);
if (c->buffer == NULL) {
free(c);
return NULL;