diff options
| author | David S. Miller <davem@davemloft.net> | 2010-04-21 00:50:39 -0700 | 
|---|---|---|
| committer | David S. Miller <davem@davemloft.net> | 2010-04-21 00:50:39 -0700 | 
| commit | e04997b13a2c2fc93af970fe95fd29a74db113e8 (patch) | |
| tree | a84ec3368edc3c2568a0d6acdfa0d0e50d8cacf7 /arch/mips/include/asm/stackframe.h | |
| parent | 6651ffc8e8bdd5fb4b7d1867c6cfebb4f309512c (diff) | |
| parent | 05ce7bfe547c9fa967d9cab6c37867a9cb6fb3fa (diff) | |
Merge branch 'master' of /home/davem/src/GIT/linux-2.6/
Diffstat (limited to 'arch/mips/include/asm/stackframe.h')
| -rw-r--r-- | arch/mips/include/asm/stackframe.h | 19 | 
1 files changed, 19 insertions, 0 deletions
| diff --git a/arch/mips/include/asm/stackframe.h b/arch/mips/include/asm/stackframe.h index 3b6da3330e3..c8419129e77 100644 --- a/arch/mips/include/asm/stackframe.h +++ b/arch/mips/include/asm/stackframe.h @@ -121,6 +121,25 @@  		.endm  #else  		.macro	get_saved_sp	/* Uniprocessor variation */ +#ifdef CONFIG_CPU_LOONGSON2F +		/* +		 * Clear BTB (branch target buffer), forbid RAS (return address +		 * stack) to workaround the Out-of-order Issue in Loongson2F +		 * via its diagnostic register. +		 */ +		move	k0, ra +		jal	1f +		 nop +1:		jal	1f +		 nop +1:		jal	1f +		 nop +1:		jal	1f +		 nop +1:		move	ra, k0 +		li	k0, 3 +		mtc0	k0, $22 +#endif /* CONFIG_CPU_LOONGSON2F */  #if defined(CONFIG_32BIT) || defined(KBUILD_64BIT_SYM32)  		lui	k1, %hi(kernelsp)  #else | 
