Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/external/gpl3/gcc/dist/gcc/config/i386 PR 46978: ICE on spil...
details: https://anonhg.NetBSD.org/src/rev/1854ec668564
branches: trunk
changeset: 781908:1854ec668564
user: joerg <joerg%NetBSD.org@localhost>
date: Sat Oct 06 14:10:46 2012 +0000
description:
PR 46978: ICE on spilling MMX registers
GCC/i386 has code to lower the required alignment for long long to 32bit
as the CPU doesn't need more. It is also using the same mode for setting
up the MMX registers and in turn, the stack slots reserved for spilling
require 32bit alignment. The actual vector types used keep the original
64bit alignment, so when the compiler wants to spill a MMX register, it
hits an assertion. Fix this by using the vector type as raw type for MMX
registers.
diffstat:
external/gpl3/gcc/dist/gcc/config/i386/i386.h | 1 +
1 files changed, 1 insertions(+), 0 deletions(-)
diffs (11 lines):
diff -r 92e617326f37 -r 1854ec668564 external/gpl3/gcc/dist/gcc/config/i386/i386.h
--- a/external/gpl3/gcc/dist/gcc/config/i386/i386.h Sat Oct 06 12:05:58 2012 +0000
+++ b/external/gpl3/gcc/dist/gcc/config/i386/i386.h Sat Oct 06 14:10:46 2012 +0000
@@ -1085,6 +1085,7 @@
#define HARD_REGNO_CALLER_SAVE_MODE(REGNO, NREGS, MODE) \
(CC_REGNO_P (REGNO) ? VOIDmode \
+ : MMX_REGNO_P (REGNO) ? V8QImode \
: (MODE) == VOIDmode && (NREGS) != 1 ? VOIDmode \
: (MODE) == VOIDmode ? choose_hard_reg_mode ((REGNO), (NREGS), false) \
: (MODE) == HImode && !TARGET_PARTIAL_REG_STALL ? SImode \
Home |
Main Index |
Thread Index |
Old Index