fpu.h revision 1.13
1/*	$NetBSD: fpu.h,v 1.13 2018/10/05 18:51:52 maxv Exp $	*/
2
3#ifndef	_X86_FPU_H_
4#define	_X86_FPU_H_
5
6#include <x86/cpu_extended_state.h>
7
8#ifdef _KERNEL
9
10struct cpu_info;
11struct lwp;
12struct trapframe;
13
14void fpuinit(struct cpu_info *);
15void fpuinit_mxcsr_mask(void);
16
17void fpu_area_save(void *);
18void fpu_area_restore(void *);
19
20void fpusave_lwp(struct lwp *, bool);
21void fpusave_cpu(bool);
22
23void fpu_eagerswitch(struct lwp *, struct lwp *);
24
25void fpu_set_default_cw(struct lwp *, unsigned int);
26
27void fputrap(struct trapframe *);
28void fpudna(struct trapframe *);
29
30/* Set all to defaults (eg during exec) */
31void fpu_save_area_clear(struct lwp *, unsigned int);
32/* Reset control words only - for signal handlers */
33void fpu_save_area_reset(struct lwp *);
34
35/* Copy data outside pcb during fork */
36void fpu_save_area_fork(struct pcb *, const struct pcb *);
37
38/* Load FP registers with user-supplied values */
39void process_write_fpregs_xmm(struct lwp *lwp, const struct fxsave *fpregs);
40void process_write_fpregs_s87(struct lwp *lwp, const struct save87 *fpregs);
41
42/* Save FP registers for copy to userspace */
43void process_read_fpregs_xmm(struct lwp *lwp, struct fxsave *fpregs);
44void process_read_fpregs_s87(struct lwp *lwp, struct save87 *fpregs);
45
46#endif
47
48#endif /* _X86_FPU_H_ */
49