powerpc/powernv: copy/paste - Mask SO bit in CR
authorHaren Myneni <haren@us.ibm.com>
Mon, 4 Jun 2018 08:33:38 +0000 (18:33 +1000)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 3 Jul 2018 09:24:50 +0000 (11:24 +0200)
commit 75743649064ec0cf5ddd69f240ef23af66dde16e upstream.

NX can set the 3rd bit in CR register for XER[SO] (Summary overflow)
which is not related to paste request. The current paste function
returns failure for a successful request when this bit is set. So mask
this bit and check the proper return status.

Fixes: 2392c8c8c045 ("powerpc/powernv/vas: Define copy/paste interfaces")
Cc: stable@vger.kernel.org # v4.14+
Signed-off-by: Haren Myneni <haren@us.ibm.com>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
arch/powerpc/platforms/powernv/copy-paste.h

index c9a50362343107b079875233faac064301435084..e9a6c35f8a297a351335a1d185217bfba12d12af 100644 (file)
@@ -42,5 +42,6 @@ static inline int vas_paste(void *paste_address, int offset)
                : "b" (offset), "b" (paste_address)
                : "memory", "cr0");
 
-       return (cr >> CR0_SHIFT) & CR0_MASK;
+       /* We mask with 0xE to ignore SO */
+       return (cr >> CR0_SHIFT) & 0xE;
 }