[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v14 08/15] hvf: arm: Ignore writes to CNTP_CTL_EL0
From: |
Phil Dennis-Jordan |
Subject: |
[PATCH v14 08/15] hvf: arm: Ignore writes to CNTP_CTL_EL0 |
Date: |
Fri, 13 Dec 2024 16:18:14 +0100 |
From: Alexander Graf <graf@amazon.com>
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>
Signed-off-by: Phil Dennis-Jordan <phil@philjordan.eu>
Reviewed-by: Akihiko Odaki <akihiko.odaki@daynix.com>
Tested-by: Akihiko Odaki <akihiko.odaki@daynix.com>
---
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 ca7ea92774a..d75e504dcda 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"
@@ -184,6 +185,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)
@@ -1620,6 +1622,13 @@ static int hvf_sysreg_write(CPUState *cpu, uint32_t reg,
uint64_t val)
case SYSREG_OSLAR_EL1:
env->cp15.oslsr_el1 = val & 1;
return 0;
+ 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");
+ return 0;
case SYSREG_OSDLR_EL1:
/* Dummy register */
return 0;
--
2.39.5 (Apple Git-154)
- [PATCH v13 10/15] hw/vmapple/aes: Introduce aes engine, (continued)
- [PATCH v13 10/15] hw/vmapple/aes: Introduce aes engine, Phil Dennis-Jordan, 2024/12/13
- [PATCH v13 04/15] hw/display/apple-gfx: Adds configurable mode list, Phil Dennis-Jordan, 2024/12/13
- [PATCH v13 06/15] hw: Add vmapple subdir, Phil Dennis-Jordan, 2024/12/13
- [PATCH v13 07/15] hw/misc/pvpanic: Add MMIO interface, Phil Dennis-Jordan, 2024/12/13
- [PATCH v13 08/15] hvf: arm: Ignore writes to CNTP_CTL_EL0, Phil Dennis-Jordan, 2024/12/13
- [PATCH v13 13/15] hw/vmapple/virtio-blk: Add support for apple virtio-blk, Phil Dennis-Jordan, 2024/12/13
- [PATCH v13 11/15] hw/vmapple/bdif: Introduce vmapple backdoor interface, Phil Dennis-Jordan, 2024/12/13
- [PATCH v13 15/15] hw/vmapple/vmapple: Add vmapple machine type, Phil Dennis-Jordan, 2024/12/13
- [PATCH v14 01/15] ui & main loop: Redesign of system-specific main thread event handling, Phil Dennis-Jordan, 2024/12/13
- [PATCH v14 03/15] hw/display/apple-gfx: Adds PCI implementation, Phil Dennis-Jordan, 2024/12/13
- [PATCH v14 08/15] hvf: arm: Ignore writes to CNTP_CTL_EL0,
Phil Dennis-Jordan <=
- [PATCH v14 09/15] gpex: Allow more than 4 legacy IRQs, Phil Dennis-Jordan, 2024/12/13
- [PATCH v14 11/15] hw/vmapple/bdif: Introduce vmapple backdoor interface, Phil Dennis-Jordan, 2024/12/13
- [PATCH v13 14/15] hw/block/virtio-blk: Replaces request free function with g_free, Phil Dennis-Jordan, 2024/12/13
- [PATCH v14 00/15] macOS PV Graphics and new vmapple machine type, Phil Dennis-Jordan, 2024/12/13
- [PATCH v14 02/15] hw/display/apple-gfx: Introduce ParavirtualizedGraphics.Framework support, Phil Dennis-Jordan, 2024/12/13
- [PATCH v14 13/15] hw/vmapple/virtio-blk: Add support for apple virtio-blk, Phil Dennis-Jordan, 2024/12/13
- [PATCH v14 06/15] hw: Add vmapple subdir, Phil Dennis-Jordan, 2024/12/13
- [PATCH v14 05/15] MAINTAINERS: Add myself as maintainer for apple-gfx, reviewer for HVF, Phil Dennis-Jordan, 2024/12/13
- [PATCH v14 07/15] hw/misc/pvpanic: Add MMIO interface, Phil Dennis-Jordan, 2024/12/13