From a3ff848b2909138ce053accec35b7a7a56b32487 Mon Sep 17 00:00:00 2001 From: David Sommerseth Date: Fri, 19 Feb 2010 17:32:56 +0100 Subject: verb 5 logging wrongly reports received bytes With --verb 5, openvpn logs a single letter (rwRW) for each package received or sent. I recently ran into a problem with the tun device on Linux where the read from that device returned 0. Unfortunately this was also logged as "r", which made me assume that openvpn had received something, while it actually hadn't. (See https://dev.openwrt.org/ticket/6650 for the bug that made me find out about this problem with openvpn.) I'm attaching a patch which prevents openvpn from logging "r" or "R" when it didn't actually read anything. This is against openvpn 2.1-rc20, but probably still applies to the most recent version. This patch was received anonymously via the sf.net bug tracker: Signed-off-by: David Sommerseth Acked-by: David Sommerseth Acked-by: Gert Doering --- forward.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/forward.c b/forward.c index 207b876..d563e11 100644 --- a/forward.c +++ b/forward.c @@ -755,7 +755,7 @@ process_incoming_link (struct context *c) /* log incoming packet */ #ifdef LOG_RW - if (c->c2.log_rw) + if (c->c2.log_rw && c->c2.buf.len > 0) fprintf (stderr, "R"); #endif msg (D_LINK_RW, "%s READ [%d] from %s: %s", @@ -965,7 +965,7 @@ process_incoming_tun (struct context *c) c->c2.tun_read_bytes += c->c2.buf.len; #ifdef LOG_RW - if (c->c2.log_rw) + if (c->c2.log_rw && c->c2.buf.len > 0) fprintf (stderr, "r"); #endif -- cgit v1.2.3