From ced920016f5e45804314b846a7642a176c0d71a0 Mon Sep 17 00:00:00 2001 From: Jarrod Johnson Date: Thu, 30 Nov 2017 09:55:34 -0500 Subject: [PATCH] Do not error if the platform does not support restricting the MAXSEG Some depressing platforms don't support this. The intent is to work around incorrect MTU settings for a network, which is hopefully rare, so being opportunistic without being fatalistic seems a wise course. Change-Id: I2108f335bdf623f6fc0a1723a8b5988c253a76b3 --- pyghmi/util/webclient.py | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/pyghmi/util/webclient.py b/pyghmi/util/webclient.py index 852d60e0..36c215ad 100644 --- a/pyghmi/util/webclient.py +++ b/pyghmi/util/webclient.py @@ -94,7 +94,10 @@ class SecureHTTPConnection(httplib.HTTPConnection, object): # in this space plainsock = socket.socket(addrinfo[0]) plainsock.settimeout(60) - plainsock.setsockopt(socket.IPPROTO_TCP, socket.TCP_MAXSEG, 1456) + try: + plainsock.setsockopt(socket.IPPROTO_TCP, socket.TCP_MAXSEG, 1456) + except socket.error: + pass plainsock.connect(addrinfo[4]) self.sock = ssl.wrap_socket(plainsock, cert_reqs=self.cert_reqs) # txtcert = self.sock.getpeercert() # currently not possible