]> git.proxmox.com Git - mirror_ubuntu-bionic-kernel.git/blame - arch/sh/include/asm/fpu.h
License cleanup: add SPDX GPL-2.0 license identifier to files with no license
[mirror_ubuntu-bionic-kernel.git] / arch / sh / include / asm / fpu.h
CommitLineData
b2441318 1/* SPDX-License-Identifier: GPL-2.0 */
332fd57b
PM
2#ifndef __ASM_SH_FPU_H
3#define __ASM_SH_FPU_H
4
332fd57b 5#ifndef __ASSEMBLY__
0ea820cf 6
f780d89a
IM
7#include <asm/ptrace.h>
8
0ea820cf 9struct task_struct;
332fd57b
PM
10
11#ifdef CONFIG_SH_FPU
12static inline void release_fpu(struct pt_regs *regs)
13{
14 regs->sr |= SR_FD;
15}
16
17static inline void grab_fpu(struct pt_regs *regs)
18{
19 regs->sr &= ~SR_FD;
20}
21
d3ea9fa0 22extern void save_fpu(struct task_struct *__tsk);
0ea820cf
PM
23extern void restore_fpu(struct task_struct *__tsk);
24extern void fpu_state_restore(struct pt_regs *regs);
25extern void __fpu_state_restore(void);
332fd57b 26#else
0ea820cf
PM
27#define save_fpu(tsk) do { } while (0)
28#define restore_fpu(tsk) do { } while (0)
29#define release_fpu(regs) do { } while (0)
30#define grab_fpu(regs) do { } while (0)
31#define fpu_state_restore(regs) do { } while (0)
32#define __fpu_state_restore(regs) do { } while (0)
332fd57b
PM
33#endif
34
e7ab3cd2
PM
35struct user_regset;
36
74d99a5e 37extern int do_fpu_inst(unsigned short, struct pt_regs *);
0ea820cf 38extern int init_fpu(struct task_struct *);
74d99a5e 39
e7ab3cd2
PM
40extern int fpregs_get(struct task_struct *target,
41 const struct user_regset *regset,
42 unsigned int pos, unsigned int count,
43 void *kbuf, void __user *ubuf);
44
d3ea9fa0
SM
45static inline void __unlazy_fpu(struct task_struct *tsk, struct pt_regs *regs)
46{
47 if (task_thread_info(tsk)->status & TS_USEDFPU) {
48 task_thread_info(tsk)->status &= ~TS_USEDFPU;
49 save_fpu(tsk);
50 release_fpu(regs);
51 } else
616c05d1 52 tsk->thread.fpu_counter = 0;
d3ea9fa0
SM
53}
54
9bbafce2
PM
55static inline void unlazy_fpu(struct task_struct *tsk, struct pt_regs *regs)
56{
57 preempt_disable();
d3ea9fa0 58 __unlazy_fpu(tsk, regs);
9bbafce2
PM
59 preempt_enable();
60}
61
62static inline void clear_fpu(struct task_struct *tsk, struct pt_regs *regs)
63{
64 preempt_disable();
d3ea9fa0
SM
65 if (task_thread_info(tsk)->status & TS_USEDFPU) {
66 task_thread_info(tsk)->status &= ~TS_USEDFPU;
9bbafce2
PM
67 release_fpu(regs);
68 }
69 preempt_enable();
70}
332fd57b
PM
71
72#endif /* __ASSEMBLY__ */
73
74#endif /* __ASM_SH_FPU_H */