#include "unwind_i.h"
#if 0#endif
HIDDEN int
tdep_access_reg (struct cursor *c, unw_regnum_t reg, unw_word_t *valp,
int write)
{
dwarf_loc_t loc = DWARF_NULL_LOC;
unsigned int mask;
int arg_num;
switch (reg)
{
case UNW_X86_64_RIP:
if (write)
c->dwarf.ip = *valp;
loc = c->dwarf.loc[RIP];
break;
case UNW_X86_64_CFA:
if (write)
return -UNW_EREADONLYREG;
*valp = c->dwarf.cfa;
return 0;
case UNW_X86_64_RAX:
case UNW_X86_64_RDX:
arg_num = reg - UNW_X86_64_RAX;
mask = (1 << arg_num);
if (write)
{
c->dwarf.eh_args[arg_num] = *valp;
c->dwarf.eh_valid_mask |= mask;
return 0;
}
else if ((c->dwarf.eh_valid_mask & mask) != 0)
{
*valp = c->dwarf.eh_args[arg_num];
return 0;
}
else
loc = c->dwarf.loc[(reg == UNW_X86_64_RAX) ? RAX : RDX];
break;
case UNW_X86_64_RCX: loc = c->dwarf.loc[RCX]; break;
case UNW_X86_64_RBX: loc = c->dwarf.loc[RBX]; break;
case UNW_X86_64_RSP: loc = c->dwarf.loc[RSP]; break;
case UNW_X86_64_RBP: loc = c->dwarf.loc[RBP]; break;
case UNW_X86_64_RSI: loc = c->dwarf.loc[RSI]; break;
case UNW_X86_64_RDI: loc = c->dwarf.loc[RDI]; break;
case UNW_X86_64_R8: loc = c->dwarf.loc[R8]; break;
case UNW_X86_64_R9: loc = c->dwarf.loc[R9]; break;
case UNW_X86_64_R10: loc = c->dwarf.loc[R10]; break;
case UNW_X86_64_R11: loc = c->dwarf.loc[R11]; break;
case UNW_X86_64_R12: loc = c->dwarf.loc[R12]; break;
case UNW_X86_64_R13: loc = c->dwarf.loc[R13]; break;
case UNW_X86_64_R14: loc = c->dwarf.loc[R14]; break;
case UNW_X86_64_R15: loc = c->dwarf.loc[R15]; break;
default:
Debug (1, "bad register number %u\n", reg);
return -UNW_EBADREG;
}
if (write)
return dwarf_put (&c->dwarf, loc, *valp);
else
return dwarf_get (&c->dwarf, loc, valp);
}
HIDDEN int
tdep_access_fpreg (struct cursor *c UNUSED, unw_regnum_t reg UNUSED,
unw_fpreg_t *valp UNUSED, int write UNUSED)
{
return -UNW_EBADREG;
}