Re: [PATCH RFC 4/5] x86,fpu: lazily skip FPU restore when still loaded

From: Dave Hansen
Date: Mon Oct 03 2016 - 16:05:08 EST


On 10/01/2016 01:31 PM, riel@xxxxxxxxxx wrote:
> /*
> + * Check whether an FPU's register set is still loaded in the CPU.
> + */
> +static inline bool fpu_lazy_skip_restore(struct fpu *fpu)
> +{
> + bool still_loaded = (fpu->fpstate_active &&
> + fpu->last_cpu == raw_smp_processor_id() &&
> + __this_cpu_read(fpu_fpregs_owner_ctx) == fpu);
> +
> + fpu->fpregs_active = still_loaded;
> + return still_loaded;
> +}

I wonder if we should call this something more along the lines of
fpregs_activate_fast(), which returns if it managed to do the activation
fast or not. I _think_ that's more along the lines of what it is
actually doing. The fact that it can be lazy is really an
implementation detail.

What are the preempt rules with this thing? This needs to be called in
preempt-disabled contexts, right?