hw/xen: Extract 'xen_igd.h' from 'xen_pt.h'
"hw/xen/xen_pt.h" requires "hw/xen/xen_native.h" which is target specific. It also declares IGD methods, which are not target specific. Target-agnostic code can use IGD methods. To allow that, extract these methos into a new "hw/xen/xen_igd.h" header. Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org> Reviewed-by: David Woodhouse <dwmw@amazon.co.uk> Message-Id: <20231114143816.71079-18-philmd@linaro.org>
This commit is contained in:
parent
92dfc8a257
commit
f28b958cbf
@ -15,6 +15,7 @@
|
|||||||
#include "hw/xen/xen_native.h"
|
#include "hw/xen/xen_native.h"
|
||||||
#include "hw/xen/xen-legacy-backend.h"
|
#include "hw/xen/xen-legacy-backend.h"
|
||||||
#include "hw/xen/xen_pt.h"
|
#include "hw/xen/xen_pt.h"
|
||||||
|
#include "hw/xen/xen_igd.h"
|
||||||
#include "chardev/char.h"
|
#include "chardev/char.h"
|
||||||
#include "qemu/accel.h"
|
#include "qemu/accel.h"
|
||||||
#include "sysemu/cpus.h"
|
#include "sysemu/cpus.h"
|
||||||
|
@ -55,6 +55,7 @@
|
|||||||
#ifdef CONFIG_XEN
|
#ifdef CONFIG_XEN
|
||||||
#include <xen/hvm/hvm_info_table.h>
|
#include <xen/hvm/hvm_info_table.h>
|
||||||
#include "hw/xen/xen_pt.h"
|
#include "hw/xen/xen_pt.h"
|
||||||
|
#include "hw/xen/xen_igd.h"
|
||||||
#endif
|
#endif
|
||||||
#include "hw/xen/xen-x86.h"
|
#include "hw/xen/xen-x86.h"
|
||||||
#include "hw/xen/xen.h"
|
#include "hw/xen/xen.h"
|
||||||
|
@ -59,7 +59,8 @@
|
|||||||
#include "hw/pci/pci.h"
|
#include "hw/pci/pci.h"
|
||||||
#include "hw/qdev-properties.h"
|
#include "hw/qdev-properties.h"
|
||||||
#include "hw/qdev-properties-system.h"
|
#include "hw/qdev-properties-system.h"
|
||||||
#include "xen_pt.h"
|
#include "hw/xen/xen_pt.h"
|
||||||
|
#include "hw/xen/xen_igd.h"
|
||||||
#include "hw/xen/xen.h"
|
#include "hw/xen/xen.h"
|
||||||
#include "hw/xen/xen-legacy-backend.h"
|
#include "hw/xen/xen-legacy-backend.h"
|
||||||
#include "qemu/range.h"
|
#include "qemu/range.h"
|
||||||
|
@ -15,9 +15,6 @@
|
|||||||
#include "xen-host-pci-device.h"
|
#include "xen-host-pci-device.h"
|
||||||
#include "qom/object.h"
|
#include "qom/object.h"
|
||||||
|
|
||||||
bool xen_igd_gfx_pt_enabled(void);
|
|
||||||
void xen_igd_gfx_pt_set(bool value, Error **errp);
|
|
||||||
|
|
||||||
void xen_pt_log(const PCIDevice *d, const char *f, ...) G_GNUC_PRINTF(2, 3);
|
void xen_pt_log(const PCIDevice *d, const char *f, ...) G_GNUC_PRINTF(2, 3);
|
||||||
|
|
||||||
#define XEN_PT_ERR(d, _f, _a...) xen_pt_log(d, "%s: Error: "_f, __func__, ##_a)
|
#define XEN_PT_ERR(d, _f, _a...) xen_pt_log(d, "%s: Error: "_f, __func__, ##_a)
|
||||||
@ -62,12 +59,6 @@ typedef struct XenPTDeviceClass {
|
|||||||
XenPTQdevRealize pci_qdev_realize;
|
XenPTQdevRealize pci_qdev_realize;
|
||||||
} XenPTDeviceClass;
|
} XenPTDeviceClass;
|
||||||
|
|
||||||
uint32_t igd_read_opregion(XenPCIPassthroughState *s);
|
|
||||||
void xen_igd_reserve_slot(PCIBus *pci_bus);
|
|
||||||
void igd_write_opregion(XenPCIPassthroughState *s, uint32_t val);
|
|
||||||
void xen_igd_passthrough_isa_bridge_create(XenPCIPassthroughState *s,
|
|
||||||
XenHostPCIDevice *dev);
|
|
||||||
|
|
||||||
/* function type for config reg */
|
/* function type for config reg */
|
||||||
typedef int (*xen_pt_conf_reg_init)
|
typedef int (*xen_pt_conf_reg_init)
|
||||||
(XenPCIPassthroughState *, XenPTRegInfo *, uint32_t real_offset,
|
(XenPCIPassthroughState *, XenPTRegInfo *, uint32_t real_offset,
|
||||||
@ -353,11 +344,6 @@ static inline bool xen_pt_has_msix_mapping(XenPCIPassthroughState *s, int bar)
|
|||||||
void *pci_assign_dev_load_option_rom(PCIDevice *dev, int *size,
|
void *pci_assign_dev_load_option_rom(PCIDevice *dev, int *size,
|
||||||
unsigned int domain, unsigned int bus,
|
unsigned int domain, unsigned int bus,
|
||||||
unsigned int slot, unsigned int function);
|
unsigned int slot, unsigned int function);
|
||||||
static inline bool is_igd_vga_passthrough(XenHostPCIDevice *dev)
|
|
||||||
{
|
|
||||||
return (xen_igd_gfx_pt_enabled()
|
|
||||||
&& ((dev->class_code >> 0x8) == PCI_CLASS_DISPLAY_VGA));
|
|
||||||
}
|
|
||||||
int xen_pt_register_vga_regions(XenHostPCIDevice *dev);
|
int xen_pt_register_vga_regions(XenHostPCIDevice *dev);
|
||||||
int xen_pt_unregister_vga_regions(XenHostPCIDevice *dev);
|
int xen_pt_unregister_vga_regions(XenHostPCIDevice *dev);
|
||||||
void xen_pt_setup_vga(XenPCIPassthroughState *s, XenHostPCIDevice *dev,
|
void xen_pt_setup_vga(XenPCIPassthroughState *s, XenHostPCIDevice *dev,
|
||||||
|
@ -15,7 +15,8 @@
|
|||||||
#include "qemu/osdep.h"
|
#include "qemu/osdep.h"
|
||||||
#include "qapi/error.h"
|
#include "qapi/error.h"
|
||||||
#include "qemu/timer.h"
|
#include "qemu/timer.h"
|
||||||
#include "xen_pt.h"
|
#include "hw/xen/xen_pt.h"
|
||||||
|
#include "hw/xen/xen_igd.h"
|
||||||
#include "hw/xen/xen-legacy-backend.h"
|
#include "hw/xen/xen-legacy-backend.h"
|
||||||
|
|
||||||
#define XEN_PT_MERGE_VALUE(value, data, val_mask) \
|
#define XEN_PT_MERGE_VALUE(value, data, val_mask) \
|
||||||
|
@ -3,7 +3,8 @@
|
|||||||
*/
|
*/
|
||||||
#include "qemu/osdep.h"
|
#include "qemu/osdep.h"
|
||||||
#include "qapi/error.h"
|
#include "qapi/error.h"
|
||||||
#include "xen_pt.h"
|
#include "hw/xen/xen_pt.h"
|
||||||
|
#include "hw/xen/xen_igd.h"
|
||||||
#include "xen-host-pci-device.h"
|
#include "xen-host-pci-device.h"
|
||||||
|
|
||||||
static unsigned long igd_guest_opregion;
|
static unsigned long igd_guest_opregion;
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "qemu/osdep.h"
|
#include "qemu/osdep.h"
|
||||||
#include "hw/xen/xen_pt.h"
|
#include "hw/xen/xen_igd.h"
|
||||||
#include "qapi/error.h"
|
#include "qapi/error.h"
|
||||||
|
|
||||||
bool xen_igd_gfx_pt_enabled(void)
|
bool xen_igd_gfx_pt_enabled(void)
|
||||||
|
33
include/hw/xen/xen_igd.h
Normal file
33
include/hw/xen/xen_igd.h
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2007, Neocleus Corporation.
|
||||||
|
* Copyright (c) 2007, Intel Corporation.
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: GPL-2.0-only
|
||||||
|
*
|
||||||
|
* Alex Novik <alex@neocleus.com>
|
||||||
|
* Allen Kay <allen.m.kay@intel.com>
|
||||||
|
* Guy Zana <guy@neocleus.com>
|
||||||
|
*/
|
||||||
|
#ifndef XEN_IGD_H
|
||||||
|
#define XEN_IGD_H
|
||||||
|
|
||||||
|
#include "hw/xen/xen-host-pci-device.h"
|
||||||
|
|
||||||
|
typedef struct XenPCIPassthroughState XenPCIPassthroughState;
|
||||||
|
|
||||||
|
bool xen_igd_gfx_pt_enabled(void);
|
||||||
|
void xen_igd_gfx_pt_set(bool value, Error **errp);
|
||||||
|
|
||||||
|
uint32_t igd_read_opregion(XenPCIPassthroughState *s);
|
||||||
|
void xen_igd_reserve_slot(PCIBus *pci_bus);
|
||||||
|
void igd_write_opregion(XenPCIPassthroughState *s, uint32_t val);
|
||||||
|
void xen_igd_passthrough_isa_bridge_create(XenPCIPassthroughState *s,
|
||||||
|
XenHostPCIDevice *dev);
|
||||||
|
|
||||||
|
static inline bool is_igd_vga_passthrough(XenHostPCIDevice *dev)
|
||||||
|
{
|
||||||
|
return (xen_igd_gfx_pt_enabled()
|
||||||
|
&& ((dev->class_code >> 0x8) == PCI_CLASS_DISPLAY_VGA));
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
Loading…
Reference in New Issue
Block a user