d7382cc0e4
Every minor version bump of a major version will result in a huge patch diff because of the moving of all the patches from version e.g. 11.2.0 to 11.3.0. This commit only use the major version for the patch folders to differentiate between the different gcc versions. This will significantly improve the reviewing of the smaller version bump patches and help to see what really changed in a minor version bump. Signed-off-by: Nick Hainke <vincent@systemli.org>
21 lines
684 B
Diff
21 lines
684 B
Diff
Fix https://gcc.gnu.org/bugzilla/show_bug.cgi?id=84790.
|
|
MIPS16 functions have a static assembler prologue which clobbers
|
|
registers v0 and v1. Add these register clobbers to function call
|
|
instructions.
|
|
|
|
--- a/gcc/config/mips/mips.c
|
|
+++ b/gcc/config/mips/mips.c
|
|
@@ -3132,6 +3132,12 @@ mips_emit_call_insn (rtx pattern, rtx or
|
|
emit_insn (gen_update_got_version ());
|
|
}
|
|
|
|
+ if (TARGET_MIPS16 && TARGET_USE_GOT)
|
|
+ {
|
|
+ clobber_reg (&CALL_INSN_FUNCTION_USAGE (insn), MIPS16_PIC_TEMP);
|
|
+ clobber_reg (&CALL_INSN_FUNCTION_USAGE (insn), MIPS_PROLOGUE_TEMP (word_mode));
|
|
+ }
|
|
+
|
|
if (TARGET_MIPS16
|
|
&& TARGET_EXPLICIT_RELOCS
|
|
&& TARGET_CALL_CLOBBERED_GP)
|