On Fri, Aug 22, 2025 at 06:24:02PM +0900, CJ Chen wrote:
> Add documentation to clarify that if `.valid.unaligned = true` but
> `.impl.unaligned = false`, QEMU’s memory core will automatically split
> unaligned guest accesses into multiple aligned accesses. This helps
> devices avoid implementing their own unaligned logic, but can be
> problematic for devices with side-effect-heavy registers. Also note
> that setting `.valid.unaligned = false` together with
> `.impl.unaligned = true` is invalid, as it contradicts itself and
> will trigger an assertion.
>
> Signed-off-by: CJ Chen <cjchen@igel.co.jp>
> Acked-by: Tomoyuki Hirose <hrstmyk811m@gmail.com>
> Suggested-by: Peter Maydell <peter.maydell@linaro.org>
> ---
> docs/devel/memory.rst | 18 ++++++++++++++++++
> 1 file changed, 18 insertions(+)
>
> diff --git a/docs/devel/memory.rst b/docs/devel/memory.rst
> index 57fb2aec76..71d7de7ae5 100644
> --- a/docs/devel/memory.rst
> +++ b/docs/devel/memory.rst
> @@ -365,6 +365,24 @@ callbacks are called:
> - .impl.unaligned specifies that the *implementation* supports unaligned
> accesses; if false, unaligned accesses will be emulated by two aligned
> accesses.
> +- Additionally, if .valid.unaligned = true but .impl.unaligned = false, the
> + memory core will emulate each unaligned guest access by splitting it into
> + multiple aligned sub-accesses. This ensures that devices which only handle
> + aligned requests do not need to implement unaligned logic themselves. For
> + example, see xhci_cap_ops in hw/usb/hcd-xhci.c: it sets .valid.unaligned
> + = true so guests can do unaligned reads on the xHCI Capability Registers,
> + while keeping .impl.unaligned = false to rely on the core splitting logic.
> + However, if a device’s registers have side effects on read or write, this
> + extra splitting can introduce undesired behavior. Specifically, for devices
> + whose registers trigger state changes on each read/write, splitting an access
> + can lead to reading or writing bytes beyond the originally requested subrange
> + thereby triggering repeated or otherwise unintended register side effects.
> + In such cases, one should set .valid.unaligned = false to reject unaligned
> + accesses entirely.
> +- Conversely, if .valid.unaligned = false but .impl.unaligned = true,
> + that setting is considered invalid; it claims unaligned access is allowed
> + by the implementation yet disallowed for the device. QEMU enforces this with
> + an assertion to prevent contradictory usage.
Some cosmetic comments only..
This shouldn't be another bullet, but rather a separate sub-section,
because it describes the relationship of above two entries.
IMO it can be better like this:
MMIO Operations
---------------
...
- .valid.min_access_size, .valid.max_access_size...
- .valid.unaligned... See :ref:`unaligned-mmio-accesses` for details.
- .impl.min_access_size, .impl.max_access_size...
- .impl.unaligned... See :ref:`unaligned-mmio-accesses` for details.
.. _unaligned-mmio-accesses:
Unaligned MMIO Accesses
~~~~~~~~~~~~~~~~~~~~~~~
...
--
Peter Xu