2 * QEMU disk image utility
4 * Copyright (c) 2003-2008 Fabrice Bellard
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:
13 * The above copyright notice and this permission notice shall be included in
14 * all copies or substantial portions of the Software.
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
24 #include "qapi-visit.h"
25 #include "qapi/qmp-output-visitor.h"
26 #include "qapi/qmp/qjson.h"
27 #include "qemu-common.h"
28 #include "qemu/option.h"
29 #include "qemu/error-report.h"
30 #include "qemu/osdep.h"
31 #include "sysemu/sysemu.h"
32 #include "block/block_int.h"
40 typedef struct img_cmd_t {
42 int (*handler)(int argc, char **argv);
47 OPTION_BACKING_CHAIN = 257,
50 typedef enum OutputFormat {
55 /* Default to cache=writeback as data integrity is not important for qemu-tcg. */
56 #define BDRV_O_FLAGS BDRV_O_CACHE_WB
57 #define BDRV_DEFAULT_CACHE "writeback"
59 static void format_print(void *opaque, const char *name)
64 /* Please keep in synch with qemu-img.texi */
65 static void help(void)
67 const char *help_msg =
68 "qemu-img version " QEMU_VERSION ", Copyright (c) 2004-2008 Fabrice Bellard\n"
69 "usage: qemu-img command [command options]\n"
70 "QEMU disk image utility\n"
73 #define DEF(option, callback, arg_string) \
75 #include "qemu-img-cmds.h"
79 "Command parameters:\n"
80 " 'filename' is a disk image filename\n"
81 " 'fmt' is the disk image format. It is guessed automatically in most cases\n"
82 " 'cache' is the cache mode used to write the output disk image, the valid\n"
83 " options are: 'none', 'writeback' (default, except for convert), 'writethrough',\n"
84 " 'directsync' and 'unsafe' (default for convert)\n"
85 " 'size' is the disk image size in bytes. Optional suffixes\n"
86 " 'k' or 'K' (kilobyte, 1024), 'M' (megabyte, 1024k), 'G' (gigabyte, 1024M)\n"
87 " and T (terabyte, 1024G) are supported. 'b' is ignored.\n"
88 " 'output_filename' is the destination disk image filename\n"
89 " 'output_fmt' is the destination format\n"
90 " 'options' is a comma separated list of format specific options in a\n"
91 " name=value format. Use -o ? for an overview of the options supported by the\n"
93 " '-c' indicates that target image must be compressed (qcow format only)\n"
94 " '-u' enables unsafe rebasing. It is assumed that old and new backing file\n"
95 " match exactly. The image doesn't need a working backing file before\n"
96 " rebasing in this case (useful for renaming the backing file)\n"
97 " '-h' with or without a command shows this help and lists the supported formats\n"
98 " '-p' show progress of command (only certain commands)\n"
99 " '-S' indicates the consecutive number of bytes that must contain only zeros\n"
100 " for qemu-img to create a sparse image during conversion\n"
101 " '--output' takes the format in which the output must be done (human or json)\n"
103 "Parameters to check subcommand:\n"
104 " '-r' tries to repair any inconsistencies that are found during the check.\n"
105 " '-r leaks' repairs only cluster leaks, whereas '-r all' fixes all\n"
106 " kinds of errors, with a higher risk of choosing the wrong fix or\n"
107 " hiding corruption that has already occurred.\n"
109 "Parameters to snapshot subcommand:\n"
110 " 'snapshot' is the name of the snapshot to create, apply or delete\n"
111 " '-a' applies a snapshot (revert disk to saved state)\n"
112 " '-c' creates a snapshot\n"
113 " '-d' deletes a snapshot\n"
114 " '-l' lists all snapshots in the given image\n";
116 printf("%s\nSupported formats:", help_msg);
117 bdrv_iterate_format(format_print, NULL);
123 /* XXX: put correct support for win32 */
124 static int read_password(char *buf, int buf_size)
127 printf("Password: ");
134 if (i < (buf_size - 1))
145 static struct termios oldtty;
147 static void term_exit(void)
149 tcsetattr (0, TCSANOW, &oldtty);
152 static void term_init(void)
159 tty.c_iflag &= ~(IGNBRK|BRKINT|PARMRK|ISTRIP
160 |INLCR|IGNCR|ICRNL|IXON);
161 tty.c_oflag |= OPOST;
162 tty.c_lflag &= ~(ECHO|ECHONL|ICANON|IEXTEN);
163 tty.c_cflag &= ~(CSIZE|PARENB);
168 tcsetattr (0, TCSANOW, &tty);
173 static int read_password(char *buf, int buf_size)
178 printf("password: ");
183 ret = read(0, &ch, 1);
185 if (errno == EAGAIN || errno == EINTR) {
191 } else if (ret == 0) {
199 if (i < (buf_size - 1))
210 static int print_block_option_help(const char *filename, const char *fmt)
212 BlockDriver *drv, *proto_drv;
213 QEMUOptionParameter *create_options = NULL;
215 /* Find driver and parse its options */
216 drv = bdrv_find_format(fmt);
218 error_report("Unknown file format '%s'", fmt);
222 proto_drv = bdrv_find_protocol(filename);
224 error_report("Unknown protocol '%s'", filename);
228 create_options = append_option_parameters(create_options,
229 drv->create_options);
230 create_options = append_option_parameters(create_options,
231 proto_drv->create_options);
232 print_option_help(create_options);
233 free_option_parameters(create_options);
237 static BlockDriverState *bdrv_new_open(const char *filename,
242 BlockDriverState *bs;
247 bs = bdrv_new("image");
250 drv = bdrv_find_format(fmt);
252 error_report("Unknown file format '%s'", fmt);
259 ret = bdrv_open(bs, filename, flags, drv);
261 error_report("Could not open '%s': %s", filename, strerror(-ret));
265 if (bdrv_is_encrypted(bs) && require_io) {
266 printf("Disk image '%s' is encrypted.\n", filename);
267 if (read_password(password, sizeof(password)) < 0) {
268 error_report("No password given");
271 if (bdrv_set_key(bs, password) < 0) {
272 error_report("invalid password");
284 static int add_old_style_options(const char *fmt, QEMUOptionParameter *list,
285 const char *base_filename,
286 const char *base_fmt)
289 if (set_option_parameter(list, BLOCK_OPT_BACKING_FILE, base_filename)) {
290 error_report("Backing file not supported for file format '%s'",
296 if (set_option_parameter(list, BLOCK_OPT_BACKING_FMT, base_fmt)) {
297 error_report("Backing file format not supported for file "
305 static int img_create(int argc, char **argv)
308 uint64_t img_size = -1;
309 const char *fmt = "raw";
310 const char *base_fmt = NULL;
311 const char *filename;
312 const char *base_filename = NULL;
313 char *options = NULL;
314 Error *local_err = NULL;
317 c = getopt(argc, argv, "F:b:f:he6o:");
330 base_filename = optarg;
336 error_report("option -e is deprecated, please use \'-o "
337 "encryption\' instead!");
340 error_report("option -6 is deprecated, please use \'-o "
341 "compat6\' instead!");
349 /* Get the filename */
350 if (optind >= argc) {
353 filename = argv[optind++];
355 /* Get image size, if specified */
359 sval = strtosz_suffix(argv[optind++], &end, STRTOSZ_DEFSUFFIX_B);
360 if (sval < 0 || *end) {
361 if (sval == -ERANGE) {
362 error_report("Image size must be less than 8 EiB!");
364 error_report("Invalid image size specified! You may use k, M, "
365 "G or T suffixes for ");
366 error_report("kilobytes, megabytes, gigabytes and terabytes.");
370 img_size = (uint64_t)sval;
373 if (options && is_help_option(options)) {
374 return print_block_option_help(filename, fmt);
377 bdrv_img_create(filename, fmt, base_filename, base_fmt,
378 options, img_size, BDRV_O_FLAGS, &local_err);
379 if (error_is_set(&local_err)) {
380 error_report("%s", error_get_pretty(local_err));
381 error_free(local_err);
388 static void dump_json_image_check(ImageCheck *check)
392 QmpOutputVisitor *ov = qmp_output_visitor_new();
394 visit_type_ImageCheck(qmp_output_get_visitor(ov),
395 &check, NULL, &errp);
396 obj = qmp_output_get_qobject(ov);
397 str = qobject_to_json_pretty(obj);
399 printf("%s\n", qstring_get_str(str));
401 qmp_output_visitor_cleanup(ov);
405 static void dump_human_image_check(ImageCheck *check)
407 if (!(check->corruptions || check->leaks || check->check_errors)) {
408 printf("No errors were found on the image.\n");
410 if (check->corruptions) {
411 printf("\n%" PRId64 " errors were found on the image.\n"
412 "Data may be corrupted, or further writes to the image "
418 printf("\n%" PRId64 " leaked clusters were found on the image.\n"
419 "This means waste of disk space, but no harm to data.\n",
423 if (check->check_errors) {
424 printf("\n%" PRId64 " internal errors have occurred during the check.\n",
425 check->check_errors);
429 if (check->total_clusters != 0 && check->allocated_clusters != 0) {
430 printf("%" PRId64 "/%" PRId64 "= %0.2f%% allocated, %0.2f%% fragmented\n",
431 check->allocated_clusters, check->total_clusters,
432 check->allocated_clusters * 100.0 / check->total_clusters,
433 check->fragmented_clusters * 100.0 / check->allocated_clusters);
436 if (check->image_end_offset) {
437 printf("Image end offset: %" PRId64 "\n", check->image_end_offset);
441 static int collect_image_check(BlockDriverState *bs,
443 const char *filename,
448 BdrvCheckResult result;
450 ret = bdrv_check(bs, &result, fix);
455 check->filename = g_strdup(filename);
456 check->format = g_strdup(bdrv_get_format_name(bs));
457 check->check_errors = result.check_errors;
458 check->corruptions = result.corruptions;
459 check->has_corruptions = result.corruptions != 0;
460 check->leaks = result.leaks;
461 check->has_leaks = result.leaks != 0;
462 check->corruptions_fixed = result.corruptions_fixed;
463 check->has_corruptions_fixed = result.corruptions != 0;
464 check->leaks_fixed = result.leaks_fixed;
465 check->has_leaks_fixed = result.leaks != 0;
466 check->image_end_offset = result.image_end_offset;
467 check->has_image_end_offset = result.image_end_offset != 0;
468 check->total_clusters = result.bfi.total_clusters;
469 check->has_total_clusters = result.bfi.total_clusters != 0;
470 check->allocated_clusters = result.bfi.allocated_clusters;
471 check->has_allocated_clusters = result.bfi.allocated_clusters != 0;
472 check->fragmented_clusters = result.bfi.fragmented_clusters;
473 check->has_fragmented_clusters = result.bfi.fragmented_clusters != 0;
479 * Checks an image for consistency. Exit codes:
481 * 0 - Check completed, image is good
482 * 1 - Check not completed because of internal errors
483 * 2 - Check completed, image is corrupted
484 * 3 - Check completed, image has leaked clusters, but is good otherwise
486 static int img_check(int argc, char **argv)
489 OutputFormat output_format = OFORMAT_HUMAN;
490 const char *filename, *fmt, *output;
491 BlockDriverState *bs;
493 int flags = BDRV_O_FLAGS | BDRV_O_CHECK;
499 int option_index = 0;
500 static const struct option long_options[] = {
501 {"help", no_argument, 0, 'h'},
502 {"format", required_argument, 0, 'f'},
503 {"repair", no_argument, 0, 'r'},
504 {"output", required_argument, 0, OPTION_OUTPUT},
507 c = getopt_long(argc, argv, "f:hr:",
508 long_options, &option_index);
521 flags |= BDRV_O_RDWR;
523 if (!strcmp(optarg, "leaks")) {
524 fix = BDRV_FIX_LEAKS;
525 } else if (!strcmp(optarg, "all")) {
526 fix = BDRV_FIX_LEAKS | BDRV_FIX_ERRORS;
536 if (optind >= argc) {
539 filename = argv[optind++];
541 if (output && !strcmp(output, "json")) {
542 output_format = OFORMAT_JSON;
543 } else if (output && !strcmp(output, "human")) {
544 output_format = OFORMAT_HUMAN;
546 error_report("--output must be used with human or json as argument.");
550 bs = bdrv_new_open(filename, fmt, flags, true);
555 check = g_new0(ImageCheck, 1);
556 ret = collect_image_check(bs, check, filename, fmt, fix);
558 if (ret == -ENOTSUP) {
559 if (output_format == OFORMAT_HUMAN) {
560 error_report("This image format does not support checks");
566 if (check->corruptions_fixed || check->leaks_fixed) {
567 int corruptions_fixed, leaks_fixed;
569 leaks_fixed = check->leaks_fixed;
570 corruptions_fixed = check->corruptions_fixed;
572 if (output_format == OFORMAT_HUMAN) {
573 printf("The following inconsistencies were found and repaired:\n\n"
574 " %" PRId64 " leaked clusters\n"
575 " %" PRId64 " corruptions\n\n"
576 "Double checking the fixed image now...\n",
578 check->corruptions_fixed);
581 ret = collect_image_check(bs, check, filename, fmt, 0);
583 check->leaks_fixed = leaks_fixed;
584 check->corruptions_fixed = corruptions_fixed;
587 switch (output_format) {
589 dump_human_image_check(check);
592 dump_json_image_check(check);
596 if (ret || check->check_errors) {
601 if (check->corruptions) {
603 } else if (check->leaks) {
610 qapi_free_ImageCheck(check);
616 static int img_commit(int argc, char **argv)
619 const char *filename, *fmt, *cache;
620 BlockDriverState *bs;
623 cache = BDRV_DEFAULT_CACHE;
625 c = getopt(argc, argv, "f:ht:");
642 if (optind >= argc) {
645 filename = argv[optind++];
648 ret = bdrv_parse_cache_flags(cache, &flags);
650 error_report("Invalid cache option: %s", cache);
654 bs = bdrv_new_open(filename, fmt, flags, true);
658 ret = bdrv_commit(bs);
661 printf("Image committed.\n");
664 error_report("No disk inserted");
667 error_report("Image is read-only");
670 error_report("Image is already committed");
673 error_report("Error while committing image");
685 * Returns true iff the first sector pointed to by 'buf' contains at least
688 * 'pnum' is set to the number of sectors (including and immediately following
689 * the first one) that are known to be in the same allocated/unallocated state.
691 static int is_allocated_sectors(const uint8_t *buf, int n, int *pnum)
700 is_zero = buffer_is_zero(buf, 512);
701 for(i = 1; i < n; i++) {
703 if (is_zero != buffer_is_zero(buf, 512)) {
712 * Like is_allocated_sectors, but if the buffer starts with a used sector,
713 * up to 'min' consecutive sectors containing zeros are ignored. This avoids
714 * breaking up write requests for only small sparse areas.
716 static int is_allocated_sectors_min(const uint8_t *buf, int n, int *pnum,
720 int num_checked, num_used;
726 ret = is_allocated_sectors(buf, n, pnum);
732 buf += BDRV_SECTOR_SIZE * *pnum;
734 num_checked = num_used;
737 ret = is_allocated_sectors(buf, n, pnum);
739 buf += BDRV_SECTOR_SIZE * *pnum;
741 num_checked += *pnum;
743 num_used = num_checked;
744 } else if (*pnum >= min) {
754 * Compares two buffers sector by sector. Returns 0 if the first sector of both
755 * buffers matches, non-zero otherwise.
757 * pnum is set to the number of sectors (including and immediately following
758 * the first one) that are known to have the same comparison result
760 static int compare_sectors(const uint8_t *buf1, const uint8_t *buf2, int n,
770 res = !!memcmp(buf1, buf2, 512);
771 for(i = 1; i < n; i++) {
775 if (!!memcmp(buf1, buf2, 512) != res) {
784 #define IO_BUF_SIZE (2 * 1024 * 1024)
786 static int img_convert(int argc, char **argv)
788 int c, ret = 0, n, n1, bs_n, bs_i, compress, cluster_size, cluster_sectors;
789 int progress = 0, flags;
790 const char *fmt, *out_fmt, *cache, *out_baseimg, *out_filename;
791 BlockDriver *drv, *proto_drv;
792 BlockDriverState **bs = NULL, *out_bs = NULL;
793 int64_t total_sectors, nb_sectors, sector_num, bs_offset;
795 uint8_t * buf = NULL;
798 QEMUOptionParameter *param = NULL, *create_options = NULL;
799 QEMUOptionParameter *out_baseimg_param;
800 char *options = NULL;
801 const char *snapshot_name = NULL;
802 float local_progress = 0;
803 int min_sparse = 8; /* Need at least 4k of zeros for sparse detection */
811 c = getopt(argc, argv, "f:O:B:s:hce6o:pS:t:");
827 out_baseimg = optarg;
833 error_report("option -e is deprecated, please use \'-o "
834 "encryption\' instead!");
837 error_report("option -6 is deprecated, please use \'-o "
838 "compat6\' instead!");
844 snapshot_name = optarg;
850 sval = strtosz_suffix(optarg, &end, STRTOSZ_DEFSUFFIX_B);
851 if (sval < 0 || *end) {
852 error_report("Invalid minimum zero buffer size for sparse output specified");
856 min_sparse = sval / BDRV_SECTOR_SIZE;
868 bs_n = argc - optind - 1;
873 out_filename = argv[argc - 1];
875 /* Initialize before goto out */
876 qemu_progress_init(progress, 2.0);
878 if (options && is_help_option(options)) {
879 ret = print_block_option_help(out_filename, out_fmt);
883 if (bs_n > 1 && out_baseimg) {
884 error_report("-B makes no sense when concatenating multiple input "
890 qemu_progress_print(0, 100);
892 bs = g_malloc0(bs_n * sizeof(BlockDriverState *));
895 for (bs_i = 0; bs_i < bs_n; bs_i++) {
896 bs[bs_i] = bdrv_new_open(argv[optind + bs_i], fmt, BDRV_O_FLAGS, true);
898 error_report("Could not open '%s'", argv[optind + bs_i]);
902 bdrv_get_geometry(bs[bs_i], &bs_sectors);
903 total_sectors += bs_sectors;
906 if (snapshot_name != NULL) {
908 error_report("No support for concatenating multiple snapshot");
912 if (bdrv_snapshot_load_tmp(bs[0], snapshot_name) < 0) {
913 error_report("Failed to load snapshot");
919 /* Find driver and parse its options */
920 drv = bdrv_find_format(out_fmt);
922 error_report("Unknown file format '%s'", out_fmt);
927 proto_drv = bdrv_find_protocol(out_filename);
929 error_report("Unknown protocol '%s'", out_filename);
934 create_options = append_option_parameters(create_options,
935 drv->create_options);
936 create_options = append_option_parameters(create_options,
937 proto_drv->create_options);
940 param = parse_option_parameters(options, create_options, param);
942 error_report("Invalid options for file format '%s'.", out_fmt);
947 param = parse_option_parameters("", create_options, param);
950 set_option_parameter_int(param, BLOCK_OPT_SIZE, total_sectors * 512);
951 ret = add_old_style_options(out_fmt, param, out_baseimg, NULL);
956 /* Get backing file name if -o backing_file was used */
957 out_baseimg_param = get_option_parameter(param, BLOCK_OPT_BACKING_FILE);
958 if (out_baseimg_param) {
959 out_baseimg = out_baseimg_param->value.s;
962 /* Check if compression is supported */
964 QEMUOptionParameter *encryption =
965 get_option_parameter(param, BLOCK_OPT_ENCRYPT);
966 QEMUOptionParameter *preallocation =
967 get_option_parameter(param, BLOCK_OPT_PREALLOC);
969 if (!drv->bdrv_write_compressed) {
970 error_report("Compression not supported for this file format");
975 if (encryption && encryption->value.n) {
976 error_report("Compression and encryption not supported at "
982 if (preallocation && preallocation->value.s
983 && strcmp(preallocation->value.s, "off"))
985 error_report("Compression and preallocation not supported at "
992 /* Create the new image */
993 ret = bdrv_create(drv, out_filename, param);
995 if (ret == -ENOTSUP) {
996 error_report("Formatting not supported for file format '%s'",
998 } else if (ret == -EFBIG) {
999 error_report("The image size is too large for file format '%s'",
1002 error_report("%s: error while converting %s: %s",
1003 out_filename, out_fmt, strerror(-ret));
1008 flags = BDRV_O_RDWR;
1009 ret = bdrv_parse_cache_flags(cache, &flags);
1011 error_report("Invalid cache option: %s", cache);
1015 out_bs = bdrv_new_open(out_filename, out_fmt, flags, true);
1023 bdrv_get_geometry(bs[0], &bs_sectors);
1024 buf = qemu_blockalign(out_bs, IO_BUF_SIZE);
1027 ret = bdrv_get_info(out_bs, &bdi);
1029 error_report("could not get block driver info");
1032 cluster_size = bdi.cluster_size;
1033 if (cluster_size <= 0 || cluster_size > IO_BUF_SIZE) {
1034 error_report("invalid cluster size");
1038 cluster_sectors = cluster_size >> 9;
1041 nb_sectors = total_sectors;
1042 if (nb_sectors != 0) {
1043 local_progress = (float)100 /
1044 (nb_sectors / MIN(nb_sectors, cluster_sectors));
1052 nb_sectors = total_sectors - sector_num;
1053 if (nb_sectors <= 0)
1055 if (nb_sectors >= cluster_sectors)
1056 n = cluster_sectors;
1060 bs_num = sector_num - bs_offset;
1061 assert (bs_num >= 0);
1064 while (remainder > 0) {
1066 while (bs_num == bs_sectors) {
1068 assert (bs_i < bs_n);
1069 bs_offset += bs_sectors;
1070 bdrv_get_geometry(bs[bs_i], &bs_sectors);
1072 /* printf("changing part: sector_num=%" PRId64 ", "
1073 "bs_i=%d, bs_offset=%" PRId64 ", bs_sectors=%" PRId64
1074 "\n", sector_num, bs_i, bs_offset, bs_sectors); */
1076 assert (bs_num < bs_sectors);
1078 nlow = (remainder > bs_sectors - bs_num) ? bs_sectors - bs_num : remainder;
1080 ret = bdrv_read(bs[bs_i], bs_num, buf2, nlow);
1082 error_report("error while reading sector %" PRId64 ": %s",
1083 bs_num, strerror(-ret));
1092 assert (remainder == 0);
1094 if (n < cluster_sectors) {
1095 memset(buf + n * 512, 0, cluster_size - n * 512);
1097 if (!buffer_is_zero(buf, cluster_size)) {
1098 ret = bdrv_write_compressed(out_bs, sector_num, buf,
1101 error_report("error while compressing sector %" PRId64
1102 ": %s", sector_num, strerror(-ret));
1107 qemu_progress_print(local_progress, 100);
1109 /* signal EOF to align */
1110 bdrv_write_compressed(out_bs, 0, NULL, 0);
1112 int has_zero_init = bdrv_has_zero_init(out_bs);
1114 sector_num = 0; // total number of sectors converted so far
1115 nb_sectors = total_sectors - sector_num;
1116 if (nb_sectors != 0) {
1117 local_progress = (float)100 /
1118 (nb_sectors / MIN(nb_sectors, IO_BUF_SIZE / 512));
1122 nb_sectors = total_sectors - sector_num;
1123 if (nb_sectors <= 0) {
1126 if (nb_sectors >= (IO_BUF_SIZE / 512)) {
1127 n = (IO_BUF_SIZE / 512);
1132 while (sector_num - bs_offset >= bs_sectors) {
1134 assert (bs_i < bs_n);
1135 bs_offset += bs_sectors;
1136 bdrv_get_geometry(bs[bs_i], &bs_sectors);
1137 /* printf("changing part: sector_num=%" PRId64 ", bs_i=%d, "
1138 "bs_offset=%" PRId64 ", bs_sectors=%" PRId64 "\n",
1139 sector_num, bs_i, bs_offset, bs_sectors); */
1142 if (n > bs_offset + bs_sectors - sector_num) {
1143 n = bs_offset + bs_sectors - sector_num;
1146 if (has_zero_init) {
1147 /* If the output image is being created as a copy on write image,
1148 assume that sectors which are unallocated in the input image
1149 are present in both the output's and input's base images (no
1150 need to copy them). */
1152 if (!bdrv_is_allocated(bs[bs_i], sector_num - bs_offset,
1157 /* The next 'n1' sectors are allocated in the input image. Copy
1158 only those as they may be followed by unallocated sectors. */
1165 ret = bdrv_read(bs[bs_i], sector_num - bs_offset, buf, n);
1167 error_report("error while reading sector %" PRId64 ": %s",
1168 sector_num - bs_offset, strerror(-ret));
1171 /* NOTE: at the same time we convert, we do not write zero
1172 sectors to have a chance to compress the image. Ideally, we
1173 should add a specific call to have the info to go faster */
1176 /* If the output image is being created as a copy on write image,
1177 copy all sectors even the ones containing only NUL bytes,
1178 because they may differ from the sectors in the base image.
1180 If the output is to a host device, we also write out
1181 sectors that are entirely 0, since whatever data was
1182 already there is garbage, not 0s. */
1183 if (!has_zero_init || out_baseimg ||
1184 is_allocated_sectors_min(buf1, n, &n1, min_sparse)) {
1185 ret = bdrv_write(out_bs, sector_num, buf1, n1);
1187 error_report("error while writing sector %" PRId64
1188 ": %s", sector_num, strerror(-ret));
1196 qemu_progress_print(local_progress, 100);
1200 qemu_progress_end();
1201 free_option_parameters(create_options);
1202 free_option_parameters(param);
1205 bdrv_delete(out_bs);
1208 for (bs_i = 0; bs_i < bs_n; bs_i++) {
1210 bdrv_delete(bs[bs_i]);
1222 static void dump_snapshots(BlockDriverState *bs)
1224 QEMUSnapshotInfo *sn_tab, *sn;
1228 nb_sns = bdrv_snapshot_list(bs, &sn_tab);
1231 printf("Snapshot list:\n");
1232 printf("%s\n", bdrv_snapshot_dump(buf, sizeof(buf), NULL));
1233 for(i = 0; i < nb_sns; i++) {
1235 printf("%s\n", bdrv_snapshot_dump(buf, sizeof(buf), sn));
1240 static void dump_json_image_info_list(ImageInfoList *list)
1244 QmpOutputVisitor *ov = qmp_output_visitor_new();
1246 visit_type_ImageInfoList(qmp_output_get_visitor(ov),
1247 &list, NULL, &errp);
1248 obj = qmp_output_get_qobject(ov);
1249 str = qobject_to_json_pretty(obj);
1250 assert(str != NULL);
1251 printf("%s\n", qstring_get_str(str));
1252 qobject_decref(obj);
1253 qmp_output_visitor_cleanup(ov);
1257 static void collect_snapshots(BlockDriverState *bs , ImageInfo *info)
1260 QEMUSnapshotInfo *sn_tab = NULL;
1261 SnapshotInfoList *info_list, *cur_item = NULL;
1262 sn_count = bdrv_snapshot_list(bs, &sn_tab);
1264 for (i = 0; i < sn_count; i++) {
1265 info->has_snapshots = true;
1266 info_list = g_new0(SnapshotInfoList, 1);
1268 info_list->value = g_new0(SnapshotInfo, 1);
1269 info_list->value->id = g_strdup(sn_tab[i].id_str);
1270 info_list->value->name = g_strdup(sn_tab[i].name);
1271 info_list->value->vm_state_size = sn_tab[i].vm_state_size;
1272 info_list->value->date_sec = sn_tab[i].date_sec;
1273 info_list->value->date_nsec = sn_tab[i].date_nsec;
1274 info_list->value->vm_clock_sec = sn_tab[i].vm_clock_nsec / 1000000000;
1275 info_list->value->vm_clock_nsec = sn_tab[i].vm_clock_nsec % 1000000000;
1277 /* XXX: waiting for the qapi to support qemu-queue.h types */
1279 info->snapshots = cur_item = info_list;
1281 cur_item->next = info_list;
1282 cur_item = info_list;
1290 static void dump_json_image_info(ImageInfo *info)
1294 QmpOutputVisitor *ov = qmp_output_visitor_new();
1296 visit_type_ImageInfo(qmp_output_get_visitor(ov),
1297 &info, NULL, &errp);
1298 obj = qmp_output_get_qobject(ov);
1299 str = qobject_to_json_pretty(obj);
1300 assert(str != NULL);
1301 printf("%s\n", qstring_get_str(str));
1302 qobject_decref(obj);
1303 qmp_output_visitor_cleanup(ov);
1307 static void collect_image_info(BlockDriverState *bs,
1309 const char *filename,
1312 uint64_t total_sectors;
1313 char backing_filename[1024];
1314 char backing_filename2[1024];
1315 BlockDriverInfo bdi;
1317 bdrv_get_geometry(bs, &total_sectors);
1319 info->filename = g_strdup(filename);
1320 info->format = g_strdup(bdrv_get_format_name(bs));
1321 info->virtual_size = total_sectors * 512;
1322 info->actual_size = bdrv_get_allocated_file_size(bs);
1323 info->has_actual_size = info->actual_size >= 0;
1324 if (bdrv_is_encrypted(bs)) {
1325 info->encrypted = true;
1326 info->has_encrypted = true;
1328 if (bdrv_get_info(bs, &bdi) >= 0) {
1329 if (bdi.cluster_size != 0) {
1330 info->cluster_size = bdi.cluster_size;
1331 info->has_cluster_size = true;
1333 info->dirty_flag = bdi.is_dirty;
1334 info->has_dirty_flag = true;
1336 bdrv_get_backing_filename(bs, backing_filename, sizeof(backing_filename));
1337 if (backing_filename[0] != '\0') {
1338 info->backing_filename = g_strdup(backing_filename);
1339 info->has_backing_filename = true;
1340 bdrv_get_full_backing_filename(bs, backing_filename2,
1341 sizeof(backing_filename2));
1343 if (strcmp(backing_filename, backing_filename2) != 0) {
1344 info->full_backing_filename =
1345 g_strdup(backing_filename2);
1346 info->has_full_backing_filename = true;
1349 if (bs->backing_format[0]) {
1350 info->backing_filename_format = g_strdup(bs->backing_format);
1351 info->has_backing_filename_format = true;
1356 static void dump_human_image_info(ImageInfo *info)
1358 char size_buf[128], dsize_buf[128];
1359 if (!info->has_actual_size) {
1360 snprintf(dsize_buf, sizeof(dsize_buf), "unavailable");
1362 get_human_readable_size(dsize_buf, sizeof(dsize_buf),
1365 get_human_readable_size(size_buf, sizeof(size_buf), info->virtual_size);
1366 printf("image: %s\n"
1368 "virtual size: %s (%" PRId64 " bytes)\n"
1370 info->filename, info->format, size_buf,
1374 if (info->has_encrypted && info->encrypted) {
1375 printf("encrypted: yes\n");
1378 if (info->has_cluster_size) {
1379 printf("cluster_size: %" PRId64 "\n", info->cluster_size);
1382 if (info->has_dirty_flag && info->dirty_flag) {
1383 printf("cleanly shut down: no\n");
1386 if (info->has_backing_filename) {
1387 printf("backing file: %s", info->backing_filename);
1388 if (info->has_full_backing_filename) {
1389 printf(" (actual path: %s)", info->full_backing_filename);
1392 if (info->has_backing_filename_format) {
1393 printf("backing file format: %s\n", info->backing_filename_format);
1397 if (info->has_snapshots) {
1398 SnapshotInfoList *elem;
1401 printf("Snapshot list:\n");
1402 printf("%s\n", bdrv_snapshot_dump(buf, sizeof(buf), NULL));
1404 /* Ideally bdrv_snapshot_dump() would operate on SnapshotInfoList but
1405 * we convert to the block layer's native QEMUSnapshotInfo for now.
1407 for (elem = info->snapshots; elem; elem = elem->next) {
1408 QEMUSnapshotInfo sn = {
1409 .vm_state_size = elem->value->vm_state_size,
1410 .date_sec = elem->value->date_sec,
1411 .date_nsec = elem->value->date_nsec,
1412 .vm_clock_nsec = elem->value->vm_clock_sec * 1000000000ULL +
1413 elem->value->vm_clock_nsec,
1416 pstrcpy(sn.id_str, sizeof(sn.id_str), elem->value->id);
1417 pstrcpy(sn.name, sizeof(sn.name), elem->value->name);
1418 printf("%s\n", bdrv_snapshot_dump(buf, sizeof(buf), &sn));
1423 static void dump_human_image_info_list(ImageInfoList *list)
1425 ImageInfoList *elem;
1428 for (elem = list; elem; elem = elem->next) {
1434 dump_human_image_info(elem->value);
1438 static gboolean str_equal_func(gconstpointer a, gconstpointer b)
1440 return strcmp(a, b) == 0;
1444 * Open an image file chain and return an ImageInfoList
1446 * @filename: topmost image filename
1447 * @fmt: topmost image format (may be NULL to autodetect)
1448 * @chain: true - enumerate entire backing file chain
1449 * false - only topmost image file
1451 * Returns a list of ImageInfo objects or NULL if there was an error opening an
1452 * image file. If there was an error a message will have been printed to
1455 static ImageInfoList *collect_image_info_list(const char *filename,
1459 ImageInfoList *head = NULL;
1460 ImageInfoList **last = &head;
1461 GHashTable *filenames;
1463 filenames = g_hash_table_new_full(g_str_hash, str_equal_func, NULL, NULL);
1466 BlockDriverState *bs;
1468 ImageInfoList *elem;
1470 if (g_hash_table_lookup_extended(filenames, filename, NULL, NULL)) {
1471 error_report("Backing file '%s' creates an infinite loop.",
1475 g_hash_table_insert(filenames, (gpointer)filename, NULL);
1477 bs = bdrv_new_open(filename, fmt, BDRV_O_FLAGS | BDRV_O_NO_BACKING,
1483 info = g_new0(ImageInfo, 1);
1484 collect_image_info(bs, info, filename, fmt);
1485 collect_snapshots(bs, info);
1487 elem = g_new0(ImageInfoList, 1);
1494 filename = fmt = NULL;
1496 if (info->has_full_backing_filename) {
1497 filename = info->full_backing_filename;
1498 } else if (info->has_backing_filename) {
1499 filename = info->backing_filename;
1501 if (info->has_backing_filename_format) {
1502 fmt = info->backing_filename_format;
1506 g_hash_table_destroy(filenames);
1510 qapi_free_ImageInfoList(head);
1511 g_hash_table_destroy(filenames);
1515 static int img_info(int argc, char **argv)
1518 OutputFormat output_format = OFORMAT_HUMAN;
1520 const char *filename, *fmt, *output;
1521 ImageInfoList *list;
1526 int option_index = 0;
1527 static const struct option long_options[] = {
1528 {"help", no_argument, 0, 'h'},
1529 {"format", required_argument, 0, 'f'},
1530 {"output", required_argument, 0, OPTION_OUTPUT},
1531 {"backing-chain", no_argument, 0, OPTION_BACKING_CHAIN},
1534 c = getopt_long(argc, argv, "f:h",
1535 long_options, &option_index);
1550 case OPTION_BACKING_CHAIN:
1555 if (optind >= argc) {
1558 filename = argv[optind++];
1560 if (output && !strcmp(output, "json")) {
1561 output_format = OFORMAT_JSON;
1562 } else if (output && !strcmp(output, "human")) {
1563 output_format = OFORMAT_HUMAN;
1564 } else if (output) {
1565 error_report("--output must be used with human or json as argument.");
1569 list = collect_image_info_list(filename, fmt, chain);
1574 switch (output_format) {
1576 dump_human_image_info_list(list);
1580 dump_json_image_info_list(list);
1582 dump_json_image_info(list->value);
1587 qapi_free_ImageInfoList(list);
1591 #define SNAPSHOT_LIST 1
1592 #define SNAPSHOT_CREATE 2
1593 #define SNAPSHOT_APPLY 3
1594 #define SNAPSHOT_DELETE 4
1596 static int img_snapshot(int argc, char **argv)
1598 BlockDriverState *bs;
1599 QEMUSnapshotInfo sn;
1600 char *filename, *snapshot_name = NULL;
1601 int c, ret = 0, bdrv_oflags;
1605 bdrv_oflags = BDRV_O_FLAGS | BDRV_O_RDWR;
1606 /* Parse commandline parameters */
1608 c = getopt(argc, argv, "la:c:d:h");
1622 action = SNAPSHOT_LIST;
1623 bdrv_oflags &= ~BDRV_O_RDWR; /* no need for RW */
1630 action = SNAPSHOT_APPLY;
1631 snapshot_name = optarg;
1638 action = SNAPSHOT_CREATE;
1639 snapshot_name = optarg;
1646 action = SNAPSHOT_DELETE;
1647 snapshot_name = optarg;
1652 if (optind >= argc) {
1655 filename = argv[optind++];
1657 /* Open the image */
1658 bs = bdrv_new_open(filename, NULL, bdrv_oflags, true);
1663 /* Perform the requested action */
1669 case SNAPSHOT_CREATE:
1670 memset(&sn, 0, sizeof(sn));
1671 pstrcpy(sn.name, sizeof(sn.name), snapshot_name);
1673 qemu_gettimeofday(&tv);
1674 sn.date_sec = tv.tv_sec;
1675 sn.date_nsec = tv.tv_usec * 1000;
1677 ret = bdrv_snapshot_create(bs, &sn);
1679 error_report("Could not create snapshot '%s': %d (%s)",
1680 snapshot_name, ret, strerror(-ret));
1684 case SNAPSHOT_APPLY:
1685 ret = bdrv_snapshot_goto(bs, snapshot_name);
1687 error_report("Could not apply snapshot '%s': %d (%s)",
1688 snapshot_name, ret, strerror(-ret));
1692 case SNAPSHOT_DELETE:
1693 ret = bdrv_snapshot_delete(bs, snapshot_name);
1695 error_report("Could not delete snapshot '%s': %d (%s)",
1696 snapshot_name, ret, strerror(-ret));
1709 static int img_rebase(int argc, char **argv)
1711 BlockDriverState *bs, *bs_old_backing = NULL, *bs_new_backing = NULL;
1712 BlockDriver *old_backing_drv, *new_backing_drv;
1714 const char *fmt, *cache, *out_basefmt, *out_baseimg;
1719 /* Parse commandline parameters */
1721 cache = BDRV_DEFAULT_CACHE;
1725 c = getopt(argc, argv, "uhf:F:b:pt:");
1738 out_basefmt = optarg;
1741 out_baseimg = optarg;
1755 if ((optind >= argc) || (!unsafe && !out_baseimg)) {
1758 filename = argv[optind++];
1760 qemu_progress_init(progress, 2.0);
1761 qemu_progress_print(0, 100);
1763 flags = BDRV_O_RDWR | (unsafe ? BDRV_O_NO_BACKING : 0);
1764 ret = bdrv_parse_cache_flags(cache, &flags);
1766 error_report("Invalid cache option: %s", cache);
1773 * Ignore the old backing file for unsafe rebase in case we want to correct
1774 * the reference to a renamed or moved backing file.
1776 bs = bdrv_new_open(filename, fmt, flags, true);
1781 /* Find the right drivers for the backing files */
1782 old_backing_drv = NULL;
1783 new_backing_drv = NULL;
1785 if (!unsafe && bs->backing_format[0] != '\0') {
1786 old_backing_drv = bdrv_find_format(bs->backing_format);
1787 if (old_backing_drv == NULL) {
1788 error_report("Invalid format name: '%s'", bs->backing_format);
1794 if (out_basefmt != NULL) {
1795 new_backing_drv = bdrv_find_format(out_basefmt);
1796 if (new_backing_drv == NULL) {
1797 error_report("Invalid format name: '%s'", out_basefmt);
1803 /* For safe rebasing we need to compare old and new backing file */
1805 /* Make the compiler happy */
1806 bs_old_backing = NULL;
1807 bs_new_backing = NULL;
1809 char backing_name[1024];
1811 bs_old_backing = bdrv_new("old_backing");
1812 bdrv_get_backing_filename(bs, backing_name, sizeof(backing_name));
1813 ret = bdrv_open(bs_old_backing, backing_name, BDRV_O_FLAGS,
1816 error_report("Could not open old backing file '%s'", backing_name);
1819 if (out_baseimg[0]) {
1820 bs_new_backing = bdrv_new("new_backing");
1821 ret = bdrv_open(bs_new_backing, out_baseimg, BDRV_O_FLAGS,
1824 error_report("Could not open new backing file '%s'",
1832 * Check each unallocated cluster in the COW file. If it is unallocated,
1833 * accesses go to the backing file. We must therefore compare this cluster
1834 * in the old and new backing file, and if they differ we need to copy it
1835 * from the old backing file into the COW file.
1837 * If qemu-img crashes during this step, no harm is done. The content of
1838 * the image is the same as the original one at any time.
1841 uint64_t num_sectors;
1842 uint64_t old_backing_num_sectors;
1843 uint64_t new_backing_num_sectors = 0;
1848 float local_progress = 0;
1850 buf_old = qemu_blockalign(bs, IO_BUF_SIZE);
1851 buf_new = qemu_blockalign(bs, IO_BUF_SIZE);
1853 bdrv_get_geometry(bs, &num_sectors);
1854 bdrv_get_geometry(bs_old_backing, &old_backing_num_sectors);
1855 if (bs_new_backing) {
1856 bdrv_get_geometry(bs_new_backing, &new_backing_num_sectors);
1859 if (num_sectors != 0) {
1860 local_progress = (float)100 /
1861 (num_sectors / MIN(num_sectors, IO_BUF_SIZE / 512));
1864 for (sector = 0; sector < num_sectors; sector += n) {
1866 /* How many sectors can we handle with the next read? */
1867 if (sector + (IO_BUF_SIZE / 512) <= num_sectors) {
1868 n = (IO_BUF_SIZE / 512);
1870 n = num_sectors - sector;
1873 /* If the cluster is allocated, we don't need to take action */
1874 ret = bdrv_is_allocated(bs, sector, n, &n);
1880 * Read old and new backing file and take into consideration that
1881 * backing files may be smaller than the COW image.
1883 if (sector >= old_backing_num_sectors) {
1884 memset(buf_old, 0, n * BDRV_SECTOR_SIZE);
1886 if (sector + n > old_backing_num_sectors) {
1887 n = old_backing_num_sectors - sector;
1890 ret = bdrv_read(bs_old_backing, sector, buf_old, n);
1892 error_report("error while reading from old backing file");
1897 if (sector >= new_backing_num_sectors || !bs_new_backing) {
1898 memset(buf_new, 0, n * BDRV_SECTOR_SIZE);
1900 if (sector + n > new_backing_num_sectors) {
1901 n = new_backing_num_sectors - sector;
1904 ret = bdrv_read(bs_new_backing, sector, buf_new, n);
1906 error_report("error while reading from new backing file");
1911 /* If they differ, we need to write to the COW file */
1912 uint64_t written = 0;
1914 while (written < n) {
1917 if (compare_sectors(buf_old + written * 512,
1918 buf_new + written * 512, n - written, &pnum))
1920 ret = bdrv_write(bs, sector + written,
1921 buf_old + written * 512, pnum);
1923 error_report("Error while writing to COW image: %s",
1931 qemu_progress_print(local_progress, 100);
1934 qemu_vfree(buf_old);
1935 qemu_vfree(buf_new);
1939 * Change the backing file. All clusters that are different from the old
1940 * backing file are overwritten in the COW file now, so the visible content
1941 * doesn't change when we switch the backing file.
1943 if (out_baseimg && *out_baseimg) {
1944 ret = bdrv_change_backing_file(bs, out_baseimg, out_basefmt);
1946 ret = bdrv_change_backing_file(bs, NULL, NULL);
1949 if (ret == -ENOSPC) {
1950 error_report("Could not change the backing file to '%s': No "
1951 "space left in the file header", out_baseimg);
1952 } else if (ret < 0) {
1953 error_report("Could not change the backing file to '%s': %s",
1954 out_baseimg, strerror(-ret));
1957 qemu_progress_print(100, 0);
1959 * TODO At this point it is possible to check if any clusters that are
1960 * allocated in the COW file are the same in the backing file. If so, they
1961 * could be dropped from the COW file. Don't do this before switching the
1962 * backing file, in case of a crash this would lead to corruption.
1965 qemu_progress_end();
1968 if (bs_old_backing != NULL) {
1969 bdrv_delete(bs_old_backing);
1971 if (bs_new_backing != NULL) {
1972 bdrv_delete(bs_new_backing);
1983 static int img_resize(int argc, char **argv)
1985 int c, ret, relative;
1986 const char *filename, *fmt, *size;
1987 int64_t n, total_size;
1988 BlockDriverState *bs = NULL;
1990 static QemuOptsList resize_options = {
1991 .name = "resize_options",
1992 .head = QTAILQ_HEAD_INITIALIZER(resize_options.head),
1995 .name = BLOCK_OPT_SIZE,
1996 .type = QEMU_OPT_SIZE,
1997 .help = "Virtual disk size"
2004 /* Remove size from argv manually so that negative numbers are not treated
2005 * as options by getopt. */
2011 size = argv[--argc];
2013 /* Parse getopt arguments */
2016 c = getopt(argc, argv, "f:h");
2030 if (optind >= argc) {
2033 filename = argv[optind++];
2035 /* Choose grow, shrink, or absolute resize mode */
2051 param = qemu_opts_create_nofail(&resize_options);
2052 if (qemu_opt_set(param, BLOCK_OPT_SIZE, size)) {
2053 /* Error message already printed when size parsing fails */
2055 qemu_opts_del(param);
2058 n = qemu_opt_get_size(param, BLOCK_OPT_SIZE, 0);
2059 qemu_opts_del(param);
2061 bs = bdrv_new_open(filename, fmt, BDRV_O_FLAGS | BDRV_O_RDWR, true);
2068 total_size = bdrv_getlength(bs) + n * relative;
2072 if (total_size <= 0) {
2073 error_report("New image size must be positive");
2078 ret = bdrv_truncate(bs, total_size);
2081 printf("Image resized.\n");
2084 error_report("This image does not support resize");
2087 error_report("Image is read-only");
2090 error_report("Error resizing image (%d)", -ret);
2103 static const img_cmd_t img_cmds[] = {
2104 #define DEF(option, callback, arg_string) \
2105 { option, callback },
2106 #include "qemu-img-cmds.h"
2112 int main(int argc, char **argv)
2114 const img_cmd_t *cmd;
2115 const char *cmdname;
2117 error_set_progname(argv[0]);
2119 qemu_init_main_loop();
2126 /* find the command */
2127 for(cmd = img_cmds; cmd->name != NULL; cmd++) {
2128 if (!strcmp(cmdname, cmd->name)) {
2129 return cmd->handler(argc, argv);