[<prev] [next>] [day] [month] [year] [list]
Message-id: <47EB2D67.9090609@shaw.ca>
Date: Wed, 26 Mar 2008 23:15:19 -0600
From: Robert Hancock <hancockr@...w.ca>
To: Stefan Richter <stefanr@...6.in-berlin.de>
Cc: linux-kernel@...r.kernel.org
Subject: Re: memory-barriers.txt: cache coherency vs mmio
Stefan Richter wrote:
> The subject section in memory-barriers.txt says:
>
> "[...] MMIO accesses may, in effect, overtake accesses to cached memory
> that were emitted earlier. A memory barrier isn't sufficient in such a
> case, but rather the cache must be flushed between the cached memory
> write and the MMIO access if the two are in any way dependent."
>
> And the lowly driver programmer immediately asks:
> How do I flush the cache?
>
> In particular, do I have to do anyhing between
>
> coherent_dma_buffer->datum = something;
>
> writel(YOU_CAN_START_DMA_NOW, register);
>
> Thanks,
That part of the document seems kind of bogus to me. Or rather, if it's
true and there are architectures where ordering between normal memory
writes and MMIO is not ensured even with wmb(), that's the bogus part.
Driver authors should not have to deal with that sort of thing.
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists