|
@@ -1,9 +1,8 @@
|
|
#ifndef __ASM_SH_FPU_H
|
|
#ifndef __ASM_SH_FPU_H
|
|
#define __ASM_SH_FPU_H
|
|
#define __ASM_SH_FPU_H
|
|
|
|
|
|
-#define SR_FD 0x00008000
|
|
|
|
-
|
|
|
|
#ifndef __ASSEMBLY__
|
|
#ifndef __ASSEMBLY__
|
|
|
|
+#include <linux/preempt.h>
|
|
#include <asm/ptrace.h>
|
|
#include <asm/ptrace.h>
|
|
|
|
|
|
#ifdef CONFIG_SH_FPU
|
|
#ifdef CONFIG_SH_FPU
|
|
@@ -28,18 +27,23 @@ extern void save_fpu(struct task_struct *__tsk, struct pt_regs *regs);
|
|
|
|
|
|
extern int do_fpu_inst(unsigned short, struct pt_regs *);
|
|
extern int do_fpu_inst(unsigned short, struct pt_regs *);
|
|
|
|
|
|
-#define unlazy_fpu(tsk, regs) do { \
|
|
|
|
- if (test_tsk_thread_flag(tsk, TIF_USEDFPU)) { \
|
|
|
|
- save_fpu(tsk, regs); \
|
|
|
|
- } \
|
|
|
|
-} while (0)
|
|
|
|
-
|
|
|
|
-#define clear_fpu(tsk, regs) do { \
|
|
|
|
- if (test_tsk_thread_flag(tsk, TIF_USEDFPU)) { \
|
|
|
|
- clear_tsk_thread_flag(tsk, TIF_USEDFPU); \
|
|
|
|
- release_fpu(regs); \
|
|
|
|
- } \
|
|
|
|
-} while (0)
|
|
|
|
|
|
+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 /* __ASSEMBLY__ */
|
|
|
|
|