[PATCH v1 04/10] mips: traps: Set WG bit in EBase register on Octeon

Daniel Schwierzeck daniel.schwierzeck at gmail.com
Wed May 13 15:10:25 CEST 2020



Am 02.05.20 um 10:59 schrieb Stefan Roese:
> WG (bit 11) needs to be set on Octeon to enable writing bits 63:30 of
> the exception base register.
> 
> Signed-off-by: Stefan Roese <sr at denx.de>
> ---
> 
>  arch/mips/lib/traps.c | 4 ++++
>  1 file changed, 4 insertions(+)
> 
> diff --git a/arch/mips/lib/traps.c b/arch/mips/lib/traps.c
> index 8fff7541e3..ccbce97161 100644
> --- a/arch/mips/lib/traps.c
> +++ b/arch/mips/lib/traps.c
> @@ -106,6 +106,10 @@ void trap_init(ulong reloc_addr)
>  
>  	saved_ebase = read_c0_ebase() & 0xfffff000;
>  
> +	/* Set WG bit on Octeon to enable writing to bits 63:30 */
> +	if (IS_ENABLED(CONFIG_ARCH_OCTEON))
> +		ebase |= BIT(11);

you should add something like this to mipsregs.h

#define EBASE_WG	(_ULCAST_(1)   << 11)

we already have EBASE_CPUNUM.

> +
>  	write_c0_ebase(ebase);
>  	clear_c0_status(ST0_BEV);
>  	execution_hazard_barrier();
> 

-- 
- Daniel


More information about the U-Boot mailing list