Skip site navigation (1)Skip section navigation (2)
Date:      Sun, 2 Sep 2001 02:10:34 -0400
From:      Paul Chvostek <paul@it.ca>
To:        freebsd-net@freebsd.org
Subject:   laptop arp weirdness
Message-ID:  <20010902021033.L60846@gahch.it.ca>

next in thread | raw e-mail | index | archive | help

Hiya.

Major weirdness here, confusing me greatly.

I've just set up a Dell Latitude XPi CD with a fresh install of
4.3-RELEASE (since the boot floppies for 4.4-RELEASE cause a kernel
panic on this box, but that's another story).  I've got a pair of
3COM 3C589D cards which both exhibit identical behaviour, both of
which have work fine in other other laptops and other operating
systems on the same laptop, on the same Ethernet cable.  I see the
same behaviour with the GENERIC kernel as well as the stripped-down
kernel with only 'device ep' for Ethernet.

The 3C589D cards are recognized properly by pccardd using the default
config file.  The interface is assigned, I see the card's MAC address,
and can assign an IP address.  The ifconfig shows:

ep0: flags=8843<UP,BROADAST,RUNNING,SIMPLEX,MULTICAST> mtu 1500
	inet 10.4.1.9 netmask 0xffffff00 broadcast 10.4.1.255
	ether 00:60:97:78:2a:e4
	media: 10baseT/UTP
	supported media: 10base2/BNC 10baseT/UTP 10base5/AUI

Oddly, the laptop's own IP and MAC address pair appears as "permanent"
in its arp table (I haven't noticed that before), and it's picking up
arp from the rest of the network.  I tried removing that entry, but it
didn't change the behaviour.  I thought at first that the card just
wasn't talking to the network, despite showing a link light on both
ends.  On a hunch, I left a ping to the laptop running for a while,
and started seeing the real weirdness.

# ping -r 10.4.1.9
PING 10.4.1.9 (10.4.1.9): 56 data bytes
64 bytes from 10.4.1.9: icmp_seq=75 ttl=255 time=78305.271 ms
64 bytes from 10.4.1.9: icmp_seq=153 ttl=255 time=99514.223 ms
64 bytes from 10.4.1.9: icmp_seq=154 ttl=255 time=98504.297 ms
64 bytes from 10.4.1.9: icmp_seq=155 ttl=255 time=97494.497 ms
64 bytes from 10.4.1.9: icmp_seq=156 ttl=255 time=96484.632 ms
64 bytes from 10.4.1.9: icmp_seq=157 ttl=255 time=95474.784 ms
64 bytes from 10.4.1.9: icmp_seq=158 ttl=255 time=94464.932 ms
64 bytes from 10.4.1.9: icmp_seq=159 ttl=255 time=93455.088 ms
64 bytes from 10.4.1.9: icmp_seq=160 ttl=255 time=92445.242 ms
64 bytes from 10.4.1.9: icmp_seq=161 ttl=255 time=91435.438 ms
64 bytes from 10.4.1.9: icmp_seq=162 ttl=255 time=90425.590 ms
64 bytes from 10.4.1.9: icmp_seq=163 ttl=255 time=89415.743 ms
64 bytes from 10.4.1.9: icmp_seq=164 ttl=255 time=88405.884 ms
64 bytes from 10.4.1.9: icmp_seq=165 ttl=255 time=87396.055 ms
64 bytes from 10.4.1.9: icmp_seq=166 ttl=255 time=86386.208 ms
64 bytes from 10.4.1.9: icmp_seq=167 ttl=255 time=85376.361 ms
64 bytes from 10.4.1.9: icmp_seq=168 ttl=255 time=84366.512 ms
64 bytes from 10.4.1.9: icmp_seq=169 ttl=255 time=83356.672 ms
64 bytes from 10.4.1.9: icmp_seq=170 ttl=255 time=82346.809 ms
64 bytes from 10.4.1.9: icmp_seq=171 ttl=255 time=81336.987 ms
64 bytes from 10.4.1.9: icmp_seq=172 ttl=255 time=80327.140 ms
64 bytes from 10.4.1.9: icmp_seq=173 ttl=255 time=79317.297 ms
64 bytes from 10.4.1.9: icmp_seq=174 ttl=255 time=78307.456 ms
^C
--- 10.4.1.9 ping statistics ---
270 packets transmitted, 23 packets received, 91% packet loss
round-trip min/avg/max/stddev = 78305.271/88449.701/99514.223/6628.680 ms

Pings in the other direction (i.e. laptop to network) look the same,
but are more difficult to cut and paste.  :)

The lines from 153 to 174 appeared ALL AT ONCE (note the decending
times).  If I leave it for a long time, the pattern repeats, with a slew
of ping responses showing up at irregular intervals.  I also ran
tcpdumps elsewhere on the network, and found that ...
 - pings *to* the laptop merely generate gobs of "arp who-has" on the
   network, none of which is seen by the laptop,
 - pings from the laptop are being seen by other hosts but ARP isn't
   being answered in a timely fashion, so other machines on the network
   can't respond to the pings.

A ping from the laptop (.9) as seen from another box (.4):

# tcpdump -neixl0 icmp or arp
tcpdump: listening on xl0
01:36:39.754243 0:60:97:89:2a:e4 0:60:8:5a:58:fc 0800 98: 10.4.1.9 > 10.4.1.4: icmp: echo request
01:36:39.754375 0:60:8:5a:58:fc ff:ff:ff:ff:ff:ff 0806 42: arp who-has 10.4.1.9 tell 10.4.1.4
01:36:40.762199 0:60:97:89:2a:e4 0:60:8:5a:58:fc 0800 98: 10.4.1.9 > 10.4.1.4: icmp: echo request
01:36:40.762276 0:60:8:5a:58:fc ff:ff:ff:ff:ff:ff 0806 42: arp who-has 10.4.1.9 tell 10.4.1.4
01:36:41.772074 0:60:97:89:2a:e4 0:60:8:5a:58:fc 0800 98: 10.4.1.9 > 10.4.1.4: icmp: echo request
01:36:41.772139 0:60:8:5a:58:fc ff:ff:ff:ff:ff:ff 0806 42: arp who-has 10.4.1.9 tell 10.4.1.4
01:36:42.781983 0:60:97:89:2a:e4 0:60:8:5a:58:fc 0800 98: 10.4.1.9 > 10.4.1.4: icmp: echo request
01:36:42.782061 0:60:8:5a:58:fc ff:ff:ff:ff:ff:ff 0806 42: arp who-has 10.4.1.9 tell 10.4.1.4
01:36:43.791886 0:60:97:89:2a:e4 0:60:8:5a:58:fc 0800 98: 10.4.1.9 > 10.4.1.4: icmp: echo request
01:36:43.791937 0:60:8:5a:58:fc ff:ff:ff:ff:ff:ff 0806 42: arp who-has 10.4.1.9 tell 10.4.1.4
01:36:44.801844 0:60:97:89:2a:e4 0:60:8:5a:58:fc 0800 98: 10.4.1.9 > 10.4.1.4: icmp: echo request
01:36:45.811725 0:60:97:89:2a:e4 0:60:8:5a:58:fc 0800 98: 10.4.1.9 > 10.4.1.4: icmp: echo request
01:36:46.821628 0:60:97:89:2a:e4 0:60:8:5a:58:fc 0800 98: 10.4.1.9 > 10.4.1.4: icmp: echo request
01:36:47.831538 0:60:97:89:2a:e4 0:60:8:5a:58:fc 0800 98: 10.4.1.9 > 10.4.1.4: icmp: echo request
01:36:48.841466 0:60:97:89:2a:e4 0:60:8:5a:58:fc 0800 98: 10.4.1.9 > 10.4.1.4: icmp: echo request
...
01:37:43.376789 0:60:97:89:2a:e4 0:60:8:5a:58:fc 0800 98: 10.4.1.9 > 10.4.1.4: icmp: echo request
01:37:44.386633 0:60:97:89:2a:e4 0:60:8:5a:58:fc 0800 98: 10.4.1.9 > 10.4.1.4: icmp: echo request
01:37:45.396575 0:60:97:89:2a:e4 0:60:8:5a:58:fc 0800 98: 10.4.1.9 > 10.4.1.4: icmp: echo request
01:37:46.406470 0:60:97:89:2a:e4 0:60:8:5a:58:fc 0800 98: 10.4.1.9 > 10.4.1.4: icmp: echo request
01:37:47.417971 0:60:97:89:2a:e4 0:60:8:5a:58:fc 0806 60: arp reply 10.4.1.9 is-at 0:60:97:89:2a:e4
01:37:47.418017 0:60:8:5a:58:fc 0:60:97:89:2a:e4 0800 98: 10.4.1.4 > 10.4.1.9: icmp: echo reply
01:37:47.418030 0:60:97:89:2a:e4 0:60:8:5a:58:fc 0806 60: arp reply 10.4.1.9 is-at 0:60:97:89:2a:e4
01:37:47.418090 0:60:97:89:2a:e4 0:60:8:5a:58:fc 0806 60: arp reply 10.4.1.9 is-at 0:60:97:89:2a:e4
01:37:47.418288 0:60:97:89:2a:e4 0:60:8:5a:58:fc 0806 60: arp reply 10.4.1.9 is-at 0:60:97:89:2a:e4
01:37:47.418356 0:60:97:89:2a:e4 0:60:8:5a:58:fc 0806 60: arp reply 10.4.1.9 is-at 0:60:97:89:2a:e4
01:37:47.418423 0:60:97:89:2a:e4 0:60:8:5a:58:fc 0806 60: arp reply 10.4.1.9 is-at 0:60:97:89:2a:e4
01:37:47.418491 0:60:97:89:2a:e4 0:60:8:5a:58:fc 0806 60: arp reply 10.4.1.9 is-at 0:60:97:89:2a:e4
01:37:47.418559 0:60:97:89:2a:e4 0:60:8:5a:58:fc 0806 60: arp reply 10.4.1.9 is-at 0:60:97:89:2a:e4
01:37:47.418627 0:60:97:89:2a:e4 0:60:8:5a:58:fc 0806 60: arp reply 10.4.1.9 is-at 0:60:97:89:2a:e4
01:37:47.418695 0:60:97:89:2a:e4 0:60:8:5a:58:fc 0806 60: arp reply 10.4.1.9 is-at 0:60:97:89:2a:e4
01:37:47.418763 0:60:97:89:2a:e4 0:60:8:5a:58:fc 0806 60: arp reply 10.4.1.9 is-at 0:60:97:89:2a:e4
01:37:47.418830 0:60:97:89:2a:e4 0:60:8:5a:58:fc 0806 60: arp reply 10.4.1.9 is-at 0:60:97:89:2a:e4
01:37:47.418899 0:60:97:89:2a:e4 0:60:8:5a:58:fc 0806 60: arp reply 10.4.1.9 is-at 0:60:97:89:2a:e4
01:37:47.418989 0:60:97:89:2a:e4 0:60:8:5a:58:fc 0806 60: arp reply 10.4.1.9 is-at 0:60:97:89:2a:e4
01:37:47.419034 0:60:97:89:2a:e4 0:60:8:5a:58:fc 0806 60: arp reply 10.4.1.9 is-at 0:60:97:89:2a:e4
01:37:47.419134 0:60:97:89:2a:e4 0:60:8:5a:58:fc 0800 98: 10.4.1.9 > 10.4.1.4: icmp: echo request
01:37:47.419192 0:60:8:5a:58:fc 0:60:97:89:2a:e4 0800 98: 10.4.1.4 > 10.4.1.9: icmp: echo reply
01:37:48.426296 0:60:97:89:2a:e4 0:60:8:5a:58:fc 0800 98: 10.4.1.9 > 10.4.1.4: icmp: echo request
01:37:48.426379 0:60:8:5a:58:fc 0:60:97:89:2a:e4 0800 98: 10.4.1.4 > 10.4.1.9: icmp: echo reply
01:37:49.436246 0:60:97:89:2a:e4 0:60:8:5a:58:fc 0800 98: 10.4.1.9 > 10.4.1.4: icmp: echo request
01:37:49.436331 0:60:8:5a:58:fc 0:60:97:89:2a:e4 0800 98: 10.4.1.4 > 10.4.1.9: icmp: echo reply

Note the collection of arp replies at 01:37:47.

So the icmp is moving, but the laptop is failing to spit out the arp
replies that would let machines on the LAN send traffic to it.  Note
that despite the "echo reply" shown by tcpdump at the end of this
session, the responses never actually showed up in ping's stdout.

It seems to me that everything would work a little better if the laptop
would respond to arp who-has packets, which it does not seem to do.  The
only time other machines get to see the laptop's MAC address is from
outbound traffic from the laptop, except for bursts which happen every
few minutes of traffic.

I've got other tcpdump details that may or may not be relevant, but
would certainly lengthen this email if included, so I won't include 'em.

Anybody have any idea what's going on?  I'm stumped.

-- 
  Paul Chvostek                                             <paul@it.ca>
  Operations / Development / Abuse / Whatever       vox: +1 416 598-0000
  IT Canada                                            http://www.it.ca/


To Unsubscribe: send mail to majordomo@FreeBSD.org
with "unsubscribe freebsd-net" in the body of the message




Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20010902021033.L60846>