Page Menu
Home
FreeBSD
Search
Configure Global Search
Log In
Files
F108631763
D42354.diff
No One
Temporary
Actions
View File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Flag For Later
Award Token
Size
5 KB
Referenced Files
None
Subscribers
None
D42354.diff
View Options
diff --git a/tests/sys/netpfil/common/pft_ping.py b/tests/sys/netpfil/common/pft_ping.py
--- a/tests/sys/netpfil/common/pft_ping.py
+++ b/tests/sys/netpfil/common/pft_ping.py
@@ -82,17 +82,29 @@
def send_icmp_ping(dst_address, sendif, send_params):
send_length = send_params['length']
+ send_frag_length = send_params['frag_length']
+ packets = []
ether = sp.Ether()
if ':' in dst_address:
ip6 = prepare_ipv6(dst_address, send_params)
icmp = sp.ICMPv6EchoRequest(data=sp.raw(build_payload(send_length)))
- req = ether / ip6 / icmp
+ if send_frag_length:
+ for packet in sp.fragment(ip6 / icmp, fragsize=send_frag_length):
+ packets.append(ether / packet)
+ else:
+ packets.append(ether / ip6 / icmp)
+
else:
ip = prepare_ipv4(dst_address, send_params)
icmp = sp.ICMP(type='echo-request')
raw = sp.raw(build_payload(send_length))
- req = ether / ip / icmp / raw
- sp.sendp(req, sendif, verbose=False)
+ if send_frag_length:
+ for packet in sp.fragment(ip / icmp / raw, fragsize=send_frag_length):
+ packets.append(ether / packet)
+ else:
+ packets.append(ether / ip / icmp / raw)
+ for packet in packets:
+ sp.sendp(packet, sendif, verbose=False)
def send_tcp_syn(dst_address, sendif, send_params):
@@ -372,7 +384,7 @@
return check_tcp_syn_reply_4(expect_params, packet)
-def setup_sniffer(recvif, ping_type, sniff_type, expect_params):
+def setup_sniffer(recvif, ping_type, sniff_type, expect_params, defrag):
if ping_type == 'icmp' and sniff_type == 'request':
checkfn = check_ping_request
elif ping_type == 'icmp' and sniff_type == 'reply':
@@ -384,7 +396,7 @@
else:
raise Exception('Unspported ping or sniff type')
- return Sniffer(expect_params, checkfn, recvif)
+ return Sniffer(expect_params, checkfn, recvif, defrag=defrag)
def parse_args():
@@ -417,6 +429,8 @@
parser_send = parser.add_argument_group('Values set in transmitted packets')
parser_send.add_argument('--send-flags', nargs=1, type=str,
help='IPv4 fragmentation flags')
+ parser_send.add_argument('--send-frag-length', nargs=1, type=int,
+ help='Force IP fragmentation with given fragment length')
parser_send.add_argument('--send-hlim', nargs=1, type=int,
help='IPv6 Hop Limit or IPv4 Time To Live')
parser_send.add_argument('--send-mss', nargs=1, type=int,
@@ -428,7 +442,7 @@
parser_send.add_argument('--send-tc', nargs=1, type=int,
help='IPv6 Traffic Class or IPv4 DiffServ / ToS')
parser_send.add_argument('--send-tcpopt-unaligned', action='store_true',
- help='Include unaligned TCP options')
+ help='Include unaligned TCP options')
# Expectations
parser_expect = parser.add_argument_group('Values expected in sniffed packets')
@@ -467,7 +481,7 @@
# Standardize parameters which have nargs=1.
send_params = {}
expect_params = {}
- for param_name in ('flags', 'hlim', 'length', 'mss', 'seq', 'tc'):
+ for param_name in ('flags', 'hlim', 'length', 'mss', 'seq', 'tc', 'frag_length'):
param_arg = vars(args).get(f'send_{param_name}')
send_params[param_name] = param_arg[0] if param_arg else None
param_arg = vars(args).get(f'expect_{param_name}')
@@ -488,6 +502,11 @@
sniffers = []
+ if send_params['frag_length']:
+ defrag = True
+ else:
+ defrag = False
+
if recv_ifs:
sniffer_params = copy(expect_params)
sniffer_params['src_address'] = None
@@ -495,7 +514,8 @@
for iface in recv_ifs:
LOGGER.debug(f'Installing receive sniffer on {iface}')
sniffers.append(
- setup_sniffer(iface, args.ping_type, 'request', sniffer_params,
+ setup_sniffer(iface, args.ping_type, 'request',
+ sniffer_params, defrag,
))
if reply_ifs:
@@ -505,7 +525,8 @@
for iface in reply_ifs:
LOGGER.debug(f'Installing reply sniffer on {iface}')
sniffers.append(
- setup_sniffer(iface, args.ping_type, 'reply', sniffer_params,
+ setup_sniffer(iface, args.ping_type, 'reply',
+ sniffer_params, defrag,
))
LOGGER.debug(f'Installed {len(sniffers)} sniffers')
diff --git a/tests/sys/netpfil/common/sniffer.py b/tests/sys/netpfil/common/sniffer.py
--- a/tests/sys/netpfil/common/sniffer.py
+++ b/tests/sys/netpfil/common/sniffer.py
@@ -30,7 +30,7 @@
import sys
class Sniffer(threading.Thread):
- def __init__(self, args, check_function, recvif, timeout=3):
+ def __init__(self, args, check_function, recvif, timeout=3, defrag=False):
threading.Thread.__init__(self)
self._sem = threading.Semaphore(0)
@@ -38,6 +38,7 @@
self._timeout = timeout
self._recvif = recvif
self._check_function = check_function
+ self._defrag = defrag
self.correctPackets = 0
self.start()
@@ -55,6 +56,15 @@
def run(self):
self.packets = []
- self.packets = sp.sniff(iface=self._recvif,
- stop_filter=self._checkPacket, timeout=self._timeout,
- started_callback=self._startedCb)
+ if self._defrag:
+ # With fragment reassembly we can't stop the sniffer after catching
+ # the good packets, as those have not been reassembled. We must
+ # wait for sniffer to finish and check returned packets instead.
+ self.packets = sp.sniff(session=sp.IPSession, iface=self._recvif,
+ timeout=self._timeout, started_callback=self._startedCb)
+ for p in self.packets:
+ self._checkPacket(p)
+ else:
+ self.packets = sp.sniff(iface=self._recvif,
+ stop_filter=self._checkPacket, timeout=self._timeout,
+ started_callback=self._startedCb)
File Metadata
Details
Attached
Mime Type
text/plain
Expires
Tue, Jan 28, 12:07 AM (9 h, 2 m)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
16225657
Default Alt Text
D42354.diff (5 KB)
Attached To
Mode
D42354: pf tests: Add option to send fragmented packets
Attached
Detach File
Event Timeline
Log In to Comment