[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PATCH 11/35] target-alpha: Add IPRs to be used by the emul
From: |
Richard Henderson |
Subject: |
[Qemu-devel] [PATCH 11/35] target-alpha: Add IPRs to be used by the emulation PALcode. |
Date: |
Mon, 9 May 2011 14:34:25 -0700 |
These aren't actually used yet, but we can at least access
them via the HW_MFPR and HW_MTPR instructions.
Signed-off-by: Richard Henderson <address@hidden>
---
target-alpha/cpu.h | 13 +++++++
target-alpha/translate.c | 87 ++++++++++++++++++++++++++++++++++++++++++++-
2 files changed, 98 insertions(+), 2 deletions(-)
diff --git a/target-alpha/cpu.h b/target-alpha/cpu.h
index 60b753f..60445dc 100644
--- a/target-alpha/cpu.h
+++ b/target-alpha/cpu.h
@@ -247,6 +247,7 @@ struct CPUAlphaState {
uint8_t intr_flag;
uint8_t fen;
uint8_t pal_mode;
+ uint32_t pcc_ofs;
/* These pass data from the exception logic in the translator and
helpers to the OS entry point. This is used for both system
@@ -255,6 +256,18 @@ struct CPUAlphaState {
uint64_t trap_arg1;
uint64_t trap_arg2;
+#if !defined(CONFIG_USER_ONLY)
+ /* The internal data required by our emulation of the Unix PALcode. */
+ uint64_t exc_addr;
+ uint64_t palbr;
+ uint64_t ptbr;
+ uint64_t vptptr;
+ uint64_t sysval;
+ uint64_t usp;
+ uint64_t shadow[8];
+ uint64_t scratch[24];
+#endif
+
#if TARGET_LONG_BITS > HOST_LONG_BITS
/* temporary fixed-point registers
* used to emulate 64 bits target on 32 bits hosts
diff --git a/target-alpha/translate.c b/target-alpha/translate.c
index b14b8fc..9e1576d 100644
--- a/target-alpha/translate.c
+++ b/target-alpha/translate.c
@@ -1468,6 +1468,89 @@ static void gen_rx(int ra, int set)
tcg_temp_free_i32(tmp);
}
+#ifndef CONFIG_USER_ONLY
+
+#define PR_BYTE 0x100000
+#define PR_LONG 0x200000
+
+static int cpu_pr_data(int pr)
+{
+ switch (pr) {
+ case 0: return offsetof(CPUAlphaState, ps) | PR_BYTE;
+ case 1: return offsetof(CPUAlphaState, fen) | PR_BYTE;
+ case 2: return offsetof(CPUAlphaState, pcc_ofs) | PR_LONG;
+ case 3: return offsetof(CPUAlphaState, trap_arg0);
+ case 4: return offsetof(CPUAlphaState, trap_arg1);
+ case 5: return offsetof(CPUAlphaState, trap_arg2);
+ case 6: return offsetof(CPUAlphaState, exc_addr);
+ case 7: return offsetof(CPUAlphaState, palbr);
+ case 8: return offsetof(CPUAlphaState, ptbr);
+ case 9: return offsetof(CPUAlphaState, vptptr);
+ case 10: return offsetof(CPUAlphaState, unique);
+ case 11: return offsetof(CPUAlphaState, sysval);
+ case 12: return offsetof(CPUAlphaState, usp);
+
+ case 32 ... 39:
+ return offsetof(CPUAlphaState, shadow[pr - 32]);
+ case 40 ... 63:
+ return offsetof(CPUAlphaState, scratch[pr - 40]);
+ }
+ return 0;
+}
+
+static void gen_mfpr(int ra, int regno)
+{
+ int data = cpu_pr_data(regno);
+
+ /* In our emulated PALcode, these processor registers have no
+ side effects from reading. */
+ if (ra == 31) {
+ return;
+ }
+
+ /* The basic registers are data only, and unknown registers
+ are read-zero, write-ignore. */
+ if (data == 0) {
+ tcg_gen_movi_i64(cpu_ir[ra], 0);
+ } else if (data & PR_BYTE) {
+ tcg_gen_ld8u_i64(cpu_ir[ra], cpu_env, data & ~PR_BYTE);
+ } else if (data & PR_LONG) {
+ tcg_gen_ld32s_i64(cpu_ir[ra], cpu_env, data & ~PR_LONG);
+ } else {
+ tcg_gen_ld_i64(cpu_ir[ra], cpu_env, data);
+ }
+}
+
+static void gen_mtpr(int rb, int regno)
+{
+ TCGv tmp;
+ int data;
+
+ if (rb == 31) {
+ tmp = tcg_const_i64(0);
+ } else {
+ tmp = cpu_ir[rb];
+ }
+
+ /* The basic registers are data only, and unknown registers
+ are read-zero, write-ignore. */
+ data = cpu_pr_data(regno);
+ if (data != 0) {
+ if (data & PR_BYTE) {
+ tcg_gen_st8_i64(tmp, cpu_env, data & ~PR_BYTE);
+ } else if (data & PR_LONG) {
+ tcg_gen_st32_i64(tmp, cpu_env, data & ~PR_LONG);
+ } else {
+ tcg_gen_st_i64(tmp, cpu_env, data);
+ }
+ }
+
+ if (rb == 31) {
+ tcg_temp_free(tmp);
+ }
+}
+#endif /* !USER_ONLY*/
+
static ExitStatus translate_one(DisasContext *ctx, uint32_t insn)
{
uint32_t palcode;
@@ -2580,7 +2663,7 @@ static ExitStatus translate_one(DisasContext *ctx,
uint32_t insn)
#else
if (!ctx->pal_mode)
goto invalid_opc;
- tcg_abort();
+ gen_mfpr(ra, insn & 0xffff);
break;
#endif
case 0x1A:
@@ -2856,7 +2939,7 @@ static ExitStatus translate_one(DisasContext *ctx,
uint32_t insn)
#else
if (!ctx->pal_mode)
goto invalid_opc;
- abort();
+ gen_mtpr(rb, insn & 0xffff);
break;
#endif
case 0x1E:
--
1.7.4.4
- [Qemu-devel] [PATCH 00/35] Alpha system emulation, v4, Richard Henderson, 2011/05/09
- [Qemu-devel] [PATCH 01/35] Export the unassigned_mem read/write functions., Richard Henderson, 2011/05/09
- [Qemu-devel] [PATCH 02/35] target-alpha: Disassemble EV6 PALcode instructions., Richard Henderson, 2011/05/09
- [Qemu-devel] [PATCH 03/35] pci: Export pci_to_cpu_addr., Richard Henderson, 2011/05/09
- [Qemu-devel] [PATCH 04/35] target-alpha: Single-step properly across branches., Richard Henderson, 2011/05/09
- [Qemu-devel] [PATCH 06/35] target-alpha: Enable the alpha-softmmu target., Richard Henderson, 2011/05/09
- [Qemu-devel] [PATCH 07/35] target-alpha: Tidy exception constants., Richard Henderson, 2011/05/09
- [Qemu-devel] [PATCH 09/35] target-alpha: Cleanup MMU modes., Richard Henderson, 2011/05/09
- [Qemu-devel] [PATCH 11/35] target-alpha: Add IPRs to be used by the emulation PALcode.,
Richard Henderson <=
- [Qemu-devel] [PATCH 10/35] target-alpha: Fixup translation of PALmode instructions., Richard Henderson, 2011/05/09
- [Qemu-devel] [PATCH 12/35] target-alpha: Tidy up arithmetic exceptions., Richard Henderson, 2011/05/09
- [Qemu-devel] [PATCH 13/35] target-alpha: Use do_restore_state for arithmetic exceptions., Richard Henderson, 2011/05/09
- [Qemu-devel] [PATCH 05/35] target-alpha: Remove partial support for palcode emulation., Richard Henderson, 2011/05/09
- [Qemu-devel] [PATCH 14/35] target-alpha: Merge HW_REI and HW_RET implementations., Richard Henderson, 2011/05/09
- [Qemu-devel] [PATCH 08/35] target-alpha: Rationalize internal processor registers., Richard Henderson, 2011/05/09
- [Qemu-devel] [PATCH 15/35] target-alpha: Implement do_interrupt for system mode., Richard Henderson, 2011/05/09
- [Qemu-devel] [PATCH 16/35] target-alpha: Swap shadow registers moving to/from PALmode., Richard Henderson, 2011/05/09
- [Qemu-devel] [PATCH 17/35] target-alpha: Add various symbolic constants., Richard Henderson, 2011/05/09
- [Qemu-devel] [PATCH 18/35] target-alpha: Use kernel mmu_idx for pal_mode., Richard Henderson, 2011/05/09