 c06fb25d1f
			
		
	
	c06fb25d1f
	
	
		
			
	
		
	
	
		
			Some checks failed
		
		
	
	Build Kernel / Build all affected Kernels (push) Has been cancelled
				
			Build all core packages / Build all core packages for selected target (push) Has been cancelled
				
			Build and Push prebuilt tools container / Build and Push all prebuilt containers (push) Has been cancelled
				
			Build Toolchains / Build Toolchains for each target (push) Has been cancelled
				
			Build host tools / Build host tools for linux and macos based systems (push) Has been cancelled
				
			Coverity scan build / Coverity x86/64 build (push) Has been cancelled
				
			
		
			
				
	
	
		
			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)
 |