On Fri, Oct 03, 2014 at 08:17:30PM -0700, Leonid Yegoshin wrote:

> --- a/arch/mips/include/asm/switch_to.h
> +++ b/arch/mips/include/asm/switch_to.h
> @@ -17,6 +17,7 @@
>  #include <asm/dsp.h>
>  #include <asm/cop2.h>
>  #include <asm/msa.h>
> +#include <asm/mmu_context.h>
>  
>  struct task_struct;
>  
> @@ -104,6 +105,16 @@ do {                                                     
>                 \
>       disable_msa();                                                  \
>  } while (0)
>  
> +static inline void flush_vdso_page(void)
> +{
> +     if (current->mm && cpu_context(raw_smp_processor_id(), current->mm) &&
> +         (current->mm->context.vdso_asid[raw_smp_processor_id()] ==
> +          cpu_asid(raw_smp_processor_id(), current->mm))) {
> +             local_flush_tlb_page(current->mm->mmap, (unsigned 
> long)current->mm->context.vdso);
> +             current->mm->context.vdso_asid[raw_smp_processor_id()] = 0;
> +     }
> +}

Why raw_smp_processor_id() and why evaluate it 3 times, sure compilers
can be expected to do some CSE but something like:

        int cpu = smp_processor_id();

        if ( ... [cpu] ...)

is far more readable as well.

> +
>  #define finish_arch_switch(prev)                                     \
>  do {                                                                 \
>       u32 __c0_stat;                                                  \
> @@ -118,6 +129,7 @@ do {                                                      
>                 \
>               __restore_dsp(current);                                 \
>       if (cpu_has_userlocal)                                          \
>               write_c0_userlocal(current_thread_info()->tp_value);    \
> +     flush_vdso_page();                                              \
>       __restore_watch();                                              \
>  } while (0)

So what I didn't see is any talk about the cost of this. Surely a TLB
flush isn't exactly free.
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to