blob: f89abf5920d808dbe545296b4b6b714c27e2ba5f [file] [log] [blame]
Paul Mundt332fd572007-11-22 17:30:50 +09001#ifndef __ASM_SH_FPU_H
2#define __ASM_SH_FPU_H
3
Paul Mundt332fd572007-11-22 17:30:50 +09004#ifndef __ASSEMBLY__
Paul Mundt9bbafce2008-03-26 19:02:47 +09005#include <linux/preempt.h>
Paul Mundt332fd572007-11-22 17:30:50 +09006#include <asm/ptrace.h>
7
8#ifdef CONFIG_SH_FPU
9static inline void release_fpu(struct pt_regs *regs)
10{
11 regs->sr |= SR_FD;
12}
13
14static inline void grab_fpu(struct pt_regs *regs)
15{
16 regs->sr &= ~SR_FD;
17}
18
19struct task_struct;
20
21extern void save_fpu(struct task_struct *__tsk, struct pt_regs *regs);
22#else
23#define release_fpu(regs) do { } while (0)
24#define grab_fpu(regs) do { } while (0)
25#define save_fpu(tsk, regs) do { } while (0)
26#endif
27
Paul Mundt74d99a52007-11-26 20:38:36 +090028extern int do_fpu_inst(unsigned short, struct pt_regs *);
29
Paul Mundt9bbafce2008-03-26 19:02:47 +090030static inline void unlazy_fpu(struct task_struct *tsk, struct pt_regs *regs)
31{
32 preempt_disable();
33 if (test_tsk_thread_flag(tsk, TIF_USEDFPU))
34 save_fpu(tsk, regs);
35 preempt_enable();
36}
Paul Mundt332fd572007-11-22 17:30:50 +090037
Paul Mundt9bbafce2008-03-26 19:02:47 +090038static inline void clear_fpu(struct task_struct *tsk, struct pt_regs *regs)
39{
40 preempt_disable();
41 if (test_tsk_thread_flag(tsk, TIF_USEDFPU)) {
42 clear_tsk_thread_flag(tsk, TIF_USEDFPU);
43 release_fpu(regs);
44 }
45 preempt_enable();
46}
Paul Mundt332fd572007-11-22 17:30:50 +090047
48#endif /* __ASSEMBLY__ */
49
50#endif /* __ASM_SH_FPU_H */