From owner-freebsd-current@FreeBSD.ORG Sat Sep 5 07:12:00 2009 Return-Path: Delivered-To: current@FreeBSD.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id C65161065670; Sat, 5 Sep 2009 07:12:00 +0000 (UTC) (envelope-from dillon@apollo.backplane.com) Received: from apollo.backplane.com (apollo.backplane.com [216.240.41.2]) by mx1.freebsd.org (Postfix) with ESMTP id 3F7C88FC17; Sat, 5 Sep 2009 07:12:00 +0000 (UTC) Received: from apollo.backplane.com (localhost [127.0.0.1]) by apollo.backplane.com (8.14.2/8.14.1) with ESMTP id n857BwmK076833; Sat, 5 Sep 2009 00:11:58 -0700 (PDT) Received: (from dillon@localhost) by apollo.backplane.com (8.14.2/8.13.4/Submit) id n857Btwx076830; Sat, 5 Sep 2009 00:11:55 -0700 (PDT) Date: Sat, 5 Sep 2009 00:11:55 -0700 (PDT) From: Matthew Dillon Message-Id: <200909050711.n857Btwx076830@apollo.backplane.com> To: Alexander Motin References: <4AA03346.5010608@FreeBSD.org> <200909032210.n83MA67F059073@apollo.backplane.com> <200909042314.n84NEMAS072077@apollo.backplane.com> <4AA1FA41.1030804@FreeBSD.org> Cc: Ryan Rogers , current@FreeBSD.org Subject: Re: non aligned DMA transfer attempted 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: Sat, 05 Sep 2009 07:12:00 -0000 :> :> By the way Scott, do you honestly believe that idiotic one-line :> answers just as a means to try to screw over my postings are :> appropriate for someone of your standing in the FreeBSD community? : :His answer is short, but correct, because all ATA drivers do use BUSDMA. :And as I have already said, BUSDMA manages proper alignment there, by :implementing bounce buffers. : :-- :Alexander Motin Perhaps, but it is hardly a civilized conversation. If he is going to act like an asshole on the lists, then he can stew in his own juices for all I care, or not post at all. But acting in such an infantile manner is something I will not tolerate. I really don't care if he maps me out of his mail server or not, but playing the 'last word' game is something only a 5-year-old would do and he's a lot older then 5 years old. I do see the FBsd ATA driver is using busdma, so I was incorrect there. It is also preallocating bounce buffers on a per-slot basis, so you shouldn't get allocation failures later on at load-time (though it's a bit unclear if the bounce zone limitations can cause a later bus dma load to fail if insufficient bounce buffers are available, and allocating bounce buffers per slot can lead to a large multiplication of wired memory reserved). I guess it will work even if it isn't pretty. I think there was another issue with ATAPI transfers... something related to the DMA having to be in multiples of 16 bytes (on older chipsets anyway), but SCSI has no such restriction so pass-through commands would not always be properly encapsulated into an ATAPI transfer. I can't find a code reference for it but I remember there being some sort of related issue. In anycase, the bounce zone mess was why I eventually started doing at least a minimal alignment closer to the user<->kernel interface, where the kernel could safely allocated memory M_WAITOK. -Matt Matthew Dillon