ARM: proc-v7: Retry uncached stmia if necessary
authorPhil Elwell <phil@raspberrypi.com>
Mon, 20 Sep 2021 10:59:23 +0000 (11:59 +0100)
committerPhil Elwell <8911409+pelwell@users.noreply.github.com>
Mon, 20 Sep 2021 16:06:58 +0000 (17:06 +0100)
commit3e1698ed5013c1054e3dbf8a9fcd3a8549a95ece
tree7dc5f0cb45e0b53ca99e32c83f2c45238895b241
parent36d449a94f35622737b08fb10a40b8f3e5255ba2
ARM: proc-v7: Retry uncached stmia if necessary

A failure of some CPU cores to come online has been traced to the
failure of a stm instruction while the cache is disabled. The symptom
is that the saved values read back as zeroes, a catastrophic error since
one of the values is a return address.

This patch forces a readback and retry until the correct value is
returned,

Notes:

At this stage in the boot process the core is running with its cache
disabled. Before enabling the cache its contents must be explicitly
invalidated, a process that requires quite a few registers that the
caller must preserve. Evidence suggests that something is writing a
block of zeroes over that space at a time when all other cores should
be idle, possibly some kind of write-combiner, and retrying is an
attempt to avoid the problem.

The previous attempted fix (forcing the accesses to only be 4-byte
aligned) appears to have only worked for a while and likely for less
obvious reasons such as a change in code alignment.

See: https://github.com/Hexxeh/rpi-firmware/issues/232

Signed-off-by: Phil Elwell <phil@raspberrypi.com>
arch/arm/mm/proc-v7.S