#include "ppc-macosx-regs.h"
#include "defs.h"
#include "frame.h"
#include "inferior.h"
#include "symtab.h"
#include "target.h"
#include "gdbcore.h"
#include "symfile.h"
#include "objfiles.h"
#include "regcache.h"
#include "ppc-macosx-regs.h"
#define supply_unsigned_int(regnum, val)\
store_unsigned_integer (buf, 4, val); \
supply_register(regnum, buf);
#define collect_unsigned_int(regnum, addr)\
regcache_collect (regnum, buf); \
(* (addr)) = extract_unsigned_integer (buf, 4);
void ppc_macosx_fetch_gp_registers (gdb_ppc_thread_state_t *gp_regs)
{
int i;
unsigned char buf[4];
for (i = 0; i < NUM_GP_REGS; i++) {
supply_unsigned_int (FIRST_GP_REGNUM + i, gp_regs->gpregs[i]);
}
supply_unsigned_int (PC_REGNUM, gp_regs->srr0);
supply_unsigned_int (PS_REGNUM, gp_regs->srr1);
supply_unsigned_int (CR_REGNUM, gp_regs->cr);
supply_unsigned_int (LR_REGNUM, gp_regs->lr);
supply_unsigned_int (CTR_REGNUM, gp_regs->ctr);
supply_unsigned_int (XER_REGNUM, gp_regs->xer);
supply_unsigned_int (MQ_REGNUM, gp_regs->mq);
}
void ppc_macosx_store_gp_registers (gdb_ppc_thread_state_t *gp_regs)
{
int i;
unsigned char buf[4];
for (i = 0; i < NUM_GP_REGS; i++) {
collect_unsigned_int (FIRST_GP_REGNUM + i, &gp_regs->gpregs[i]);
}
collect_unsigned_int (PC_REGNUM, &gp_regs->srr0);
collect_unsigned_int (PS_REGNUM, &gp_regs->srr1);
collect_unsigned_int (CR_REGNUM, &gp_regs->cr);
collect_unsigned_int (LR_REGNUM, &gp_regs->lr);
collect_unsigned_int (CTR_REGNUM, &gp_regs->ctr);
collect_unsigned_int (XER_REGNUM, &gp_regs->xer);
collect_unsigned_int (MQ_REGNUM, &gp_regs->mq);
}
void ppc_macosx_fetch_fp_registers (gdb_ppc_thread_fpstate_t *fp_regs)
{
int i;
unsigned char buf[sizeof (FP_REGISTER_TYPE)];
FP_REGISTER_TYPE *fpr = fp_regs->fpregs;
for (i = 0; i < NUM_FP_REGS; i++) {
store_floating (buf, sizeof (FP_REGISTER_TYPE), fpr[i]);
supply_register (FIRST_FP_REGNUM + i, buf);
}
supply_unsigned_int (FPSCR_REGNUM, fp_regs->fpscr);
}
void ppc_macosx_store_fp_registers (gdb_ppc_thread_fpstate_t *fp_regs)
{
int i;
unsigned char buf[sizeof (FP_REGISTER_TYPE)];
FP_REGISTER_TYPE *fpr = fp_regs->fpregs;
for (i = 0; i < NUM_FP_REGS; i++) {
regcache_collect (FIRST_FP_REGNUM + i, buf);
fpr[i] = extract_floating (buf, sizeof (FP_REGISTER_TYPE));
}
fp_regs->fpscr_pad = 0;
collect_unsigned_int (FPSCR_REGNUM, &fp_regs->fpscr);
}
void ppc_macosx_fetch_vp_registers (gdb_ppc_thread_vpstate_t *vp_regs)
{
int i, j;
char buf[16];
for (i = 0; i < NUM_VP_REGS; i++) {
for (j = 0; j < 4; j++) {
store_unsigned_integer (buf + (j * 4), 4, vp_regs->save_vr[i][j]);
}
supply_register (FIRST_VP_REGNUM + i, buf);
}
supply_unsigned_int (VSCR_REGNUM, vp_regs->save_vscr[3]);
supply_unsigned_int (VRSAVE_REGNUM, vp_regs->save_vrvalid);
}
void ppc_macosx_store_vp_registers (gdb_ppc_thread_vpstate_t *vp_regs)
{
int i, j;
char buf[16];
for (i = 0; i < NUM_VP_REGS; i++) {
regcache_collect (FIRST_VP_REGNUM + i, buf);
for (j = 0; j < 4; j++) {
vp_regs->save_vr[i][j] = extract_unsigned_integer (buf + (j * 4), 4);
}
}
memset (&vp_regs->save_vscr, 0, sizeof (vp_regs->save_vscr));
regcache_collect (VSCR_REGNUM, &vp_regs->save_vscr[3]);
memset (&vp_regs->save_pad5, 0, sizeof (vp_regs->save_pad5));
regcache_collect (VRSAVE_REGNUM, &vp_regs->save_vrvalid);
memset (&vp_regs->save_pad5, 0, sizeof (vp_regs->save_pad6));
}
int
ppc_macosx_stab_reg_to_regnum (int num)
{
int regnum;
if (num <= 64)
{
regnum = num;
}
else if (num >= 77 && num < 109)
{
regnum = VP0_REGNUM + num - 77;
}
else
{
switch (num)
{
case 64:
regnum = MQ_REGNUM;
break;
case 65:
regnum = LR_REGNUM;
break;
case 66:
regnum = CTR_REGNUM;
break;
case 76:
regnum = XER_REGNUM;
break;
case 109:
regnum = VRSAVE_REGNUM;
break;
default:
regnum = num;
break;
}
}
return regnum;
}