MIPS: CPS: use 32b accesses to GCRs
authorPaul Burton <paul.burton@imgtec.com>
Wed, 5 Aug 2015 22:42:35 +0000 (15:42 -0700)
committerRalf Baechle <ralf@linux-mips.org>
Fri, 28 Aug 2015 09:48:22 +0000 (11:48 +0200)
commit90996511187d6282db6d02d3f97006b4dbb5c457
tree58ac2c5b6f3b8e9105ecc02168023f442be9b2e0
parentc13dcf9f2d6f5f06ef1bf79ec456df614c5e058b
MIPS: CPS: use 32b accesses to GCRs

Commit b677bc03d757 ("MIPS: cps-vec: Use macros for various arithmetics
and memory operations") replaced various load & store instructions
through cps-vec.S with the PTR_L & PTR_S macros. However it was somewhat
overzealous in doing so for CM GCR accesses, since the bit width of the
CM doesn't necessarily match that of the CPU. The registers accessed
(GCR_CL_COHERENCE & GCR_CL_ID) should be safe to simply always access
using 32b instructions, so do so in order to avoid issues when using a
32b CM with a 64b CPU.

Signed-off-by: Paul Burton <paul.burton@imgtec.com>
Cc: Markos Chandras <markos.chandras@imgtec.com>
Cc: <stable@vger.kernel.org> # 3.16+
Cc: linux-mips@linux-mips.org
Cc: linux-kernel@vger.kernel.org
Cc: James Hogan <james.hogan@imgtec.com>
Patchwork: https://patchwork.linux-mips.org/patch/10864/
Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
arch/mips/kernel/cps-vec.S