> -----Original Message----- > From: Russell King - ARM Linux [mailto:linux@xxxxxxxxxxxxxxxx] > Sent: Tuesday, July 27, 2010 7:51 PM > To: Shilimkar, Santosh > Cc: Mankad, Maulik Ojas; linux-usb@xxxxxxxxxxxxxxx; linux- > omap@xxxxxxxxxxxxxxx; linux-arm-kernel@xxxxxxxxxxxxxxxxxxx > Subject: Re: Issue with file transfers to a mass storage device on SMP > system > > On Tue, Jul 27, 2010 at 07:44:20PM +0530, Shilimkar, Santosh wrote: > > OMAP doesn't override because the default definition is good enough now. > > Ah, good to know. > > > Shouldn't below work ? > > #elif __LINUX_ARM_ARCH__ >= 7 || defined(CONFIG_SMP) > > #define mb() do { dsb(); outer_sync(); } while (0) > > #define rmb() dmb() > > #define wmb() mb() > > Yes, that should get it out of the CPU and caches, and onto the bus. > However, I need to check up exactly what a write to the L2x0 SYNC > register gives us... > > > > As the OMAP mandatory barrier implementation isn't in mainline, I > can't > > > comment on that. However, I feel certain that this is where the > problem > > > is. > > > > Do you think with above setting it should be still a problem ? I mean > > with " CONFIG_ARCH_HAS_BARRIERS" not enabled > > Well, the question is whether getting it out of the outer cache (and > performing an effective memory barrier to the outer cache) is sufficient > for the DMA agent to see the data. > > Could the data be sitting somewhere in the interconnect between the > CPU pushing it out of the outer cache and the DMA agent trying to read > from memory? Once it's pushed out of L2X WB, it will hit the memory. Just to give an additional data point, with CATC analyzer what we see that only those 16 bytes CDB are 0x0. This buffer was memset to 0x0 just before the memcpy. I am just wondering who will issue a barrier(wmb) on this buffer before DMA start if we don't use dma-mapping APIs? May be for dma_alloc_coherent buffers, we need to explicitly issue the barrier. Is that the expectation? If yes then the work-around we used seems to the fix. Regards, Santosh -- To unsubscribe from this list: send the line "unsubscribe linux-omap" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html