mirror of git://git.musl-libc.org/musl
fix ld-behavior-dependent crash in ppc64 ldso startup
the 32-bit pc-relative address for stage 2 of dynamic linker entry was wrongly loaded with a zero-extending load instead of sign-extending load, resulting in an invalid jump if the offset happened to be negative, which depends on the linker's ordering of text sections.
This commit is contained in:
parent
827c4e6fbe
commit
fc85fb3860
|
@ -27,6 +27,6 @@
|
|||
" bl 1f \n" \
|
||||
" .long " #sym "-. \n" \
|
||||
"1: mflr %1 \n" \
|
||||
" lwz %0, 0(%1) \n" \
|
||||
" lwa %0, 0(%1) \n" \
|
||||
" add %0, %0, %1 \n" \
|
||||
: "=r"(*(fp)), "=r"((long){0}) : : "memory", "lr" )
|
||||
|
|
Loading…
Reference in New Issue