/pmtu-regress

regression tests for OpenBSD path MTU discovery

Primary LanguagePythonISC LicenseISC

Regression tests for path MTU discovery implementation in the kernel.

The test suite runs on the machine LOCAL, the kernel under test is
running on REMOTE.  On LOCAL a Scapy program is simulating a
connection to REMOTE TCP chargen service.  The source address is a
non existing address on FAKE_NET.  The LOCAL machine acts as a
router between REMOTE and virtual FAKE_NET_ADDR and can create ICMP
packets.

After the three-way handshake REMOTE fills the virtual TCP receive
buffer of FAKE_NET_ADDR with generated chars.  The data is not
acknowledged.  Then LOCAL sends a fragmentation-needed ICMP packet
and expects REMOTE to retransmit the TCP data.  It is checked that
the TCP packet from the REMOTE side has the MTU size that was
announced in the ICMP packet.

The same TCP test is done with IPv6 and a packet too big ICMP6.

An IPv6 UDP packet with 1400 octets payload is sent from FAKE_NET
to REMOTE.  The echo answer triggers an ICMP6 packet too big with
1300 MTU limit from LOCAL.  The response to the next UDP echo packet
has to be fragmented by REMOTE.

After removing the gateway route of the PMTU route on REMOTE, the
first IPv6 UDP echo must have 1400 octets payload.  A single ICMP6
packet too big must change the existing PMTU route so that the next
echo is fragmented.

EXAMPLE

To run this test I use the following configuration files.
You should choose a different set of MAC and IP addresses.

- My local machine where I run the regression test:

/etc/hosts
# to login to qemu with SSH via IPv6 link-local
fe80::725f:caff:fe21:8d70%tap0		q70

/etc/hostname.tap0
lladdr fe:e1:ba:d0:d5:6d up
inet 10.188.70.17 255.255.255.0
inet6 fdd7:e83e:66bc:70:3e97:eff:fea7:9b2
!route add -inet 10.188.219.0/24 127.0.0.1 -blackhole
!route add -inet6 fdd7:e83e:66bc:219::/64 ::1 -blackhole

- My qemu where the kernel under test is running

/etc/hostname.vio0
lladdr 70:5f:ca:21:8d:70
inet 10.188.70.70 255.255.255.0
inet6 fdd7:e83e:66bc:70:725f:caff:fe21:8d70
!route add -inet 10.188.219.0/24 10.188.70.17
!route add -inet6 fdd7:e83e:66bc:219::/64 fdd7:e83e:66bc:70:3e97:eff:fea7:9b2

/etc/inetd.conf
chargen stream  tcp     nowait  root    internal
chargen stream  tcp6    nowait  root    internal
echo            dgram   udp6    wait    root    internal

/etc/rc.conf.local
inetd_flags=
sshd_flags=

- My environment when executing the test

LOCAL_IF=tap0
LOCAL_MAC=fe:e1:ba:d0:d5:6d
REMOTE_MAC=70:5f:ca:21:8d:70
REMOTE_SSH=q70

LOCAL_ADDR=10.188.70.17
REMOTE_ADDR=10.188.70.70
FAKE_NET=10.188.219.0/24
FAKE_NET_ADDR=10.188.219.188

LOCAL_ADDR6=fdd7:e83e:66bc:70:3e97:eff:fea7:9b2
REMOTE_ADDR6=fdd7:e83e:66bc:70:725f:caff:fe21:8d70
FAKE_NET6=fdd7:e83e:66bc:219::/64
FAKE_NET_ADDR6=fdd7:e83e:66bc:219::188

- Fix your configuration until make check-setup passes