xref: /openbsd-src/regress/sys/net/pf_fragment/frag6_ext.py (revision 9a7ee091fad639065b941b87634d41ec395438e6)
1#!/usr/local/bin/python2.7
2# send 2 ping6 fragments with hop-by-hop extension header
3
4import os
5import threading
6from addr import *
7from scapy.all import *
8
9class Sniff1(threading.Thread):
10	filter = None
11	captured = None
12	packet = None
13	def run(self):
14		self.captured = sniff(iface=SRC_IF, filter=self.filter,
15		    count=1, timeout=3)
16		if self.captured:
17			self.packet = self.captured[0]
18
19dstaddr=sys.argv[1]
20pid=os.getpid() & 0xffff
21payload="ABCDEFGHIJKLOMNO"
22packet=IPv6(src=SRC_OUT6, dst=dstaddr)/ICMPv6EchoRequest(id=pid, data=payload)
23frag0=IPv6ExtHdrFragment(nh=58, id=pid, m=1)/str(packet)[40:56]
24frag1=IPv6ExtHdrFragment(nh=58, id=pid, offset=2)/str(packet)[56:64]
25pkt0=IPv6(src=SRC_OUT6, dst=dstaddr)/IPv6ExtHdrHopByHop()/frag0
26pkt1=IPv6(src=SRC_OUT6, dst=dstaddr)/IPv6ExtHdrHopByHop()/frag1
27eth=[]
28eth.append(Ether(src=SRC_MAC, dst=PF_MAC)/pkt0)
29eth.append(Ether(src=SRC_MAC, dst=PF_MAC)/pkt1)
30
31sniffer = Sniff1();
32sniffer.filter = "ip6 and src %s and dst %s and icmp6" % (dstaddr, SRC_OUT6)
33sniffer.start()
34time.sleep(1)
35sendp(eth, iface=SRC_IF)
36sniffer.join(timeout=5)
37a = sniffer.packet
38
39if a and a.type == ETH_P_IPV6 and \
40    ipv6nh[a.payload.nh] == 'ICMPv6' and \
41    icmp6types[a.payload.payload.type] == 'Echo Reply':
42	id=a.payload.payload.id
43	print "id=%#x" % (id)
44	if id != pid:
45		print "WRONG ECHO REPLY ID"
46		exit(2)
47	data=a.payload.payload.data
48	print "payload=%s" % (data)
49	if data == payload:
50		exit(0)
51	print "PAYLOAD!=%s" % (payload)
52	exit(1)
53print "NO ECHO REPLY"
54exit(2)
55