From owner-freebsd-hackers Thu Jun 3 9: 6: 1 1999 Delivered-To: freebsd-hackers@freebsd.org Received: from panzer.plutotech.com (panzer.plutotech.com [206.168.67.125]) by hub.freebsd.org (Postfix) with ESMTP id 8058E14FF8 for ; Thu, 3 Jun 1999 09:05:59 -0700 (PDT) (envelope-from ken@panzer.plutotech.com) Received: (from ken@localhost) by panzer.plutotech.com (8.9.3/8.8.5) id KAA93292; Thu, 3 Jun 1999 10:05:46 -0600 (MDT) From: "Kenneth D. Merry" Message-Id: <199906031605.KAA93292@panzer.plutotech.com> Subject: Re: The choice of MAXPHYS In-Reply-To: <19990603172907.A20792@hal.mpn.cp.philips.com> from Jos Backus at "Jun 3, 1999 05:29:07 pm" To: Jos.Backus@nl.origin-it.com (Jos Backus) Date: Thu, 3 Jun 1999 10:05:46 -0600 (MDT) Cc: zzhang@cs.binghamton.edu (Zhihui Zhang), freebsd-hackers@FreeBSD.ORG X-Mailer: ELM [version 2.4ME+ PL54 (25)] MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: owner-freebsd-hackers@FreeBSD.ORG Precedence: bulk X-Loop: FreeBSD.ORG Jos Backus wrote... > On Thu, Jun 03, 1999 at 10:40:10AM -0400, Zhihui Zhang wrote: > > The value of MAXPHYS is chosen to be 64K for the maximum raw I/O transfer > > size. I am wondering why it is not set larger. > > Just a guess: maybe this has something to do with DMA address counters on ISA > cards being 16 bit? (ducks) Or is this total nonsense? :-) Actually, MAXPHYS is 128K, not 64K. This is from sys/i386/include/param.h: #define DFLTPHYS (64 * 1024) /* default max raw I/O transfer size */ #define MAXPHYS (128 * 1024) /* max raw I/O transfer size */ MAXPHYS was 64K for a good while, and then John Dyson changed it to 128K in revision 1.42 of param.h (early '98). I think the 64K value may have been chosen because cards like the Adaptec 1542 can't handle more than that. That's the reason the CAM passthrough driver won't allow transfers larger than 64K in most cases. We plan on implementing a facility at some point that will allow userland applications to ask what the maximum transfer size is for a given path. At some point we should implement some sort of buffer chaining mechanism or something else that would allow larger I/O sizes for devices that support it. Ken -- Kenneth Merry ken@plutotech.com To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-hackers" in the body of the message