]> git.proxmox.com Git - mirror_qemu.git/blame - include/block/dirty-bitmap.h
Merge tag 'pull-maintainer-may24-160524-2' of https://gitlab.com/stsquad/qemu into...
[mirror_qemu.git] / include / block / dirty-bitmap.h
CommitLineData
ebab2259
FZ
1#ifndef BLOCK_DIRTY_BITMAP_H
2#define BLOCK_DIRTY_BITMAP_H
3
e2c1c34f 4#include "block/block-common.h"
9af23989 5#include "qapi/qapi-types-block-core.h"
ebab2259
FZ
6#include "qemu/hbitmap.h"
7
3ae96d66
JS
8typedef enum BitmapCheckFlags {
9 BDRV_BITMAP_BUSY = 1,
10 BDRV_BITMAP_RO = 2,
11 BDRV_BITMAP_INCONSISTENT = 4,
12} BitmapCheckFlags;
13
14#define BDRV_BITMAP_DEFAULT (BDRV_BITMAP_BUSY | BDRV_BITMAP_RO | \
15 BDRV_BITMAP_INCONSISTENT)
16#define BDRV_BITMAP_ALLOW_RO (BDRV_BITMAP_BUSY | BDRV_BITMAP_INCONSISTENT)
17
cf7c49cf
EB
18#define BDRV_BITMAP_MAX_NAME_SIZE 1023
19
ef893b5c 20bool bdrv_supports_persistent_dirty_bitmap(BlockDriverState *bs);
ebab2259
FZ
21BdrvDirtyBitmap *bdrv_create_dirty_bitmap(BlockDriverState *bs,
22 uint32_t granularity,
23 const char *name,
24 Error **errp);
5deb6cbd 25int bdrv_dirty_bitmap_create_successor(BdrvDirtyBitmap *bitmap,
ebab2259 26 Error **errp);
5deb6cbd 27BdrvDirtyBitmap *bdrv_dirty_bitmap_abdicate(BdrvDirtyBitmap *bitmap,
ebab2259 28 Error **errp);
5deb6cbd 29BdrvDirtyBitmap *bdrv_reclaim_dirty_bitmap(BdrvDirtyBitmap *bitmap,
ebab2259 30 Error **errp);
e73a265e 31void bdrv_dirty_bitmap_enable_successor(BdrvDirtyBitmap *bitmap);
ebab2259
FZ
32BdrvDirtyBitmap *bdrv_find_dirty_bitmap(BlockDriverState *bs,
33 const char *name);
3ae96d66
JS
34int bdrv_dirty_bitmap_check(const BdrvDirtyBitmap *bitmap, uint32_t flags,
35 Error **errp);
5deb6cbd 36void bdrv_release_dirty_bitmap(BdrvDirtyBitmap *bitmap);
ebab2259 37void bdrv_release_named_dirty_bitmaps(BlockDriverState *bs);
0508d0be 38
167f748d
KW
39int coroutine_fn GRAPH_RDLOCK
40bdrv_co_remove_persistent_dirty_bitmap(BlockDriverState *bs, const char *name,
41 Error **errp);
42int co_wrapper_bdrv_rdlock
43bdrv_remove_persistent_dirty_bitmap(BlockDriverState *bs, const char *name,
44 Error **errp);
0508d0be 45
ebab2259
FZ
46void bdrv_disable_dirty_bitmap(BdrvDirtyBitmap *bitmap);
47void bdrv_enable_dirty_bitmap(BdrvDirtyBitmap *bitmap);
92bcea40 48void bdrv_enable_dirty_bitmap_locked(BdrvDirtyBitmap *bitmap);
ebab2259
FZ
49BlockDirtyInfoList *bdrv_query_dirty_bitmaps(BlockDriverState *bs);
50uint32_t bdrv_get_default_bitmap_granularity(BlockDriverState *bs);
ba06ff1a 51uint32_t bdrv_dirty_bitmap_granularity(const BdrvDirtyBitmap *bitmap);
ebab2259 52bool bdrv_dirty_bitmap_enabled(BdrvDirtyBitmap *bitmap);
50a47257 53bool bdrv_dirty_bitmap_has_successor(BdrvDirtyBitmap *bitmap);
15891fac
FZ
54const char *bdrv_dirty_bitmap_name(const BdrvDirtyBitmap *bitmap);
55int64_t bdrv_dirty_bitmap_size(const BdrvDirtyBitmap *bitmap);
ebab2259 56void bdrv_set_dirty_bitmap(BdrvDirtyBitmap *bitmap,
e0d7f73e 57 int64_t offset, int64_t bytes);
ebab2259 58void bdrv_reset_dirty_bitmap(BdrvDirtyBitmap *bitmap,
e0d7f73e 59 int64_t offset, int64_t bytes);
715a74d8 60BdrvDirtyBitmapIter *bdrv_dirty_iter_new(BdrvDirtyBitmap *bitmap);
dc162c8e 61void bdrv_dirty_iter_free(BdrvDirtyBitmapIter *iter);
ebab2259 62
882c36f5 63uint64_t bdrv_dirty_bitmap_serialization_size(const BdrvDirtyBitmap *bitmap,
86f6ae67 64 uint64_t offset, uint64_t bytes);
882c36f5 65uint64_t bdrv_dirty_bitmap_serialization_align(const BdrvDirtyBitmap *bitmap);
35f428ba
VSO
66uint64_t bdrv_dirty_bitmap_serialization_coverage(int serialized_chunk_size,
67 const BdrvDirtyBitmap *bitmap);
882c36f5 68void bdrv_dirty_bitmap_serialize_part(const BdrvDirtyBitmap *bitmap,
86f6ae67
EB
69 uint8_t *buf, uint64_t offset,
70 uint64_t bytes);
882c36f5 71void bdrv_dirty_bitmap_deserialize_part(BdrvDirtyBitmap *bitmap,
86f6ae67
EB
72 uint8_t *buf, uint64_t offset,
73 uint64_t bytes, bool finish);
882c36f5 74void bdrv_dirty_bitmap_deserialize_zeroes(BdrvDirtyBitmap *bitmap,
86f6ae67 75 uint64_t offset, uint64_t bytes,
882c36f5 76 bool finish);
6bdc8b71 77void bdrv_dirty_bitmap_deserialize_ones(BdrvDirtyBitmap *bitmap,
86f6ae67 78 uint64_t offset, uint64_t bytes,
6bdc8b71 79 bool finish);
882c36f5
VSO
80void bdrv_dirty_bitmap_deserialize_finish(BdrvDirtyBitmap *bitmap);
81
d6883bc9 82void bdrv_dirty_bitmap_set_readonly(BdrvDirtyBitmap *bitmap, bool value);
796a3798 83void bdrv_dirty_bitmap_set_persistence(BdrvDirtyBitmap *bitmap,
a88b179f 84 bool persistent);
b0f45559 85void bdrv_dirty_bitmap_set_inconsistent(BdrvDirtyBitmap *bitmap);
27a1b301 86void bdrv_dirty_bitmap_set_busy(BdrvDirtyBitmap *bitmap, bool busy);
34ffacb7 87bool bdrv_merge_dirty_bitmap(BdrvDirtyBitmap *dest, const BdrvDirtyBitmap *src,
fa000f2f 88 HBitmap **backup, Error **errp);
c4e4b0fa 89void bdrv_dirty_bitmap_skip_store(BdrvDirtyBitmap *bitmap, bool skip);
28636b82 90bool bdrv_dirty_bitmap_get(BdrvDirtyBitmap *bitmap, int64_t offset);
d6883bc9 91
b64bd51e
PB
92/* Functions that require manual locking. */
93void bdrv_dirty_bitmap_lock(BdrvDirtyBitmap *bitmap);
94void bdrv_dirty_bitmap_unlock(BdrvDirtyBitmap *bitmap);
28636b82 95bool bdrv_dirty_bitmap_get_locked(BdrvDirtyBitmap *bitmap, int64_t offset);
b64bd51e 96void bdrv_set_dirty_bitmap_locked(BdrvDirtyBitmap *bitmap,
e0d7f73e 97 int64_t offset, int64_t bytes);
b64bd51e 98void bdrv_reset_dirty_bitmap_locked(BdrvDirtyBitmap *bitmap,
e0d7f73e 99 int64_t offset, int64_t bytes);
b64bd51e 100int64_t bdrv_dirty_iter_next(BdrvDirtyBitmapIter *iter);
715a74d8 101void bdrv_set_dirty_iter(BdrvDirtyBitmapIter *hbi, int64_t offset);
b64bd51e 102int64_t bdrv_get_dirty_count(BdrvDirtyBitmap *bitmap);
1b6cc579 103void bdrv_dirty_bitmap_truncate(BlockDriverState *bs, int64_t bytes);
d6883bc9
VSO
104bool bdrv_dirty_bitmap_readonly(const BdrvDirtyBitmap *bitmap);
105bool bdrv_has_readonly_bitmaps(BlockDriverState *bs);
7ae89a0d 106bool bdrv_has_named_bitmaps(BlockDriverState *bs);
a0319aac 107bool bdrv_dirty_bitmap_get_autoload(const BdrvDirtyBitmap *bitmap);
796a3798 108bool bdrv_dirty_bitmap_get_persistence(BdrvDirtyBitmap *bitmap);
b0f45559 109bool bdrv_dirty_bitmap_inconsistent(const BdrvDirtyBitmap *bitmap);
ef9041a7
VSO
110
111BdrvDirtyBitmap *bdrv_dirty_bitmap_first(BlockDriverState *bs);
112BdrvDirtyBitmap *bdrv_dirty_bitmap_next(BdrvDirtyBitmap *bitmap);
113#define FOR_EACH_DIRTY_BITMAP(bs, bitmap) \
114for (bitmap = bdrv_dirty_bitmap_first(bs); bitmap; \
115 bitmap = bdrv_dirty_bitmap_next(bitmap))
116
a3b52535 117char *bdrv_dirty_bitmap_sha256(const BdrvDirtyBitmap *bitmap, Error **errp);
9399c54b
VSO
118int64_t bdrv_dirty_bitmap_next_dirty(BdrvDirtyBitmap *bitmap, int64_t offset,
119 int64_t bytes);
642700fd
VSO
120int64_t bdrv_dirty_bitmap_next_zero(BdrvDirtyBitmap *bitmap, int64_t offset,
121 int64_t bytes);
a78a1a48 122bool bdrv_dirty_bitmap_next_dirty_area(BdrvDirtyBitmap *bitmap,
299ea9ff
VSO
123 int64_t start, int64_t end, int64_t max_dirty_count,
124 int64_t *dirty_start, int64_t *dirty_count);
a6426475
VSO
125bool bdrv_dirty_bitmap_status(BdrvDirtyBitmap *bitmap, int64_t offset,
126 int64_t bytes, int64_t *count);
5deb6cbd 127BdrvDirtyBitmap *bdrv_reclaim_dirty_bitmap_locked(BdrvDirtyBitmap *bitmap,
044ee8e1 128 Error **errp);
b64bd51e 129
ebab2259 130#endif