boringssl/util/fipstools/testdata/x86_64-GOTRewrite/in.s
David Benjamin c5cc88d800 Test that movsd without arguments is left as-is.
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>
2017-09-18 19:09:31 +00:00

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