2019-03-06 09:50:11 +01:00
|
|
|
/*
|
|
|
|
* QEMU PowerPC XIVE interrupt controller model
|
|
|
|
*
|
|
|
|
* Copyright (c) 2017-2019, IBM Corporation.
|
|
|
|
*
|
|
|
|
* This code is licensed under the GPL version 2 or later. See the
|
|
|
|
* COPYING file in the top-level directory.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef PPC_PNV_XIVE_H
|
|
|
|
#define PPC_PNV_XIVE_H
|
|
|
|
|
|
|
|
#include "hw/ppc/xive.h"
|
2020-09-03 22:43:22 +02:00
|
|
|
#include "qom/object.h"
|
2019-03-06 09:50:11 +01:00
|
|
|
|
|
|
|
struct PnvChip;
|
|
|
|
|
|
|
|
#define TYPE_PNV_XIVE "pnv-xive"
|
2020-08-31 23:07:37 +02:00
|
|
|
OBJECT_DECLARE_TYPE(PnvXive, PnvXiveClass,
|
qom: Remove module_obj_name parameter from OBJECT_DECLARE* macros
One of the goals of having less boilerplate on QOM declarations
is to avoid human error. Requiring an extra argument that is
never used is an opportunity for mistakes.
Remove the unused argument from OBJECT_DECLARE_TYPE and
OBJECT_DECLARE_SIMPLE_TYPE.
Coccinelle patch used to convert all users of the macros:
@@
declarer name OBJECT_DECLARE_TYPE;
identifier InstanceType, ClassType, lowercase, UPPERCASE;
@@
OBJECT_DECLARE_TYPE(InstanceType, ClassType,
- lowercase,
UPPERCASE);
@@
declarer name OBJECT_DECLARE_SIMPLE_TYPE;
identifier InstanceType, lowercase, UPPERCASE;
@@
OBJECT_DECLARE_SIMPLE_TYPE(InstanceType,
- lowercase,
UPPERCASE);
Signed-off-by: Eduardo Habkost <ehabkost@redhat.com>
Reviewed-by: Cédric Le Goater <clg@kaod.org>
Acked-by: Cornelia Huck <cohuck@redhat.com>
Acked-by: Igor Mammedov <imammedo@redhat.com>
Acked-by: Paul Durrant <paul@xen.org>
Acked-by: Thomas Huth <thuth@redhat.com>
Message-Id: <20200916182519.415636-4-ehabkost@redhat.com>
Signed-off-by: Eduardo Habkost <ehabkost@redhat.com>
2020-09-16 20:25:17 +02:00
|
|
|
PNV_XIVE)
|
2019-03-06 09:50:11 +01:00
|
|
|
|
|
|
|
#define XIVE_BLOCK_MAX 16
|
|
|
|
|
|
|
|
#define XIVE_TABLE_BLK_MAX 16 /* Block Scope Table (0-15) */
|
|
|
|
#define XIVE_TABLE_MIG_MAX 16 /* Migration Register Table (1-15) */
|
|
|
|
#define XIVE_TABLE_VDT_MAX 16 /* VDT Domain Table (0-15) */
|
|
|
|
#define XIVE_TABLE_EDT_MAX 64 /* EDT Domain Table (0-63) */
|
|
|
|
|
2020-09-03 22:43:22 +02:00
|
|
|
struct PnvXive {
|
2019-03-06 09:50:11 +01:00
|
|
|
XiveRouter parent_obj;
|
|
|
|
|
|
|
|
/* Owning chip */
|
|
|
|
struct PnvChip *chip;
|
|
|
|
|
|
|
|
/* XSCOM addresses giving access to the controller registers */
|
|
|
|
MemoryRegion xscom_regs;
|
|
|
|
|
|
|
|
/* Main MMIO regions that can be configured by FW */
|
|
|
|
MemoryRegion ic_mmio;
|
|
|
|
MemoryRegion ic_reg_mmio;
|
|
|
|
MemoryRegion ic_notify_mmio;
|
|
|
|
MemoryRegion ic_lsi_mmio;
|
|
|
|
MemoryRegion tm_indirect_mmio;
|
|
|
|
MemoryRegion vc_mmio;
|
|
|
|
MemoryRegion pc_mmio;
|
|
|
|
MemoryRegion tm_mmio;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* IPI and END address spaces modeling the EDT segmentation in the
|
|
|
|
* VC region
|
|
|
|
*/
|
|
|
|
AddressSpace ipi_as;
|
|
|
|
MemoryRegion ipi_mmio;
|
|
|
|
MemoryRegion ipi_edt_mmio;
|
|
|
|
|
|
|
|
AddressSpace end_as;
|
|
|
|
MemoryRegion end_mmio;
|
|
|
|
MemoryRegion end_edt_mmio;
|
|
|
|
|
|
|
|
/* Shortcut values for the Main MMIO regions */
|
|
|
|
hwaddr ic_base;
|
|
|
|
uint32_t ic_shift;
|
|
|
|
hwaddr vc_base;
|
|
|
|
uint32_t vc_shift;
|
|
|
|
hwaddr pc_base;
|
|
|
|
uint32_t pc_shift;
|
|
|
|
hwaddr tm_base;
|
|
|
|
uint32_t tm_shift;
|
|
|
|
|
|
|
|
/* Our XIVE source objects for IPIs and ENDs */
|
|
|
|
XiveSource ipi_source;
|
|
|
|
XiveENDSource end_source;
|
|
|
|
|
|
|
|
/* Interrupt controller registers */
|
|
|
|
uint64_t regs[0x300];
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Virtual Structure Descriptor tables : EAT, SBE, ENDT, NVTT, IRQ
|
|
|
|
* These are in a SRAM protected by ECC.
|
|
|
|
*/
|
|
|
|
uint64_t vsds[5][XIVE_BLOCK_MAX];
|
|
|
|
|
|
|
|
/* Translation tables */
|
|
|
|
uint64_t blk[XIVE_TABLE_BLK_MAX];
|
|
|
|
uint64_t mig[XIVE_TABLE_MIG_MAX];
|
|
|
|
uint64_t vdt[XIVE_TABLE_VDT_MAX];
|
|
|
|
uint64_t edt[XIVE_TABLE_EDT_MAX];
|
2020-09-03 22:43:22 +02:00
|
|
|
};
|
2019-03-06 09:50:11 +01:00
|
|
|
|
2020-09-03 22:43:22 +02:00
|
|
|
struct PnvXiveClass {
|
2020-01-06 15:56:36 +01:00
|
|
|
XiveRouterClass parent_class;
|
|
|
|
|
|
|
|
DeviceRealize parent_realize;
|
2020-09-03 22:43:22 +02:00
|
|
|
};
|
2020-01-06 15:56:36 +01:00
|
|
|
|
2019-03-06 09:50:11 +01:00
|
|
|
void pnv_xive_pic_print_info(PnvXive *xive, Monitor *mon);
|
|
|
|
|
|
|
|
#endif /* PPC_PNV_XIVE_H */
|