From owner-freebsd-current Thu Oct 2 07:57:21 1997 Return-Path: <owner-freebsd-current> Received: (from root@localhost) by hub.freebsd.org (8.8.7/8.8.7) id HAA00188 for current-outgoing; Thu, 2 Oct 1997 07:57:21 -0700 (PDT) Received: from khavrinen.lcs.mit.edu (khavrinen.lcs.mit.edu [18.24.4.193]) by hub.freebsd.org (8.8.7/8.8.7) with ESMTP id HAA00176 for <current@FreeBSD.ORG>; Thu, 2 Oct 1997 07:57:16 -0700 (PDT) Received: (from wollman@localhost) by khavrinen.lcs.mit.edu (8.8.5/8.8.5) id KAA22895; Thu, 2 Oct 1997 10:56:31 -0400 (EDT) Date: Thu, 2 Oct 1997 10:56:31 -0400 (EDT) From: Garrett Wollman <wollman@khavrinen.lcs.mit.edu> Message-Id: <199710021456.KAA22895@khavrinen.lcs.mit.edu> To: Luigi Rizzo <luigi@labinfo.iet.unipi.it> Cc: wollman@khavrinen.lcs.mit.edu (Garrett Wollman), ache@nagual.pp.ru, current@FreeBSD.ORG Subject: Re: Which PCI Ethernet card is best for FreeBSD-current? In-Reply-To: <199710021223.NAA12138@labinfo.iet.unipi.it> References: <199710021304.JAA22567@khavrinen.lcs.mit.edu> <199710021223.NAA12138@labinfo.iet.unipi.it> Sender: owner-freebsd-current@FreeBSD.ORG X-Loop: FreeBSD.org Precedence: bulk <<On Thu, 2 Oct 1997 13:23:52 +0100 (MET), Luigi Rizzo <luigi@labinfo.iet.unipi.it> said: > Secondly the 2114x is used by many many vendors so you can find > these cards very cheap. Well, the Intel chip is pretty cheap, and in our tests performed better (had a lower DMA overhead) than the DEC chip. The trades are advertising a retail price of $65 each for the Intels (in quantity 5), and I know I can get a discount off of that. What's more, a lot of motherboards are starting to come with built in Fast Ethernet, and many of those (including all of the Intel-OEMed motherboards) have the 82557 chip on them. We have indeed had some trouble getting the actual documentation out of Intel; they seem to be reluctant to give out documents for this whizzo updateable microcode feature, but we don't much care about that (although it might be nice if we could program the DMA engine to speak mbuf directly). The overall programming model for this thing is just like every other Intel Ethernet chip ever made; a colleague here was able to implement the multicast filtering by almost directly copying the code out of the `ie' (82586/82596) driver. DEC chips have the bug that the Ethernet header has to be aligned on a longword boundary, which means that the protocol header---i.e., the part that actually matters---is guaranteed unaligned, thus necessitating an expensive copy operation or expensive unaligned accesses, depending on the CPU architecture. For someone building a router-type box, the standard designs involving either one is really inappropriate. What we would have liked (I no longer work on that project) would be a board with several NIC chips, a PCI-to-PCI bridge, and (most importantly) a good chunk of memory, on the order of a megabyte. We were easily able to DMA-starve the systems we were using for testing at that time (with slow Orion chipsets) using the workstation-type cards, since all of the traffic had to transit the (only) PCI bus twice. With a shared-memory design, the NIC and the CPU no longer have to compete for bus bandwith, and in a single-copy network implementation this is a big win. (It probably would also be helpful for SMP.) -GAWollman -- Garrett A. Wollman | O Siem / We are all family / O Siem / We're all the same wollman@lcs.mit.edu | O Siem / The fires of freedom Opinions not those of| Dance in the burning flame MIT, LCS, CRS, or NSA| - Susan Aglukark and Chad Irschick