qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
* [Qemu-devel] [PATCH v5 0/3] spapr: introduce a fixed IRQ number space and an IRQ controller backend
@ 2018-07-26 13:37 Cédric Le Goater
  2018-07-26 13:37 ` [Qemu-devel] [PATCH v5 1/3] spapr: introduce a fixed IRQ number space Cédric Le Goater
                   ` (2 more replies)
  0 siblings, 3 replies; 12+ messages in thread
From: Cédric Le Goater @ 2018-07-26 13:37 UTC (permalink / raw)
  To: David Gibson; +Cc: qemu-ppc, qemu-devel, Greg Kurz, Cédric Le Goater

Here is a proposal for a new IRQ number space layout using static
numbers and a bitmap allocator for the MSIs. The previous layout is
kept for compatibly in machines raising the 'legacy_irq_allocation' flag.

The patchset also introduces a sPAPR IRQ interface which offers the
possibility to provide different IRQ controller backend to the sPAPR
machine. This is preparing ground for the new XIVE controller.

The new XICS layout will only be activated when a new pseries-3.1
machine is introduced.

Thanks,

C.

Changes since v4 :

 - assigned IRQ numbers to their default static values
 - improved the reg_to_irq conversion routine for the VIO devices

Changes since v3 :

 - introduced a reg_to_irq conversion routine for the VIO devices

Changes since v2 :

 - renamed 'xics_legacy' to 'legacy_irq_allocation'
 - introduced the sPAPR IRQ backend interface
 - increase the size of the IRQ number space for newer machines

Changes since v1 :

 - removed block allocation
 - spaced the IRQ offsets 
 - check for overlaps when allocating VIO irqs
 - removed 'Error *' arg from spapr_irq_msi_init() 

Cédric Le Goater (3):
  spapr: introduce a fixed IRQ number space
  spapr: introduce a IRQ controller backend to the machine
  spapr: increase the size of the IRQ number space

 include/hw/ppc/spapr.h     |  16 +-
 include/hw/ppc/spapr_irq.h |  55 +++++++
 hw/ppc/spapr.c             | 203 ++++---------------------
 hw/ppc/spapr_cpu_core.c    |   1 +
 hw/ppc/spapr_events.c      |  12 +-
 hw/ppc/spapr_irq.c         | 296 +++++++++++++++++++++++++++++++++++++
 hw/ppc/spapr_pci.c         |  29 +++-
 hw/ppc/spapr_vio.c         |  65 +++++++-
 hw/ppc/Makefile.objs       |   2 +-
 9 files changed, 480 insertions(+), 199 deletions(-)
 create mode 100644 include/hw/ppc/spapr_irq.h
 create mode 100644 hw/ppc/spapr_irq.c

-- 
2.17.1

^ permalink raw reply	[flat|nested] 12+ messages in thread

end of thread, other threads:[~2018-07-30 13:57 UTC | newest]

Thread overview: 12+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2018-07-26 13:37 [Qemu-devel] [PATCH v5 0/3] spapr: introduce a fixed IRQ number space and an IRQ controller backend Cédric Le Goater
2018-07-26 13:37 ` [Qemu-devel] [PATCH v5 1/3] spapr: introduce a fixed IRQ number space Cédric Le Goater
2018-07-27  3:56   ` David Gibson
2018-07-27  6:56     ` Cédric Le Goater
2018-07-30  9:05     ` Cédric Le Goater
2018-07-30  9:39       ` David Gibson
2018-07-26 13:37 ` [Qemu-devel] [PATCH v5 2/3] spapr: introduce a IRQ controller backend to the machine Cédric Le Goater
2018-07-27  5:16   ` David Gibson
2018-07-27  7:04     ` Cédric Le Goater
2018-07-30  4:05       ` David Gibson
2018-07-30 13:57     ` Cédric Le Goater
2018-07-26 13:37 ` [Qemu-devel] [PATCH v5 3/3] spapr: increase the size of the IRQ number space Cédric Le Goater

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).