|  | #ifndef __ASM_SH_FPU_H | 
|  | #define __ASM_SH_FPU_H | 
|  |  | 
|  | #ifndef __ASSEMBLY__ | 
|  | #include <linux/preempt.h> | 
|  | #include <asm/ptrace.h> | 
|  |  | 
|  | #ifdef CONFIG_SH_FPU | 
|  | static inline void release_fpu(struct pt_regs *regs) | 
|  | { | 
|  | regs->sr |= SR_FD; | 
|  | } | 
|  |  | 
|  | static inline void grab_fpu(struct pt_regs *regs) | 
|  | { | 
|  | regs->sr &= ~SR_FD; | 
|  | } | 
|  |  | 
|  | struct task_struct; | 
|  |  | 
|  | extern void save_fpu(struct task_struct *__tsk, struct pt_regs *regs); | 
|  | #else | 
|  |  | 
|  | #define release_fpu(regs)	do { } while (0) | 
|  | #define grab_fpu(regs)		do { } while (0) | 
|  |  | 
|  | static inline void save_fpu(struct task_struct *tsk, struct pt_regs *regs) | 
|  | { | 
|  | clear_tsk_thread_flag(tsk, TIF_USEDFPU); | 
|  | } | 
|  | #endif | 
|  |  | 
|  | extern int do_fpu_inst(unsigned short, struct pt_regs *); | 
|  |  | 
|  | static inline void unlazy_fpu(struct task_struct *tsk, struct pt_regs *regs) | 
|  | { | 
|  | preempt_disable(); | 
|  | if (test_tsk_thread_flag(tsk, TIF_USEDFPU)) | 
|  | save_fpu(tsk, regs); | 
|  | preempt_enable(); | 
|  | } | 
|  |  | 
|  | static inline void clear_fpu(struct task_struct *tsk, struct pt_regs *regs) | 
|  | { | 
|  | preempt_disable(); | 
|  | if (test_tsk_thread_flag(tsk, TIF_USEDFPU)) { | 
|  | clear_tsk_thread_flag(tsk, TIF_USEDFPU); | 
|  | release_fpu(regs); | 
|  | } | 
|  | preempt_enable(); | 
|  | } | 
|  |  | 
|  | #endif /* __ASSEMBLY__ */ | 
|  |  | 
|  | #endif /* __ASM_SH_FPU_H */ |