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? -- 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