The ->pre_plug() callback is invoked before the device is realized. The ->plug() callback is invoked when the device is being realized but before it is reset. This patch adds a ->post_plug() callback which is invoked after the device has been reset. This callback is needed by HotplugHandlers that need to wait until after ->reset(). Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com> Message-Id: <20180716083732.3347-2-stefanha@redhat.com> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
		
			
				
	
	
		
			82 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			82 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * 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 "qemu/osdep.h"
 | |
| #include "hw/hotplug.h"
 | |
| #include "qemu/module.h"
 | |
| 
 | |
| void hotplug_handler_pre_plug(HotplugHandler *plug_handler,
 | |
|                               DeviceState *plugged_dev,
 | |
|                               Error **errp)
 | |
| {
 | |
|     HotplugHandlerClass *hdc = HOTPLUG_HANDLER_GET_CLASS(plug_handler);
 | |
| 
 | |
|     if (hdc->pre_plug) {
 | |
|         hdc->pre_plug(plug_handler, plugged_dev, errp);
 | |
|     }
 | |
| }
 | |
| 
 | |
| 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_post_plug(HotplugHandler *plug_handler,
 | |
|                                DeviceState *plugged_dev)
 | |
| {
 | |
|     HotplugHandlerClass *hdc = HOTPLUG_HANDLER_GET_CLASS(plug_handler);
 | |
| 
 | |
|     if (hdc->post_plug) {
 | |
|         hdc->post_plug(plug_handler, plugged_dev);
 | |
|     }
 | |
| }
 | |
| 
 | |
| void hotplug_handler_unplug_request(HotplugHandler *plug_handler,
 | |
|                                     DeviceState *plugged_dev,
 | |
|                                     Error **errp)
 | |
| {
 | |
|     HotplugHandlerClass *hdc = HOTPLUG_HANDLER_GET_CLASS(plug_handler);
 | |
| 
 | |
|     if (hdc->unplug_request) {
 | |
|         hdc->unplug_request(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)
 |