Lines Matching refs:fpu
29 extern void fpu__prepare_read(struct fpu *fpu);
30 extern void fpu__prepare_write(struct fpu *fpu);
31 extern void fpu__save(struct fpu *fpu);
33 extern void fpu__drop(struct fpu *fpu);
35 extern void fpu__clear_user_states(struct fpu *fpu);
36 extern void fpu__clear_all(struct fpu *fpu);
37 extern int fpu__exception_code(struct fpu *fpu, int trap_nr);
104 extern void fpstate_sanitize_xstate(struct fpu *fpu);
200 static inline void copy_fxregs_to_kernel(struct fpu *fpu) in copy_fxregs_to_kernel() argument
203 asm volatile( "fxsave %[fx]" : [fx] "=m" (fpu->state.fxsave)); in copy_fxregs_to_kernel()
205 asm volatile("fxsaveq %[fx]" : [fx] "=m" (fpu->state.fxsave)); in copy_fxregs_to_kernel()
405 extern int copy_fpregs_to_fpstate(struct fpu *fpu);
443 DECLARE_PER_CPU(struct fpu *, fpu_fpregs_owner_ctx);
467 static inline void __fpu_invalidate_fpregs_state(struct fpu *fpu) in __fpu_invalidate_fpregs_state() argument
469 fpu->last_cpu = -1; in __fpu_invalidate_fpregs_state()
472 static inline int fpregs_state_valid(struct fpu *fpu, unsigned int cpu) in fpregs_state_valid() argument
474 return fpu == this_cpu_read(fpu_fpregs_owner_ctx) && cpu == fpu->last_cpu; in fpregs_state_valid()
481 static inline void fpregs_deactivate(struct fpu *fpu) in fpregs_deactivate() argument
484 trace_x86_fpu_regs_deactivated(fpu); in fpregs_deactivate()
487 static inline void fpregs_activate(struct fpu *fpu) in fpregs_activate() argument
489 this_cpu_write(fpu_fpregs_owner_ctx, fpu); in fpregs_activate()
490 trace_x86_fpu_regs_activated(fpu); in fpregs_activate()
498 struct fpu *fpu = ¤t->thread.fpu; in __fpregs_load_activate() local
504 if (!fpregs_state_valid(fpu, cpu)) { in __fpregs_load_activate()
505 copy_kernel_to_fpregs(&fpu->state); in __fpregs_load_activate()
506 fpregs_activate(fpu); in __fpregs_load_activate()
507 fpu->last_cpu = cpu; in __fpregs_load_activate()
536 struct fpu *old_fpu = &prev->thread.fpu; in switch_fpu_prepare()
561 struct fpu *next_fpu = &next->thread.fpu; in switch_fpu_finish()