提交 fc85fb38 编写于 作者: R Rich Felker

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.
上级 827c4e6f
...@@ -27,6 +27,6 @@ ...@@ -27,6 +27,6 @@
" bl 1f \n" \ " bl 1f \n" \
" .long " #sym "-. \n" \ " .long " #sym "-. \n" \
"1: mflr %1 \n" \ "1: mflr %1 \n" \
" lwz %0, 0(%1) \n" \ " lwa %0, 0(%1) \n" \
" add %0, %0, %1 \n" \ " add %0, %0, %1 \n" \
: "=r"(*(fp)), "=r"((long){0}) : : "memory", "lr" ) : "=r"(*(fp)), "=r"((long){0}) : : "memory", "lr" )
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册