xref: /linux/tools/testing/selftests/net/packetdrill/tcp_inq_client.pkt (revision 9410645520e9b820069761f3450ef6661418e279)
1*8a405552SWillem de Bruijn// SPDX-License-Identifier: GPL-2.0
2*8a405552SWillem de Bruijn// Test TCP_INQ and TCP_CM_INQ on the client side.
3*8a405552SWillem de Bruijn`./defaults.sh
4*8a405552SWillem de Bruijn`
5*8a405552SWillem de Bruijn
6*8a405552SWillem de Bruijn// Create a socket and set it to non-blocking.
7*8a405552SWillem de Bruijn    0	socket(..., SOCK_STREAM, IPPROTO_TCP) = 3
8*8a405552SWillem de Bruijn   +0	fcntl(3, F_GETFL) = 0x2 (flags O_RDWR)
9*8a405552SWillem de Bruijn   +0	fcntl(3, F_SETFL, O_RDWR|O_NONBLOCK) = 0
10*8a405552SWillem de Bruijn
11*8a405552SWillem de Bruijn// Connect to the server and enable TCP_INQ.
12*8a405552SWillem de Bruijn   +0	connect(3, ..., ...) = -1 EINPROGRESS (Operation now in progress)
13*8a405552SWillem de Bruijn   +0	setsockopt(3, SOL_TCP, TCP_INQ, [1], 4) = 0
14*8a405552SWillem de Bruijn
15*8a405552SWillem de Bruijn   +0	> S 0:0(0) <mss 1460,sackOK,TS val 100 ecr 0,nop,wscale 8>
16*8a405552SWillem de Bruijn +.01	< S. 0:0(0) ack 1 win 5792 <mss 1460,sackOK,TS val 700 ecr 100,nop,wscale 7>
17*8a405552SWillem de Bruijn   +0	> . 1:1(0) ack 1 <nop,nop,TS val 200 ecr 700>
18*8a405552SWillem de Bruijn
19*8a405552SWillem de Bruijn// Now we have 10K of data ready on the socket.
20*8a405552SWillem de Bruijn   +0	< . 1:10001(10000) ack 1 win 514
21*8a405552SWillem de Bruijn   +0	> . 1:1(0) ack 10001 <nop,nop,TS val 200 ecr 700>
22*8a405552SWillem de Bruijn
23*8a405552SWillem de Bruijn// We read 1K and we should have 9K ready to read.
24*8a405552SWillem de Bruijn   +0	recvmsg(3, {msg_name(...)=...,
25*8a405552SWillem de Bruijn		    msg_iov(1)=[{..., 1000}],
26*8a405552SWillem de Bruijn		    msg_flags=0,
27*8a405552SWillem de Bruijn		    msg_control=[{cmsg_level=SOL_TCP,
28*8a405552SWillem de Bruijn				  cmsg_type=TCP_CM_INQ,
29*8a405552SWillem de Bruijn				  cmsg_data=9000}]}, 0) = 1000
30*8a405552SWillem de Bruijn// We read 9K and we should have no further data ready to read.
31*8a405552SWillem de Bruijn   +0	recvmsg(3, {msg_name(...)=...,
32*8a405552SWillem de Bruijn		    msg_iov(1)=[{..., 9000}],
33*8a405552SWillem de Bruijn		    msg_flags=0,
34*8a405552SWillem de Bruijn		    msg_control=[{cmsg_level=SOL_TCP,
35*8a405552SWillem de Bruijn				  cmsg_type=TCP_CM_INQ,
36*8a405552SWillem de Bruijn				  cmsg_data=0}]}, 0) = 9000
37*8a405552SWillem de Bruijn
38*8a405552SWillem de Bruijn// Server sends more data and closes the connections.
39*8a405552SWillem de Bruijn   +0	< F. 10001:20001(10000) ack 1 win 514
40*8a405552SWillem de Bruijn   +0	> . 1:1(0) ack 20002 <nop,nop,TS val 200 ecr 700>
41*8a405552SWillem de Bruijn
42*8a405552SWillem de Bruijn// We read 10K and we should have one "fake" byte because the connection is
43*8a405552SWillem de Bruijn// closed.
44*8a405552SWillem de Bruijn   +0	recvmsg(3, {msg_name(...)=...,
45*8a405552SWillem de Bruijn		    msg_iov(1)=[{..., 10000}],
46*8a405552SWillem de Bruijn		    msg_flags=0,
47*8a405552SWillem de Bruijn		    msg_control=[{cmsg_level=SOL_TCP,
48*8a405552SWillem de Bruijn				  cmsg_type=TCP_CM_INQ,
49*8a405552SWillem de Bruijn				  cmsg_data=1}]}, 0) = 10000
50*8a405552SWillem de Bruijn// Now, receive EOF.
51*8a405552SWillem de Bruijn   +0	read(3, ..., 2000) = 0
52