From: David Gibson <david@gibson.dropbear.id.au>
To: agraf@suse.de, qemu-ppc@nongnu.org
Cc: Alexey Kardashevskiy <aik@ozlabs.ru>,
aliguori@us.ibm.com, qemu-devel@nongnu.org,
David Gibson <david@gibson.dropbear.id.au>
Subject: [Qemu-devel] [PATCH 04/10] pseries: Separate PCI RTAS setup from common from emulation specific PCI setup
Date: Wed, 8 Aug 2012 12:10:33 +1000 [thread overview]
Message-ID: <1344391839-2006-5-git-send-email-david@gibson.dropbear.id.au> (raw)
In-Reply-To: <1344391839-2006-1-git-send-email-david@gibson.dropbear.id.au>
Currently the RTAS functions for handling PCI are registered from the
class init code for the PCI host bridge. That sort of makes sense
now, but will break in the future when vfio gives us multiple types of
host bridge for pseries (emulated and pass-through, at least). The
RTAS functions will be common across all host bridge types (and will
call out to different places internally depending on the type).
So, this patch moves the RTAS registration into its own function
called direct from the machine setup code.
Signed-off-by: Alexey Kardashevskiy <aik@ozlabs.ru>
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
---
hw/spapr.c | 2 ++
hw/spapr_pci.c | 13 ++++++++-----
hw/spapr_pci.h | 2 ++
3 files changed, 12 insertions(+), 5 deletions(-)
diff --git a/hw/spapr.c b/hw/spapr.c
index cdc66d1..8b4af62 100644
--- a/hw/spapr.c
+++ b/hw/spapr.c
@@ -681,6 +681,8 @@ static void ppc_spapr_init(ram_addr_t ram_size,
}
/* Set up PCI */
+ spapr_pci_rtas_init();
+
spapr_create_phb(spapr, "pci", SPAPR_PCI_BUID,
SPAPR_PCI_MEM_WIN_ADDR,
SPAPR_PCI_MEM_WIN_SIZE,
diff --git a/hw/spapr_pci.c b/hw/spapr_pci.c
index 65ae8c4..fcc358e 100644
--- a/hw/spapr_pci.c
+++ b/hw/spapr_pci.c
@@ -359,11 +359,6 @@ static void spapr_phb_class_init(ObjectClass *klass, void *data)
sdc->init = spapr_phb_init;
dc->props = spapr_phb_properties;
-
- spapr_rtas_register("read-pci-config", rtas_read_pci_config);
- spapr_rtas_register("write-pci-config", rtas_write_pci_config);
- spapr_rtas_register("ibm,read-pci-config", rtas_ibm_read_pci_config);
- spapr_rtas_register("ibm,write-pci-config", rtas_ibm_write_pci_config);
}
static TypeInfo spapr_phb_info = {
@@ -488,6 +483,14 @@ int spapr_populate_pci_dt(sPAPRPHBState *phb,
return 0;
}
+void spapr_pci_rtas_init(void)
+{
+ spapr_rtas_register("read-pci-config", rtas_read_pci_config);
+ spapr_rtas_register("write-pci-config", rtas_write_pci_config);
+ spapr_rtas_register("ibm,read-pci-config", rtas_ibm_read_pci_config);
+ spapr_rtas_register("ibm,write-pci-config", rtas_ibm_write_pci_config);
+}
+
static void register_types(void)
{
type_register_static(&spapr_phb_info);
diff --git a/hw/spapr_pci.h b/hw/spapr_pci.h
index 6bba885..2aee67f 100644
--- a/hw/spapr_pci.h
+++ b/hw/spapr_pci.h
@@ -63,4 +63,6 @@ int spapr_populate_pci_dt(sPAPRPHBState *phb,
uint32_t xics_phandle,
void *fdt);
+void spapr_pci_rtas_init(void);
+
#endif /* __HW_SPAPR_PCI_H__ */
--
1.7.10.4
next prev parent reply other threads:[~2012-08-08 2:10 UTC|newest]
Thread overview: 17+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-08-08 2:10 [Qemu-devel] [0/10] pseries updates and cleanups David Gibson
2012-08-08 2:10 ` [Qemu-devel] [PATCH 01/10] pseries: Update SLOF David Gibson
2012-08-08 2:10 ` [Qemu-devel] [PATCH 02/10] pseries: Remove extraneous prints David Gibson
2012-08-08 2:10 ` [Qemu-devel] [PATCH 03/10] pseries: Rework irq assignment to avoid carrying qemu_irqs around David Gibson
2012-08-08 2:10 ` David Gibson [this message]
2012-08-08 2:10 ` [Qemu-devel] [PATCH 05/10] pseries: added allocator for a block of IRQs David Gibson
2012-08-08 2:10 ` [Qemu-devel] [PATCH 06/10] pseries: Export find_phb() utility function for PCI code David Gibson
2012-08-14 11:45 ` Alexander Graf
2012-08-15 1:03 ` [Qemu-devel] [Qemu-ppc] " David Gibson
2012-08-08 2:10 ` [Qemu-devel] [PATCH 07/10] pseries: Add trace event for PCI irqs David Gibson
2012-08-08 2:10 ` [Qemu-devel] [PATCH 08/10] pseries: Add PCI MSI/MSI-X support David Gibson
2012-08-08 2:10 ` [Qemu-devel] [PATCH 09/10] pseries dma: DMA window params added to PHB and DT population changed David Gibson
2012-08-08 2:10 ` [Qemu-devel] [PATCH 10/10] pseries: Update SLOF firmware image David Gibson
2012-08-14 12:34 ` [Qemu-devel] [0/10] pseries updates and cleanups Alexander Graf
2012-08-14 12:56 ` [Qemu-devel] [Qemu-ppc] " Alexander Graf
2012-08-15 1:05 ` David Gibson
2012-08-15 9:30 ` Alexander Graf
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=1344391839-2006-5-git-send-email-david@gibson.dropbear.id.au \
--to=david@gibson.dropbear.id.au \
--cc=agraf@suse.de \
--cc=aik@ozlabs.ru \
--cc=aliguori@us.ibm.com \
--cc=qemu-devel@nongnu.org \
--cc=qemu-ppc@nongnu.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).