| /* |
| * Copyright 2014, Michael Ellerman, IBM Corp. |
| * Licensed under GPLv2. |
| */ |
| |
| #include <ppc-asm.h> |
| |
| .text |
| |
| FUNC_START(core_busy_loop) |
| stdu %r1, -168(%r1) |
| std r14, 160(%r1) |
| std r15, 152(%r1) |
| std r16, 144(%r1) |
| std r17, 136(%r1) |
| std r18, 128(%r1) |
| std r19, 120(%r1) |
| std r20, 112(%r1) |
| std r21, 104(%r1) |
| std r22, 96(%r1) |
| std r23, 88(%r1) |
| std r24, 80(%r1) |
| std r25, 72(%r1) |
| std r26, 64(%r1) |
| std r27, 56(%r1) |
| std r28, 48(%r1) |
| std r29, 40(%r1) |
| std r30, 32(%r1) |
| std r31, 24(%r1) |
| |
| li r3, 0x3030 |
| std r3, -96(%r1) |
| li r4, 0x4040 |
| std r4, -104(%r1) |
| li r5, 0x5050 |
| std r5, -112(%r1) |
| li r6, 0x6060 |
| std r6, -120(%r1) |
| li r7, 0x7070 |
| std r7, -128(%r1) |
| li r8, 0x0808 |
| std r8, -136(%r1) |
| li r9, 0x0909 |
| std r9, -144(%r1) |
| li r10, 0x1010 |
| std r10, -152(%r1) |
| li r11, 0x1111 |
| std r11, -160(%r1) |
| li r14, 0x1414 |
| std r14, -168(%r1) |
| li r15, 0x1515 |
| std r15, -176(%r1) |
| li r16, 0x1616 |
| std r16, -184(%r1) |
| li r17, 0x1717 |
| std r17, -192(%r1) |
| li r18, 0x1818 |
| std r18, -200(%r1) |
| li r19, 0x1919 |
| std r19, -208(%r1) |
| li r20, 0x2020 |
| std r20, -216(%r1) |
| li r21, 0x2121 |
| std r21, -224(%r1) |
| li r22, 0x2222 |
| std r22, -232(%r1) |
| li r23, 0x2323 |
| std r23, -240(%r1) |
| li r24, 0x2424 |
| std r24, -248(%r1) |
| li r25, 0x2525 |
| std r25, -256(%r1) |
| li r26, 0x2626 |
| std r26, -264(%r1) |
| li r27, 0x2727 |
| std r27, -272(%r1) |
| li r28, 0x2828 |
| std r28, -280(%r1) |
| li r29, 0x2929 |
| std r29, -288(%r1) |
| li r30, 0x3030 |
| li r31, 0x3131 |
| |
| li r3, 0 |
| 0: addi r3, r3, 1 |
| cmpwi r3, 100 |
| blt 0b |
| |
| /* Return 1 (fail) unless we get through all the checks */ |
| li r3, 1 |
| |
| /* Check none of our registers have been corrupted */ |
| cmpwi r4, 0x4040 |
| bne 1f |
| cmpwi r5, 0x5050 |
| bne 1f |
| cmpwi r6, 0x6060 |
| bne 1f |
| cmpwi r7, 0x7070 |
| bne 1f |
| cmpwi r8, 0x0808 |
| bne 1f |
| cmpwi r9, 0x0909 |
| bne 1f |
| cmpwi r10, 0x1010 |
| bne 1f |
| cmpwi r11, 0x1111 |
| bne 1f |
| cmpwi r14, 0x1414 |
| bne 1f |
| cmpwi r15, 0x1515 |
| bne 1f |
| cmpwi r16, 0x1616 |
| bne 1f |
| cmpwi r17, 0x1717 |
| bne 1f |
| cmpwi r18, 0x1818 |
| bne 1f |
| cmpwi r19, 0x1919 |
| bne 1f |
| cmpwi r20, 0x2020 |
| bne 1f |
| cmpwi r21, 0x2121 |
| bne 1f |
| cmpwi r22, 0x2222 |
| bne 1f |
| cmpwi r23, 0x2323 |
| bne 1f |
| cmpwi r24, 0x2424 |
| bne 1f |
| cmpwi r25, 0x2525 |
| bne 1f |
| cmpwi r26, 0x2626 |
| bne 1f |
| cmpwi r27, 0x2727 |
| bne 1f |
| cmpwi r28, 0x2828 |
| bne 1f |
| cmpwi r29, 0x2929 |
| bne 1f |
| cmpwi r30, 0x3030 |
| bne 1f |
| cmpwi r31, 0x3131 |
| bne 1f |
| |
| /* Load junk into all our registers before we reload them from the stack. */ |
| li r3, 0xde |
| li r4, 0xad |
| li r5, 0xbe |
| li r6, 0xef |
| li r7, 0xde |
| li r8, 0xad |
| li r9, 0xbe |
| li r10, 0xef |
| li r11, 0xde |
| li r14, 0xad |
| li r15, 0xbe |
| li r16, 0xef |
| li r17, 0xde |
| li r18, 0xad |
| li r19, 0xbe |
| li r20, 0xef |
| li r21, 0xde |
| li r22, 0xad |
| li r23, 0xbe |
| li r24, 0xef |
| li r25, 0xde |
| li r26, 0xad |
| li r27, 0xbe |
| li r28, 0xef |
| li r29, 0xdd |
| |
| ld r3, -96(%r1) |
| cmpwi r3, 0x3030 |
| bne 1f |
| ld r4, -104(%r1) |
| cmpwi r4, 0x4040 |
| bne 1f |
| ld r5, -112(%r1) |
| cmpwi r5, 0x5050 |
| bne 1f |
| ld r6, -120(%r1) |
| cmpwi r6, 0x6060 |
| bne 1f |
| ld r7, -128(%r1) |
| cmpwi r7, 0x7070 |
| bne 1f |
| ld r8, -136(%r1) |
| cmpwi r8, 0x0808 |
| bne 1f |
| ld r9, -144(%r1) |
| cmpwi r9, 0x0909 |
| bne 1f |
| ld r10, -152(%r1) |
| cmpwi r10, 0x1010 |
| bne 1f |
| ld r11, -160(%r1) |
| cmpwi r11, 0x1111 |
| bne 1f |
| ld r14, -168(%r1) |
| cmpwi r14, 0x1414 |
| bne 1f |
| ld r15, -176(%r1) |
| cmpwi r15, 0x1515 |
| bne 1f |
| ld r16, -184(%r1) |
| cmpwi r16, 0x1616 |
| bne 1f |
| ld r17, -192(%r1) |
| cmpwi r17, 0x1717 |
| bne 1f |
| ld r18, -200(%r1) |
| cmpwi r18, 0x1818 |
| bne 1f |
| ld r19, -208(%r1) |
| cmpwi r19, 0x1919 |
| bne 1f |
| ld r20, -216(%r1) |
| cmpwi r20, 0x2020 |
| bne 1f |
| ld r21, -224(%r1) |
| cmpwi r21, 0x2121 |
| bne 1f |
| ld r22, -232(%r1) |
| cmpwi r22, 0x2222 |
| bne 1f |
| ld r23, -240(%r1) |
| cmpwi r23, 0x2323 |
| bne 1f |
| ld r24, -248(%r1) |
| cmpwi r24, 0x2424 |
| bne 1f |
| ld r25, -256(%r1) |
| cmpwi r25, 0x2525 |
| bne 1f |
| ld r26, -264(%r1) |
| cmpwi r26, 0x2626 |
| bne 1f |
| ld r27, -272(%r1) |
| cmpwi r27, 0x2727 |
| bne 1f |
| ld r28, -280(%r1) |
| cmpwi r28, 0x2828 |
| bne 1f |
| ld r29, -288(%r1) |
| cmpwi r29, 0x2929 |
| bne 1f |
| |
| /* Load 0 (success) to return */ |
| li r3, 0 |
| |
| 1: ld r14, 160(%r1) |
| ld r15, 152(%r1) |
| ld r16, 144(%r1) |
| ld r17, 136(%r1) |
| ld r18, 128(%r1) |
| ld r19, 120(%r1) |
| ld r20, 112(%r1) |
| ld r21, 104(%r1) |
| ld r22, 96(%r1) |
| ld r23, 88(%r1) |
| ld r24, 80(%r1) |
| ld r25, 72(%r1) |
| ld r26, 64(%r1) |
| ld r27, 56(%r1) |
| ld r28, 48(%r1) |
| ld r29, 40(%r1) |
| ld r30, 32(%r1) |
| ld r31, 24(%r1) |
| addi %r1, %r1, 168 |
| blr |