Port-mips archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
Re: R5000SC issues and fix
On Fri, 5 Dec 2025 at 01:58, Izumi Tsutsui <tsutsui%ceres.dti.ne.jp@localhost> wrote:
>
> > Simply reverting the math change done fixes it, ie:
> >
> > ===
> > diff --git a/sys/arch/mips/include/cache_r5k.h
> > b/sys/arch/mips/include/cache_r5k.h
> > index a59fa18fdc02..6bdf9bd688c2 100644
> > --- a/sys/arch/mips/include/cache_r5k.h
> > +++ b/sys/arch/mips/include/cache_r5k.h
> > @@ -68,6 +68,11 @@ void r5k_sdcache_wb_range(register_t, vsize_t);
> > #define R5K_SC_PAGESIZE (R5K_SC_LINESIZE * 128)
> > #define R5K_SC_PAGEMASK (R5K_SC_PAGESIZE - 1)
> >
> > +#if 0
> > #define mips_r5k_round_page(x) (((x) + (register_t)R5K_SC_PAGEMASK) \
> > & (register_t)R5K_SC_PAGEMASK)
> > #define mips_r5k_trunc_page(x) ((x) & (register_t)R5K_SC_PAGEMASK)
> > +#else
> > +#define mips_r5k_round_page(x) round_line(x, PAGE_SIZE)
> > +#define mips_r5k_trunc_page(x) trunc_line(x, PAGE_SIZE)
> > +#endif
> > ===
>
> Ah, sorry, my serious botch. It should be:
>
> >> #define mips_r5k_round_page(x) (((x) + (register_t)R5K_SC_PAGEMASK) \
> >> & (register_t)~R5K_SC_PAGEMASK)
> >> #define mips_r5k_trunc_page(x) ((x) & (register_t)~R5K_SC_PAGEMASK)
I'll test with this today and report back!
Thanks everyone!
-adrian
Home |
Main Index |
Thread Index |
Old Index