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