From mboxrd@z Thu Jan 1 00:00:00 1970 From: Takashi Iwai Subject: Re: [BUG] pgprot_noncached() is -NOT- safe for mapping vmalloc buffers into userspace Date: Fri, 25 Mar 2011 14:17:59 +0100 Message-ID: References: <1301005008.2402.453.camel@pasglop> <1301044533.2402.478.camel@pasglop> <1301048606.2402.486.camel@pasglop> Mime-Version: 1.0 (generated by SEMI 1.14.6 - "Maruoka") Content-Type: text/plain; charset=US-ASCII Return-path: Received: from cantor2.suse.de ([195.135.220.15]:42248 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752059Ab1CYNSD (ORCPT ); Fri, 25 Mar 2011 09:18:03 -0400 In-Reply-To: <1301048606.2402.486.camel@pasglop> Sender: linux-arch-owner@vger.kernel.org List-ID: To: Benjamin Herrenschmidt Cc: "linux-kernel@vger.kernel.org" , linuxppc-dev , linux-arch@vger.kernel.org, Matthew Evans At Fri, 25 Mar 2011 21:23:26 +1100, Benjamin Herrenschmidt wrote: > > On Fri, 2011-03-25 at 11:12 +0100, Takashi Iwai wrote: > > At Fri, 25 Mar 2011 20:15:33 +1100, > > Benjamin Herrenschmidt wrote: > > > > > > > > We > > > > > must also make sure we don't go down that path for vmalloc memory > > > > > though. > > > > > > > > Yes. > > > > > > I haven't actually checked, but I assume that the test > > > > > > substream->dma_buffer.dev.type == SNDRV_DMA_TYPE_DEV > > > > > > In snd_pcm_default_mmap() takes care of that, please correct me if > > > I'm wrong in which case we'll need something else there. > > > > Well, in the case of usb-audio, it's not handled via > > dma_mmap_coherent(), as the page isn't allocated via > > dma_alloc_coherent() but vmalloc(). > > Right, I just wanted to make sure I was right to assume that a page > allocated by vmalloc() was going to fail the above test in > snd_pcm_default_mmap() and thus -not- get into dma_mmap_coherent()... > just double checking as I'm not totally familiar with the intricacies of > the pcm code :-) > > > The bad commit was to overcome some problems on SH platform, IIRC, > > when it's used with dmix -- i.e. concurrent accesses on the mmapped > > buffer from multiple processes. But, this looks obviously like a > > wrong approach. > > Is this a vivt architecture ? Maybe enforcing some restrictions on the > virtual addresses so they hit the same cache congruence classes ? Possibly, yes. But we need to re-test the problem first with the recent kernel. > > Actually, the buffer allocated there in usb-audio is an intermediate > > buffer, that isn't directly transferred to hardware. We may need a > > bit more consideration what is the best way to solve that issue (if > > it's still really present). > > Right. I wouldn't expect vmalloc stuff to hit HW in most cases anyways, > though I do wonder why you don't pass the buffer directly to the HCD and > avoid that intermediate step but that's a completely different > question :-) The direct buffer was used partly in the older versions. But there was a problem in the accuracy of the buffer playback position, so this was switched to full double-buffering. thanks, Takashi