[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v2 04/12] hvf: arm: Ignore writes to CNTP_CTL_EL0
From: |
Alexander Graf |
Subject: |
[PATCH v2 04/12] hvf: arm: Ignore writes to CNTP_CTL_EL0 |
Date: |
Wed, 30 Aug 2023 16:14:17 +0000 |
MacOS unconditionally disables interrupts of the physical timer on boot
and then continues to use the virtual one. We don't really want to support
a full physical timer emulation, so let's just ignore those writes.
Signed-off-by: Alexander Graf <graf@amazon.com>
---
v1 -> v2:
- Add log message on write
---
target/arm/hvf/hvf.c | 9 +++++++++
1 file changed, 9 insertions(+)
diff --git a/target/arm/hvf/hvf.c b/target/arm/hvf/hvf.c
index 486f90be1d..02db3dc908 100644
--- a/target/arm/hvf/hvf.c
+++ b/target/arm/hvf/hvf.c
@@ -11,6 +11,7 @@
#include "qemu/osdep.h"
#include "qemu/error-report.h"
+#include "qemu/log.h"
#include "sysemu/runstate.h"
#include "sysemu/hvf.h"
@@ -179,6 +180,7 @@ void hvf_arm_init_debug(void)
#define SYSREG_OSLSR_EL1 SYSREG(2, 0, 1, 1, 4)
#define SYSREG_OSDLR_EL1 SYSREG(2, 0, 1, 3, 4)
#define SYSREG_CNTPCT_EL0 SYSREG(3, 3, 14, 0, 1)
+#define SYSREG_CNTP_CTL_EL0 SYSREG(3, 3, 14, 2, 1)
#define SYSREG_PMCR_EL0 SYSREG(3, 3, 9, 12, 0)
#define SYSREG_PMUSERENR_EL0 SYSREG(3, 3, 9, 14, 0)
#define SYSREG_PMCNTENSET_EL0 SYSREG(3, 3, 9, 12, 1)
@@ -1551,6 +1553,13 @@ static int hvf_sysreg_write(CPUState *cpu, uint32_t reg,
uint64_t val)
case SYSREG_OSLAR_EL1:
env->cp15.oslsr_el1 = val & 1;
break;
+ case SYSREG_CNTP_CTL_EL0:
+ /*
+ * Guests should not rely on the physical counter, but macOS emits
+ * disable writes to it. Let it do so, but ignore the requests.
+ */
+ qemu_log_mask(LOG_UNIMP, "Unsupported write to CNTP_CTL_EL0\n");
+ break;
case SYSREG_OSDLR_EL1:
/* Dummy register */
break;
--
2.39.2 (Apple Git-143)
Amazon Development Center Germany GmbH
Krausenstr. 38
10117 Berlin
Geschaeftsfuehrung: Christian Schlaeger, Jonathan Weiss
Eingetragen am Amtsgericht Charlottenburg unter HRB 149173 B
Sitz: Berlin
Ust-ID: DE 289 237 879
[PATCH v2 02/12] hw/misc/pvpanic: Add MMIO interface, Alexander Graf, 2023/08/30
[PATCH v2 04/12] hvf: arm: Ignore writes to CNTP_CTL_EL0,
Alexander Graf <=
[PATCH v2 05/12] hw: Add vmapple subdir, Alexander Graf, 2023/08/30
[PATCH v2 09/12] hw/vmapple/cfg: Introduce vmapple cfg region, Alexander Graf, 2023/08/30
[PATCH v2 06/12] gpex: Allow more than 4 legacy IRQs, Alexander Graf, 2023/08/30
[PATCH v2 10/12] hw/vmapple/apple-gfx: Introduce ParavirtualizedGraphics.Framework support, Alexander Graf, 2023/08/30
[PATCH v2 11/12] hw/vmapple/virtio-blk: Add support for apple virtio-blk, Alexander Graf, 2023/08/30
[PATCH v2 08/12] hw/vmapple/bdif: Introduce vmapple backdoor interface, Alexander Graf, 2023/08/30