c5cc88d800
This works fine, but probably worth a test. Change-Id: If060b473958c1664e450102cafe0ca28951bff49 Reviewed-on: https://boringssl-review.googlesource.com/20444 Reviewed-by: Adam Langley <agl@google.com> Commit-Queue: Adam Langley <agl@google.com> CQ-Verified: CQ bot account: commit-bot@chromium.org <commit-bot@chromium.org>
38 lines
951 B
ArmAsm
38 lines
951 B
ArmAsm
.text
|
|
foo:
|
|
# leaq of OPENSSL_ia32cap_P is supported.
|
|
leaq OPENSSL_ia32cap_P(%rip), %r11
|
|
|
|
# As is the equivalent GOTPCREL movq.
|
|
movq OPENSSL_ia32cap_P@GOTPCREL(%rip), %r12
|
|
|
|
# Test that GOTPCREL accesses get translated. They are handled
|
|
# differently for local and external symbols.
|
|
|
|
pushq stderr@GOTPCREL(%rip)
|
|
pushq foo@GOTPCREL(%rip)
|
|
|
|
movq stderr@GOTPCREL(%rip), %r11
|
|
movq foo@GOTPCREL(%rip), %r11
|
|
|
|
vmovq stderr@GOTPCREL(%rip), %xmm0
|
|
vmovq foo@GOTPCREL(%rip), %xmm0
|
|
|
|
cmoveq stderr@GOTPCREL(%rip), %r11
|
|
cmoveq foo@GOTPCREL(%rip), %r11
|
|
cmovneq stderr@GOTPCREL(%rip), %r11
|
|
cmovneq foo@GOTPCREL(%rip), %r11
|
|
|
|
movsd foo@GOTPCREL(%rip), %xmm0
|
|
vmovsd foo@GOTPCREL(%rip), %xmm0
|
|
|
|
# movsd without arguments should be left as-is.
|
|
movsd
|
|
|
|
# Synthesized symbols do not use the GOT.
|
|
movq BORINGSSL_bcm_text_start@GOTPCREL(%rip), %r11
|
|
movq foobar_bss_get@GOTPCREL(%rip), %r11
|
|
movq OPENSSL_ia32cap_get@GOTPCREL(%rip), %r11
|
|
|
|
.comm foobar,64,32
|