1d097b3dcSMihai Carabas /* 2d097b3dcSMihai Carabas * QEMU simulated PCI pvpanic device. 3d097b3dcSMihai Carabas * 4d097b3dcSMihai Carabas * Copyright (C) 2020 Oracle 5d097b3dcSMihai Carabas * 6d097b3dcSMihai Carabas * Authors: 7d097b3dcSMihai Carabas * Mihai Carabas <mihai.carabas@oracle.com> 8d097b3dcSMihai Carabas * 9d097b3dcSMihai Carabas * This work is licensed under the terms of the GNU GPL, version 2 or later. 10d097b3dcSMihai Carabas * See the COPYING file in the top-level directory. 11d097b3dcSMihai Carabas * 12d097b3dcSMihai Carabas */ 13d097b3dcSMihai Carabas 14d097b3dcSMihai Carabas #include "qemu/osdep.h" 15d097b3dcSMihai Carabas #include "qemu/module.h" 1632cad1ffSPhilippe Mathieu-Daudé #include "system/runstate.h" 17d097b3dcSMihai Carabas 18d097b3dcSMihai Carabas #include "hw/nvram/fw_cfg.h" 19d097b3dcSMihai Carabas #include "hw/qdev-properties.h" 20d097b3dcSMihai Carabas #include "migration/vmstate.h" 21d097b3dcSMihai Carabas #include "hw/misc/pvpanic.h" 22d097b3dcSMihai Carabas #include "qom/object.h" 23edf5ca5dSMarkus Armbruster #include "hw/pci/pci_device.h" 24b8116f4cSPaolo Bonzini #include "standard-headers/misc/pvpanic.h" 25d097b3dcSMihai Carabas 26d097b3dcSMihai Carabas OBJECT_DECLARE_SIMPLE_TYPE(PVPanicPCIState, PVPANIC_PCI_DEVICE) 27d097b3dcSMihai Carabas 28d097b3dcSMihai Carabas /* 29d097b3dcSMihai Carabas * PVPanicPCIState for PCI device 30d097b3dcSMihai Carabas */ 31d097b3dcSMihai Carabas typedef struct PVPanicPCIState { 32d097b3dcSMihai Carabas PCIDevice dev; 33d097b3dcSMihai Carabas PVPanicState pvpanic; 34d097b3dcSMihai Carabas } PVPanicPCIState; 35d097b3dcSMihai Carabas 36d097b3dcSMihai Carabas static const VMStateDescription vmstate_pvpanic_pci = { 37d097b3dcSMihai Carabas .name = "pvpanic-pci", 38d097b3dcSMihai Carabas .version_id = 1, 39d097b3dcSMihai Carabas .minimum_version_id = 1, 40e4ea952fSRichard Henderson .fields = (const VMStateField[]) { 41d097b3dcSMihai Carabas VMSTATE_PCI_DEVICE(dev, PVPanicPCIState), 42d097b3dcSMihai Carabas VMSTATE_END_OF_LIST() 43d097b3dcSMihai Carabas } 44d097b3dcSMihai Carabas }; 45d097b3dcSMihai Carabas 46d097b3dcSMihai Carabas static void pvpanic_pci_realizefn(PCIDevice *dev, Error **errp) 47d097b3dcSMihai Carabas { 48d097b3dcSMihai Carabas PVPanicPCIState *s = PVPANIC_PCI_DEVICE(dev); 49d097b3dcSMihai Carabas PVPanicState *ps = &s->pvpanic; 50d097b3dcSMihai Carabas 51ee1004bbSPhilippe Mathieu-Daudé pvpanic_setup_io(ps, DEVICE(s), 2); 52d097b3dcSMihai Carabas 53d097b3dcSMihai Carabas pci_register_bar(dev, 0, PCI_BASE_ADDRESS_SPACE_MEMORY, &ps->mr); 54d097b3dcSMihai Carabas } 55d097b3dcSMihai Carabas 5630029973SRichard Henderson static const Property pvpanic_pci_properties[] = { 5745d8c052Szhenwei pi DEFINE_PROP_UINT8("events", PVPanicPCIState, pvpanic.events, 589b13640dSThomas Weißschuh PVPANIC_EVENTS), 59d097b3dcSMihai Carabas }; 60d097b3dcSMihai Carabas 61*12d1a768SPhilippe Mathieu-Daudé static void pvpanic_pci_class_init(ObjectClass *klass, const void *data) 62d097b3dcSMihai Carabas { 63d097b3dcSMihai Carabas DeviceClass *dc = DEVICE_CLASS(klass); 64d097b3dcSMihai Carabas PCIDeviceClass *pc = PCI_DEVICE_CLASS(klass); 65d097b3dcSMihai Carabas 66d097b3dcSMihai Carabas device_class_set_props(dc, pvpanic_pci_properties); 67d097b3dcSMihai Carabas 68d097b3dcSMihai Carabas pc->realize = pvpanic_pci_realizefn; 69d097b3dcSMihai Carabas pc->vendor_id = PCI_VENDOR_ID_REDHAT; 70d097b3dcSMihai Carabas pc->device_id = PCI_DEVICE_ID_REDHAT_PVPANIC; 71d097b3dcSMihai Carabas pc->revision = 1; 72d097b3dcSMihai Carabas pc->class_id = PCI_CLASS_SYSTEM_OTHER; 73d097b3dcSMihai Carabas dc->vmsd = &vmstate_pvpanic_pci; 74d097b3dcSMihai Carabas 75d097b3dcSMihai Carabas set_bit(DEVICE_CATEGORY_MISC, dc->categories); 76d097b3dcSMihai Carabas } 77d097b3dcSMihai Carabas 785e78c98bSBernhard Beschow static const TypeInfo pvpanic_pci_info = { 79d097b3dcSMihai Carabas .name = TYPE_PVPANIC_PCI_DEVICE, 80d097b3dcSMihai Carabas .parent = TYPE_PCI_DEVICE, 81d097b3dcSMihai Carabas .instance_size = sizeof(PVPanicPCIState), 82d097b3dcSMihai Carabas .class_init = pvpanic_pci_class_init, 83d097b3dcSMihai Carabas .interfaces = (InterfaceInfo[]) { 84d097b3dcSMihai Carabas { INTERFACE_CONVENTIONAL_PCI_DEVICE }, 85d097b3dcSMihai Carabas { } 86d097b3dcSMihai Carabas } 87d097b3dcSMihai Carabas }; 88d097b3dcSMihai Carabas 89d097b3dcSMihai Carabas static void pvpanic_register_types(void) 90d097b3dcSMihai Carabas { 91d097b3dcSMihai Carabas type_register_static(&pvpanic_pci_info); 92d097b3dcSMihai Carabas } 93d097b3dcSMihai Carabas 94d097b3dcSMihai Carabas type_init(pvpanic_register_types); 95