From owner-freebsd-net@FreeBSD.ORG Mon Sep 8 06:38:10 2003 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 02EC216A4BF for ; Mon, 8 Sep 2003 06:38:10 -0700 (PDT) Received: from duke.cs.duke.edu (duke.cs.duke.edu [152.3.140.1]) by mx1.FreeBSD.org (Postfix) with ESMTP id 1845543FAF for ; Mon, 8 Sep 2003 06:38:09 -0700 (PDT) (envelope-from gallatin@cs.duke.edu) Received: from grasshopper.cs.duke.edu (grasshopper.cs.duke.edu [152.3.145.30]) by duke.cs.duke.edu (8.12.9/8.12.9) with ESMTP id h88Dc7JV008046 (version=TLSv1/SSLv3 cipher=EDH-RSA-DES-CBC3-SHA bits=168 verify=NO); Mon, 8 Sep 2003 09:38:07 -0400 (EDT) Received: (from gallatin@localhost) by grasshopper.cs.duke.edu (8.11.6/8.9.1) id h88Dc2j42397; Mon, 8 Sep 2003 09:38:02 -0400 (EDT) (envelope-from gallatin@cs.duke.edu) From: Andrew Gallatin MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Transfer-Encoding: 7bit Message-ID: <16220.34362.594825.422966@grasshopper.cs.duke.edu> Date: Mon, 8 Sep 2003 09:38:02 -0400 (EDT) To: Luigi Rizzo In-Reply-To: <20030906090701.A3163@xorpc.icir.org> References: <16216.63066.954104.582195@grasshopper.cs.duke.edu> <20030906090701.A3163@xorpc.icir.org> X-Mailer: VM 6.75 under 21.1 (patch 12) "Channel Islands" XEmacs Lucid cc: freebsd-net@freebsd.org Subject: Re: TCP Segmentation Offload 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, 08 Sep 2003 13:38:10 -0000 Luigi Rizzo writes: > On Fri, Sep 05, 2003 at 04:47:22PM -0400, Andrew Gallatin wrote: > > > > I've been reading a little about TCP Segmentation Offload (aka TSO). > > We don't appear to support it, but at least 2 of our supported nics > > (e1000 and bge) apparently could support it. > > i believe there is more commercial hype than actual savings in doing > TCP Segmentation Offload. > > With delayed acks (or better, "ack every second packet"), > the sender's TCP typically sends out two > packets at a time. Without delayed acks, it is just one at a > time. So yes, you avoid looping in tcp_output() twice, but I think that the loop in tcp_output() is not such a big deal. IMHO, the bigger savings is from not making extra trips through the driver, and from allowing the adapter to perform a smaller number of large DMAs. Naturally, this is all just speculation until there's an actual implementation which can be profiled ;) Drew