Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1750708AbWA1TdF (ORCPT ); Sat, 28 Jan 2006 14:33:05 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1750706AbWA1TdF (ORCPT ); Sat, 28 Jan 2006 14:33:05 -0500 Received: from [85.8.13.51] ([85.8.13.51]:34779 "EHLO smtp.drzeus.cx") by vger.kernel.org with ESMTP id S1750708AbWA1TdB (ORCPT ); Sat, 28 Jan 2006 14:33:01 -0500 Message-ID: <43DBC6E2.4000305@drzeus.cx> Date: Sat, 28 Jan 2006 20:32:50 +0100 From: Pierre Ossman User-Agent: Thunderbird 1.5 (X11/20060112) MIME-Version: 1.0 To: Jens Axboe CC: LKML Subject: Re: How to map high memory for block io References: <20060127104321.GE4311@suse.de> <43DA0E97.5030504@drzeus.cx> <20060127194318.GA1433@flint.arm.linux.org.uk> <43DA7CD1.4040301@drzeus.cx> <20060127201458.GA2767@flint.arm.linux.org.uk> <20060127202206.GH9068@suse.de> <20060127202646.GC2767@flint.arm.linux.org.uk> <43DA84B2.8010501@drzeus.cx> <43DA97A3.4080408@drzeus.cx> <20060127225428.GD2767@flint.arm.linux.org.uk> <20060128191759.GC9750@suse.de> In-Reply-To: <20060128191759.GC9750@suse.de> Content-Type: text/plain; charset=ISO-8859-1 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1760 Lines: 51 Jens Axboe wrote: > On Fri, Jan 27 2006, Russell King wrote: > >> On Fri, Jan 27, 2006 at 10:58:59PM +0100, Pierre Ossman wrote: >> >>> Test done here, few minutes ago. Added this to the wbsd driver in its >>> kmap routine: >>> >>> if ((host->cur_sg->offset + host->cur_sg->length) > PAGE_SIZE) >>> printk(KERN_DEBUG "wbsd: Big sg: %d, %d\n", >>> host->cur_sg->offset, host->cur_sg->length); >>> >>> got: >>> >>> [17385.425389] wbsd: Big sg: 0, 8192 >>> [17385.436849] wbsd: Big sg: 0, 7168 >>> [17385.436859] wbsd: Big sg: 0, 7168 >>> [17385.454029] wbsd: Big sg: 2560, 5632 >>> [17385.454216] wbsd: Big sg: 2560, 5632 >>> >> Jens - what's going on? These look like invalid sg entries to me. >> >> If they are supposed to be like that, there will be additional problems >> for block drivers ensuring cache coherency on PIO. >> > > No freaking idea, must be coming out of the pci dma mapping. The IOMMU > doing funky stuff? How are these sg lists mapped? > > This is an ISA (i.e. platform) device, so no PCI involved. There is also no IOMMU on this system. As for the mapping there doesn't seem to be anything fancy about it (this is Russell's territory so this is just my naive view of it). The queue is set up in mmc_queue.c and the sg is mapped using blk_rq_map_sg() in mmc_block.c. But if sg entries are not supposed to cross pages, then I guess that means that any transfer is limited in size by PAGE_SIZE * min(max_phys_seg, max_hw_seg), right? Rgds Pierre - To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/