@@ -3062,3 +3062,32 @@ int bdrv_get_conversion_options(BlockDriverState *bs,
}
return bs->drv->bdrv_get_conversion_options(bs, options);
}
+
+/**
+ * Gets a mapping from an offset in the image to an offset within a file
+ *
+ * All offsets are in bytes. Functions starts its search at offset host_offset
+ * + count (offset within the image, not the file offset)
+ *
+ * @param guest_offset used to calculate starting search location on
+ * function call. On return it is the starting
+ * offset of the mapping in the image.
+ * @param host_offset[out] The starting file offset of the mapping.
+ * @param contiguous_bytes[out] The number of bytes for which this mapping is
+ * contiguous. If 0, there are no more mapppings in
+ * the image
+ */
+
+int bdrv_get_mapping(BlockDriverState *bs, uint64_t *guest_offset,
+ uint64_t *host_offset, uint64_t *contiguous_bytes)
+{
+ BlockDriver *drv = bs->drv;
+ if (!drv) {
+ return -ENOMEDIUM;
+ }
+ if (!drv->bdrv_get_mapping) {
+ return -ENOTSUP;
+ }
+ return drv->bdrv_get_mapping(bs, guest_offset, host_offset,
+ contiguous_bytes);
+}
@@ -255,6 +255,8 @@ int bdrv_get_conversion_options(BlockDriverState *bs,
int bdrv_open_conversion_target(BlockDriverState **bs, BlockDriverState *file,
QEMUOptionParameter *options,
const char *target_fmt);
+int bdrv_get_mapping(BlockDriverState *bs, uint64_t *guest_offset,
+ uint64_t *host_offset, uint64_t *contiguous_bytes);
typedef enum {
BLKDBG_L1_UPDATE,
Conflicts: block.h Signed-off-by: Devin Nakamura <devin122@gmail.com> --- block.c | 29 +++++++++++++++++++++++++++++ block.h | 2 ++ 2 files changed, 31 insertions(+), 0 deletions(-)