From: Mykyta Poturai <Mykyta_Poturai@epam.com>
To: "xen-devel@lists.xenproject.org" <xen-devel@lists.xenproject.org>
Cc: "Mykyta Poturai" <Mykyta_Poturai@epam.com>,
"Andrew Cooper" <andrew.cooper3@citrix.com>,
"Anthony PERARD" <anthony.perard@vates.tech>,
"Michal Orzel" <michal.orzel@amd.com>,
"Jan Beulich" <jbeulich@suse.com>,
"Julien Grall" <julien@xen.org>,
"Roger Pau Monné" <roger.pau@citrix.com>,
"Stefano Stabellini" <sstabellini@kernel.org>,
"Bertrand Marquis" <bertrand.marquis@arm.com>,
"Volodymyr Babchuk" <Volodymyr_Babchuk@epam.com>
Subject: [PATCH v1 0/8] Implement PCI device enumeration on Arm part 1
Date: Wed, 24 Sep 2025 07:59:19 +0000 [thread overview]
Message-ID: <cover.1758618839.git.mykyta_poturai@epam.com> (raw)
This series adds basic PCI device enumeration in Xen on Arm. This will allow us
to not rely on Dom0 enumeration for supported controllers, which will enable PCI
passthrough for dom0less setups.
Enumeration is disabled by default and can be enabled with "pci-scan" cmdline
option.
For now the discovered devices are only assigned to HW domain. To achieve this,
several things need to be done:
1. A VPCI node is created for HW domain device tree, and the real PCI nodes are
hidden from it.
2. Discovered devices BARs are initialized.
3. Register handles for VPCI are updated to change behaviour depending on
whether or not the calling domain uses VPCI or HW PCI, instead of relying on
is_hardware_domain()
4. PCI physdev ops are disabled for HW domain using VPCI.
Edward Pickup (1):
arm/pci: Add pci-scan boot argument
Luca Fancellu (3):
xen/pci: update DT for hwdom when it uses vpci
xen/pci: disable pci_device_{add,remove} when hwdom uses vpci on arm
xen/pci: assign discovered devices to hwdom
Mykyta Poturai (1):
arm/pci: enable vpci for hwdom when pci-scan is enabled
Stefano Stabellini (1):
xen/pci: introduce has_vpci_bridge
Stewart Hildebrand (2):
xen/dt: pass flags to callback in dt_for_each_range()
xen/pci: initialize BARs
docs/misc/xen-command-line.pandoc | 9 ++
xen/arch/arm/device.c | 4 +-
xen/arch/arm/domain_build.c | 154 +++++++++++++++++++++++-
xen/arch/arm/include/asm/domain.h | 3 +-
xen/arch/arm/include/asm/domain_build.h | 1 +
xen/arch/arm/include/asm/pci.h | 25 ++++
xen/arch/arm/include/asm/setup.h | 2 +-
xen/arch/arm/pci/pci-host-common.c | 83 ++++++++++++-
xen/arch/arm/pci/pci.c | 24 +++-
xen/arch/x86/include/asm/pci.h | 20 +++
xen/common/device-tree/device-tree.c | 5 +-
xen/common/rangeset.c | 35 ++++++
xen/drivers/passthrough/arm/iommu.c | 9 ++
xen/drivers/passthrough/pci.c | 119 +++++++++++++++++-
xen/drivers/pci/physdev.c | 6 +
xen/drivers/vpci/header.c | 14 +--
xen/drivers/vpci/vpci.c | 4 +-
xen/include/xen/device_tree.h | 2 +-
xen/include/xen/rangeset.h | 6 +-
xen/include/xen/vpci.h | 9 ++
20 files changed, 509 insertions(+), 25 deletions(-)
--
2.34.1
next reply other threads:[~2025-09-24 7:59 UTC|newest]
Thread overview: 18+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-09-24 7:59 Mykyta Poturai [this message]
2025-09-24 7:59 ` [PATCH v1 1/8] arm/pci: Add pci-scan boot argument Mykyta Poturai
2025-09-25 6:48 ` Jan Beulich
2025-09-24 7:59 ` [PATCH v1 3/8] xen/pci: update DT for hwdom when it uses vpci Mykyta Poturai
2025-09-25 6:50 ` Jan Beulich
2025-09-24 7:59 ` [PATCH v1 2/8] xen/dt: pass flags to callback in dt_for_each_range() Mykyta Poturai
2025-09-24 7:59 ` [PATCH v1 4/8] xen/pci: disable pci_device_{add,remove} when hwdom uses vpci on arm Mykyta Poturai
2025-10-13 11:56 ` Jan Beulich
2025-09-24 7:59 ` [PATCH v1 5/8] xen/pci: introduce has_vpci_bridge Mykyta Poturai
2025-11-06 12:15 ` Jan Beulich
2025-11-13 9:49 ` Mykyta Poturai
2025-11-13 10:07 ` Jan Beulich
2025-09-24 7:59 ` [PATCH v1 7/8] xen/pci: assign discovered devices to hwdom Mykyta Poturai
2025-11-06 13:18 ` Jan Beulich
2025-09-24 7:59 ` [PATCH v1 6/8] xen/pci: initialize BARs Mykyta Poturai
2025-11-06 13:03 ` Jan Beulich
2025-09-24 7:59 ` [PATCH v1 8/8] arm/pci: enable vpci for hwdom when pci-scan is enabled Mykyta Poturai
2025-09-24 9:50 ` Yann Sionneau
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=cover.1758618839.git.mykyta_poturai@epam.com \
--to=mykyta_poturai@epam.com \
--cc=Volodymyr_Babchuk@epam.com \
--cc=andrew.cooper3@citrix.com \
--cc=anthony.perard@vates.tech \
--cc=bertrand.marquis@arm.com \
--cc=jbeulich@suse.com \
--cc=julien@xen.org \
--cc=michal.orzel@amd.com \
--cc=roger.pau@citrix.com \
--cc=sstabellini@kernel.org \
--cc=xen-devel@lists.xenproject.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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.