1 /* 2 * QEMU System Emulator block driver 3 * 4 * Copyright (c) 2003 Fabrice Bellard 5 * 6 * Permission is hereby granted, free of charge, to any person obtaining a copy 7 * of this software and associated documentation files (the "Software"), to deal 8 * in the Software without restriction, including without limitation the rights 9 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 10 * copies of the Software, and to permit persons to whom the Software is 11 * furnished to do so, subject to the following conditions: 12 * 13 * The above copyright notice and this permission notice shall be included in 14 * all copies or substantial portions of the Software. 15 * 16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 17 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 18 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 19 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 20 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 21 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 22 * THE SOFTWARE. 23 */ 24 #ifndef BLOCK_INT_GLOBAL_STATE_H 25 #define BLOCK_INT_GLOBAL_STATE_H 26 27 #include "block_int-common.h" 28 29 /* 30 * Global state (GS) API. These functions run under the BQL. 31 * 32 * See include/block/block-global-state.h for more information about 33 * the GS API. 34 */ 35 36 /** 37 * stream_start: 38 * @job_id: The id of the newly-created job, or %NULL to use the 39 * device name of @bs. 40 * @bs: Block device to operate on. 41 * @base: Block device that will become the new base, or %NULL to 42 * flatten the whole backing file chain onto @bs. 43 * @backing_file_str: The file name that will be written to @bs as the 44 * the new backing file if the job completes. Ignored if @base is %NULL. 45 * @creation_flags: Flags that control the behavior of the Job lifetime. 46 * See @BlockJobCreateFlags 47 * @speed: The maximum speed, in bytes per second, or 0 for unlimited. 48 * @on_error: The action to take upon error. 49 * @filter_node_name: The node name that should be assigned to the filter 50 * driver that the stream job inserts into the graph above 51 * @bs. NULL means that a node name should be autogenerated. 52 * @errp: Error object. 53 * 54 * Start a streaming operation on @bs. Clusters that are unallocated 55 * in @bs, but allocated in any image between @base and @bs (both 56 * exclusive) will be written to @bs. At the end of a successful 57 * streaming job, the backing file of @bs will be changed to 58 * @backing_file_str in the written image and to @base in the live 59 * BlockDriverState. 60 */ 61 void stream_start(const char *job_id, BlockDriverState *bs, 62 BlockDriverState *base, const char *backing_file_str, 63 BlockDriverState *bottom, 64 int creation_flags, int64_t speed, 65 BlockdevOnError on_error, 66 const char *filter_node_name, 67 Error **errp); 68 69 /** 70 * commit_start: 71 * @job_id: The id of the newly-created job, or %NULL to use the 72 * device name of @bs. 73 * @bs: Active block device. 74 * @top: Top block device to be committed. 75 * @base: Block device that will be written into, and become the new top. 76 * @creation_flags: Flags that control the behavior of the Job lifetime. 77 * See @BlockJobCreateFlags 78 * @speed: The maximum speed, in bytes per second, or 0 for unlimited. 79 * @on_error: The action to take upon error. 80 * @backing_file_str: String to use as the backing file in @top's overlay 81 * @filter_node_name: The node name that should be assigned to the filter 82 * driver that the commit job inserts into the graph above @top. NULL means 83 * that a node name should be autogenerated. 84 * @errp: Error object. 85 * 86 */ 87 void commit_start(const char *job_id, BlockDriverState *bs, 88 BlockDriverState *base, BlockDriverState *top, 89 int creation_flags, int64_t speed, 90 BlockdevOnError on_error, const char *backing_file_str, 91 const char *filter_node_name, Error **errp); 92 /** 93 * commit_active_start: 94 * @job_id: The id of the newly-created job, or %NULL to use the 95 * device name of @bs. 96 * @bs: Active block device to be committed. 97 * @base: Block device that will be written into, and become the new top. 98 * @creation_flags: Flags that control the behavior of the Job lifetime. 99 * See @BlockJobCreateFlags 100 * @speed: The maximum speed, in bytes per second, or 0 for unlimited. 101 * @on_error: The action to take upon error. 102 * @filter_node_name: The node name that should be assigned to the filter 103 * driver that the commit job inserts into the graph above @bs. NULL means that 104 * a node name should be autogenerated. 105 * @cb: Completion function for the job. 106 * @opaque: Opaque pointer value passed to @cb. 107 * @auto_complete: Auto complete the job. 108 * @errp: Error object. 109 * 110 */ 111 BlockJob *commit_active_start(const char *job_id, BlockDriverState *bs, 112 BlockDriverState *base, int creation_flags, 113 int64_t speed, BlockdevOnError on_error, 114 const char *filter_node_name, 115 BlockCompletionFunc *cb, void *opaque, 116 bool auto_complete, Error **errp); 117 /* 118 * mirror_start: 119 * @job_id: The id of the newly-created job, or %NULL to use the 120 * device name of @bs. 121 * @bs: Block device to operate on. 122 * @target: Block device to write to. 123 * @replaces: Block graph node name to replace once the mirror is done. Can 124 * only be used when full mirroring is selected. 125 * @creation_flags: Flags that control the behavior of the Job lifetime. 126 * See @BlockJobCreateFlags 127 * @speed: The maximum speed, in bytes per second, or 0 for unlimited. 128 * @granularity: The chosen granularity for the dirty bitmap. 129 * @buf_size: The amount of data that can be in flight at one time. 130 * @mode: Whether to collapse all images in the chain to the target. 131 * @backing_mode: How to establish the target's backing chain after completion. 132 * @zero_target: Whether the target should be explicitly zero-initialized 133 * @on_source_error: The action to take upon error reading from the source. 134 * @on_target_error: The action to take upon error writing to the target. 135 * @unmap: Whether to unmap target where source sectors only contain zeroes. 136 * @filter_node_name: The node name that should be assigned to the filter 137 * driver that the mirror job inserts into the graph above @bs. NULL means that 138 * a node name should be autogenerated. 139 * @copy_mode: When to trigger writes to the target. 140 * @errp: Error object. 141 * 142 * Start a mirroring operation on @bs. Clusters that are allocated 143 * in @bs will be written to @target until the job is cancelled or 144 * manually completed. At the end of a successful mirroring job, 145 * @bs will be switched to read from @target. 146 */ 147 void mirror_start(const char *job_id, BlockDriverState *bs, 148 BlockDriverState *target, const char *replaces, 149 int creation_flags, int64_t speed, 150 uint32_t granularity, int64_t buf_size, 151 MirrorSyncMode mode, BlockMirrorBackingMode backing_mode, 152 bool zero_target, 153 BlockdevOnError on_source_error, 154 BlockdevOnError on_target_error, 155 bool unmap, const char *filter_node_name, 156 MirrorCopyMode copy_mode, Error **errp); 157 158 /* 159 * backup_job_create: 160 * @job_id: The id of the newly-created job, or %NULL to use the 161 * device name of @bs. 162 * @bs: Block device to operate on. 163 * @target: Block device to write to. 164 * @speed: The maximum speed, in bytes per second, or 0 for unlimited. 165 * @sync_mode: What parts of the disk image should be copied to the destination. 166 * @sync_bitmap: The dirty bitmap if sync_mode is 'bitmap' or 'incremental' 167 * @bitmap_mode: The bitmap synchronization policy to use. 168 * @perf: Performance options. All actual fields assumed to be present, 169 * all ".has_*" fields are ignored. 170 * @on_source_error: The action to take upon error reading from the source. 171 * @on_target_error: The action to take upon error writing to the target. 172 * @creation_flags: Flags that control the behavior of the Job lifetime. 173 * See @BlockJobCreateFlags 174 * @cb: Completion function for the job. 175 * @opaque: Opaque pointer value passed to @cb. 176 * @txn: Transaction that this job is part of (may be NULL). 177 * 178 * Create a backup operation on @bs. Clusters in @bs are written to @target 179 * until the job is cancelled or manually completed. 180 */ 181 BlockJob *backup_job_create(const char *job_id, BlockDriverState *bs, 182 BlockDriverState *target, int64_t speed, 183 MirrorSyncMode sync_mode, 184 BdrvDirtyBitmap *sync_bitmap, 185 BitmapSyncMode bitmap_mode, 186 bool compress, 187 const char *filter_node_name, 188 BackupPerf *perf, 189 BlockdevOnError on_source_error, 190 BlockdevOnError on_target_error, 191 int creation_flags, 192 BlockCompletionFunc *cb, void *opaque, 193 JobTxn *txn, Error **errp); 194 195 BdrvChild *bdrv_root_attach_child(BlockDriverState *child_bs, 196 const char *child_name, 197 const BdrvChildClass *child_class, 198 BdrvChildRole child_role, 199 uint64_t perm, uint64_t shared_perm, 200 void *opaque, Error **errp); 201 void bdrv_root_unref_child(BdrvChild *child); 202 203 void bdrv_get_cumulative_perm(BlockDriverState *bs, uint64_t *perm, 204 uint64_t *shared_perm); 205 206 /** 207 * Sets a BdrvChild's permissions. Avoid if the parent is a BDS; use 208 * bdrv_child_refresh_perms() instead and make the parent's 209 * .bdrv_child_perm() implementation return the correct values. 210 */ 211 int bdrv_child_try_set_perm(BdrvChild *c, uint64_t perm, uint64_t shared, 212 Error **errp); 213 214 /** 215 * Calls bs->drv->bdrv_child_perm() and updates the child's permission 216 * masks with the result. 217 * Drivers should invoke this function whenever an event occurs that 218 * makes their .bdrv_child_perm() implementation return different 219 * values than before, but which will not result in the block layer 220 * automatically refreshing the permissions. 221 */ 222 int bdrv_child_refresh_perms(BlockDriverState *bs, BdrvChild *c, Error **errp); 223 224 bool bdrv_recurse_can_replace(BlockDriverState *bs, 225 BlockDriverState *to_replace); 226 227 /* 228 * Default implementation for BlockDriver.bdrv_child_perm() that can 229 * be used by block filters and image formats, as long as they use the 230 * child_of_bds child class and set an appropriate BdrvChildRole. 231 */ 232 void bdrv_default_perms(BlockDriverState *bs, BdrvChild *c, 233 BdrvChildRole role, BlockReopenQueue *reopen_queue, 234 uint64_t perm, uint64_t shared, 235 uint64_t *nperm, uint64_t *nshared); 236 237 void blk_dev_change_media_cb(BlockBackend *blk, bool load, Error **errp); 238 bool blk_dev_has_removable_media(BlockBackend *blk); 239 void blk_dev_eject_request(BlockBackend *blk, bool force); 240 bool blk_dev_is_medium_locked(BlockBackend *blk); 241 242 void bdrv_restore_dirty_bitmap(BdrvDirtyBitmap *bitmap, HBitmap *backup); 243 244 void bdrv_set_monitor_owned(BlockDriverState *bs); 245 246 void blockdev_close_all_bdrv_states(void); 247 248 BlockDriverState *bds_tree_init(QDict *bs_opts, Error **errp); 249 250 /** 251 * Simple implementation of bdrv_co_create_opts for protocol drivers 252 * which only support creation via opening a file 253 * (usually existing raw storage device) 254 */ 255 int coroutine_fn bdrv_co_create_opts_simple(BlockDriver *drv, 256 const char *filename, 257 QemuOpts *opts, 258 Error **errp); 259 260 BdrvDirtyBitmap *block_dirty_bitmap_lookup(const char *node, 261 const char *name, 262 BlockDriverState **pbs, 263 Error **errp); 264 BdrvDirtyBitmap *block_dirty_bitmap_merge(const char *node, const char *target, 265 BlockDirtyBitmapMergeSourceList *bms, 266 HBitmap **backup, Error **errp); 267 BdrvDirtyBitmap *block_dirty_bitmap_remove(const char *node, const char *name, 268 bool release, 269 BlockDriverState **bitmap_bs, 270 Error **errp); 271 272 273 BlockDriverState *bdrv_skip_implicit_filters(BlockDriverState *bs); 274 275 /** 276 * bdrv_add_aio_context_notifier: 277 * 278 * If a long-running job intends to be always run in the same AioContext as a 279 * certain BDS, it may use this function to be notified of changes regarding the 280 * association of the BDS to an AioContext. 281 * 282 * attached_aio_context() is called after the target BDS has been attached to a 283 * new AioContext; detach_aio_context() is called before the target BDS is being 284 * detached from its old AioContext. 285 */ 286 void bdrv_add_aio_context_notifier(BlockDriverState *bs, 287 void (*attached_aio_context)(AioContext *new_context, void *opaque), 288 void (*detach_aio_context)(void *opaque), void *opaque); 289 290 /** 291 * bdrv_remove_aio_context_notifier: 292 * 293 * Unsubscribe of change notifications regarding the BDS's AioContext. The 294 * parameters given here have to be the same as those given to 295 * bdrv_add_aio_context_notifier(). 296 */ 297 void bdrv_remove_aio_context_notifier(BlockDriverState *bs, 298 void (*aio_context_attached)(AioContext *, 299 void *), 300 void (*aio_context_detached)(void *), 301 void *opaque); 302 303 /** 304 * End all quiescent sections started by bdrv_drain_all_begin(). This is 305 * needed when deleting a BDS before bdrv_drain_all_end() is called. 306 * 307 * NOTE: this is an internal helper for bdrv_close() *only*. No one else 308 * should call it. 309 */ 310 void bdrv_drain_all_end_quiesce(BlockDriverState *bs); 311 312 /** 313 * Make sure that the function is running under both drain and BQL. 314 * The latter protects from concurrent writings 315 * from the GS API, while the former prevents concurrent reads 316 * from I/O. 317 */ 318 static inline void assert_bdrv_graph_writable(BlockDriverState *bs) 319 { 320 /* 321 * TODO: this function is incomplete. Because the users of this 322 * assert lack the necessary drains, check only for BQL. 323 * Once the necessary drains are added, 324 * assert also for qatomic_read(&bs->quiesce_counter) > 0 325 */ 326 assert(qemu_in_main_thread()); 327 } 328 329 #endif /* BLOCK_INT_GLOBAL_STATE */ 330