12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788 |
- /*
- * RISC-V register structures
- *
- * Copyright (c) 2019 Mark Corbin
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, see <http://www.gnu.org/licenses/>.
- */
- #ifndef TARGET_ARCH_REG_H
- #define TARGET_ARCH_REG_H
- /* Compare with riscv/include/reg.h */
- typedef struct target_reg {
- uint64_t ra; /* return address */
- uint64_t sp; /* stack pointer */
- uint64_t gp; /* global pointer */
- uint64_t tp; /* thread pointer */
- uint64_t t[7]; /* temporaries */
- uint64_t s[12]; /* saved registers */
- uint64_t a[8]; /* function arguments */
- uint64_t sepc; /* exception program counter */
- uint64_t sstatus; /* status register */
- } target_reg_t;
- typedef struct target_fpreg {
- uint64_t fp_x[32][2]; /* Floating point registers */
- uint64_t fp_fcsr; /* Floating point control reg */
- } target_fpreg_t;
- #define tswapreg(ptr) tswapal(ptr)
- /* Compare with struct trapframe in riscv/include/frame.h */
- static inline void target_copy_regs(target_reg_t *regs,
- const CPURISCVState *env)
- {
- regs->ra = tswapreg(env->gpr[1]);
- regs->sp = tswapreg(env->gpr[2]);
- regs->gp = tswapreg(env->gpr[3]);
- regs->tp = tswapreg(env->gpr[4]);
- regs->t[0] = tswapreg(env->gpr[5]);
- regs->t[1] = tswapreg(env->gpr[6]);
- regs->t[2] = tswapreg(env->gpr[7]);
- regs->t[3] = tswapreg(env->gpr[28]);
- regs->t[4] = tswapreg(env->gpr[29]);
- regs->t[5] = tswapreg(env->gpr[30]);
- regs->t[6] = tswapreg(env->gpr[31]);
- regs->s[0] = tswapreg(env->gpr[8]);
- regs->s[1] = tswapreg(env->gpr[9]);
- regs->s[2] = tswapreg(env->gpr[18]);
- regs->s[3] = tswapreg(env->gpr[19]);
- regs->s[4] = tswapreg(env->gpr[20]);
- regs->s[5] = tswapreg(env->gpr[21]);
- regs->s[6] = tswapreg(env->gpr[22]);
- regs->s[7] = tswapreg(env->gpr[23]);
- regs->s[8] = tswapreg(env->gpr[24]);
- regs->s[9] = tswapreg(env->gpr[25]);
- regs->s[10] = tswapreg(env->gpr[26]);
- regs->s[11] = tswapreg(env->gpr[27]);
- regs->a[0] = tswapreg(env->gpr[10]);
- regs->a[1] = tswapreg(env->gpr[11]);
- regs->a[2] = tswapreg(env->gpr[12]);
- regs->a[3] = tswapreg(env->gpr[13]);
- regs->a[4] = tswapreg(env->gpr[14]);
- regs->a[5] = tswapreg(env->gpr[15]);
- regs->a[6] = tswapreg(env->gpr[16]);
- regs->a[7] = tswapreg(env->gpr[17]);
- regs->sepc = tswapreg(env->pc);
- }
- #undef tswapreg
- #endif /* TARGET_ARCH_REG_H */
|