2000-09-29 13:46:07 +00:00
|
|
|
/*-
|
|
|
|
* Copyright (c) 2000 Doug Rabson
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
|
|
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
|
|
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
* SUCH DAMAGE.
|
|
|
|
*
|
|
|
|
* $FreeBSD$
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _MACHINE_REG_H_
|
|
|
|
#define _MACHINE_REG_H_
|
|
|
|
|
2000-10-04 17:53:03 +00:00
|
|
|
#ifndef _IA64_FPREG_DEFINED
|
|
|
|
|
2000-09-29 13:46:07 +00:00
|
|
|
struct ia64_fpreg {
|
2002-05-10 07:33:11 +00:00
|
|
|
uint64_t fpr_bits[2];
|
2000-09-29 13:46:07 +00:00
|
|
|
} __attribute__ ((aligned (16)));
|
|
|
|
|
2000-10-04 17:53:03 +00:00
|
|
|
#define _IA64_FPREG_DEFINED
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
2000-09-29 13:46:07 +00:00
|
|
|
struct reg {
|
2002-05-10 07:33:11 +00:00
|
|
|
uint64_t r_gr[128];
|
|
|
|
uint64_t r_br[8];
|
|
|
|
uint64_t r_cfm;
|
|
|
|
uint64_t r_ip; /* Bits 0-3 encode the slot number */
|
|
|
|
uint64_t r_pr;
|
|
|
|
uint64_t r_psr; /* User mask */
|
|
|
|
uint64_t r_ar_rsc;
|
|
|
|
uint64_t r_ar_bsp;
|
|
|
|
uint64_t r_ar_bspstore;
|
|
|
|
uint64_t r_ar_rnat;
|
|
|
|
uint64_t r_ar_ccv;
|
|
|
|
uint64_t r_ar_unat;
|
|
|
|
uint64_t r_ar_fpsr;
|
|
|
|
uint64_t r_ar_pfs;
|
|
|
|
uint64_t r_ar_lc;
|
2002-05-20 05:41:20 +00:00
|
|
|
uint64_t r_ar_ec;
|
2000-09-29 13:46:07 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
struct fpreg {
|
|
|
|
struct ia64_fpreg fpr_regs[128];
|
|
|
|
};
|
|
|
|
|
|
|
|
struct dbreg {
|
2002-05-10 07:33:11 +00:00
|
|
|
uint64_t dbr_data[8];
|
|
|
|
uint64_t dbr_inst[8];
|
2000-09-29 13:46:07 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#ifdef _KERNEL
|
|
|
|
|
2001-09-12 08:38:13 +00:00
|
|
|
struct thread;
|
2000-09-29 13:46:07 +00:00
|
|
|
|
2002-03-20 23:30:31 +00:00
|
|
|
void restorehighfp(struct ia64_fpreg *);
|
|
|
|
void savehighfp(struct ia64_fpreg *);
|
[partially forced commit due to pilot error in earlier commit attempt]
{set,fill}_{,fp,db}regs() fixup:
- Add dummy {set,fill}_dbregs() on architectures that don't have them.
- KSEfy the powerpc versions (struct proc -> struct thread).
- Some architectures had the prototypes in md_var.h, some in reg.h, and
some in both; for consistency, move them to reg.h on all platforms.
These functions aren't really MD (the implementation is MD, but the interface
is MI), so they should move to an MI header, but I haven't figured out which
one yet.
Run-tested on i386, build-tested on Alpha, untested on other platforms.
2001-10-21 22:16:48 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* XXX these interfaces are MI, so they should be declared in a MI place.
|
|
|
|
*/
|
2002-03-20 23:30:31 +00:00
|
|
|
void setregs(struct thread *, u_long, u_long, u_long);
|
|
|
|
int fill_regs(struct thread *, struct reg *);
|
|
|
|
int set_regs(struct thread *, struct reg *);
|
|
|
|
int fill_fpregs(struct thread *, struct fpreg *);
|
|
|
|
int set_fpregs(struct thread *, struct fpreg *);
|
|
|
|
int fill_dbregs(struct thread *, struct dbreg *);
|
|
|
|
int set_dbregs(struct thread *, struct dbreg *);
|
2000-09-29 13:46:07 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* _MACHINE_REG_H_ */
|