From owner-freebsd-hackers Tue Feb 4 09:18:40 1997 Return-Path: Received: (from root@localhost) by freefall.freebsd.org (8.8.5/8.8.5) id JAA29278 for hackers-outgoing; Tue, 4 Feb 1997 09:18:40 -0800 (PST) Received: from darkstar (dialin2.anlw.anl.gov [141.221.252.102]) by freefall.freebsd.org (8.8.5/8.8.5) with SMTP id JAA29269 for ; Tue, 4 Feb 1997 09:18:37 -0800 (PST) Received: (from cmott@localhost) by darkstar (8.6.12/8.6.12) id KAA08767; Tue, 4 Feb 1997 10:17:46 -0700 Date: Tue, 4 Feb 1997 10:17:41 -0700 (MST) From: Charles Mott X-Sender: cmott@darkstar To: Brian Somers cc: Julian Elischer , Eivind Eklund , Brian Somers , Ari Suutari , hackers@freebsd.org Subject: Re: Single socket version of natd In-Reply-To: <199702041659.QAA00486@ui-gate.utell.co.uk> Message-ID: MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII Sender: owner-hackers@freebsd.org X-Loop: FreeBSD.org Precedence: bulk > If we leave it in both ppp & natd, can we add a (third) arg to > PacketAlias{In,Out}() that tells it not to do anything with the > ip_sum ? If it's reading raw packets from a wire (with ppp), > the sum may be wrong (this has been discussed before) and > we want to leave incorrect the sum alone, but with natd, it's a > terrible waste to have the kernel code zero the sum, have natd > re-calculate it, have PacketAliasIn() check it, and then probably > re-calculate it again (if anything's changed). > > With a "leave the sum alone option", natd could pass the packet > with the zero'd ip_sum to PacketAliasIn() and know that it has > to calculate it itself afterwards.... Why does the kernel zero the checksum? IP checksum has never been much of a problem, because it is only 20 bytes or so. It is the TCP, UDP and ICMP layers where efficiency pays off. In any event, all IP checksums modifications in alias*.c are now differential, so calculations are only made for packet data which has been altered. Unlike older versions, there is no checking and recomputation of the complete IP header. Charles Mott