|  | /* | 
|  | * QEMU Block backends | 
|  | * | 
|  | * Copyright (C) 2014-2016 Red Hat, Inc. | 
|  | * | 
|  | * Authors: | 
|  | *  Markus Armbruster <armbru@redhat.com>, | 
|  | * | 
|  | * This work is licensed under the terms of the GNU LGPL, version 2.1 | 
|  | * or later.  See the COPYING.LIB file in the top-level directory. | 
|  | */ | 
|  |  | 
|  | #ifndef BLOCK_BACKEND_COMMON_H | 
|  | #define BLOCK_BACKEND_COMMON_H | 
|  |  | 
|  | #include "qemu/iov.h" | 
|  | #include "block/throttle-groups.h" | 
|  |  | 
|  | /* | 
|  | * TODO Have to include block/block.h for a bunch of block layer | 
|  | * types.  Unfortunately, this pulls in the whole BlockDriverState | 
|  | * API, which we don't want used by many BlockBackend users.  Some of | 
|  | * the types belong here, and the rest should be split into a common | 
|  | * header and one for the BlockDriverState API. | 
|  | */ | 
|  | #include "block/block.h" | 
|  |  | 
|  | /* Callbacks for block device models */ | 
|  | typedef struct BlockDevOps { | 
|  |  | 
|  | /* | 
|  | * Global state (GS) API. These functions run under the BQL. | 
|  | * | 
|  | * See include/block/block-global-state.h for more information about | 
|  | * the GS API. | 
|  | */ | 
|  |  | 
|  | /* | 
|  | * Runs when virtual media changed (monitor commands eject, change) | 
|  | * Argument load is true on load and false on eject. | 
|  | * Beware: doesn't run when a host device's physical media | 
|  | * changes.  Sure would be useful if it did. | 
|  | * Device models with removable media must implement this callback. | 
|  | */ | 
|  | void (*change_media_cb)(void *opaque, bool load, Error **errp); | 
|  | /* | 
|  | * Runs when an eject request is issued from the monitor, the tray | 
|  | * is closed, and the medium is locked. | 
|  | * Device models that do not implement is_medium_locked will not need | 
|  | * this callback.  Device models that can lock the medium or tray might | 
|  | * want to implement the callback and unlock the tray when "force" is | 
|  | * true, even if they do not support eject requests. | 
|  | */ | 
|  | void (*eject_request_cb)(void *opaque, bool force); | 
|  |  | 
|  | /* | 
|  | * Is the virtual medium locked into the device? | 
|  | * Device models implement this only when device has such a lock. | 
|  | */ | 
|  | bool (*is_medium_locked)(void *opaque); | 
|  |  | 
|  | /* | 
|  | * Runs when the backend receives a drain request. | 
|  | */ | 
|  | void (*drained_begin)(void *opaque); | 
|  | /* | 
|  | * Runs when the backend's last drain request ends. | 
|  | */ | 
|  | void (*drained_end)(void *opaque); | 
|  | /* | 
|  | * Is the device still busy? | 
|  | */ | 
|  | bool (*drained_poll)(void *opaque); | 
|  |  | 
|  | /* | 
|  | * I/O API functions. These functions are thread-safe. | 
|  | * | 
|  | * See include/block/block-io.h for more information about | 
|  | * the I/O API. | 
|  | */ | 
|  |  | 
|  | /* | 
|  | * Is the virtual tray open? | 
|  | * Device models implement this only when the device has a tray. | 
|  | */ | 
|  | bool (*is_tray_open)(void *opaque); | 
|  |  | 
|  | /* | 
|  | * Runs when the size changed (e.g. monitor command block_resize) | 
|  | */ | 
|  | void (*resize_cb)(void *opaque); | 
|  | } BlockDevOps; | 
|  |  | 
|  | /* | 
|  | * This struct is embedded in (the private) BlockBackend struct and contains | 
|  | * fields that must be public. This is in particular for QLIST_ENTRY() and | 
|  | * friends so that BlockBackends can be kept in lists outside block-backend.c | 
|  | */ | 
|  | typedef struct BlockBackendPublic { | 
|  | ThrottleGroupMember throttle_group_member; | 
|  | } BlockBackendPublic; | 
|  |  | 
|  | #endif /* BLOCK_BACKEND_COMMON_H */ |