0d8d6a24fc
When compiling the ppc code with clang and -std=gnu99, there are a couple of warnings/errors like this one: CC ppc64-softmmu/hw/intc/xics.o In file included from hw/intc/xics.c:35: include/hw/ppc/xics.h:43:25: error: redefinition of typedef 'ICPState' is a C11 feature [-Werror,-Wtypedef-redefinition] typedef struct ICPState ICPState; ^ target/ppc/cpu.h:1181:25: note: previous definition is here typedef struct ICPState ICPState; ^ Work around the problems by including the proper headers in spapr.h and by using struct forward declarations in cpu.h. Reviewed-by: Greg Kurz <groug@kaod.org> Signed-off-by: Thomas Huth <thuth@redhat.com>
51 lines
1.4 KiB
C
51 lines
1.4 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);
|
|
|
|
void spapr_xive_hcall_init(sPAPRMachineState *spapr);
|
|
void spapr_dt_xive(sPAPRMachineState *spapr, uint32_t nr_servers, void *fdt,
|
|
uint32_t phandle);
|
|
void spapr_xive_set_tctx_os_cam(XiveTCTX *tctx);
|
|
void spapr_xive_mmio_set_enabled(sPAPRXive *xive, bool enable);
|
|
|
|
#endif /* PPC_SPAPR_XIVE_H */
|