qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
From: Helge Deller <deller@kernel.org>
To: Richard Henderson <richard.henderson@linaro.org>
Cc: qemu-devel@nongnu.org, Helge Deller <deller@gmx.de>
Subject: Re: [PATCH v3 5/9] hw/hppa: Move software power button address back into PDC
Date: Fri, 12 Jan 2024 23:44:17 +0100	[thread overview]
Message-ID: <ZaHAwUC1V3WJpk5T@p100> (raw)
In-Reply-To: <477fa733-0957-4026-ac06-57d76d4b0388@linaro.org>

> I think it would be better to pass this as a parameter to create_fw_cfg, or
> to drop the translated FW_CFG_IO_BASE parameter and merely pass in translate
> itself.

Like this?


The various operating systems (e.g. Linux, NetBSD) have issues
mapping the power button when it's stored in page zero.
NetBSD even crashes, because it fails to map that page and then
accesses unmapped memory.

Since we now have a consistent memory mapping of PDC in 32-bit
and 64-bit address space (the lower 32-bits of the address are in
sync) the power button can be moved back to PDC space.

This patch fixes the power button on Linux, NetBSD and HP-UX.

Signed-off-by: Helge Deller <deller@gmx.de>
Tested-by: Bruno Haible <bruno@clisp.org>

diff --git a/hw/hppa/machine.c b/hw/hppa/machine.c
index 54ca2fd91a..da85050f60 100644
--- a/hw/hppa/machine.c
+++ b/hw/hppa/machine.c
@@ -36,8 +36,8 @@
 
 #define MIN_SEABIOS_HPPA_VERSION 12 /* require at least this fw version */
 
-/* Power button address at &PAGE0->pad[4] */
-#define HPA_POWER_BUTTON (0x40 + 4 * sizeof(uint32_t))
+#define HPA_POWER_BUTTON        (FIRMWARE_END - 0x10)
+static hwaddr soft_power_reg;
 
 #define enable_lasi_lan()       0
 
@@ -45,7 +45,6 @@ static DeviceState *lasi_dev;
 
 static void hppa_powerdown_req(Notifier *n, void *opaque)
 {
-    hwaddr soft_power_reg = HPA_POWER_BUTTON;
     uint32_t val;
 
     val = ldl_be_phys(&address_space_memory, soft_power_reg);
@@ -191,7 +190,7 @@ static void fw_cfg_boot_set(void *opaque, const char *boot_device,
 }
 
 static FWCfgState *create_fw_cfg(MachineState *ms, PCIBus *pci_bus,
-                                 hwaddr addr)
+                                 hwaddr addr, hwaddr pwr_button_addr)
 {
     FWCfgState *fw_cfg;
     uint64_t val;
@@ -221,7 +220,7 @@ static FWCfgState *create_fw_cfg(MachineState *ms, PCIBus *pci_bus,
     fw_cfg_add_file(fw_cfg, "/etc/hppa/machine",
                     g_memdup(mc->name, len), len);
 
-    val = cpu_to_le64(HPA_POWER_BUTTON);
+    val = cpu_to_le64(pwr_button_addr);
     fw_cfg_add_file(fw_cfg, "/etc/hppa/power-button-addr",
                     g_memdup(&val, sizeof(val)), sizeof(val));
 
@@ -295,6 +294,8 @@ static TranslateFn *machine_HP_common_init_cpus(MachineState *machine)
         ram_max = 0xf0000000;      /* 3.75 GB (32-bit CPU) */
     }
 
+    soft_power_reg = translate(NULL, HPA_POWER_BUTTON);
+
     for (unsigned int i = 0; i < smp_cpus; i++) {
         g_autofree char *name = g_strdup_printf("cpu%u-io-eir", i);
 
@@ -407,7 +408,8 @@ static void machine_HP_common_init_tail(MachineState *machine, PCIBus *pci_bus,
     qemu_register_powerdown_notifier(&hppa_system_powerdown_notifier);
 
     /* fw_cfg configuration interface */
-    create_fw_cfg(machine, pci_bus, translate(NULL, FW_CFG_IO_BASE));
+    create_fw_cfg(machine, pci_bus, translate(NULL, FW_CFG_IO_BASE),
+        translate(NULL, HPA_POWER_BUTTON));
 
     /* Load firmware.  Given that this is not "real" firmware,
        but one explicitly written for the emulation, we might as


  reply	other threads:[~2024-01-12 22:44 UTC|newest]

Thread overview: 25+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2024-01-12 10:29 [PATCH v3 0/9] target/hppa qemu v8.2 regression fixes deller
2024-01-12 10:29 ` [PATCH v3 1/9] hw/hppa/machine: Allow up to 3840 MB total memory deller
2024-01-12 10:29 ` [PATCH v3 2/9] hw/hppa/machine: Disable default devices with --nodefaults option deller
2024-01-12 20:39   ` Richard Henderson
2024-01-26 12:02   ` David Woodhouse
2024-01-26 14:49     ` Helge Deller
2024-01-26 14:51       ` David Woodhouse
2024-01-12 10:29 ` [PATCH v3 3/9] hw/pci-host/astro: Add missing astro & elroy registers for NetBSD deller
2024-01-12 10:29 ` [PATCH v3 4/9] target/hppa: Fix PDC address translation on PA2.0 with PSW.W=0 deller
2024-01-12 21:54   ` Richard Henderson
2024-01-12 22:23     ` Helge Deller
2024-01-12 22:24       ` Richard Henderson
2024-01-12 10:29 ` [PATCH v3 5/9] hw/hppa: Move software power button address back into PDC deller
2024-01-12 22:07   ` Richard Henderson
2024-01-12 22:44     ` Helge Deller [this message]
2024-01-12 23:11       ` Richard Henderson
2024-01-12 23:15         ` Helge Deller
2024-01-12 23:27           ` Richard Henderson
2024-01-12 10:29 ` [PATCH v3 6/9] target/hppa: Avoid accessing %gr0 when raising exception deller
2024-01-12 10:29 ` [PATCH v3 7/9] target/hppa: Export function hppa_set_ior_and_isr() deller
2024-01-12 22:08   ` Richard Henderson
2024-01-12 10:29 ` [PATCH v3 8/9] target/hppa: Fix IOR and ISR on unaligned access trap deller
2024-01-12 22:08   ` Richard Henderson
2024-01-12 10:29 ` [PATCH v3 9/9] target/hppa: Fix IOR and ISR on error in probe deller
2024-01-12 22:08   ` Richard Henderson

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=ZaHAwUC1V3WJpk5T@p100 \
    --to=deller@kernel.org \
    --cc=deller@gmx.de \
    --cc=qemu-devel@nongnu.org \
    --cc=richard.henderson@linaro.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).