From: Sean Hefty Date: Mon, 4 Jun 2012 20:22:10 +0000 (-0700) Subject: rsocket: Handle TCP_MAXSEG socket option X-Git-Url: https://openfabrics.org/gitweb/?a=commitdiff_plain;h=b99bd0638e7d22b1b0976a34a58efd352db420b3;p=~shefty%2Flibrdmacm.git rsocket: Handle TCP_MAXSEG socket option netperf uses the TCP_MAXSEG socket option. Add support for it. Problem reported by Sridhar Samudrala Signed-off-by: Sean Hefty --- diff --git a/src/rsocket.c b/src/rsocket.c index 8f20b4ab..2fd106a4 100644 --- a/src/rsocket.c +++ b/src/rsocket.c @@ -1716,6 +1716,9 @@ int rsetsockopt(int socket, int level, int optname, opt_on = *(int *) optval; ret = 0; break; + case TCP_MAXSEG: + ret = 0; + break; default: break; } @@ -1802,6 +1805,12 @@ int rgetsockopt(int socket, int level, int optname, *((int *) optval) = !!(rs->tcp_opts & (1 << optname)); *optlen = sizeof(int); break; + case TCP_MAXSEG: + *((int *) optval) = (rs->cm_id && rs->cm_id->route.num_paths) ? + 1 << (7 + rs->cm_id->route.path_rec->mtu) : + 2048; + *optlen = sizeof(int); + break; default: ret = ENOTSUP; break;