xref: /freebsd/sys/powerpc/include/reg.h (revision a3557ef0)
1 /* $NetBSD: reg.h,v 1.4 2000/06/04 09:30:44 tsubai Exp $	*/
2 /* $FreeBSD$	*/
3 
4 #ifndef _POWERPC_REG_H_
5 #define	_POWERPC_REG_H_
6 
7 /* Must match struct trapframe */
8 struct reg {
9 	register_t fixreg[32];
10 	register_t lr;
11 	register_t cr;
12 	register_t xer;
13 	register_t ctr;
14 	register_t pc;
15 };
16 
17 struct fpreg {
18 	double fpreg[32];
19 	double fpscr;
20 };
21 
22 /* Must match pcb.pcb_vec */
23 struct vmxreg {
24 	uint32_t vr[32][4];
25 	uint32_t pad[2];
26 	uint32_t vrsave;
27 	uint32_t vscr;
28 };
29 
30 struct dbreg {
31 	unsigned int	junk;
32 };
33 
34 #ifdef __LP64__
35 /* Must match struct trapframe */
36 struct reg32 {
37 	int32_t fixreg[32];
38 	int32_t lr;
39 	int32_t cr;
40 	int32_t xer;
41 	int32_t ctr;
42 	int32_t pc;
43 };
44 
45 struct fpreg32 {
46 	struct fpreg data;
47 };
48 
49 struct vmxreg32 {
50 	struct vmxreg data;
51 };
52 
53 struct dbreg32 {
54 	struct dbreg data;
55 };
56 
57 #define __HAVE_REG32
58 #endif
59 
60 #ifdef _KERNEL
61 /*
62  * XXX these interfaces are MI, so they should be declared in a MI place.
63  */
64 int	fill_regs(struct thread *, struct reg *);
65 int	set_regs(struct thread *, struct reg *);
66 int	fill_fpregs(struct thread *, struct fpreg *);
67 int	set_fpregs(struct thread *, struct fpreg *);
68 int	fill_dbregs(struct thread *, struct dbreg *);
69 int	set_dbregs(struct thread *, struct dbreg *);
70 
71 #ifdef COMPAT_FREEBSD32
72 struct image_params;
73 
74 int	fill_regs32(struct thread *, struct reg32 *);
75 int	set_regs32(struct thread *, struct reg32 *);
76 void	ppc32_setregs(struct thread *, struct image_params *, uintptr_t);
77 
78 #define	fill_fpregs32(td, reg)	fill_fpregs(td,(struct fpreg *)reg)
79 #define	set_fpregs32(td, reg)	set_fpregs(td,(struct fpreg *)reg)
80 #define	fill_dbregs32(td, reg)	fill_dbregs(td,(struct dbreg *)reg)
81 #define	set_dbregs32(td, reg)	set_dbregs(td,(struct dbreg *)reg)
82 #endif
83 
84 #endif
85 
86 #endif /* _POWERPC_REG_H_ */
87