ARM: domains: add memory dependencies to get_domain/set_domain
authorRussell King <rmk+kernel@arm.linux.org.uk>
Fri, 11 Sep 2015 07:34:52 +0000 (08:34 +0100)
committerRussell King <rmk+kernel@arm.linux.org.uk>
Fri, 11 Sep 2015 15:08:18 +0000 (16:08 +0100)
commit6e8f580d1fcc18e290713984c379cb97131c015a
treef4dc7a3e4310c64cacacae02d8c20476bc6f4c37
parent716ff1921a86c637b8875c7bb312fc6755fa9300
ARM: domains: add memory dependencies to get_domain/set_domain

We need to have memory dependencies on get_domain/set_domain to avoid
the compiler over-optimising these inline assembly instructions.

Loads/stores must not be reordered across a set_domain(), so introduce
a compiler barrier for that assembly.

The value of get_domain() must not be cached across a set_domain(), but
we still want to allow the compiler to optimise it away.  Introduce a
dependency on current_thread_info()->cpu_domain to avoid this; the new
memory clobber in set_domain() should therefore cause the compiler to
re-load this.  The other advantage of using this is we should have its
address in the register set already, or very soon after at most call
sites.

Tested-by: Robert Jarzmik <robert.jarzmik@free.fr>
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
arch/arm/include/asm/domain.h