]> git.ipfire.org Git - thirdparty/glibc.git/commit
x86-64: Verify that _dl_runtime_resolve preserves vector registers
authorH.J. Lu <hjl.tools@gmail.com>
Thu, 19 Oct 2017 15:52:50 +0000 (08:52 -0700)
committerH.J. Lu <hjl.tools@gmail.com>
Thu, 19 Oct 2017 15:53:02 +0000 (08:53 -0700)
commit5084717ffa05d15e98bc98a2c8b710ee57c4d133
treed547102f42ddf210039167cbc3a0d5a610816190
parent37f4c94e1f0ae24b03d49839cd39c03076bd5c5b
x86-64: Verify that _dl_runtime_resolve preserves vector registers

On x86-64, _dl_runtime_resolve must preserve the first 8 vector
registers.  Add 3 _dl_runtime_resolve tests to verify that SSE,
AVX and AVX512 registers are preserved.

* sysdeps/x86_64/Makefile (tests): Add tst-sse, tst-avx and
tst-avx512.
(test-extras): Add tst-avx-aux and tst-avx512-aux.
(extra-test-objs): Add tst-avx-aux.o and tst-avx512-aux.o.
(modules-names): Add tst-ssemod, tst-avxmod and tst-avx512mod.
($(objpfx)tst-sse): New rule.
($(objpfx)tst-avx): Likewise.
($(objpfx)tst-avx512): Likewise.
(CFLAGS-tst-avx-aux.c): New.
(CFLAGS-tst-avxmod.c): Likewise.
(CFLAGS-tst-avx512-aux.c): Likewise.
(CFLAGS-tst-avx512mod.c): Likewise.
* sysdeps/x86_64/tst-avx-aux.c: New file.
* sysdeps/x86_64/tst-avx.c: Likewise.
* sysdeps/x86_64/tst-avx512-aux.c: Likewise.
* sysdeps/x86_64/tst-avx512.c: Likewise.
* sysdeps/x86_64/tst-avx512mod.c: Likewise.
* sysdeps/x86_64/tst-avxmod.c: Likewise.
* sysdeps/x86_64/tst-sse.c: Likewise.
* sysdeps/x86_64/tst-ssemod.c: Likewise.

(cherry picked from commit 3403a17fea8ccef7dc5f99553a13231acf838744)
ChangeLog
sysdeps/x86_64/Makefile
sysdeps/x86_64/tst-avx-aux.c [new file with mode: 0644]
sysdeps/x86_64/tst-avx.c [new file with mode: 0644]
sysdeps/x86_64/tst-avx512-aux.c [new file with mode: 0644]
sysdeps/x86_64/tst-avx512.c [new file with mode: 0644]
sysdeps/x86_64/tst-avx512mod.c [new file with mode: 0644]
sysdeps/x86_64/tst-avxmod.c [new file with mode: 0644]
sysdeps/x86_64/tst-sse.c [new file with mode: 0644]
sysdeps/x86_64/tst-ssemod.c [new file with mode: 0644]