/* * 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