From owner-freebsd-net@FreeBSD.ORG Thu Dec 25 09:04:51 2008 Return-Path: Delivered-To: net@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id C5CBD106567B; Thu, 25 Dec 2008 09:04:51 +0000 (UTC) (envelope-from prvs=julian=238a38e37@elischer.org) Received: from smtp-outbound.ironport.com (smtp-outbound.ironport.com [63.251.108.112]) by mx1.freebsd.org (Postfix) with ESMTP id B0A168FC1C; Thu, 25 Dec 2008 09:04:51 +0000 (UTC) (envelope-from prvs=julian=238a38e37@elischer.org) Received: from unknown (HELO julian-mac.elischer.org) ([10.251.60.27]) by smtp-outbound.ironport.com with ESMTP; 25 Dec 2008 01:04:48 -0800 Message-ID: <49534CAF.8050608@elischer.org> Date: Thu, 25 Dec 2008 01:04:47 -0800 From: Julian Elischer User-Agent: Thunderbird 2.0.0.18 (Macintosh/20081105) MIME-Version: 1.0 To: gnn@freebsd.org References: <7ihc4u3adr.wl%gnn@neville-neil.com> <4951515C.4030706@elischer.org> <7i63l9r33o.wl%gnn@neville-neil.com> <4952CE97.3010506@elischer.org> In-Reply-To: <4952CE97.3010506@elischer.org> Content-Type: text/plain; charset=ISO-8859-1; format=flowed Content-Transfer-Encoding: 7bit Cc: net@freebsd.org Subject: Re: A new tool for low level testing... X-BeenThere: freebsd-net@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: Networking and TCP/IP with FreeBSD List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Thu, 25 Dec 2008 09:04:52 -0000 Julian Elischer wrote: > > cd /usr/src/sys/modules/netgraph/ether_echo > make > make install > kldload ng_ether > kldload ng_ether_echo > ngctl mkpeer em0: ether_echo lower echo > > should work for 7 and 6 without any change. > > It's not hooked to the build yet but I'll do that when I've seen it loop > back into my system via the mirrors.. > Now hooked into -current in my not so quick machines: This is recorded from the pinging machine, so this includes 2 x rx delay and 2 x xmit delay and 2 x "on the wire" time. (1GB ethernet...) on top of the echo time for the module on the far end. ====== 07:42:36.380924 00:13:72:5d:99:51 > ff:ff:ff:ff:ff:ff, ethertype ARP (0x0806), length 42: arp who-has 172.28.2.2 tell 172.28.2.6 07:42:36.381077 00:0f:1f:6a:7b:91 > 00:13:72:5d:99:51, ethertype ARP (0x0806), length 60: arp who-has 172.28.2.2 tell 172.28.2.6 153usecs 07:42:37.408370 00:13:72:5d:99:51 > ff:ff:ff:ff:ff:ff, ethertype ARP (0x0806), length 42: arp who-has 172.28.2.2 tell 172.28.2.6 07:42:37.408465 00:0f:1f:6a:7b:91 > 00:13:72:5d:99:51, ethertype ARP (0x0806), length 60: arp who-has 172.28.2.2 tell 172.28.2.6 95 usecs 07:42:38.436187 00:13:72:5d:99:51 > ff:ff:ff:ff:ff:ff, ethertype ARP (0x0806), length 42: arp who-has 172.28.2.2 tell 172.28.2.6 07:42:38.436312 00:0f:1f:6a:7b:91 > 00:13:72:5d:99:51, ethertype ARP (0x0806), length 60: arp who-has 172.28.2.2 tell 172.28.2.6 125 uSec 07:42:39.464488 00:13:72:5d:99:51 > ff:ff:ff:ff:ff:ff, ethertype ARP (0x0806), length 42: arp who-has 172.28.2.2 tell 172.28.2.6 07:42:39.464582 00:0f:1f:6a:7b:91 > 00:13:72:5d:99:51, ethertype ARP (0x0806), length 60: arp who-has 172.28.2.2 tell 172.28.2.6 94 uSec 07:42:40.492874 00:13:72:5d:99:51 > ff:ff:ff:ff:ff:ff, ethertype ARP (0x0806), length 42: arp who-has 172.28.2.2 tell 172.28.2.6 07:42:40.493024 00:0f:1f:6a:7b:91 > 00:13:72:5d:99:51, ethertype ARP (0x0806), length 60: arp who-has 172.28.2.2 tell 172.28.2.6 149 uSec ========= vs for an actual ping: ========= 07:47:50.589232 00:13:72:5d:99:51 > 00:0f:1f:6a:7b:91, ethertype IPv4 (0x0800), length 98: 172.28.2.6 > 172.28.2.2: ICMP echo request, id 64053, seq 0, length 64 07:47:50.589347 00:0f:1f:6a:7b:91 > 00:13:72:5d:99:51, ethertype IPv4 (0x0800), length 98: 172.28.2.2 > 172.28.2.6: ICMP echo reply, id 64053, seq 0, length 64 115 uSec 07:47:51.616851 00:13:72:5d:99:51 > 00:0f:1f:6a:7b:91, ethertype IPv4 (0x0800), length 98: 172.28.2.6 > 172.28.2.2: ICMP echo request, id 64053, seq 1, length 64 07:47:51.617192 00:0f:1f:6a:7b:91 > 00:13:72:5d:99:51, ethertype IPv4 (0x0800), length 98: 172.28.2.2 > 172.28.2.6: ICMP echo reply, id 64053, seq 1, length 64 343 uSec 07:47:52.644629 00:13:72:5d:99:51 > 00:0f:1f:6a:7b:91, ethertype IPv4 (0x0800), length 98: 172.28.2.6 > 172.28.2.2: ICMP echo request, id 64053, seq 2, length 64 07:47:52.644741 00:0f:1f:6a:7b:91 > 00:13:72:5d:99:51, ethertype IPv4 (0x0800), length 98: 172.28.2.2 > 172.28.2.6: ICMP echo reply, id 64053, seq 2, length 64 112 uSec 07:47:53.672976 00:13:72:5d:99:51 > 00:0f:1f:6a:7b:91, ethertype IPv4 (0x0800), length 98: 172.28.2.6 > 172.28.2.2: ICMP echo request, id 64053, seq 3, length 64 07:47:53.673179 00:0f:1f:6a:7b:91 > 00:13:72:5d:99:51, ethertype IPv4 (0x0800), length 98: 172.28.2.2 > 172.28.2.6: ICMP echo reply, id 64053, seq 3, length 64 223 uSec 07:47:54.700774 00:13:72:5d:99:51 > 00:0f:1f:6a:7b:91, ethertype IPv4 (0x0800), length 98: 172.28.2.6 > 172.28.2.2: ICMP echo request, id 64053, seq 4, length 64 07:47:54.700868 00:0f:1f:6a:7b:91 > 00:13:72:5d:99:51, ethertype IPv4 (0x0800), length 98: 172.28.2.2 > 172.28.2.6: ICMP echo reply, id 64053, seq 4, length 64 94 uSec ======== so a bit faster but not hugely. to get rid of the transmit times etc: on the echoing machine tcpdump shows: about 14uSec for ether_echo (with an occasional 16 or 19uSec) vs varying between 26usec and 46uSec for icmp echo. now even that isn't 'optimal' we can probably do better than that, as netgraph does have some overhead.. anyhow it's gotta be better than libpcap and a user program...