Re: Athlon/AGP issue update

David S. Miller (davem@redhat.com)
Wed, 23 Jan 2002 02:24:41 -0800 (PST)


From: Denis Vlasenko <vda@port.imtp.ilyichevsk.odessa.ua>
Date: Wed, 23 Jan 2002 12:10:57 -0200

Did AMD tell in what 4M page a cache line was speculativery read ant then
written? I mean, there are only a few 4M pages used by Linux, which one had
'cacheable' bit wrongly set? It's all we need to know now.

See my other email, actually it appears AMD tells us this and my
previous analysis was wrong.

> The problem that has been experienced is caused by a speculative store
> instruction that is not ultimately executed. The logical address of the
> store is through the 4MB translation to physical memory also translated
> by GART and used by the AGP processor.
>
> The effect of the store is to write-allocate a cache line in the data
> cache and fill that cache line with data from the underlying physical
> memory. Because the line was write-allocated it is subsequently written
> back to physical memory even though the bits have not been changed by
> the processor. This write-back occurs when the cache-line is
> re-allocated based upon replacement policy and is far removed in time
> from the point at which the bits were read.

He can only mean by this that there is some branch protected store
(not taken) to the 4MB linear mappings used by the kernel (starting
at PAGE_OFFSET).

But the only thing I am still confused about, is what 4MB mappings
have to do with any of this. What I take from the description is that
the problem will still exist after 4MB mappings are disabled. What
prevents the processor from doing the speculative store to the
cacheable mappings once 4MB pages are disabled?

At best, I bet turning off 4MB pages makes the bug less likely.
It does not eliminate the chance to hit the bug.

So what it sounds like is that if there is any cacheable mapping
_WHATSOEVER_ to physical memory accessible by the GART, the problem
can occur due to a speculative store being cancelled.

A real fix would be much more involved, therefore.

In fact, we map the GART mapped memory to the user fully cacheable.
That would have to be fixed, plus we'd need to mark non-cacheable the
linear PAGE_OFFSET mappings of the kernel (4MB or not) as well.
-
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/