ia64/pv_ops/xen: implement xen pv_time_ops.
[pv_ops_mirror.git] / include / asm-sh / fpu.h
blob91462fea1507c69af30d42a8e2315e8730ced5b0
1 #ifndef __ASM_SH_FPU_H
2 #define __ASM_SH_FPU_H
4 #ifndef __ASSEMBLY__
5 #include <linux/preempt.h>
6 #include <asm/ptrace.h>
8 #ifdef CONFIG_SH_FPU
9 static inline void release_fpu(struct pt_regs *regs)
11 regs->sr |= SR_FD;
14 static inline void grab_fpu(struct pt_regs *regs)
16 regs->sr &= ~SR_FD;
19 struct task_struct;
21 extern void save_fpu(struct task_struct *__tsk, struct pt_regs *regs);
22 #else
24 #define release_fpu(regs) do { } while (0)
25 #define grab_fpu(regs) do { } while (0)
27 static inline void save_fpu(struct task_struct *tsk, struct pt_regs *regs)
29 clear_tsk_thread_flag(tsk, TIF_USEDFPU);
31 #endif
33 extern int do_fpu_inst(unsigned short, struct pt_regs *);
35 static inline void unlazy_fpu(struct task_struct *tsk, struct pt_regs *regs)
37 preempt_disable();
38 if (test_tsk_thread_flag(tsk, TIF_USEDFPU))
39 save_fpu(tsk, regs);
40 preempt_enable();
43 static inline void clear_fpu(struct task_struct *tsk, struct pt_regs *regs)
45 preempt_disable();
46 if (test_tsk_thread_flag(tsk, TIF_USEDFPU)) {
47 clear_tsk_thread_flag(tsk, TIF_USEDFPU);
48 release_fpu(regs);
50 preempt_enable();
53 #endif /* __ASSEMBLY__ */
55 #endif /* __ASM_SH_FPU_H */