aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2022-03-15 10:24:22 +0100
committerJakub Jelinek <jakub@redhat.com>2022-03-15 10:24:22 +0100
commitda24fce323eaf088239e0f900dd23f6b05d552c1 (patch)
tree78bf9a35b7b819168f1bfa11f3b2d9935dda0a95
parent49fb0af9bf8f16907980d383c2bbc85e185ec2e0 (diff)
downloadgcc-da24fce323eaf088239e0f900dd23f6b05d552c1.zip
gcc-da24fce323eaf088239e0f900dd23f6b05d552c1.tar.gz
gcc-da24fce323eaf088239e0f900dd23f6b05d552c1.tar.bz2
i386: Use no-mmx,no-sse for LIBGCC2_UNWIND_ATTRIBUTE [PR104890]
Regardless of the outcome of the general-regs-only stuff in x86gprintrin.h, apparently general-regs-only is much bigger hammer than no-sse, and e.g. using 387 instructions in the unwinder isn't a big deal, it never needs to realign the stack because of it. So, the following patch uses no-sse (and adds no-mmx to it, even when not strictly needed). 2022-03-15 Jakub Jelinek <jakub@redhat.com> PR target/104890 * config/i386/i386.h (LIBGCC2_UNWIND_ATTRIBUTE): Use no-mmx,no-sse instead of general-regs-only.
-rw-r--r--gcc/config/i386/i386.h6
1 files changed, 3 insertions, 3 deletions
diff --git a/gcc/config/i386/i386.h b/gcc/config/i386/i386.h
index 0d28e57..37b523c 100644
--- a/gcc/config/i386/i386.h
+++ b/gcc/config/i386/i386.h
@@ -2848,10 +2848,10 @@ extern enum attr_cpu ix86_schedule;
#define NUM_X86_64_MS_CLOBBERED_REGS 12
#endif
-/* __builtin_eh_return can't handle stack realignment, so restrict to
- general regs in 32-bit libgcc functions that call it. */
+/* __builtin_eh_return can't handle stack realignment, so disable MMX/SSE
+ in 32-bit libgcc functions that call it. */
#ifndef __x86_64__
-#define LIBGCC2_UNWIND_ATTRIBUTE __attribute__((target ("general-regs-only")))
+#define LIBGCC2_UNWIND_ATTRIBUTE __attribute__((target ("no-mmx,no-sse")))
#endif
/*