Fix AVX check

This commit is contained in:
Andreas Schwab 2011-07-22 14:33:47 -04:00 committed by Ulrich Drepper
parent a65c0b7a32
commit 1d002f2539
2 changed files with 21 additions and 6 deletions

View File

@ -1,3 +1,9 @@
2011-07-21 Andreas Schwab <schwab@redhat.com>
* sysdeps/x86_64/dl-trampoline.S (_dl_runtime_profile): Fix last
change.
(_dl_x86_64_save_sse): Use correct AVX check.
2011-07-21 Ulrich Drepper <drepper@gmail.com>
* string/tester.c (test_strcat): Add tests for different alignments

View File

@ -150,7 +150,8 @@ L(have_avx):
cmpl $0x6, %eax
// Nonzero if SSE and AVX state saving is enabled.
sete %al
2: movl %eax, L(have_avx)(%rip)
2: leal -1(%eax,%eax), %eax
movl %eax, L(have_avx)(%rip)
cmpl $0, %eax
1: js L(no_avx)
@ -183,11 +184,19 @@ _dl_x86_64_save_sse:
movl $1, %eax
cpuid
movq %r11,%rbx # Restore rbx
movl $1, %eax
testl $(1 << 28), %ecx
jne 2f
negl %eax
2: movl %eax, L(have_avx)(%rip)
xorl %eax, %eax
// AVX and XSAVE supported?
testl $((1 << 28) | (1 << 27)), %ecx
je 2f
xorl %ecx, %ecx
// Get XFEATURE_ENABLED_MASK
xgetbv
andl $0x6, %eax
cmpl $0x6, %eax
// Nonzero if SSE and AVX state saving is enabled.
sete %al
2: leal -1(%eax,%eax), %eax
movl %eax, L(have_avx)(%rip)
cmpl $0, %eax
1: js L(no_avx5)