mirror of
https://github.com/qemu/qemu.git
synced 2025-08-03 06:33:33 +00:00

The different XIVE virtualization structures (sources and event queues) are configured with a set of Hypervisor calls : - H_INT_GET_SOURCE_INFO used to obtain the address of the MMIO page of the Event State Buffer (ESB) entry associated with the source. - H_INT_SET_SOURCE_CONFIG assigns a source to a "target". - H_INT_GET_SOURCE_CONFIG determines which "target" and "priority" is assigned to a source - H_INT_GET_QUEUE_INFO returns the address of the notification management page associated with the specified "target" and "priority". - H_INT_SET_QUEUE_CONFIG sets or resets the event queue for a given "target" and "priority". It is also used to set the notification configuration associated with the queue, only unconditional notification is supported for the moment. Reset is performed with a queue size of 0 and queueing is disabled in that case. - H_INT_GET_QUEUE_CONFIG returns the queue settings for a given "target" and "priority". - H_INT_RESET resets all of the guest's internal interrupt structures to their initial state, losing all configuration set via the hcalls H_INT_SET_SOURCE_CONFIG and H_INT_SET_QUEUE_CONFIG. - H_INT_SYNC issue a synchronisation on a source to make sure all notifications have reached their queue. Calls that still need to be addressed : H_INT_SET_OS_REPORTING_LINE H_INT_GET_OS_REPORTING_LINE See the code for more documentation on each hcall. Signed-off-by: Cédric Le Goater <clg@kaod.org> Reviewed-by: David Gibson <david@gibson.dropbear.id.au> [dwg: Folded in fix for field accessors] Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
50 lines
1.3 KiB
C
50 lines
1.3 KiB
C
/*
|
|
* QEMU PowerPC sPAPR XIVE interrupt controller model
|
|
*
|
|
* Copyright (c) 2017-2018, IBM Corporation.
|
|
*
|
|
* This code is licensed under the GPL version 2 or later. See the
|
|
* COPYING file in the top-level directory.
|
|
*/
|
|
|
|
#ifndef PPC_SPAPR_XIVE_H
|
|
#define PPC_SPAPR_XIVE_H
|
|
|
|
#include "hw/ppc/xive.h"
|
|
|
|
#define TYPE_SPAPR_XIVE "spapr-xive"
|
|
#define SPAPR_XIVE(obj) OBJECT_CHECK(sPAPRXive, (obj), TYPE_SPAPR_XIVE)
|
|
|
|
typedef struct sPAPRXive {
|
|
XiveRouter parent;
|
|
|
|
/* Internal interrupt source for IPIs and virtual devices */
|
|
XiveSource source;
|
|
hwaddr vc_base;
|
|
|
|
/* END ESB MMIOs */
|
|
XiveENDSource end_source;
|
|
hwaddr end_base;
|
|
|
|
/* Routing table */
|
|
XiveEAS *eat;
|
|
uint32_t nr_irqs;
|
|
XiveEND *endt;
|
|
uint32_t nr_ends;
|
|
|
|
/* TIMA mapping address */
|
|
hwaddr tm_base;
|
|
MemoryRegion tm_mmio;
|
|
} sPAPRXive;
|
|
|
|
bool spapr_xive_irq_claim(sPAPRXive *xive, uint32_t lisn, bool lsi);
|
|
bool spapr_xive_irq_free(sPAPRXive *xive, uint32_t lisn);
|
|
void spapr_xive_pic_print_info(sPAPRXive *xive, Monitor *mon);
|
|
qemu_irq spapr_xive_qirq(sPAPRXive *xive, uint32_t lisn);
|
|
|
|
typedef struct sPAPRMachineState sPAPRMachineState;
|
|
|
|
void spapr_xive_hcall_init(sPAPRMachineState *spapr);
|
|
|
|
#endif /* PPC_SPAPR_XIVE_H */
|