Re: [PATCH] x86/reboot: Don't corrupt memory on non-BIOS systems
From: Roman Kisel
Date: Fri Jan 10 2025 - 15:51:38 EST
On Thu, 09 Jan 2025 19:23:31 -0800, H. Peter Anvin <hpa@xxxxxxxxx> wrote:
[...]
>Which system have you seen where this "corrupts" memory?
These are X86_64 systems that boot off of confguration in DeviceTree,
and neither ACPI, BIOS, nor UEFI are present. The processors start running
in the long mode right off the bat, and the physical memory below 4GiB
is non-RAM or reserved. The systems are virtual machines.
All that makes `*((unsigned short *)__va(0x472)) = mode;` constitue a
stray write and effectively corrupt contents at the address of 0x472
for these virtual systems.
On the physical systems I have had access to, 0x0..0x1000 seems to be
reported as reserved in E820 or UEFI memory map, and that's what the
CPU might need in the 16-bit mode for the brief times it might be used.
Perhaps, `native_machine_emergency_restart` being tailored to the quirks
of the physical hardware cannot absorb some condition around
`*((unsigned short *)__va(0x472)) = mode;` to make sure it is fine
to write at that address? In the light of that, the callback
`machine_ops.emergency_restart` looks as a safer option.