Restore all SPRs and CR up-front, these are longer latency
instructions. Move register restore around to maximise pairs of
adjacent loads (e.g., restore r0 next to r1).
Signed-off-by: Nicholas Piggin <npiggin@gmail.com>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
        mtxer   r9
        ld      r9,_LINK(r1)
        mtlr    r9
-       REST_GPR(0, r1)
+       ld      r9,_CCR(r1)
+       mtcr    r9
        REST_8GPRS(2, r1)
-       REST_GPR(10, r1)
-       ld      r11,_CCR(r1)
-       mtcr    r11
-       REST_GPR(11, r1)
-       REST_2GPRS(12, r1)
+       REST_4GPRS(10, r1)
+       REST_GPR(0, r1)
        /* restore original r1. */
        ld      r1,GPR1(r1)
        RFI_TO_USER_OR_KERNEL
        mtxer   r9;                                     \
        ld      r9,_LINK(r1);                           \
        mtlr    r9;                                     \
-       REST_GPR(0, r1);                                \
+       ld      r9,_CCR(r1);                            \
+       mtcr    r9;                                     \
        REST_8GPRS(2, r1);                              \
-       REST_GPR(10, r1);                               \
-       ld      r11,_CCR(r1);                           \
-       mtcr    r11;                                    \
-       REST_GPR(11, r1);                               \
-       REST_2GPRS(12, r1);                             \
+       REST_4GPRS(10, r1);                             \
+       REST_GPR(0, r1);                                \
        /* restore original r1. */                      \
        ld      r1,GPR1(r1)
 
        mtxer   r9
        ld      r9,_LINK(r1)
        mtlr    r9
-       REST_GPR(0, r1)
+       ld      r9,_CCR(r1)
+       mtcr    r9
        REST_8GPRS(2, r1)
-       REST_GPR(10, r1)
-       ld      r11,_CCR(r1)
-       REST_2GPRS(12, r1)
-       mtcr    r11
-       REST_GPR(11, r1)
+       REST_4GPRS(10, r1)
+       REST_GPR(0, r1)
        ld      r1,GPR1(r1)
        HRFI_TO_USER_OR_KERNEL
 
        mtxer   r9
        ld      r9,_LINK(r1)
        mtlr    r9
-       REST_GPR(0, r1)
+       ld      r9,_CCR(r1)
+       mtcr    r9
        REST_8GPRS(2, r1)
-       REST_GPR(10, r1)
-       ld      r11,_CCR(r1)
-       REST_2GPRS(12, r1)
-       mtcr    r11
-       REST_GPR(11, r1)
+       REST_4GPRS(10, r1)
+       REST_GPR(0, r1)
        ld      r1,GPR1(r1)
 
        /*