From owner-freebsd-net@FreeBSD.ORG Mon Feb 21 22:37:11 2005 Return-Path: Delivered-To: freebsd-net@freebsd.org Received: from mx1.FreeBSD.org (mx1.freebsd.org [216.136.204.125]) by hub.freebsd.org (Postfix) with ESMTP id 7BAF716A4CE; Mon, 21 Feb 2005 22:37:11 +0000 (GMT) Received: from ylpvm01.prodigy.net (ylpvm01-ext.prodigy.net [207.115.57.32]) by mx1.FreeBSD.org (Postfix) with ESMTP id 13F7443D3F; Mon, 21 Feb 2005 22:37:11 +0000 (GMT) (envelope-from kbyanc@posi.net) Received: from gateway.posi.net (adsl-63-201-89-53.dsl.snfc21.pacbell.net [63.201.89.53])j1LMb9vE022558; Mon, 21 Feb 2005 17:37:09 -0500 Received: from localhost (localhost [127.0.0.1]) by gateway.posi.net (Postfix) with ESMTP id D406375E077; Mon, 21 Feb 2005 15:39:48 -0800 (PST) Date: Mon, 21 Feb 2005 15:39:48 -0800 (PST) From: Kelly Yancey To: freebsd-net@FreeBSD.org Message-ID: <20050221153304.J2022@gateway.posi.net> MIME-Version: 1.0 Content-Type: MULTIPART/MIXED; BOUNDARY="0-1444105768-1109029188=:2022" cc: Pawel Worach cc: des@FreeBSD.org Subject: [patch] Update to libfetch X-BeenThere: freebsd-net@freebsd.org X-Mailman-Version: 2.1.1 Precedence: list List-Id: Networking and TCP/IP with FreeBSD List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Mon, 21 Feb 2005 22:37:11 -0000 This message is in MIME format. The first part should be readable text, while the remaining parts are likely unreadable without MIME-aware tools. Send mail to mime@docserver.cac.washington.edu for more info. --0-1444105768-1109029188=:2022 Content-Type: TEXT/PLAIN; charset=US-ASCII Attached is a patch to address concerns raised by Pawel Worach with regards to the recent change to set TCP_NOPUSH when sending HTTP requests from libfetch. The previous revision also introduced a call to shutdown(2) to close the write half of the socket in order to force the queued request to be sent. While this should be perfectly acceptable behavior for a TCP client, it appears that squid provides a configuration option to disallow half-closed clients (which Pawel is currently using). As such, after introducing the shutdown(2) call, fetch(1) can no longer fetch files via HTTP through such proxies. To address this issue, the attached patch replaces the call to shutdown(2) with some socket option fiddling (clearing TCP_NOPUSH and setting TCP_NODELAY) which does the same job of forcing the client to write the queued request to the network without closing the write half of the socket. This feels a bit hackish to me, but gets the job done. Anyway, I would appreciate any feedback. Thanks, Kelly -- Kelly Yancey - kbyanc@{posi.net,FreeBSD.org} - kelly@nttmcl.com --0-1444105768-1109029188=:2022 Content-Type: TEXT/PLAIN; charset=US-ASCII; name="fetch-nodelay.diff" Content-Transfer-Encoding: BASE64 Content-ID: <20050221153948.B2022@gateway.posi.net> Content-Description: Content-Disposition: attachment; filename="fetch-nodelay.diff" PyBmZXRjaC4zLmd6DQo/IGZ0cGVyci5oDQo/IGh0dHBlcnIuaA0KPyBsaWJm ZXRjaC5zby4zDQo/IH5mZXRjaC1ub2RlbGF5LmRpZmYNCkluZGV4OiBodHRw LmMNCj09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09 PT09PT09PT09PT09PT09PT09PT09PT09PT0NClJDUyBmaWxlOiAvaG9tZS9u Y3ZzL3NyYy9saWIvbGliZmV0Y2gvaHR0cC5jLHYNCnJldHJpZXZpbmcgcmV2 aXNpb24gMS43NQ0KZGlmZiAtdSAtcCAtcjEuNzUgaHR0cC5jDQotLS0gaHR0 cC5jCTE2IEZlYiAyMDA1IDAwOjIyOjIwIC0wMDAwCTEuNzUNCisrKyBodHRw LmMJMjEgRmViIDIwMDUgMjI6Mjk6MTYgLTAwMDANCkBAIC03OTIsNyArNzky LDcgQEAgX2h0dHBfcmVxdWVzdChzdHJ1Y3QgdXJsICpVUkwsIGNvbnN0IGNo YQ0KIAljb25uX3QgKmNvbm47DQogCXN0cnVjdCB1cmwgKnVybCwgKm5ldzsN CiAJaW50IGNodW5rZWQsIGRpcmVjdCwgbmVlZF9hdXRoLCBub3JlZGlyZWN0 LCB2ZXJib3NlOw0KLQlpbnQgZSwgaSwgbjsNCisJaW50IGUsIGksIG4sIHZh bDsNCiAJb2ZmX3Qgb2Zmc2V0LCBjbGVuZ3RoLCBsZW5ndGgsIHNpemU7DQog CXRpbWVfdCBtdGltZTsNCiAJY29uc3QgY2hhciAqcDsNCkBAIC05MTMsNyAr OTEzLDIwIEBAIF9odHRwX3JlcXVlc3Qoc3RydWN0IHVybCAqVVJMLCBjb25z dCBjaGENCiAJCQlfaHR0cF9jbWQoY29ubiwgIlJhbmdlOiBieXRlcz0lbGxk LSIsIChsb25nIGxvbmcpdXJsLT5vZmZzZXQpOw0KIAkJX2h0dHBfY21kKGNv bm4sICJDb25uZWN0aW9uOiBjbG9zZSIpOw0KIAkJX2h0dHBfY21kKGNvbm4s ICIiKTsNCi0JCXNodXRkb3duKGNvbm4tPnNkLCBTSFVUX1dSKTsNCisNCisJ CS8qDQorCQkgKiBGb3JjZSB0aGUgcXVldWVkIHJlcXVlc3QgdG8gYmUgZGlz cGF0Y2hlZC4gIE5vcm1hbGx5LCBvbmUNCisJCSAqIHdvdWxkIGRvIHRoaXMg d2l0aCBzaHV0ZG93bigyKSBidXQgc3F1aWQgcHJveGllcyBjYW4gYmUNCisJ CSAqIGNvbmZpZ3VyZWQgdG8gZGlzYWxsb3cgc3VjaCBoYWxmLWNsb3NlZCBj b25uZWN0aW9ucy4gIFRvDQorCQkgKiBiZSBjb21wYXRpYmxlIHdpdGggc3Vj aCBjb25maWd1cmF0aW9ucywgZmlkZGxlIHdpdGggc29ja2V0DQorCQkgKiBv cHRpb25zIHRvIGZvcmNlIHRoZSBwZW5kaW5nIGRhdGEgdG8gYmUgd3JpdHRl bi4NCisJCSAqLw0KKwkJdmFsID0gMDsNCisJCXNldHNvY2tvcHQoY29ubi0+ c2QsIElQUFJPVE9fVENQLCBUQ1BfTk9QVVNILCAmdmFsLA0KKwkJCSAgIHNp emVvZih2YWwpKTsNCisJCXZhbCA9IDE7DQorCQlzZXRzb2Nrb3B0KGNvbm4t PnNkLCBJUFBST1RPX1RDUCwgVENQX05PREVMQVksICZ2YWwsDQorCQkJICAg c2l6ZW9mKHZhbCkpOw0KIA0KIAkJLyogZ2V0IHJlcGx5ICovDQogCQlzd2l0 Y2ggKF9odHRwX2dldF9yZXBseShjb25uKSkgew0K --0-1444105768-1109029188=:2022--