X-Git-Url: http://nsz.repo.hu/git/?p=musl;a=blobdiff_plain;f=src%2Fldso%2Fpowerpc%2Fstart.s;fp=src%2Fldso%2Fpowerpc%2Fstart.s;h=ac2c20c84eb45a2d819c86678cfcf517e691cc75;hp=d2060e3d4459e2ba3e981f02dbeca8dcaea5975a;hb=d1bf452d75bef2b098765fe94b9ccb24cdb6568b;hpb=e7257d3e63b10d4725450c383e94cdbb997d9151 diff --git a/src/ldso/powerpc/start.s b/src/ldso/powerpc/start.s index d2060e3d..ac2c20c8 100644 --- a/src/ldso/powerpc/start.s +++ b/src/ldso/powerpc/start.s @@ -1,23 +1,22 @@ # FIXME : does not work, the small data array needs to be relocated. # see elfspec_ppc.pdf, page 76-84 - .global _start - .type _start,@function + .global _start + .type _start,@function _start: - mr 9, 1 # Save the original stack pointer. - clrrwi 1, 1, 4 # Align the stack to 16 bytes. - lis 13, _SDA_BASE_@ha # r13 points to the small data area. - addi 13, 13, _SDA_BASE_@l - li 0, 0 # Zero the frame pointer. - lwz 3, 0(9) # and argc... - addi 4, 9, 4 # and argv ... - mtlr 0 # Clear the link register. - # Go to the musl dynamic linker entry point. - bl __dynlink - cmpi 4, 0, 3, 1 # Check for a 1. - bne 4, . # Stay here - mtlr 3 # Set the link address... - li 3, 0 - blr # and go. - .end _start - .size _start, .-_start - + mr 9, 1 # Save the original stack pointer. + clrrwi 1, 1, 4 # Align the stack to 16 bytes. + lis 13, _SDA_BASE_@ha # r13 points to the small data area. + addi 13, 13, _SDA_BASE_@l + li 0, 0 # Zero the frame pointer. + lwz 3, 0(9) # and argc... + addi 4, 9, 4 # and argv ... + mtlr 0 # Clear the link register. + # Go to the musl dynamic linker entry point. + bl __dynlink + cmpi 4, 0, 3, 1 # Check for a 1. + bne 4, . # Stay here + mtlr 3 # Set the link address... + li 3, 0 + blr # and go. + .end _start + .size _start, .-_start