On Mon, Sep 05, 2016 at 03:24:54PM +0100, Paul Burton wrote:
> Commit f70ddc07b637 ("MIPS: c-r4k: Avoid small flush_icache_range SMP
> calls") adds checks to force use of hit-type cache ops for small icache
> flushes where they are globalised & index-type cache ops aren't, in
> order to avoid the overhead of IPIs in those cases. However it
> calculated the size of the region being flushed incorrectly, subtracting
> the end address from the start address rather than the reverse. This
> would have led to an overflow with size wrapping round to some large
> value, and likely to the special case for avoiding IPIs not actually
> being hit.
>
> Signed-off-by: Paul Burton <[email protected]>
> Cc: James Hogan <[email protected]>
> Fixes: f70ddc07b637 ("MIPS: c-r4k: Avoid small flush_icache_range SMP calls")Good catch Paul! I've no idea how that happened. Reviewed-by: James Hogan <[email protected]> Ralf: It'd be great to get this into v4.8 if possible. Thanks James > --- > > arch/mips/mm/c-r4k.c | 2 +- > 1 file changed, 1 insertion(+), 1 deletion(-) > > diff --git a/arch/mips/mm/c-r4k.c b/arch/mips/mm/c-r4k.c > index 1af381f..69b1f10 100644 > --- a/arch/mips/mm/c-r4k.c > +++ b/arch/mips/mm/c-r4k.c > @@ -811,7 +811,7 @@ static void __r4k_flush_icache_range(unsigned long start, > unsigned long end, > * If address-based cache ops don't require an SMP call, then > * use them exclusively for small flushes. > */ > - size = start - end; > + size = end - start; > cache_size = icache_size; > if (!cpu_has_ic_fills_f_dc) { > size *= 2; > -- > 2.9.3 >
signature.asc
Description: Digital signature

