From owner-freebsd-current@FreeBSD.ORG Tue Jan 10 22:28:16 2012 Return-Path: Delivered-To: freebsd-current@FreeBSD.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id 77C7C1065670 for ; Tue, 10 Jan 2012 22:28:16 +0000 (UTC) (envelope-from avg@FreeBSD.org) Received: from citadel.icyb.net.ua (citadel.icyb.net.ua [212.40.38.140]) by mx1.freebsd.org (Postfix) with ESMTP id C401D8FC0A for ; Tue, 10 Jan 2012 22:28:15 +0000 (UTC) Received: from porto.starpoint.kiev.ua (porto-e.starpoint.kiev.ua [212.40.38.100]) by citadel.icyb.net.ua (8.8.8p3/ICyb-2.3exp) with ESMTP id AAA07363; Wed, 11 Jan 2012 00:28:10 +0200 (EET) (envelope-from avg@FreeBSD.org) Received: from localhost ([127.0.0.1]) by porto.starpoint.kiev.ua with esmtp (Exim 4.34 (FreeBSD)) id 1RkkAs-00082R-IJ; Wed, 11 Jan 2012 00:28:10 +0200 Message-ID: <4F0CBB78.502@FreeBSD.org> Date: Wed, 11 Jan 2012 00:28:08 +0200 From: Andriy Gapon User-Agent: Mozilla/5.0 (X11; FreeBSD amd64; rv:9.0) Gecko/20111222 Thunderbird/9.0 MIME-Version: 1.0 To: mj@feral.com References: <4F0C9D14.60705@FreeBSD.org> <4F0CAD03.1090605@FreeBSD.org> In-Reply-To: X-Enigmail-Version: undefined Content-Type: text/plain; charset=ISO-8859-1 Content-Transfer-Encoding: 7bit Cc: FreeBSD current Subject: Re: bus dma: a flag/quirk for page zero X-BeenThere: freebsd-current@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: Discussions about the use of FreeBSD-current List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Tue, 10 Jan 2012 22:28:16 -0000 on 11/01/2012 00:23 Matthew Jacob said the following: >>> At the very least, require bounce buffers. >> >> Not sure if I got this suggestion in this terse form. >> Could you please explain? > > Physical address zero can be DMA'd, but via bounce buffers. > bcopy from address zero up through a pagesize to a bounce buffer, do the dma > from there (read case), write case the opposite order Ah, right. I think that that's what the patch tries to do (among other things) if the flag is set. -- Andriy Gapon