2024-08-08 14:58:52 +03:00
|
|
|
/*
|
|
|
|
* QEMU Xen PVH machine - common code.
|
|
|
|
*
|
|
|
|
* Copyright (c) 2024 Advanced Micro Devices, Inc.
|
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: GPL-2.0-or-later
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef XEN_PVH_COMMON_H__
|
|
|
|
#define XEN_PVH_COMMON_H__
|
|
|
|
|
|
|
|
#include <assert.h>
|
|
|
|
#include "hw/sysbus.h"
|
|
|
|
#include "hw/hw.h"
|
|
|
|
#include "hw/xen/xen-hvm-common.h"
|
|
|
|
#include "hw/pci-host/gpex.h"
|
|
|
|
|
|
|
|
#define TYPE_XEN_PVH_MACHINE MACHINE_TYPE_NAME("xen-pvh-base")
|
|
|
|
OBJECT_DECLARE_TYPE(XenPVHMachineState, XenPVHMachineClass,
|
|
|
|
XEN_PVH_MACHINE)
|
|
|
|
|
|
|
|
struct XenPVHMachineClass {
|
|
|
|
MachineClass parent;
|
|
|
|
|
|
|
|
/* PVH implementation specific init. */
|
|
|
|
void (*init)(MachineState *state);
|
|
|
|
|
2024-08-16 17:00:45 +03:00
|
|
|
/*
|
|
|
|
* set_pci_intx_irq - Deliver INTX irqs to the guest.
|
|
|
|
*
|
|
|
|
* @opaque: pointer to XenPVHMachineState.
|
|
|
|
* @irq: IRQ after swizzling, between 0-3.
|
|
|
|
* @level: IRQ level.
|
|
|
|
*/
|
|
|
|
void (*set_pci_intx_irq)(void *opaque, int irq, int level);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* set_pci_link_route: - optional implementation call to setup
|
|
|
|
* routing between INTX IRQ (0 - 3) and GSI's.
|
|
|
|
*
|
|
|
|
* @line: line the INTx line (0 => A .. 3 => B)
|
|
|
|
* @irq: GSI
|
|
|
|
*/
|
|
|
|
int (*set_pci_link_route)(uint8_t line, uint8_t irq);
|
|
|
|
|
2024-08-08 14:58:52 +03:00
|
|
|
/*
|
|
|
|
* Each implementation can optionally enable features that it
|
|
|
|
* supports and are known to work.
|
|
|
|
*/
|
2024-08-16 17:00:45 +03:00
|
|
|
bool has_pci;
|
2024-08-08 14:58:52 +03:00
|
|
|
bool has_tpm;
|
|
|
|
bool has_virtio_mmio;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct XenPVHMachineState {
|
|
|
|
/*< private >*/
|
|
|
|
MachineState parent;
|
|
|
|
|
|
|
|
XenIOState ioreq;
|
|
|
|
|
|
|
|
struct {
|
|
|
|
MemoryRegion low;
|
|
|
|
MemoryRegion high;
|
|
|
|
} ram;
|
|
|
|
|
2024-08-16 17:00:45 +03:00
|
|
|
struct {
|
|
|
|
GPEXHost gpex;
|
|
|
|
MemoryRegion mmio_alias;
|
|
|
|
MemoryRegion mmio_high_alias;
|
|
|
|
} pci;
|
|
|
|
|
2024-08-08 14:58:52 +03:00
|
|
|
struct {
|
|
|
|
MemMapEntry ram_low, ram_high;
|
|
|
|
MemMapEntry tpm;
|
|
|
|
|
|
|
|
/* Virtio-mmio */
|
|
|
|
MemMapEntry virtio_mmio;
|
|
|
|
uint32_t virtio_mmio_num;
|
|
|
|
uint32_t virtio_mmio_irq_base;
|
2024-08-16 17:00:45 +03:00
|
|
|
|
|
|
|
/* PCI */
|
|
|
|
MemMapEntry pci_ecam, pci_mmio, pci_mmio_high;
|
|
|
|
uint32_t pci_intx_irq_base;
|
2024-08-08 14:58:52 +03:00
|
|
|
} cfg;
|
|
|
|
};
|
|
|
|
|
|
|
|
void xen_pvh_class_setup_common_props(XenPVHMachineClass *xpc);
|
|
|
|
#endif
|