define hotplug interface
Provide a generic hotplug interface for hotplug handlers. Intended for replacing hotplug mechanism used by PCI/PCIE/SHPC code and will be used for memory hotplug. Signed-off-by: Igor Mammedov <imammedo@redhat.com> Reviewed-by: Michael S. Tsirkin <mst@redhat.com> Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
This commit is contained in:
parent
a1483f88b6
commit
9f117d4184
@ -2,6 +2,7 @@
|
|||||||
common-obj-y += qdev.o qdev-properties.o
|
common-obj-y += qdev.o qdev-properties.o
|
||||||
# irq.o needed for qdev GPIO handling:
|
# irq.o needed for qdev GPIO handling:
|
||||||
common-obj-y += irq.o
|
common-obj-y += irq.o
|
||||||
|
common-obj-y += hotplug.o
|
||||||
|
|
||||||
common-obj-$(CONFIG_EMPTY_SLOT) += empty_slot.o
|
common-obj-$(CONFIG_EMPTY_SLOT) += empty_slot.o
|
||||||
common-obj-$(CONFIG_XILINX_AXI) += stream.o
|
common-obj-$(CONFIG_XILINX_AXI) += stream.o
|
||||||
|
48
hw/core/hotplug.c
Normal file
48
hw/core/hotplug.c
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
/*
|
||||||
|
* Hotplug handler interface.
|
||||||
|
*
|
||||||
|
* Copyright (c) 2014 Red Hat Inc.
|
||||||
|
*
|
||||||
|
* Authors:
|
||||||
|
* Igor Mammedov <imammedo@redhat.com>,
|
||||||
|
*
|
||||||
|
* This work is licensed under the terms of the GNU GPL, version 2 or later.
|
||||||
|
* See the COPYING file in the top-level directory.
|
||||||
|
*/
|
||||||
|
#include "hw/hotplug.h"
|
||||||
|
#include "qemu/module.h"
|
||||||
|
|
||||||
|
void hotplug_handler_plug(HotplugHandler *plug_handler,
|
||||||
|
DeviceState *plugged_dev,
|
||||||
|
Error **errp)
|
||||||
|
{
|
||||||
|
HotplugHandlerClass *hdc = HOTPLUG_HANDLER_GET_CLASS(plug_handler);
|
||||||
|
|
||||||
|
if (hdc->plug) {
|
||||||
|
hdc->plug(plug_handler, plugged_dev, errp);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void hotplug_handler_unplug(HotplugHandler *plug_handler,
|
||||||
|
DeviceState *plugged_dev,
|
||||||
|
Error **errp)
|
||||||
|
{
|
||||||
|
HotplugHandlerClass *hdc = HOTPLUG_HANDLER_GET_CLASS(plug_handler);
|
||||||
|
|
||||||
|
if (hdc->unplug) {
|
||||||
|
hdc->unplug(plug_handler, plugged_dev, errp);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static const TypeInfo hotplug_handler_info = {
|
||||||
|
.name = TYPE_HOTPLUG_HANDLER,
|
||||||
|
.parent = TYPE_INTERFACE,
|
||||||
|
.class_size = sizeof(HotplugHandlerClass),
|
||||||
|
};
|
||||||
|
|
||||||
|
static void hotplug_handler_register_types(void)
|
||||||
|
{
|
||||||
|
type_register_static(&hotplug_handler_info);
|
||||||
|
}
|
||||||
|
|
||||||
|
type_init(hotplug_handler_register_types)
|
78
include/hw/hotplug.h
Normal file
78
include/hw/hotplug.h
Normal file
@ -0,0 +1,78 @@
|
|||||||
|
/*
|
||||||
|
* Hotplug handler interface.
|
||||||
|
*
|
||||||
|
* Copyright (c) 2014 Red Hat Inc.
|
||||||
|
*
|
||||||
|
* Authors:
|
||||||
|
* Igor Mammedov <imammedo@redhat.com>,
|
||||||
|
*
|
||||||
|
* This work is licensed under the terms of the GNU GPL, version 2 or later.
|
||||||
|
* See the COPYING file in the top-level directory.
|
||||||
|
*/
|
||||||
|
#ifndef HOTPLUG_H
|
||||||
|
#define HOTPLUG_H
|
||||||
|
|
||||||
|
#include "qom/object.h"
|
||||||
|
#include "qemu/typedefs.h"
|
||||||
|
|
||||||
|
#define TYPE_HOTPLUG_HANDLER "hotplug-handler"
|
||||||
|
|
||||||
|
#define HOTPLUG_HANDLER_CLASS(klass) \
|
||||||
|
OBJECT_CLASS_CHECK(HotplugHandlerClass, (klass), TYPE_HOTPLUG_HANDLER)
|
||||||
|
#define HOTPLUG_HANDLER_GET_CLASS(obj) \
|
||||||
|
OBJECT_GET_CLASS(HotplugHandlerClass, (obj), TYPE_HOTPLUG_HANDLER)
|
||||||
|
#define HOTPLUG_HANDLER(obj) \
|
||||||
|
INTERFACE_CHECK(HotplugHandler, (obj), TYPE_HOTPLUG_HANDLER)
|
||||||
|
|
||||||
|
|
||||||
|
typedef struct HotplugHandler {
|
||||||
|
/* <private> */
|
||||||
|
Object Parent;
|
||||||
|
} HotplugHandler;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* hotplug_fn:
|
||||||
|
* @plug_handler: a device performing plug/uplug action
|
||||||
|
* @plugged_dev: a device that has been (un)plugged
|
||||||
|
* @errp: returns an error if this function fails
|
||||||
|
*/
|
||||||
|
typedef void (*hotplug_fn)(HotplugHandler *plug_handler,
|
||||||
|
DeviceState *plugged_dev, Error **errp);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* HotplugDeviceClass:
|
||||||
|
*
|
||||||
|
* Interface to be implemented by a device performing
|
||||||
|
* hardware (un)plug functions.
|
||||||
|
*
|
||||||
|
* @parent: Opaque parent interface.
|
||||||
|
* @plug: plug callback.
|
||||||
|
* @unplug: unplug callback.
|
||||||
|
*/
|
||||||
|
typedef struct HotplugHandlerClass {
|
||||||
|
/* <private> */
|
||||||
|
InterfaceClass parent;
|
||||||
|
|
||||||
|
/* <public> */
|
||||||
|
hotplug_fn plug;
|
||||||
|
hotplug_fn unplug;
|
||||||
|
} HotplugHandlerClass;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* hotplug_handler_plug:
|
||||||
|
*
|
||||||
|
* Call #HotplugHandlerClass.plug callback of @plug_handler.
|
||||||
|
*/
|
||||||
|
void hotplug_handler_plug(HotplugHandler *plug_handler,
|
||||||
|
DeviceState *plugged_dev,
|
||||||
|
Error **errp);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* hotplug_handler_unplug:
|
||||||
|
*
|
||||||
|
* Call #HotplugHandlerClass.unplug callback of @plug_handler.
|
||||||
|
*/
|
||||||
|
void hotplug_handler_unplug(HotplugHandler *plug_handler,
|
||||||
|
DeviceState *plugged_dev,
|
||||||
|
Error **errp);
|
||||||
|
#endif
|
Loading…
Reference in New Issue
Block a user