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