From 74db3a0a0deb9ff3f319466f3f0c9b7f5a107635 Mon Sep 17 00:00:00 2001 From: pjd Date: Fri, 6 Apr 2007 11:19:48 +0000 Subject: [PATCH] Implement a work-around for poor ggate write performance. --- ggatec/Makefile | 1 + shared/ggate.c | 12 +++++++++++- 2 files changed, 12 insertions(+), 1 deletion(-) diff --git a/ggatec/Makefile b/ggatec/Makefile index c49cfe8..4d8917f 100644 --- a/ggatec/Makefile +++ b/ggatec/Makefile @@ -6,6 +6,7 @@ PROG= ggatec MAN= ggatec.8 SRCS= ggatec.c ggate.c +CFLAGS+= -DMAX_SEND_SIZE=32768 CFLAGS+= -DLIBGEOM CFLAGS+= -I${.CURDIR}/../shared diff --git a/shared/ggate.c b/shared/ggate.c index 09e35d3..dd40790 100644 --- a/shared/ggate.c +++ b/shared/ggate.c @@ -222,6 +222,16 @@ g_gate_load_module(void) } } +/* + * When we send from ggatec packets larger than 32kB, performance drops + * significantly (eg. to 256kB/s over 1Gbit/s link). This is not a problem + * when data is send from ggated. I don't know why, so for now I limit + * size of packets send from ggatec to 32kB by defining MAX_SEND_SIZE + * in ggatec Makefile. + */ +#ifndef MAX_SEND_SIZE +#define MAX_SEND_SIZE MAXPHYS +#endif ssize_t g_gate_send(int s, const void *buf, size_t len, int flags) { @@ -229,7 +239,7 @@ g_gate_send(int s, const void *buf, size_t len, int flags) const unsigned char *p = buf; while (len > 0) { - done2 = send(s, p, len, flags); + done2 = send(s, p, MIN(len, MAX_SEND_SIZE), flags); if (done2 == 0) break; else if (done2 == -1) {