xref: /openbmc/qemu/hw/misc/pvpanic-pci.c (revision 1406b7fc4bbaab42133b1ef03270179746e91723)
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"
16d097b3dcSMihai Carabas #include "sysemu/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 
pvpanic_pci_realizefn(PCIDevice * dev,Error ** errp)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 
56d097b3dcSMihai Carabas static Property pvpanic_pci_properties[] = {
5745d8c052Szhenwei pi     DEFINE_PROP_UINT8("events", PVPanicPCIState, pvpanic.events,
58*9b13640dSThomas Weißschuh                       PVPANIC_EVENTS),
59d097b3dcSMihai Carabas     DEFINE_PROP_END_OF_LIST(),
60d097b3dcSMihai Carabas };
61d097b3dcSMihai Carabas 
pvpanic_pci_class_init(ObjectClass * klass,void * data)62d097b3dcSMihai Carabas static void pvpanic_pci_class_init(ObjectClass *klass, void *data)
63d097b3dcSMihai Carabas {
64d097b3dcSMihai Carabas     DeviceClass *dc = DEVICE_CLASS(klass);
65d097b3dcSMihai Carabas     PCIDeviceClass *pc = PCI_DEVICE_CLASS(klass);
66d097b3dcSMihai Carabas 
67d097b3dcSMihai Carabas     device_class_set_props(dc, pvpanic_pci_properties);
68d097b3dcSMihai Carabas 
69d097b3dcSMihai Carabas     pc->realize = pvpanic_pci_realizefn;
70d097b3dcSMihai Carabas     pc->vendor_id = PCI_VENDOR_ID_REDHAT;
71d097b3dcSMihai Carabas     pc->device_id = PCI_DEVICE_ID_REDHAT_PVPANIC;
72d097b3dcSMihai Carabas     pc->revision = 1;
73d097b3dcSMihai Carabas     pc->class_id = PCI_CLASS_SYSTEM_OTHER;
74d097b3dcSMihai Carabas     dc->vmsd = &vmstate_pvpanic_pci;
75d097b3dcSMihai Carabas 
76d097b3dcSMihai Carabas     set_bit(DEVICE_CATEGORY_MISC, dc->categories);
77d097b3dcSMihai Carabas }
78d097b3dcSMihai Carabas 
795e78c98bSBernhard Beschow static const TypeInfo pvpanic_pci_info = {
80d097b3dcSMihai Carabas     .name          = TYPE_PVPANIC_PCI_DEVICE,
81d097b3dcSMihai Carabas     .parent        = TYPE_PCI_DEVICE,
82d097b3dcSMihai Carabas     .instance_size = sizeof(PVPanicPCIState),
83d097b3dcSMihai Carabas     .class_init    = pvpanic_pci_class_init,
84d097b3dcSMihai Carabas     .interfaces = (InterfaceInfo[]) {
85d097b3dcSMihai Carabas         { INTERFACE_CONVENTIONAL_PCI_DEVICE },
86d097b3dcSMihai Carabas         { }
87d097b3dcSMihai Carabas     }
88d097b3dcSMihai Carabas };
89d097b3dcSMihai Carabas 
pvpanic_register_types(void)90d097b3dcSMihai Carabas static void pvpanic_register_types(void)
91d097b3dcSMihai Carabas {
92d097b3dcSMihai Carabas     type_register_static(&pvpanic_pci_info);
93d097b3dcSMihai Carabas }
94d097b3dcSMihai Carabas 
95d097b3dcSMihai Carabas type_init(pvpanic_register_types);
96