spapr/xive: introduce a XIVE interrupt controller
commit3aa597f6505b4d7b62a1b77ab95a233dd5c7c5f0
authorCédric Le Goater <clg@kaod.org>
Sun, 9 Dec 2018 19:45:56 +0000 (9 20:45 +0100)
committerDavid Gibson <david@gibson.dropbear.id.au>
Thu, 20 Dec 2018 22:37:38 +0000 (21 09:37 +1100)
tree013741d51fb30d5d39296624fdb237cb65247044
parentcdd4de68edb6745d35e2a9e14c32f9a588c1fee7
spapr/xive: introduce a XIVE interrupt controller

sPAPRXive models the XIVE interrupt controller of the sPAPR machine.
It inherits from the XiveRouter and provisions storage for the routing
tables :

  - Event Assignment Structure (EAS)
  - Event Notification Descriptor (END)

The sPAPRXive model incorporates an internal XiveSource for the IPIs
and for the interrupts of the virtual devices of the guest. This model
is consistent with XIVE architecture which also incorporates an
internal IVSE for IPIs and accelerator interrupts in the IVRE
sub-engine.

The sPAPRXive model exports two memory regions, one for the ESB
trigger and management pages used to control the sources and one for
the TIMA pages. They are mapped by default at the addresses found on
chip 0 of a baremetal system. This is also consistent with the XIVE
architecture which defines a Virtualization Controller BAR for the
internal IVSE ESB pages and a Thread Managment BAR for the TIMA.

Signed-off-by: Cédric Le Goater <clg@kaod.org>
Reviewed-by: David Gibson <david@gibson.dropbear.id.au>
[dwg: Fold in field accessor fixes]
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
default-configs/ppc64-softmmu.mak
hw/intc/Makefile.objs
hw/intc/spapr_xive.c [new file with mode: 0644]
include/hw/ppc/spapr_xive.h [new file with mode: 0644]