8f6a487488
ACPI DSDT generator needs information like ECAM range, PIO range, 32-bit and 64-bit PCI MMIO range etc related to the PCI host bridge. Instead of making these values machine specific, create properties for the GPEX host bridge with default value 0. During initialization, the firmware can initialize these properties with correct values for the platform. This basically allows DSDT generator code independent of the machine specific memory map accesses. Suggested-by: Igor Mammedov <imammedo@redhat.com> Signed-off-by: Sunil V L <sunilvl@ventanamicro.com> Acked-by: Alistair Francis <alistair.francis@wdc.com> Acked-by: Michael S. Tsirkin <mst@redhat.com> Reviewed-by: Daniel Henrique Barboza <dbarboza@ventanamicro.com> Message-ID: <20231218150247.466427-11-sunilvl@ventanamicro.com> Signed-off-by: Alistair Francis <alistair.francis@wdc.com>
86 lines
2.4 KiB
C
86 lines
2.4 KiB
C
/*
|
|
* QEMU Generic PCI Express Bridge Emulation
|
|
*
|
|
* Copyright (C) 2015 Alexander Graf <agraf@suse.de>
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, see <http://www.gnu.org/licenses/>
|
|
*/
|
|
|
|
#ifndef HW_GPEX_H
|
|
#define HW_GPEX_H
|
|
|
|
#include "exec/hwaddr.h"
|
|
#include "hw/sysbus.h"
|
|
#include "hw/pci/pci_device.h"
|
|
#include "hw/pci/pcie_host.h"
|
|
#include "qom/object.h"
|
|
|
|
#define TYPE_GPEX_HOST "gpex-pcihost"
|
|
OBJECT_DECLARE_SIMPLE_TYPE(GPEXHost, GPEX_HOST)
|
|
|
|
#define TYPE_GPEX_ROOT_DEVICE "gpex-root"
|
|
OBJECT_DECLARE_SIMPLE_TYPE(GPEXRootState, GPEX_ROOT_DEVICE)
|
|
|
|
#define GPEX_NUM_IRQS 4
|
|
|
|
struct GPEXRootState {
|
|
/*< private >*/
|
|
PCIDevice parent_obj;
|
|
/*< public >*/
|
|
};
|
|
|
|
struct GPEXConfig {
|
|
MemMapEntry ecam;
|
|
MemMapEntry mmio32;
|
|
MemMapEntry mmio64;
|
|
MemMapEntry pio;
|
|
int irq;
|
|
PCIBus *bus;
|
|
};
|
|
|
|
struct GPEXHost {
|
|
/*< private >*/
|
|
PCIExpressHost parent_obj;
|
|
/*< public >*/
|
|
|
|
GPEXRootState gpex_root;
|
|
|
|
MemoryRegion io_ioport;
|
|
MemoryRegion io_mmio;
|
|
MemoryRegion io_ioport_window;
|
|
MemoryRegion io_mmio_window;
|
|
qemu_irq irq[GPEX_NUM_IRQS];
|
|
int irq_num[GPEX_NUM_IRQS];
|
|
|
|
bool allow_unmapped_accesses;
|
|
|
|
struct GPEXConfig gpex_cfg;
|
|
};
|
|
|
|
int gpex_set_irq_num(GPEXHost *s, int index, int gsi);
|
|
|
|
void acpi_dsdt_add_gpex(Aml *scope, struct GPEXConfig *cfg);
|
|
void acpi_dsdt_add_gpex_host(Aml *scope, uint32_t irq);
|
|
|
|
#define PCI_HOST_PIO_BASE "x-pio-base"
|
|
#define PCI_HOST_PIO_SIZE "x-pio-size"
|
|
#define PCI_HOST_ECAM_BASE "x-ecam-base"
|
|
#define PCI_HOST_ECAM_SIZE "x-ecam-size"
|
|
#define PCI_HOST_BELOW_4G_MMIO_BASE "x-below-4g-mmio-base"
|
|
#define PCI_HOST_BELOW_4G_MMIO_SIZE "x-below-4g-mmio-size"
|
|
#define PCI_HOST_ABOVE_4G_MMIO_BASE "x-above-4g-mmio-base"
|
|
#define PCI_HOST_ABOVE_4G_MMIO_SIZE "x-above-4g-mmio-size"
|
|
|
|
#endif /* HW_GPEX_H */
|