xref: /openbmc/qemu/block.c (revision 40daca54)
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 #include "config-host.h"
25 #include "qemu-common.h"
26 #include "trace.h"
27 #include "monitor/monitor.h"
28 #include "block/block_int.h"
29 #include "block/blockjob.h"
30 #include "qemu/module.h"
31 #include "qapi/qmp/qjson.h"
32 #include "sysemu/sysemu.h"
33 #include "qemu/notify.h"
34 #include "block/coroutine.h"
35 #include "qmp-commands.h"
36 #include "qemu/timer.h"
37 
38 #ifdef CONFIG_BSD
39 #include <sys/types.h>
40 #include <sys/stat.h>
41 #include <sys/ioctl.h>
42 #include <sys/queue.h>
43 #ifndef __DragonFly__
44 #include <sys/disk.h>
45 #endif
46 #endif
47 
48 #ifdef _WIN32
49 #include <windows.h>
50 #endif
51 
52 #define NOT_DONE 0x7fffffff /* used while emulated sync operation in progress */
53 
54 typedef enum {
55     BDRV_REQ_COPY_ON_READ = 0x1,
56     BDRV_REQ_ZERO_WRITE   = 0x2,
57 } BdrvRequestFlags;
58 
59 static void bdrv_dev_change_media_cb(BlockDriverState *bs, bool load);
60 static BlockDriverAIOCB *bdrv_aio_readv_em(BlockDriverState *bs,
61         int64_t sector_num, QEMUIOVector *qiov, int nb_sectors,
62         BlockDriverCompletionFunc *cb, void *opaque);
63 static BlockDriverAIOCB *bdrv_aio_writev_em(BlockDriverState *bs,
64         int64_t sector_num, QEMUIOVector *qiov, int nb_sectors,
65         BlockDriverCompletionFunc *cb, void *opaque);
66 static int coroutine_fn bdrv_co_readv_em(BlockDriverState *bs,
67                                          int64_t sector_num, int nb_sectors,
68                                          QEMUIOVector *iov);
69 static int coroutine_fn bdrv_co_writev_em(BlockDriverState *bs,
70                                          int64_t sector_num, int nb_sectors,
71                                          QEMUIOVector *iov);
72 static int coroutine_fn bdrv_co_do_readv(BlockDriverState *bs,
73     int64_t sector_num, int nb_sectors, QEMUIOVector *qiov,
74     BdrvRequestFlags flags);
75 static int coroutine_fn bdrv_co_do_writev(BlockDriverState *bs,
76     int64_t sector_num, int nb_sectors, QEMUIOVector *qiov,
77     BdrvRequestFlags flags);
78 static BlockDriverAIOCB *bdrv_co_aio_rw_vector(BlockDriverState *bs,
79                                                int64_t sector_num,
80                                                QEMUIOVector *qiov,
81                                                int nb_sectors,
82                                                BlockDriverCompletionFunc *cb,
83                                                void *opaque,
84                                                bool is_write);
85 static void coroutine_fn bdrv_co_do_rw(void *opaque);
86 static int coroutine_fn bdrv_co_do_write_zeroes(BlockDriverState *bs,
87     int64_t sector_num, int nb_sectors);
88 
89 static bool bdrv_exceed_bps_limits(BlockDriverState *bs, int nb_sectors,
90         bool is_write, double elapsed_time, uint64_t *wait);
91 static bool bdrv_exceed_iops_limits(BlockDriverState *bs, bool is_write,
92         double elapsed_time, uint64_t *wait);
93 static bool bdrv_exceed_io_limits(BlockDriverState *bs, int nb_sectors,
94         bool is_write, int64_t *wait);
95 
96 static QTAILQ_HEAD(, BlockDriverState) bdrv_states =
97     QTAILQ_HEAD_INITIALIZER(bdrv_states);
98 
99 static QLIST_HEAD(, BlockDriver) bdrv_drivers =
100     QLIST_HEAD_INITIALIZER(bdrv_drivers);
101 
102 /* If non-zero, use only whitelisted block drivers */
103 static int use_bdrv_whitelist;
104 
105 #ifdef _WIN32
106 static int is_windows_drive_prefix(const char *filename)
107 {
108     return (((filename[0] >= 'a' && filename[0] <= 'z') ||
109              (filename[0] >= 'A' && filename[0] <= 'Z')) &&
110             filename[1] == ':');
111 }
112 
113 int is_windows_drive(const char *filename)
114 {
115     if (is_windows_drive_prefix(filename) &&
116         filename[2] == '\0')
117         return 1;
118     if (strstart(filename, "\\\\.\\", NULL) ||
119         strstart(filename, "//./", NULL))
120         return 1;
121     return 0;
122 }
123 #endif
124 
125 /* throttling disk I/O limits */
126 void bdrv_io_limits_disable(BlockDriverState *bs)
127 {
128     bs->io_limits_enabled = false;
129 
130     do {} while (qemu_co_enter_next(&bs->throttled_reqs));
131 
132     if (bs->block_timer) {
133         qemu_del_timer(bs->block_timer);
134         qemu_free_timer(bs->block_timer);
135         bs->block_timer = NULL;
136     }
137 
138     bs->slice_start = 0;
139     bs->slice_end   = 0;
140 }
141 
142 static void bdrv_block_timer(void *opaque)
143 {
144     BlockDriverState *bs = opaque;
145 
146     qemu_co_enter_next(&bs->throttled_reqs);
147 }
148 
149 void bdrv_io_limits_enable(BlockDriverState *bs)
150 {
151     bs->block_timer = qemu_new_timer_ns(vm_clock, bdrv_block_timer, bs);
152     bs->io_limits_enabled = true;
153 }
154 
155 bool bdrv_io_limits_enabled(BlockDriverState *bs)
156 {
157     BlockIOLimit *io_limits = &bs->io_limits;
158     return io_limits->bps[BLOCK_IO_LIMIT_READ]
159          || io_limits->bps[BLOCK_IO_LIMIT_WRITE]
160          || io_limits->bps[BLOCK_IO_LIMIT_TOTAL]
161          || io_limits->iops[BLOCK_IO_LIMIT_READ]
162          || io_limits->iops[BLOCK_IO_LIMIT_WRITE]
163          || io_limits->iops[BLOCK_IO_LIMIT_TOTAL];
164 }
165 
166 static void bdrv_io_limits_intercept(BlockDriverState *bs,
167                                      bool is_write, int nb_sectors)
168 {
169     int64_t wait_time = -1;
170 
171     if (!qemu_co_queue_empty(&bs->throttled_reqs)) {
172         qemu_co_queue_wait(&bs->throttled_reqs);
173     }
174 
175     /* In fact, we hope to keep each request's timing, in FIFO mode. The next
176      * throttled requests will not be dequeued until the current request is
177      * allowed to be serviced. So if the current request still exceeds the
178      * limits, it will be inserted to the head. All requests followed it will
179      * be still in throttled_reqs queue.
180      */
181 
182     while (bdrv_exceed_io_limits(bs, nb_sectors, is_write, &wait_time)) {
183         qemu_mod_timer(bs->block_timer,
184                        wait_time + qemu_get_clock_ns(vm_clock));
185         qemu_co_queue_wait_insert_head(&bs->throttled_reqs);
186     }
187 
188     qemu_co_queue_next(&bs->throttled_reqs);
189 }
190 
191 /* check if the path starts with "<protocol>:" */
192 static int path_has_protocol(const char *path)
193 {
194     const char *p;
195 
196 #ifdef _WIN32
197     if (is_windows_drive(path) ||
198         is_windows_drive_prefix(path)) {
199         return 0;
200     }
201     p = path + strcspn(path, ":/\\");
202 #else
203     p = path + strcspn(path, ":/");
204 #endif
205 
206     return *p == ':';
207 }
208 
209 int path_is_absolute(const char *path)
210 {
211 #ifdef _WIN32
212     /* specific case for names like: "\\.\d:" */
213     if (is_windows_drive(path) || is_windows_drive_prefix(path)) {
214         return 1;
215     }
216     return (*path == '/' || *path == '\\');
217 #else
218     return (*path == '/');
219 #endif
220 }
221 
222 /* if filename is absolute, just copy it to dest. Otherwise, build a
223    path to it by considering it is relative to base_path. URL are
224    supported. */
225 void path_combine(char *dest, int dest_size,
226                   const char *base_path,
227                   const char *filename)
228 {
229     const char *p, *p1;
230     int len;
231 
232     if (dest_size <= 0)
233         return;
234     if (path_is_absolute(filename)) {
235         pstrcpy(dest, dest_size, filename);
236     } else {
237         p = strchr(base_path, ':');
238         if (p)
239             p++;
240         else
241             p = base_path;
242         p1 = strrchr(base_path, '/');
243 #ifdef _WIN32
244         {
245             const char *p2;
246             p2 = strrchr(base_path, '\\');
247             if (!p1 || p2 > p1)
248                 p1 = p2;
249         }
250 #endif
251         if (p1)
252             p1++;
253         else
254             p1 = base_path;
255         if (p1 > p)
256             p = p1;
257         len = p - base_path;
258         if (len > dest_size - 1)
259             len = dest_size - 1;
260         memcpy(dest, base_path, len);
261         dest[len] = '\0';
262         pstrcat(dest, dest_size, filename);
263     }
264 }
265 
266 void bdrv_get_full_backing_filename(BlockDriverState *bs, char *dest, size_t sz)
267 {
268     if (bs->backing_file[0] == '\0' || path_has_protocol(bs->backing_file)) {
269         pstrcpy(dest, sz, bs->backing_file);
270     } else {
271         path_combine(dest, sz, bs->filename, bs->backing_file);
272     }
273 }
274 
275 void bdrv_register(BlockDriver *bdrv)
276 {
277     /* Block drivers without coroutine functions need emulation */
278     if (!bdrv->bdrv_co_readv) {
279         bdrv->bdrv_co_readv = bdrv_co_readv_em;
280         bdrv->bdrv_co_writev = bdrv_co_writev_em;
281 
282         /* bdrv_co_readv_em()/brdv_co_writev_em() work in terms of aio, so if
283          * the block driver lacks aio we need to emulate that too.
284          */
285         if (!bdrv->bdrv_aio_readv) {
286             /* add AIO emulation layer */
287             bdrv->bdrv_aio_readv = bdrv_aio_readv_em;
288             bdrv->bdrv_aio_writev = bdrv_aio_writev_em;
289         }
290     }
291 
292     QLIST_INSERT_HEAD(&bdrv_drivers, bdrv, list);
293 }
294 
295 /* create a new block device (by default it is empty) */
296 BlockDriverState *bdrv_new(const char *device_name)
297 {
298     BlockDriverState *bs;
299 
300     bs = g_malloc0(sizeof(BlockDriverState));
301     pstrcpy(bs->device_name, sizeof(bs->device_name), device_name);
302     if (device_name[0] != '\0') {
303         QTAILQ_INSERT_TAIL(&bdrv_states, bs, list);
304     }
305     bdrv_iostatus_disable(bs);
306     notifier_list_init(&bs->close_notifiers);
307     notifier_with_return_list_init(&bs->before_write_notifiers);
308     qemu_co_queue_init(&bs->throttled_reqs);
309 
310     return bs;
311 }
312 
313 void bdrv_add_close_notifier(BlockDriverState *bs, Notifier *notify)
314 {
315     notifier_list_add(&bs->close_notifiers, notify);
316 }
317 
318 BlockDriver *bdrv_find_format(const char *format_name)
319 {
320     BlockDriver *drv1;
321     QLIST_FOREACH(drv1, &bdrv_drivers, list) {
322         if (!strcmp(drv1->format_name, format_name)) {
323             return drv1;
324         }
325     }
326     return NULL;
327 }
328 
329 static int bdrv_is_whitelisted(BlockDriver *drv, bool read_only)
330 {
331     static const char *whitelist_rw[] = {
332         CONFIG_BDRV_RW_WHITELIST
333     };
334     static const char *whitelist_ro[] = {
335         CONFIG_BDRV_RO_WHITELIST
336     };
337     const char **p;
338 
339     if (!whitelist_rw[0] && !whitelist_ro[0]) {
340         return 1;               /* no whitelist, anything goes */
341     }
342 
343     for (p = whitelist_rw; *p; p++) {
344         if (!strcmp(drv->format_name, *p)) {
345             return 1;
346         }
347     }
348     if (read_only) {
349         for (p = whitelist_ro; *p; p++) {
350             if (!strcmp(drv->format_name, *p)) {
351                 return 1;
352             }
353         }
354     }
355     return 0;
356 }
357 
358 BlockDriver *bdrv_find_whitelisted_format(const char *format_name,
359                                           bool read_only)
360 {
361     BlockDriver *drv = bdrv_find_format(format_name);
362     return drv && bdrv_is_whitelisted(drv, read_only) ? drv : NULL;
363 }
364 
365 typedef struct CreateCo {
366     BlockDriver *drv;
367     char *filename;
368     QEMUOptionParameter *options;
369     int ret;
370 } CreateCo;
371 
372 static void coroutine_fn bdrv_create_co_entry(void *opaque)
373 {
374     CreateCo *cco = opaque;
375     assert(cco->drv);
376 
377     cco->ret = cco->drv->bdrv_create(cco->filename, cco->options);
378 }
379 
380 int bdrv_create(BlockDriver *drv, const char* filename,
381     QEMUOptionParameter *options)
382 {
383     int ret;
384 
385     Coroutine *co;
386     CreateCo cco = {
387         .drv = drv,
388         .filename = g_strdup(filename),
389         .options = options,
390         .ret = NOT_DONE,
391     };
392 
393     if (!drv->bdrv_create) {
394         ret = -ENOTSUP;
395         goto out;
396     }
397 
398     if (qemu_in_coroutine()) {
399         /* Fast-path if already in coroutine context */
400         bdrv_create_co_entry(&cco);
401     } else {
402         co = qemu_coroutine_create(bdrv_create_co_entry);
403         qemu_coroutine_enter(co, &cco);
404         while (cco.ret == NOT_DONE) {
405             qemu_aio_wait();
406         }
407     }
408 
409     ret = cco.ret;
410 
411 out:
412     g_free(cco.filename);
413     return ret;
414 }
415 
416 int bdrv_create_file(const char* filename, QEMUOptionParameter *options)
417 {
418     BlockDriver *drv;
419 
420     drv = bdrv_find_protocol(filename, true);
421     if (drv == NULL) {
422         return -ENOENT;
423     }
424 
425     return bdrv_create(drv, filename, options);
426 }
427 
428 /*
429  * Create a uniquely-named empty temporary file.
430  * Return 0 upon success, otherwise a negative errno value.
431  */
432 int get_tmp_filename(char *filename, int size)
433 {
434 #ifdef _WIN32
435     char temp_dir[MAX_PATH];
436     /* GetTempFileName requires that its output buffer (4th param)
437        have length MAX_PATH or greater.  */
438     assert(size >= MAX_PATH);
439     return (GetTempPath(MAX_PATH, temp_dir)
440             && GetTempFileName(temp_dir, "qem", 0, filename)
441             ? 0 : -GetLastError());
442 #else
443     int fd;
444     const char *tmpdir;
445     tmpdir = getenv("TMPDIR");
446     if (!tmpdir)
447         tmpdir = "/tmp";
448     if (snprintf(filename, size, "%s/vl.XXXXXX", tmpdir) >= size) {
449         return -EOVERFLOW;
450     }
451     fd = mkstemp(filename);
452     if (fd < 0) {
453         return -errno;
454     }
455     if (close(fd) != 0) {
456         unlink(filename);
457         return -errno;
458     }
459     return 0;
460 #endif
461 }
462 
463 /*
464  * Detect host devices. By convention, /dev/cdrom[N] is always
465  * recognized as a host CDROM.
466  */
467 static BlockDriver *find_hdev_driver(const char *filename)
468 {
469     int score_max = 0, score;
470     BlockDriver *drv = NULL, *d;
471 
472     QLIST_FOREACH(d, &bdrv_drivers, list) {
473         if (d->bdrv_probe_device) {
474             score = d->bdrv_probe_device(filename);
475             if (score > score_max) {
476                 score_max = score;
477                 drv = d;
478             }
479         }
480     }
481 
482     return drv;
483 }
484 
485 BlockDriver *bdrv_find_protocol(const char *filename,
486                                 bool allow_protocol_prefix)
487 {
488     BlockDriver *drv1;
489     char protocol[128];
490     int len;
491     const char *p;
492 
493     /* TODO Drivers without bdrv_file_open must be specified explicitly */
494 
495     /*
496      * XXX(hch): we really should not let host device detection
497      * override an explicit protocol specification, but moving this
498      * later breaks access to device names with colons in them.
499      * Thanks to the brain-dead persistent naming schemes on udev-
500      * based Linux systems those actually are quite common.
501      */
502     drv1 = find_hdev_driver(filename);
503     if (drv1) {
504         return drv1;
505     }
506 
507     if (!path_has_protocol(filename) || !allow_protocol_prefix) {
508         return bdrv_find_format("file");
509     }
510 
511     p = strchr(filename, ':');
512     assert(p != NULL);
513     len = p - filename;
514     if (len > sizeof(protocol) - 1)
515         len = sizeof(protocol) - 1;
516     memcpy(protocol, filename, len);
517     protocol[len] = '\0';
518     QLIST_FOREACH(drv1, &bdrv_drivers, list) {
519         if (drv1->protocol_name &&
520             !strcmp(drv1->protocol_name, protocol)) {
521             return drv1;
522         }
523     }
524     return NULL;
525 }
526 
527 static int find_image_format(BlockDriverState *bs, const char *filename,
528                              BlockDriver **pdrv)
529 {
530     int score, score_max;
531     BlockDriver *drv1, *drv;
532     uint8_t buf[2048];
533     int ret = 0;
534 
535     /* Return the raw BlockDriver * to scsi-generic devices or empty drives */
536     if (bs->sg || !bdrv_is_inserted(bs) || bdrv_getlength(bs) == 0) {
537         drv = bdrv_find_format("raw");
538         if (!drv) {
539             ret = -ENOENT;
540         }
541         *pdrv = drv;
542         return ret;
543     }
544 
545     ret = bdrv_pread(bs, 0, buf, sizeof(buf));
546     if (ret < 0) {
547         *pdrv = NULL;
548         return ret;
549     }
550 
551     score_max = 0;
552     drv = NULL;
553     QLIST_FOREACH(drv1, &bdrv_drivers, list) {
554         if (drv1->bdrv_probe) {
555             score = drv1->bdrv_probe(buf, ret, filename);
556             if (score > score_max) {
557                 score_max = score;
558                 drv = drv1;
559             }
560         }
561     }
562     if (!drv) {
563         ret = -ENOENT;
564     }
565     *pdrv = drv;
566     return ret;
567 }
568 
569 /**
570  * Set the current 'total_sectors' value
571  */
572 static int refresh_total_sectors(BlockDriverState *bs, int64_t hint)
573 {
574     BlockDriver *drv = bs->drv;
575 
576     /* Do not attempt drv->bdrv_getlength() on scsi-generic devices */
577     if (bs->sg)
578         return 0;
579 
580     /* query actual device if possible, otherwise just trust the hint */
581     if (drv->bdrv_getlength) {
582         int64_t length = drv->bdrv_getlength(bs);
583         if (length < 0) {
584             return length;
585         }
586         hint = length >> BDRV_SECTOR_BITS;
587     }
588 
589     bs->total_sectors = hint;
590     return 0;
591 }
592 
593 /**
594  * Set open flags for a given discard mode
595  *
596  * Return 0 on success, -1 if the discard mode was invalid.
597  */
598 int bdrv_parse_discard_flags(const char *mode, int *flags)
599 {
600     *flags &= ~BDRV_O_UNMAP;
601 
602     if (!strcmp(mode, "off") || !strcmp(mode, "ignore")) {
603         /* do nothing */
604     } else if (!strcmp(mode, "on") || !strcmp(mode, "unmap")) {
605         *flags |= BDRV_O_UNMAP;
606     } else {
607         return -1;
608     }
609 
610     return 0;
611 }
612 
613 /**
614  * Set open flags for a given cache mode
615  *
616  * Return 0 on success, -1 if the cache mode was invalid.
617  */
618 int bdrv_parse_cache_flags(const char *mode, int *flags)
619 {
620     *flags &= ~BDRV_O_CACHE_MASK;
621 
622     if (!strcmp(mode, "off") || !strcmp(mode, "none")) {
623         *flags |= BDRV_O_NOCACHE | BDRV_O_CACHE_WB;
624     } else if (!strcmp(mode, "directsync")) {
625         *flags |= BDRV_O_NOCACHE;
626     } else if (!strcmp(mode, "writeback")) {
627         *flags |= BDRV_O_CACHE_WB;
628     } else if (!strcmp(mode, "unsafe")) {
629         *flags |= BDRV_O_CACHE_WB;
630         *flags |= BDRV_O_NO_FLUSH;
631     } else if (!strcmp(mode, "writethrough")) {
632         /* this is the default */
633     } else {
634         return -1;
635     }
636 
637     return 0;
638 }
639 
640 /**
641  * The copy-on-read flag is actually a reference count so multiple users may
642  * use the feature without worrying about clobbering its previous state.
643  * Copy-on-read stays enabled until all users have called to disable it.
644  */
645 void bdrv_enable_copy_on_read(BlockDriverState *bs)
646 {
647     bs->copy_on_read++;
648 }
649 
650 void bdrv_disable_copy_on_read(BlockDriverState *bs)
651 {
652     assert(bs->copy_on_read > 0);
653     bs->copy_on_read--;
654 }
655 
656 static int bdrv_open_flags(BlockDriverState *bs, int flags)
657 {
658     int open_flags = flags | BDRV_O_CACHE_WB;
659 
660     /*
661      * Clear flags that are internal to the block layer before opening the
662      * image.
663      */
664     open_flags &= ~(BDRV_O_SNAPSHOT | BDRV_O_NO_BACKING);
665 
666     /*
667      * Snapshots should be writable.
668      */
669     if (bs->is_temporary) {
670         open_flags |= BDRV_O_RDWR;
671     }
672 
673     return open_flags;
674 }
675 
676 /*
677  * Common part for opening disk images and files
678  *
679  * Removes all processed options from *options.
680  */
681 static int bdrv_open_common(BlockDriverState *bs, BlockDriverState *file,
682     QDict *options, int flags, BlockDriver *drv)
683 {
684     int ret, open_flags;
685     const char *filename;
686 
687     assert(drv != NULL);
688     assert(bs->file == NULL);
689     assert(options != NULL && bs->options != options);
690 
691     if (file != NULL) {
692         filename = file->filename;
693     } else {
694         filename = qdict_get_try_str(options, "filename");
695     }
696 
697     trace_bdrv_open_common(bs, filename ?: "", flags, drv->format_name);
698 
699     /* bdrv_open() with directly using a protocol as drv. This layer is already
700      * opened, so assign it to bs (while file becomes a closed BlockDriverState)
701      * and return immediately. */
702     if (file != NULL && drv->bdrv_file_open) {
703         bdrv_swap(file, bs);
704         return 0;
705     }
706 
707     bs->open_flags = flags;
708     bs->buffer_alignment = 512;
709     bs->zero_beyond_eof = true;
710     open_flags = bdrv_open_flags(bs, flags);
711     bs->read_only = !(open_flags & BDRV_O_RDWR);
712 
713     if (use_bdrv_whitelist && !bdrv_is_whitelisted(drv, bs->read_only)) {
714         return -ENOTSUP;
715     }
716 
717     assert(bs->copy_on_read == 0); /* bdrv_new() and bdrv_close() make it so */
718     if (!bs->read_only && (flags & BDRV_O_COPY_ON_READ)) {
719         bdrv_enable_copy_on_read(bs);
720     }
721 
722     if (filename != NULL) {
723         pstrcpy(bs->filename, sizeof(bs->filename), filename);
724     } else {
725         bs->filename[0] = '\0';
726     }
727 
728     bs->drv = drv;
729     bs->opaque = g_malloc0(drv->instance_size);
730 
731     bs->enable_write_cache = !!(flags & BDRV_O_CACHE_WB);
732 
733     /* Open the image, either directly or using a protocol */
734     if (drv->bdrv_file_open) {
735         assert(file == NULL);
736         assert(drv->bdrv_parse_filename || filename != NULL);
737         ret = drv->bdrv_file_open(bs, options, open_flags);
738     } else {
739         if (file == NULL) {
740             qerror_report(ERROR_CLASS_GENERIC_ERROR, "Can't use '%s' as a "
741                           "block driver for the protocol level",
742                           drv->format_name);
743             ret = -EINVAL;
744             goto free_and_fail;
745         }
746         assert(file != NULL);
747         bs->file = file;
748         ret = drv->bdrv_open(bs, options, open_flags);
749     }
750 
751     if (ret < 0) {
752         goto free_and_fail;
753     }
754 
755     ret = refresh_total_sectors(bs, bs->total_sectors);
756     if (ret < 0) {
757         goto free_and_fail;
758     }
759 
760 #ifndef _WIN32
761     if (bs->is_temporary) {
762         assert(filename != NULL);
763         unlink(filename);
764     }
765 #endif
766     return 0;
767 
768 free_and_fail:
769     bs->file = NULL;
770     g_free(bs->opaque);
771     bs->opaque = NULL;
772     bs->drv = NULL;
773     return ret;
774 }
775 
776 /*
777  * Opens a file using a protocol (file, host_device, nbd, ...)
778  *
779  * options is a QDict of options to pass to the block drivers, or NULL for an
780  * empty set of options. The reference to the QDict belongs to the block layer
781  * after the call (even on failure), so if the caller intends to reuse the
782  * dictionary, it needs to use QINCREF() before calling bdrv_file_open.
783  */
784 int bdrv_file_open(BlockDriverState **pbs, const char *filename,
785                    QDict *options, int flags)
786 {
787     BlockDriverState *bs;
788     BlockDriver *drv;
789     const char *drvname;
790     bool allow_protocol_prefix = false;
791     int ret;
792 
793     /* NULL means an empty set of options */
794     if (options == NULL) {
795         options = qdict_new();
796     }
797 
798     bs = bdrv_new("");
799     bs->options = options;
800     options = qdict_clone_shallow(options);
801 
802     /* Fetch the file name from the options QDict if necessary */
803     if (!filename) {
804         filename = qdict_get_try_str(options, "filename");
805     } else if (filename && !qdict_haskey(options, "filename")) {
806         qdict_put(options, "filename", qstring_from_str(filename));
807         allow_protocol_prefix = true;
808     } else {
809         qerror_report(ERROR_CLASS_GENERIC_ERROR, "Can't specify 'file' and "
810                       "'filename' options at the same time");
811         ret = -EINVAL;
812         goto fail;
813     }
814 
815     /* Find the right block driver */
816     drvname = qdict_get_try_str(options, "driver");
817     if (drvname) {
818         drv = bdrv_find_whitelisted_format(drvname, !(flags & BDRV_O_RDWR));
819         qdict_del(options, "driver");
820     } else if (filename) {
821         drv = bdrv_find_protocol(filename, allow_protocol_prefix);
822         if (!drv) {
823             qerror_report(ERROR_CLASS_GENERIC_ERROR, "Unknown protocol");
824         }
825     } else {
826         qerror_report(ERROR_CLASS_GENERIC_ERROR,
827                       "Must specify either driver or file");
828         drv = NULL;
829     }
830 
831     if (!drv) {
832         ret = -ENOENT;
833         goto fail;
834     }
835 
836     /* Parse the filename and open it */
837     if (drv->bdrv_parse_filename && filename) {
838         Error *local_err = NULL;
839         drv->bdrv_parse_filename(filename, options, &local_err);
840         if (error_is_set(&local_err)) {
841             qerror_report_err(local_err);
842             error_free(local_err);
843             ret = -EINVAL;
844             goto fail;
845         }
846         qdict_del(options, "filename");
847     } else if (!drv->bdrv_parse_filename && !filename) {
848         qerror_report(ERROR_CLASS_GENERIC_ERROR,
849                       "The '%s' block driver requires a file name",
850                       drv->format_name);
851         ret = -EINVAL;
852         goto fail;
853     }
854 
855     ret = bdrv_open_common(bs, NULL, options, flags, drv);
856     if (ret < 0) {
857         goto fail;
858     }
859 
860     /* Check if any unknown options were used */
861     if (qdict_size(options) != 0) {
862         const QDictEntry *entry = qdict_first(options);
863         qerror_report(ERROR_CLASS_GENERIC_ERROR, "Block protocol '%s' doesn't "
864                       "support the option '%s'",
865                       drv->format_name, entry->key);
866         ret = -EINVAL;
867         goto fail;
868     }
869     QDECREF(options);
870 
871     bs->growable = 1;
872     *pbs = bs;
873     return 0;
874 
875 fail:
876     QDECREF(options);
877     if (!bs->drv) {
878         QDECREF(bs->options);
879     }
880     bdrv_delete(bs);
881     return ret;
882 }
883 
884 /*
885  * Opens the backing file for a BlockDriverState if not yet open
886  *
887  * options is a QDict of options to pass to the block drivers, or NULL for an
888  * empty set of options. The reference to the QDict is transferred to this
889  * function (even on failure), so if the caller intends to reuse the dictionary,
890  * it needs to use QINCREF() before calling bdrv_file_open.
891  */
892 int bdrv_open_backing_file(BlockDriverState *bs, QDict *options)
893 {
894     char backing_filename[PATH_MAX];
895     int back_flags, ret;
896     BlockDriver *back_drv = NULL;
897 
898     if (bs->backing_hd != NULL) {
899         QDECREF(options);
900         return 0;
901     }
902 
903     /* NULL means an empty set of options */
904     if (options == NULL) {
905         options = qdict_new();
906     }
907 
908     bs->open_flags &= ~BDRV_O_NO_BACKING;
909     if (qdict_haskey(options, "file.filename")) {
910         backing_filename[0] = '\0';
911     } else if (bs->backing_file[0] == '\0' && qdict_size(options) == 0) {
912         QDECREF(options);
913         return 0;
914     }
915 
916     bs->backing_hd = bdrv_new("");
917     bdrv_get_full_backing_filename(bs, backing_filename,
918                                    sizeof(backing_filename));
919 
920     if (bs->backing_format[0] != '\0') {
921         back_drv = bdrv_find_format(bs->backing_format);
922     }
923 
924     /* backing files always opened read-only */
925     back_flags = bs->open_flags & ~(BDRV_O_RDWR | BDRV_O_SNAPSHOT);
926 
927     ret = bdrv_open(bs->backing_hd,
928                     *backing_filename ? backing_filename : NULL, options,
929                     back_flags, back_drv);
930     if (ret < 0) {
931         bdrv_delete(bs->backing_hd);
932         bs->backing_hd = NULL;
933         bs->open_flags |= BDRV_O_NO_BACKING;
934         return ret;
935     }
936     return 0;
937 }
938 
939 static void extract_subqdict(QDict *src, QDict **dst, const char *start)
940 {
941     const QDictEntry *entry, *next;
942     const char *p;
943 
944     *dst = qdict_new();
945     entry = qdict_first(src);
946 
947     while (entry != NULL) {
948         next = qdict_next(src, entry);
949         if (strstart(entry->key, start, &p)) {
950             qobject_incref(entry->value);
951             qdict_put_obj(*dst, p, entry->value);
952             qdict_del(src, entry->key);
953         }
954         entry = next;
955     }
956 }
957 
958 /*
959  * Opens a disk image (raw, qcow2, vmdk, ...)
960  *
961  * options is a QDict of options to pass to the block drivers, or NULL for an
962  * empty set of options. The reference to the QDict belongs to the block layer
963  * after the call (even on failure), so if the caller intends to reuse the
964  * dictionary, it needs to use QINCREF() before calling bdrv_open.
965  */
966 int bdrv_open(BlockDriverState *bs, const char *filename, QDict *options,
967               int flags, BlockDriver *drv)
968 {
969     int ret;
970     /* TODO: extra byte is a hack to ensure MAX_PATH space on Windows. */
971     char tmp_filename[PATH_MAX + 1];
972     BlockDriverState *file = NULL;
973     QDict *file_options = NULL;
974     const char *drvname;
975 
976     /* NULL means an empty set of options */
977     if (options == NULL) {
978         options = qdict_new();
979     }
980 
981     bs->options = options;
982     options = qdict_clone_shallow(options);
983 
984     /* For snapshot=on, create a temporary qcow2 overlay */
985     if (flags & BDRV_O_SNAPSHOT) {
986         BlockDriverState *bs1;
987         int64_t total_size;
988         BlockDriver *bdrv_qcow2;
989         QEMUOptionParameter *create_options;
990         char backing_filename[PATH_MAX];
991 
992         if (qdict_size(options) != 0) {
993             error_report("Can't use snapshot=on with driver-specific options");
994             ret = -EINVAL;
995             goto fail;
996         }
997         assert(filename != NULL);
998 
999         /* if snapshot, we create a temporary backing file and open it
1000            instead of opening 'filename' directly */
1001 
1002         /* if there is a backing file, use it */
1003         bs1 = bdrv_new("");
1004         ret = bdrv_open(bs1, filename, NULL, 0, drv);
1005         if (ret < 0) {
1006             bdrv_delete(bs1);
1007             goto fail;
1008         }
1009         total_size = bdrv_getlength(bs1) & BDRV_SECTOR_MASK;
1010 
1011         bdrv_delete(bs1);
1012 
1013         ret = get_tmp_filename(tmp_filename, sizeof(tmp_filename));
1014         if (ret < 0) {
1015             goto fail;
1016         }
1017 
1018         /* Real path is meaningless for protocols */
1019         if (path_has_protocol(filename)) {
1020             snprintf(backing_filename, sizeof(backing_filename),
1021                      "%s", filename);
1022         } else if (!realpath(filename, backing_filename)) {
1023             ret = -errno;
1024             goto fail;
1025         }
1026 
1027         bdrv_qcow2 = bdrv_find_format("qcow2");
1028         create_options = parse_option_parameters("", bdrv_qcow2->create_options,
1029                                                  NULL);
1030 
1031         set_option_parameter_int(create_options, BLOCK_OPT_SIZE, total_size);
1032         set_option_parameter(create_options, BLOCK_OPT_BACKING_FILE,
1033                              backing_filename);
1034         if (drv) {
1035             set_option_parameter(create_options, BLOCK_OPT_BACKING_FMT,
1036                 drv->format_name);
1037         }
1038 
1039         ret = bdrv_create(bdrv_qcow2, tmp_filename, create_options);
1040         free_option_parameters(create_options);
1041         if (ret < 0) {
1042             goto fail;
1043         }
1044 
1045         filename = tmp_filename;
1046         drv = bdrv_qcow2;
1047         bs->is_temporary = 1;
1048     }
1049 
1050     /* Open image file without format layer */
1051     if (flags & BDRV_O_RDWR) {
1052         flags |= BDRV_O_ALLOW_RDWR;
1053     }
1054 
1055     extract_subqdict(options, &file_options, "file.");
1056 
1057     ret = bdrv_file_open(&file, filename, file_options,
1058                          bdrv_open_flags(bs, flags | BDRV_O_UNMAP));
1059     if (ret < 0) {
1060         goto fail;
1061     }
1062 
1063     /* Find the right image format driver */
1064     drvname = qdict_get_try_str(options, "driver");
1065     if (drvname) {
1066         drv = bdrv_find_whitelisted_format(drvname, !(flags & BDRV_O_RDWR));
1067         qdict_del(options, "driver");
1068     }
1069 
1070     if (!drv) {
1071         ret = find_image_format(file, filename, &drv);
1072     }
1073 
1074     if (!drv) {
1075         goto unlink_and_fail;
1076     }
1077 
1078     /* Open the image */
1079     ret = bdrv_open_common(bs, file, options, flags, drv);
1080     if (ret < 0) {
1081         goto unlink_and_fail;
1082     }
1083 
1084     if (bs->file != file) {
1085         bdrv_delete(file);
1086         file = NULL;
1087     }
1088 
1089     /* If there is a backing file, use it */
1090     if ((flags & BDRV_O_NO_BACKING) == 0) {
1091         QDict *backing_options;
1092 
1093         extract_subqdict(options, &backing_options, "backing.");
1094         ret = bdrv_open_backing_file(bs, backing_options);
1095         if (ret < 0) {
1096             goto close_and_fail;
1097         }
1098     }
1099 
1100     /* Check if any unknown options were used */
1101     if (qdict_size(options) != 0) {
1102         const QDictEntry *entry = qdict_first(options);
1103         qerror_report(ERROR_CLASS_GENERIC_ERROR, "Block format '%s' used by "
1104             "device '%s' doesn't support the option '%s'",
1105             drv->format_name, bs->device_name, entry->key);
1106 
1107         ret = -EINVAL;
1108         goto close_and_fail;
1109     }
1110     QDECREF(options);
1111 
1112     if (!bdrv_key_required(bs)) {
1113         bdrv_dev_change_media_cb(bs, true);
1114     }
1115 
1116     /* throttling disk I/O limits */
1117     if (bs->io_limits_enabled) {
1118         bdrv_io_limits_enable(bs);
1119     }
1120 
1121     return 0;
1122 
1123 unlink_and_fail:
1124     if (file != NULL) {
1125         bdrv_delete(file);
1126     }
1127     if (bs->is_temporary) {
1128         unlink(filename);
1129     }
1130 fail:
1131     QDECREF(bs->options);
1132     QDECREF(options);
1133     bs->options = NULL;
1134     return ret;
1135 
1136 close_and_fail:
1137     bdrv_close(bs);
1138     QDECREF(options);
1139     return ret;
1140 }
1141 
1142 typedef struct BlockReopenQueueEntry {
1143      bool prepared;
1144      BDRVReopenState state;
1145      QSIMPLEQ_ENTRY(BlockReopenQueueEntry) entry;
1146 } BlockReopenQueueEntry;
1147 
1148 /*
1149  * Adds a BlockDriverState to a simple queue for an atomic, transactional
1150  * reopen of multiple devices.
1151  *
1152  * bs_queue can either be an existing BlockReopenQueue that has had QSIMPLE_INIT
1153  * already performed, or alternatively may be NULL a new BlockReopenQueue will
1154  * be created and initialized. This newly created BlockReopenQueue should be
1155  * passed back in for subsequent calls that are intended to be of the same
1156  * atomic 'set'.
1157  *
1158  * bs is the BlockDriverState to add to the reopen queue.
1159  *
1160  * flags contains the open flags for the associated bs
1161  *
1162  * returns a pointer to bs_queue, which is either the newly allocated
1163  * bs_queue, or the existing bs_queue being used.
1164  *
1165  */
1166 BlockReopenQueue *bdrv_reopen_queue(BlockReopenQueue *bs_queue,
1167                                     BlockDriverState *bs, int flags)
1168 {
1169     assert(bs != NULL);
1170 
1171     BlockReopenQueueEntry *bs_entry;
1172     if (bs_queue == NULL) {
1173         bs_queue = g_new0(BlockReopenQueue, 1);
1174         QSIMPLEQ_INIT(bs_queue);
1175     }
1176 
1177     if (bs->file) {
1178         bdrv_reopen_queue(bs_queue, bs->file, flags);
1179     }
1180 
1181     bs_entry = g_new0(BlockReopenQueueEntry, 1);
1182     QSIMPLEQ_INSERT_TAIL(bs_queue, bs_entry, entry);
1183 
1184     bs_entry->state.bs = bs;
1185     bs_entry->state.flags = flags;
1186 
1187     return bs_queue;
1188 }
1189 
1190 /*
1191  * Reopen multiple BlockDriverStates atomically & transactionally.
1192  *
1193  * The queue passed in (bs_queue) must have been built up previous
1194  * via bdrv_reopen_queue().
1195  *
1196  * Reopens all BDS specified in the queue, with the appropriate
1197  * flags.  All devices are prepared for reopen, and failure of any
1198  * device will cause all device changes to be abandonded, and intermediate
1199  * data cleaned up.
1200  *
1201  * If all devices prepare successfully, then the changes are committed
1202  * to all devices.
1203  *
1204  */
1205 int bdrv_reopen_multiple(BlockReopenQueue *bs_queue, Error **errp)
1206 {
1207     int ret = -1;
1208     BlockReopenQueueEntry *bs_entry, *next;
1209     Error *local_err = NULL;
1210 
1211     assert(bs_queue != NULL);
1212 
1213     bdrv_drain_all();
1214 
1215     QSIMPLEQ_FOREACH(bs_entry, bs_queue, entry) {
1216         if (bdrv_reopen_prepare(&bs_entry->state, bs_queue, &local_err)) {
1217             error_propagate(errp, local_err);
1218             goto cleanup;
1219         }
1220         bs_entry->prepared = true;
1221     }
1222 
1223     /* If we reach this point, we have success and just need to apply the
1224      * changes
1225      */
1226     QSIMPLEQ_FOREACH(bs_entry, bs_queue, entry) {
1227         bdrv_reopen_commit(&bs_entry->state);
1228     }
1229 
1230     ret = 0;
1231 
1232 cleanup:
1233     QSIMPLEQ_FOREACH_SAFE(bs_entry, bs_queue, entry, next) {
1234         if (ret && bs_entry->prepared) {
1235             bdrv_reopen_abort(&bs_entry->state);
1236         }
1237         g_free(bs_entry);
1238     }
1239     g_free(bs_queue);
1240     return ret;
1241 }
1242 
1243 
1244 /* Reopen a single BlockDriverState with the specified flags. */
1245 int bdrv_reopen(BlockDriverState *bs, int bdrv_flags, Error **errp)
1246 {
1247     int ret = -1;
1248     Error *local_err = NULL;
1249     BlockReopenQueue *queue = bdrv_reopen_queue(NULL, bs, bdrv_flags);
1250 
1251     ret = bdrv_reopen_multiple(queue, &local_err);
1252     if (local_err != NULL) {
1253         error_propagate(errp, local_err);
1254     }
1255     return ret;
1256 }
1257 
1258 
1259 /*
1260  * Prepares a BlockDriverState for reopen. All changes are staged in the
1261  * 'opaque' field of the BDRVReopenState, which is used and allocated by
1262  * the block driver layer .bdrv_reopen_prepare()
1263  *
1264  * bs is the BlockDriverState to reopen
1265  * flags are the new open flags
1266  * queue is the reopen queue
1267  *
1268  * Returns 0 on success, non-zero on error.  On error errp will be set
1269  * as well.
1270  *
1271  * On failure, bdrv_reopen_abort() will be called to clean up any data.
1272  * It is the responsibility of the caller to then call the abort() or
1273  * commit() for any other BDS that have been left in a prepare() state
1274  *
1275  */
1276 int bdrv_reopen_prepare(BDRVReopenState *reopen_state, BlockReopenQueue *queue,
1277                         Error **errp)
1278 {
1279     int ret = -1;
1280     Error *local_err = NULL;
1281     BlockDriver *drv;
1282 
1283     assert(reopen_state != NULL);
1284     assert(reopen_state->bs->drv != NULL);
1285     drv = reopen_state->bs->drv;
1286 
1287     /* if we are to stay read-only, do not allow permission change
1288      * to r/w */
1289     if (!(reopen_state->bs->open_flags & BDRV_O_ALLOW_RDWR) &&
1290         reopen_state->flags & BDRV_O_RDWR) {
1291         error_set(errp, QERR_DEVICE_IS_READ_ONLY,
1292                   reopen_state->bs->device_name);
1293         goto error;
1294     }
1295 
1296 
1297     ret = bdrv_flush(reopen_state->bs);
1298     if (ret) {
1299         error_set(errp, ERROR_CLASS_GENERIC_ERROR, "Error (%s) flushing drive",
1300                   strerror(-ret));
1301         goto error;
1302     }
1303 
1304     if (drv->bdrv_reopen_prepare) {
1305         ret = drv->bdrv_reopen_prepare(reopen_state, queue, &local_err);
1306         if (ret) {
1307             if (local_err != NULL) {
1308                 error_propagate(errp, local_err);
1309             } else {
1310                 error_setg(errp, "failed while preparing to reopen image '%s'",
1311                            reopen_state->bs->filename);
1312             }
1313             goto error;
1314         }
1315     } else {
1316         /* It is currently mandatory to have a bdrv_reopen_prepare()
1317          * handler for each supported drv. */
1318         error_set(errp, QERR_BLOCK_FORMAT_FEATURE_NOT_SUPPORTED,
1319                   drv->format_name, reopen_state->bs->device_name,
1320                  "reopening of file");
1321         ret = -1;
1322         goto error;
1323     }
1324 
1325     ret = 0;
1326 
1327 error:
1328     return ret;
1329 }
1330 
1331 /*
1332  * Takes the staged changes for the reopen from bdrv_reopen_prepare(), and
1333  * makes them final by swapping the staging BlockDriverState contents into
1334  * the active BlockDriverState contents.
1335  */
1336 void bdrv_reopen_commit(BDRVReopenState *reopen_state)
1337 {
1338     BlockDriver *drv;
1339 
1340     assert(reopen_state != NULL);
1341     drv = reopen_state->bs->drv;
1342     assert(drv != NULL);
1343 
1344     /* If there are any driver level actions to take */
1345     if (drv->bdrv_reopen_commit) {
1346         drv->bdrv_reopen_commit(reopen_state);
1347     }
1348 
1349     /* set BDS specific flags now */
1350     reopen_state->bs->open_flags         = reopen_state->flags;
1351     reopen_state->bs->enable_write_cache = !!(reopen_state->flags &
1352                                               BDRV_O_CACHE_WB);
1353     reopen_state->bs->read_only = !(reopen_state->flags & BDRV_O_RDWR);
1354 }
1355 
1356 /*
1357  * Abort the reopen, and delete and free the staged changes in
1358  * reopen_state
1359  */
1360 void bdrv_reopen_abort(BDRVReopenState *reopen_state)
1361 {
1362     BlockDriver *drv;
1363 
1364     assert(reopen_state != NULL);
1365     drv = reopen_state->bs->drv;
1366     assert(drv != NULL);
1367 
1368     if (drv->bdrv_reopen_abort) {
1369         drv->bdrv_reopen_abort(reopen_state);
1370     }
1371 }
1372 
1373 
1374 void bdrv_close(BlockDriverState *bs)
1375 {
1376     if (bs->job) {
1377         block_job_cancel_sync(bs->job);
1378     }
1379     bdrv_drain_all(); /* complete I/O */
1380     bdrv_flush(bs);
1381     bdrv_drain_all(); /* in case flush left pending I/O */
1382     notifier_list_notify(&bs->close_notifiers, bs);
1383 
1384     if (bs->drv) {
1385         if (bs->backing_hd) {
1386             bdrv_delete(bs->backing_hd);
1387             bs->backing_hd = NULL;
1388         }
1389         bs->drv->bdrv_close(bs);
1390         g_free(bs->opaque);
1391 #ifdef _WIN32
1392         if (bs->is_temporary) {
1393             unlink(bs->filename);
1394         }
1395 #endif
1396         bs->opaque = NULL;
1397         bs->drv = NULL;
1398         bs->copy_on_read = 0;
1399         bs->backing_file[0] = '\0';
1400         bs->backing_format[0] = '\0';
1401         bs->total_sectors = 0;
1402         bs->encrypted = 0;
1403         bs->valid_key = 0;
1404         bs->sg = 0;
1405         bs->growable = 0;
1406         bs->zero_beyond_eof = false;
1407         QDECREF(bs->options);
1408         bs->options = NULL;
1409 
1410         if (bs->file != NULL) {
1411             bdrv_delete(bs->file);
1412             bs->file = NULL;
1413         }
1414     }
1415 
1416     bdrv_dev_change_media_cb(bs, false);
1417 
1418     /*throttling disk I/O limits*/
1419     if (bs->io_limits_enabled) {
1420         bdrv_io_limits_disable(bs);
1421     }
1422 }
1423 
1424 void bdrv_close_all(void)
1425 {
1426     BlockDriverState *bs;
1427 
1428     QTAILQ_FOREACH(bs, &bdrv_states, list) {
1429         bdrv_close(bs);
1430     }
1431 }
1432 
1433 /* Check if any requests are in-flight (including throttled requests) */
1434 static bool bdrv_requests_pending(BlockDriverState *bs)
1435 {
1436     if (!QLIST_EMPTY(&bs->tracked_requests)) {
1437         return true;
1438     }
1439     if (!qemu_co_queue_empty(&bs->throttled_reqs)) {
1440         return true;
1441     }
1442     if (bs->file && bdrv_requests_pending(bs->file)) {
1443         return true;
1444     }
1445     if (bs->backing_hd && bdrv_requests_pending(bs->backing_hd)) {
1446         return true;
1447     }
1448     return false;
1449 }
1450 
1451 static bool bdrv_requests_pending_all(void)
1452 {
1453     BlockDriverState *bs;
1454     QTAILQ_FOREACH(bs, &bdrv_states, list) {
1455         if (bdrv_requests_pending(bs)) {
1456             return true;
1457         }
1458     }
1459     return false;
1460 }
1461 
1462 /*
1463  * Wait for pending requests to complete across all BlockDriverStates
1464  *
1465  * This function does not flush data to disk, use bdrv_flush_all() for that
1466  * after calling this function.
1467  *
1468  * Note that completion of an asynchronous I/O operation can trigger any
1469  * number of other I/O operations on other devices---for example a coroutine
1470  * can be arbitrarily complex and a constant flow of I/O can come until the
1471  * coroutine is complete.  Because of this, it is not possible to have a
1472  * function to drain a single device's I/O queue.
1473  */
1474 void bdrv_drain_all(void)
1475 {
1476     /* Always run first iteration so any pending completion BHs run */
1477     bool busy = true;
1478     BlockDriverState *bs;
1479 
1480     while (busy) {
1481         /* FIXME: We do not have timer support here, so this is effectively
1482          * a busy wait.
1483          */
1484         QTAILQ_FOREACH(bs, &bdrv_states, list) {
1485             while (qemu_co_enter_next(&bs->throttled_reqs)) {
1486                 busy = true;
1487             }
1488         }
1489 
1490         busy = bdrv_requests_pending_all();
1491         busy |= aio_poll(qemu_get_aio_context(), busy);
1492     }
1493 }
1494 
1495 /* make a BlockDriverState anonymous by removing from bdrv_state list.
1496    Also, NULL terminate the device_name to prevent double remove */
1497 void bdrv_make_anon(BlockDriverState *bs)
1498 {
1499     if (bs->device_name[0] != '\0') {
1500         QTAILQ_REMOVE(&bdrv_states, bs, list);
1501     }
1502     bs->device_name[0] = '\0';
1503 }
1504 
1505 static void bdrv_rebind(BlockDriverState *bs)
1506 {
1507     if (bs->drv && bs->drv->bdrv_rebind) {
1508         bs->drv->bdrv_rebind(bs);
1509     }
1510 }
1511 
1512 static void bdrv_move_feature_fields(BlockDriverState *bs_dest,
1513                                      BlockDriverState *bs_src)
1514 {
1515     /* move some fields that need to stay attached to the device */
1516     bs_dest->open_flags         = bs_src->open_flags;
1517 
1518     /* dev info */
1519     bs_dest->dev_ops            = bs_src->dev_ops;
1520     bs_dest->dev_opaque         = bs_src->dev_opaque;
1521     bs_dest->dev                = bs_src->dev;
1522     bs_dest->buffer_alignment   = bs_src->buffer_alignment;
1523     bs_dest->copy_on_read       = bs_src->copy_on_read;
1524 
1525     bs_dest->enable_write_cache = bs_src->enable_write_cache;
1526 
1527     /* i/o timing parameters */
1528     bs_dest->slice_start        = bs_src->slice_start;
1529     bs_dest->slice_end          = bs_src->slice_end;
1530     bs_dest->slice_submitted    = bs_src->slice_submitted;
1531     bs_dest->io_limits          = bs_src->io_limits;
1532     bs_dest->throttled_reqs     = bs_src->throttled_reqs;
1533     bs_dest->block_timer        = bs_src->block_timer;
1534     bs_dest->io_limits_enabled  = bs_src->io_limits_enabled;
1535 
1536     /* r/w error */
1537     bs_dest->on_read_error      = bs_src->on_read_error;
1538     bs_dest->on_write_error     = bs_src->on_write_error;
1539 
1540     /* i/o status */
1541     bs_dest->iostatus_enabled   = bs_src->iostatus_enabled;
1542     bs_dest->iostatus           = bs_src->iostatus;
1543 
1544     /* dirty bitmap */
1545     bs_dest->dirty_bitmap       = bs_src->dirty_bitmap;
1546 
1547     /* job */
1548     bs_dest->in_use             = bs_src->in_use;
1549     bs_dest->job                = bs_src->job;
1550 
1551     /* keep the same entry in bdrv_states */
1552     pstrcpy(bs_dest->device_name, sizeof(bs_dest->device_name),
1553             bs_src->device_name);
1554     bs_dest->list = bs_src->list;
1555 }
1556 
1557 /*
1558  * Swap bs contents for two image chains while they are live,
1559  * while keeping required fields on the BlockDriverState that is
1560  * actually attached to a device.
1561  *
1562  * This will modify the BlockDriverState fields, and swap contents
1563  * between bs_new and bs_old. Both bs_new and bs_old are modified.
1564  *
1565  * bs_new is required to be anonymous.
1566  *
1567  * This function does not create any image files.
1568  */
1569 void bdrv_swap(BlockDriverState *bs_new, BlockDriverState *bs_old)
1570 {
1571     BlockDriverState tmp;
1572 
1573     /* bs_new must be anonymous and shouldn't have anything fancy enabled */
1574     assert(bs_new->device_name[0] == '\0');
1575     assert(bs_new->dirty_bitmap == NULL);
1576     assert(bs_new->job == NULL);
1577     assert(bs_new->dev == NULL);
1578     assert(bs_new->in_use == 0);
1579     assert(bs_new->io_limits_enabled == false);
1580     assert(bs_new->block_timer == NULL);
1581 
1582     tmp = *bs_new;
1583     *bs_new = *bs_old;
1584     *bs_old = tmp;
1585 
1586     /* there are some fields that should not be swapped, move them back */
1587     bdrv_move_feature_fields(&tmp, bs_old);
1588     bdrv_move_feature_fields(bs_old, bs_new);
1589     bdrv_move_feature_fields(bs_new, &tmp);
1590 
1591     /* bs_new shouldn't be in bdrv_states even after the swap!  */
1592     assert(bs_new->device_name[0] == '\0');
1593 
1594     /* Check a few fields that should remain attached to the device */
1595     assert(bs_new->dev == NULL);
1596     assert(bs_new->job == NULL);
1597     assert(bs_new->in_use == 0);
1598     assert(bs_new->io_limits_enabled == false);
1599     assert(bs_new->block_timer == NULL);
1600 
1601     bdrv_rebind(bs_new);
1602     bdrv_rebind(bs_old);
1603 }
1604 
1605 /*
1606  * Add new bs contents at the top of an image chain while the chain is
1607  * live, while keeping required fields on the top layer.
1608  *
1609  * This will modify the BlockDriverState fields, and swap contents
1610  * between bs_new and bs_top. Both bs_new and bs_top are modified.
1611  *
1612  * bs_new is required to be anonymous.
1613  *
1614  * This function does not create any image files.
1615  */
1616 void bdrv_append(BlockDriverState *bs_new, BlockDriverState *bs_top)
1617 {
1618     bdrv_swap(bs_new, bs_top);
1619 
1620     /* The contents of 'tmp' will become bs_top, as we are
1621      * swapping bs_new and bs_top contents. */
1622     bs_top->backing_hd = bs_new;
1623     bs_top->open_flags &= ~BDRV_O_NO_BACKING;
1624     pstrcpy(bs_top->backing_file, sizeof(bs_top->backing_file),
1625             bs_new->filename);
1626     pstrcpy(bs_top->backing_format, sizeof(bs_top->backing_format),
1627             bs_new->drv ? bs_new->drv->format_name : "");
1628 }
1629 
1630 void bdrv_delete(BlockDriverState *bs)
1631 {
1632     assert(!bs->dev);
1633     assert(!bs->job);
1634     assert(!bs->in_use);
1635 
1636     bdrv_close(bs);
1637 
1638     /* remove from list, if necessary */
1639     bdrv_make_anon(bs);
1640 
1641     g_free(bs);
1642 }
1643 
1644 int bdrv_attach_dev(BlockDriverState *bs, void *dev)
1645 /* TODO change to DeviceState *dev when all users are qdevified */
1646 {
1647     if (bs->dev) {
1648         return -EBUSY;
1649     }
1650     bs->dev = dev;
1651     bdrv_iostatus_reset(bs);
1652     return 0;
1653 }
1654 
1655 /* TODO qdevified devices don't use this, remove when devices are qdevified */
1656 void bdrv_attach_dev_nofail(BlockDriverState *bs, void *dev)
1657 {
1658     if (bdrv_attach_dev(bs, dev) < 0) {
1659         abort();
1660     }
1661 }
1662 
1663 void bdrv_detach_dev(BlockDriverState *bs, void *dev)
1664 /* TODO change to DeviceState *dev when all users are qdevified */
1665 {
1666     assert(bs->dev == dev);
1667     bs->dev = NULL;
1668     bs->dev_ops = NULL;
1669     bs->dev_opaque = NULL;
1670     bs->buffer_alignment = 512;
1671 }
1672 
1673 /* TODO change to return DeviceState * when all users are qdevified */
1674 void *bdrv_get_attached_dev(BlockDriverState *bs)
1675 {
1676     return bs->dev;
1677 }
1678 
1679 void bdrv_set_dev_ops(BlockDriverState *bs, const BlockDevOps *ops,
1680                       void *opaque)
1681 {
1682     bs->dev_ops = ops;
1683     bs->dev_opaque = opaque;
1684 }
1685 
1686 void bdrv_emit_qmp_error_event(const BlockDriverState *bdrv,
1687                                enum MonitorEvent ev,
1688                                BlockErrorAction action, bool is_read)
1689 {
1690     QObject *data;
1691     const char *action_str;
1692 
1693     switch (action) {
1694     case BDRV_ACTION_REPORT:
1695         action_str = "report";
1696         break;
1697     case BDRV_ACTION_IGNORE:
1698         action_str = "ignore";
1699         break;
1700     case BDRV_ACTION_STOP:
1701         action_str = "stop";
1702         break;
1703     default:
1704         abort();
1705     }
1706 
1707     data = qobject_from_jsonf("{ 'device': %s, 'action': %s, 'operation': %s }",
1708                               bdrv->device_name,
1709                               action_str,
1710                               is_read ? "read" : "write");
1711     monitor_protocol_event(ev, data);
1712 
1713     qobject_decref(data);
1714 }
1715 
1716 static void bdrv_emit_qmp_eject_event(BlockDriverState *bs, bool ejected)
1717 {
1718     QObject *data;
1719 
1720     data = qobject_from_jsonf("{ 'device': %s, 'tray-open': %i }",
1721                               bdrv_get_device_name(bs), ejected);
1722     monitor_protocol_event(QEVENT_DEVICE_TRAY_MOVED, data);
1723 
1724     qobject_decref(data);
1725 }
1726 
1727 static void bdrv_dev_change_media_cb(BlockDriverState *bs, bool load)
1728 {
1729     if (bs->dev_ops && bs->dev_ops->change_media_cb) {
1730         bool tray_was_closed = !bdrv_dev_is_tray_open(bs);
1731         bs->dev_ops->change_media_cb(bs->dev_opaque, load);
1732         if (tray_was_closed) {
1733             /* tray open */
1734             bdrv_emit_qmp_eject_event(bs, true);
1735         }
1736         if (load) {
1737             /* tray close */
1738             bdrv_emit_qmp_eject_event(bs, false);
1739         }
1740     }
1741 }
1742 
1743 bool bdrv_dev_has_removable_media(BlockDriverState *bs)
1744 {
1745     return !bs->dev || (bs->dev_ops && bs->dev_ops->change_media_cb);
1746 }
1747 
1748 void bdrv_dev_eject_request(BlockDriverState *bs, bool force)
1749 {
1750     if (bs->dev_ops && bs->dev_ops->eject_request_cb) {
1751         bs->dev_ops->eject_request_cb(bs->dev_opaque, force);
1752     }
1753 }
1754 
1755 bool bdrv_dev_is_tray_open(BlockDriverState *bs)
1756 {
1757     if (bs->dev_ops && bs->dev_ops->is_tray_open) {
1758         return bs->dev_ops->is_tray_open(bs->dev_opaque);
1759     }
1760     return false;
1761 }
1762 
1763 static void bdrv_dev_resize_cb(BlockDriverState *bs)
1764 {
1765     if (bs->dev_ops && bs->dev_ops->resize_cb) {
1766         bs->dev_ops->resize_cb(bs->dev_opaque);
1767     }
1768 }
1769 
1770 bool bdrv_dev_is_medium_locked(BlockDriverState *bs)
1771 {
1772     if (bs->dev_ops && bs->dev_ops->is_medium_locked) {
1773         return bs->dev_ops->is_medium_locked(bs->dev_opaque);
1774     }
1775     return false;
1776 }
1777 
1778 /*
1779  * Run consistency checks on an image
1780  *
1781  * Returns 0 if the check could be completed (it doesn't mean that the image is
1782  * free of errors) or -errno when an internal error occurred. The results of the
1783  * check are stored in res.
1784  */
1785 int bdrv_check(BlockDriverState *bs, BdrvCheckResult *res, BdrvCheckMode fix)
1786 {
1787     if (bs->drv->bdrv_check == NULL) {
1788         return -ENOTSUP;
1789     }
1790 
1791     memset(res, 0, sizeof(*res));
1792     return bs->drv->bdrv_check(bs, res, fix);
1793 }
1794 
1795 #define COMMIT_BUF_SECTORS 2048
1796 
1797 /* commit COW file into the raw image */
1798 int bdrv_commit(BlockDriverState *bs)
1799 {
1800     BlockDriver *drv = bs->drv;
1801     int64_t sector, total_sectors;
1802     int n, ro, open_flags;
1803     int ret = 0;
1804     uint8_t *buf;
1805     char filename[PATH_MAX];
1806 
1807     if (!drv)
1808         return -ENOMEDIUM;
1809 
1810     if (!bs->backing_hd) {
1811         return -ENOTSUP;
1812     }
1813 
1814     if (bdrv_in_use(bs) || bdrv_in_use(bs->backing_hd)) {
1815         return -EBUSY;
1816     }
1817 
1818     ro = bs->backing_hd->read_only;
1819     /* Use pstrcpy (not strncpy): filename must be NUL-terminated. */
1820     pstrcpy(filename, sizeof(filename), bs->backing_hd->filename);
1821     open_flags =  bs->backing_hd->open_flags;
1822 
1823     if (ro) {
1824         if (bdrv_reopen(bs->backing_hd, open_flags | BDRV_O_RDWR, NULL)) {
1825             return -EACCES;
1826         }
1827     }
1828 
1829     total_sectors = bdrv_getlength(bs) >> BDRV_SECTOR_BITS;
1830     buf = g_malloc(COMMIT_BUF_SECTORS * BDRV_SECTOR_SIZE);
1831 
1832     for (sector = 0; sector < total_sectors; sector += n) {
1833         if (bdrv_is_allocated(bs, sector, COMMIT_BUF_SECTORS, &n)) {
1834 
1835             if (bdrv_read(bs, sector, buf, n) != 0) {
1836                 ret = -EIO;
1837                 goto ro_cleanup;
1838             }
1839 
1840             if (bdrv_write(bs->backing_hd, sector, buf, n) != 0) {
1841                 ret = -EIO;
1842                 goto ro_cleanup;
1843             }
1844         }
1845     }
1846 
1847     if (drv->bdrv_make_empty) {
1848         ret = drv->bdrv_make_empty(bs);
1849         bdrv_flush(bs);
1850     }
1851 
1852     /*
1853      * Make sure all data we wrote to the backing device is actually
1854      * stable on disk.
1855      */
1856     if (bs->backing_hd)
1857         bdrv_flush(bs->backing_hd);
1858 
1859 ro_cleanup:
1860     g_free(buf);
1861 
1862     if (ro) {
1863         /* ignoring error return here */
1864         bdrv_reopen(bs->backing_hd, open_flags & ~BDRV_O_RDWR, NULL);
1865     }
1866 
1867     return ret;
1868 }
1869 
1870 int bdrv_commit_all(void)
1871 {
1872     BlockDriverState *bs;
1873 
1874     QTAILQ_FOREACH(bs, &bdrv_states, list) {
1875         if (bs->drv && bs->backing_hd) {
1876             int ret = bdrv_commit(bs);
1877             if (ret < 0) {
1878                 return ret;
1879             }
1880         }
1881     }
1882     return 0;
1883 }
1884 
1885 /**
1886  * Remove an active request from the tracked requests list
1887  *
1888  * This function should be called when a tracked request is completing.
1889  */
1890 static void tracked_request_end(BdrvTrackedRequest *req)
1891 {
1892     QLIST_REMOVE(req, list);
1893     qemu_co_queue_restart_all(&req->wait_queue);
1894 }
1895 
1896 /**
1897  * Add an active request to the tracked requests list
1898  */
1899 static void tracked_request_begin(BdrvTrackedRequest *req,
1900                                   BlockDriverState *bs,
1901                                   int64_t sector_num,
1902                                   int nb_sectors, bool is_write)
1903 {
1904     *req = (BdrvTrackedRequest){
1905         .bs = bs,
1906         .sector_num = sector_num,
1907         .nb_sectors = nb_sectors,
1908         .is_write = is_write,
1909         .co = qemu_coroutine_self(),
1910     };
1911 
1912     qemu_co_queue_init(&req->wait_queue);
1913 
1914     QLIST_INSERT_HEAD(&bs->tracked_requests, req, list);
1915 }
1916 
1917 /**
1918  * Round a region to cluster boundaries
1919  */
1920 void bdrv_round_to_clusters(BlockDriverState *bs,
1921                             int64_t sector_num, int nb_sectors,
1922                             int64_t *cluster_sector_num,
1923                             int *cluster_nb_sectors)
1924 {
1925     BlockDriverInfo bdi;
1926 
1927     if (bdrv_get_info(bs, &bdi) < 0 || bdi.cluster_size == 0) {
1928         *cluster_sector_num = sector_num;
1929         *cluster_nb_sectors = nb_sectors;
1930     } else {
1931         int64_t c = bdi.cluster_size / BDRV_SECTOR_SIZE;
1932         *cluster_sector_num = QEMU_ALIGN_DOWN(sector_num, c);
1933         *cluster_nb_sectors = QEMU_ALIGN_UP(sector_num - *cluster_sector_num +
1934                                             nb_sectors, c);
1935     }
1936 }
1937 
1938 static bool tracked_request_overlaps(BdrvTrackedRequest *req,
1939                                      int64_t sector_num, int nb_sectors) {
1940     /*        aaaa   bbbb */
1941     if (sector_num >= req->sector_num + req->nb_sectors) {
1942         return false;
1943     }
1944     /* bbbb   aaaa        */
1945     if (req->sector_num >= sector_num + nb_sectors) {
1946         return false;
1947     }
1948     return true;
1949 }
1950 
1951 static void coroutine_fn wait_for_overlapping_requests(BlockDriverState *bs,
1952         int64_t sector_num, int nb_sectors)
1953 {
1954     BdrvTrackedRequest *req;
1955     int64_t cluster_sector_num;
1956     int cluster_nb_sectors;
1957     bool retry;
1958 
1959     /* If we touch the same cluster it counts as an overlap.  This guarantees
1960      * that allocating writes will be serialized and not race with each other
1961      * for the same cluster.  For example, in copy-on-read it ensures that the
1962      * CoR read and write operations are atomic and guest writes cannot
1963      * interleave between them.
1964      */
1965     bdrv_round_to_clusters(bs, sector_num, nb_sectors,
1966                            &cluster_sector_num, &cluster_nb_sectors);
1967 
1968     do {
1969         retry = false;
1970         QLIST_FOREACH(req, &bs->tracked_requests, list) {
1971             if (tracked_request_overlaps(req, cluster_sector_num,
1972                                          cluster_nb_sectors)) {
1973                 /* Hitting this means there was a reentrant request, for
1974                  * example, a block driver issuing nested requests.  This must
1975                  * never happen since it means deadlock.
1976                  */
1977                 assert(qemu_coroutine_self() != req->co);
1978 
1979                 qemu_co_queue_wait(&req->wait_queue);
1980                 retry = true;
1981                 break;
1982             }
1983         }
1984     } while (retry);
1985 }
1986 
1987 /*
1988  * Return values:
1989  * 0        - success
1990  * -EINVAL  - backing format specified, but no file
1991  * -ENOSPC  - can't update the backing file because no space is left in the
1992  *            image file header
1993  * -ENOTSUP - format driver doesn't support changing the backing file
1994  */
1995 int bdrv_change_backing_file(BlockDriverState *bs,
1996     const char *backing_file, const char *backing_fmt)
1997 {
1998     BlockDriver *drv = bs->drv;
1999     int ret;
2000 
2001     /* Backing file format doesn't make sense without a backing file */
2002     if (backing_fmt && !backing_file) {
2003         return -EINVAL;
2004     }
2005 
2006     if (drv->bdrv_change_backing_file != NULL) {
2007         ret = drv->bdrv_change_backing_file(bs, backing_file, backing_fmt);
2008     } else {
2009         ret = -ENOTSUP;
2010     }
2011 
2012     if (ret == 0) {
2013         pstrcpy(bs->backing_file, sizeof(bs->backing_file), backing_file ?: "");
2014         pstrcpy(bs->backing_format, sizeof(bs->backing_format), backing_fmt ?: "");
2015     }
2016     return ret;
2017 }
2018 
2019 /*
2020  * Finds the image layer in the chain that has 'bs' as its backing file.
2021  *
2022  * active is the current topmost image.
2023  *
2024  * Returns NULL if bs is not found in active's image chain,
2025  * or if active == bs.
2026  */
2027 BlockDriverState *bdrv_find_overlay(BlockDriverState *active,
2028                                     BlockDriverState *bs)
2029 {
2030     BlockDriverState *overlay = NULL;
2031     BlockDriverState *intermediate;
2032 
2033     assert(active != NULL);
2034     assert(bs != NULL);
2035 
2036     /* if bs is the same as active, then by definition it has no overlay
2037      */
2038     if (active == bs) {
2039         return NULL;
2040     }
2041 
2042     intermediate = active;
2043     while (intermediate->backing_hd) {
2044         if (intermediate->backing_hd == bs) {
2045             overlay = intermediate;
2046             break;
2047         }
2048         intermediate = intermediate->backing_hd;
2049     }
2050 
2051     return overlay;
2052 }
2053 
2054 typedef struct BlkIntermediateStates {
2055     BlockDriverState *bs;
2056     QSIMPLEQ_ENTRY(BlkIntermediateStates) entry;
2057 } BlkIntermediateStates;
2058 
2059 
2060 /*
2061  * Drops images above 'base' up to and including 'top', and sets the image
2062  * above 'top' to have base as its backing file.
2063  *
2064  * Requires that the overlay to 'top' is opened r/w, so that the backing file
2065  * information in 'bs' can be properly updated.
2066  *
2067  * E.g., this will convert the following chain:
2068  * bottom <- base <- intermediate <- top <- active
2069  *
2070  * to
2071  *
2072  * bottom <- base <- active
2073  *
2074  * It is allowed for bottom==base, in which case it converts:
2075  *
2076  * base <- intermediate <- top <- active
2077  *
2078  * to
2079  *
2080  * base <- active
2081  *
2082  * Error conditions:
2083  *  if active == top, that is considered an error
2084  *
2085  */
2086 int bdrv_drop_intermediate(BlockDriverState *active, BlockDriverState *top,
2087                            BlockDriverState *base)
2088 {
2089     BlockDriverState *intermediate;
2090     BlockDriverState *base_bs = NULL;
2091     BlockDriverState *new_top_bs = NULL;
2092     BlkIntermediateStates *intermediate_state, *next;
2093     int ret = -EIO;
2094 
2095     QSIMPLEQ_HEAD(states_to_delete, BlkIntermediateStates) states_to_delete;
2096     QSIMPLEQ_INIT(&states_to_delete);
2097 
2098     if (!top->drv || !base->drv) {
2099         goto exit;
2100     }
2101 
2102     new_top_bs = bdrv_find_overlay(active, top);
2103 
2104     if (new_top_bs == NULL) {
2105         /* we could not find the image above 'top', this is an error */
2106         goto exit;
2107     }
2108 
2109     /* special case of new_top_bs->backing_hd already pointing to base - nothing
2110      * to do, no intermediate images */
2111     if (new_top_bs->backing_hd == base) {
2112         ret = 0;
2113         goto exit;
2114     }
2115 
2116     intermediate = top;
2117 
2118     /* now we will go down through the list, and add each BDS we find
2119      * into our deletion queue, until we hit the 'base'
2120      */
2121     while (intermediate) {
2122         intermediate_state = g_malloc0(sizeof(BlkIntermediateStates));
2123         intermediate_state->bs = intermediate;
2124         QSIMPLEQ_INSERT_TAIL(&states_to_delete, intermediate_state, entry);
2125 
2126         if (intermediate->backing_hd == base) {
2127             base_bs = intermediate->backing_hd;
2128             break;
2129         }
2130         intermediate = intermediate->backing_hd;
2131     }
2132     if (base_bs == NULL) {
2133         /* something went wrong, we did not end at the base. safely
2134          * unravel everything, and exit with error */
2135         goto exit;
2136     }
2137 
2138     /* success - we can delete the intermediate states, and link top->base */
2139     ret = bdrv_change_backing_file(new_top_bs, base_bs->filename,
2140                                    base_bs->drv ? base_bs->drv->format_name : "");
2141     if (ret) {
2142         goto exit;
2143     }
2144     new_top_bs->backing_hd = base_bs;
2145 
2146 
2147     QSIMPLEQ_FOREACH_SAFE(intermediate_state, &states_to_delete, entry, next) {
2148         /* so that bdrv_close() does not recursively close the chain */
2149         intermediate_state->bs->backing_hd = NULL;
2150         bdrv_delete(intermediate_state->bs);
2151     }
2152     ret = 0;
2153 
2154 exit:
2155     QSIMPLEQ_FOREACH_SAFE(intermediate_state, &states_to_delete, entry, next) {
2156         g_free(intermediate_state);
2157     }
2158     return ret;
2159 }
2160 
2161 
2162 static int bdrv_check_byte_request(BlockDriverState *bs, int64_t offset,
2163                                    size_t size)
2164 {
2165     int64_t len;
2166 
2167     if (!bdrv_is_inserted(bs))
2168         return -ENOMEDIUM;
2169 
2170     if (bs->growable)
2171         return 0;
2172 
2173     len = bdrv_getlength(bs);
2174 
2175     if (offset < 0)
2176         return -EIO;
2177 
2178     if ((offset > len) || (len - offset < size))
2179         return -EIO;
2180 
2181     return 0;
2182 }
2183 
2184 static int bdrv_check_request(BlockDriverState *bs, int64_t sector_num,
2185                               int nb_sectors)
2186 {
2187     return bdrv_check_byte_request(bs, sector_num * BDRV_SECTOR_SIZE,
2188                                    nb_sectors * BDRV_SECTOR_SIZE);
2189 }
2190 
2191 typedef struct RwCo {
2192     BlockDriverState *bs;
2193     int64_t sector_num;
2194     int nb_sectors;
2195     QEMUIOVector *qiov;
2196     bool is_write;
2197     int ret;
2198     BdrvRequestFlags flags;
2199 } RwCo;
2200 
2201 static void coroutine_fn bdrv_rw_co_entry(void *opaque)
2202 {
2203     RwCo *rwco = opaque;
2204 
2205     if (!rwco->is_write) {
2206         rwco->ret = bdrv_co_do_readv(rwco->bs, rwco->sector_num,
2207                                      rwco->nb_sectors, rwco->qiov,
2208                                      rwco->flags);
2209     } else {
2210         rwco->ret = bdrv_co_do_writev(rwco->bs, rwco->sector_num,
2211                                       rwco->nb_sectors, rwco->qiov,
2212                                       rwco->flags);
2213     }
2214 }
2215 
2216 /*
2217  * Process a vectored synchronous request using coroutines
2218  */
2219 static int bdrv_rwv_co(BlockDriverState *bs, int64_t sector_num,
2220                        QEMUIOVector *qiov, bool is_write,
2221                        BdrvRequestFlags flags)
2222 {
2223     Coroutine *co;
2224     RwCo rwco = {
2225         .bs = bs,
2226         .sector_num = sector_num,
2227         .nb_sectors = qiov->size >> BDRV_SECTOR_BITS,
2228         .qiov = qiov,
2229         .is_write = is_write,
2230         .ret = NOT_DONE,
2231         .flags = flags,
2232     };
2233     assert((qiov->size & (BDRV_SECTOR_SIZE - 1)) == 0);
2234 
2235     /**
2236      * In sync call context, when the vcpu is blocked, this throttling timer
2237      * will not fire; so the I/O throttling function has to be disabled here
2238      * if it has been enabled.
2239      */
2240     if (bs->io_limits_enabled) {
2241         fprintf(stderr, "Disabling I/O throttling on '%s' due "
2242                         "to synchronous I/O.\n", bdrv_get_device_name(bs));
2243         bdrv_io_limits_disable(bs);
2244     }
2245 
2246     if (qemu_in_coroutine()) {
2247         /* Fast-path if already in coroutine context */
2248         bdrv_rw_co_entry(&rwco);
2249     } else {
2250         co = qemu_coroutine_create(bdrv_rw_co_entry);
2251         qemu_coroutine_enter(co, &rwco);
2252         while (rwco.ret == NOT_DONE) {
2253             qemu_aio_wait();
2254         }
2255     }
2256     return rwco.ret;
2257 }
2258 
2259 /*
2260  * Process a synchronous request using coroutines
2261  */
2262 static int bdrv_rw_co(BlockDriverState *bs, int64_t sector_num, uint8_t *buf,
2263                       int nb_sectors, bool is_write, BdrvRequestFlags flags)
2264 {
2265     QEMUIOVector qiov;
2266     struct iovec iov = {
2267         .iov_base = (void *)buf,
2268         .iov_len = nb_sectors * BDRV_SECTOR_SIZE,
2269     };
2270 
2271     qemu_iovec_init_external(&qiov, &iov, 1);
2272     return bdrv_rwv_co(bs, sector_num, &qiov, is_write, flags);
2273 }
2274 
2275 /* return < 0 if error. See bdrv_write() for the return codes */
2276 int bdrv_read(BlockDriverState *bs, int64_t sector_num,
2277               uint8_t *buf, int nb_sectors)
2278 {
2279     return bdrv_rw_co(bs, sector_num, buf, nb_sectors, false, 0);
2280 }
2281 
2282 /* Just like bdrv_read(), but with I/O throttling temporarily disabled */
2283 int bdrv_read_unthrottled(BlockDriverState *bs, int64_t sector_num,
2284                           uint8_t *buf, int nb_sectors)
2285 {
2286     bool enabled;
2287     int ret;
2288 
2289     enabled = bs->io_limits_enabled;
2290     bs->io_limits_enabled = false;
2291     ret = bdrv_read(bs, sector_num, buf, nb_sectors);
2292     bs->io_limits_enabled = enabled;
2293     return ret;
2294 }
2295 
2296 /* Return < 0 if error. Important errors are:
2297   -EIO         generic I/O error (may happen for all errors)
2298   -ENOMEDIUM   No media inserted.
2299   -EINVAL      Invalid sector number or nb_sectors
2300   -EACCES      Trying to write a read-only device
2301 */
2302 int bdrv_write(BlockDriverState *bs, int64_t sector_num,
2303                const uint8_t *buf, int nb_sectors)
2304 {
2305     return bdrv_rw_co(bs, sector_num, (uint8_t *)buf, nb_sectors, true, 0);
2306 }
2307 
2308 int bdrv_writev(BlockDriverState *bs, int64_t sector_num, QEMUIOVector *qiov)
2309 {
2310     return bdrv_rwv_co(bs, sector_num, qiov, true, 0);
2311 }
2312 
2313 int bdrv_write_zeroes(BlockDriverState *bs, int64_t sector_num, int nb_sectors)
2314 {
2315     return bdrv_rw_co(bs, sector_num, NULL, nb_sectors, true,
2316                       BDRV_REQ_ZERO_WRITE);
2317 }
2318 
2319 int bdrv_pread(BlockDriverState *bs, int64_t offset,
2320                void *buf, int count1)
2321 {
2322     uint8_t tmp_buf[BDRV_SECTOR_SIZE];
2323     int len, nb_sectors, count;
2324     int64_t sector_num;
2325     int ret;
2326 
2327     count = count1;
2328     /* first read to align to sector start */
2329     len = (BDRV_SECTOR_SIZE - offset) & (BDRV_SECTOR_SIZE - 1);
2330     if (len > count)
2331         len = count;
2332     sector_num = offset >> BDRV_SECTOR_BITS;
2333     if (len > 0) {
2334         if ((ret = bdrv_read(bs, sector_num, tmp_buf, 1)) < 0)
2335             return ret;
2336         memcpy(buf, tmp_buf + (offset & (BDRV_SECTOR_SIZE - 1)), len);
2337         count -= len;
2338         if (count == 0)
2339             return count1;
2340         sector_num++;
2341         buf += len;
2342     }
2343 
2344     /* read the sectors "in place" */
2345     nb_sectors = count >> BDRV_SECTOR_BITS;
2346     if (nb_sectors > 0) {
2347         if ((ret = bdrv_read(bs, sector_num, buf, nb_sectors)) < 0)
2348             return ret;
2349         sector_num += nb_sectors;
2350         len = nb_sectors << BDRV_SECTOR_BITS;
2351         buf += len;
2352         count -= len;
2353     }
2354 
2355     /* add data from the last sector */
2356     if (count > 0) {
2357         if ((ret = bdrv_read(bs, sector_num, tmp_buf, 1)) < 0)
2358             return ret;
2359         memcpy(buf, tmp_buf, count);
2360     }
2361     return count1;
2362 }
2363 
2364 int bdrv_pwritev(BlockDriverState *bs, int64_t offset, QEMUIOVector *qiov)
2365 {
2366     uint8_t tmp_buf[BDRV_SECTOR_SIZE];
2367     int len, nb_sectors, count;
2368     int64_t sector_num;
2369     int ret;
2370 
2371     count = qiov->size;
2372 
2373     /* first write to align to sector start */
2374     len = (BDRV_SECTOR_SIZE - offset) & (BDRV_SECTOR_SIZE - 1);
2375     if (len > count)
2376         len = count;
2377     sector_num = offset >> BDRV_SECTOR_BITS;
2378     if (len > 0) {
2379         if ((ret = bdrv_read(bs, sector_num, tmp_buf, 1)) < 0)
2380             return ret;
2381         qemu_iovec_to_buf(qiov, 0, tmp_buf + (offset & (BDRV_SECTOR_SIZE - 1)),
2382                           len);
2383         if ((ret = bdrv_write(bs, sector_num, tmp_buf, 1)) < 0)
2384             return ret;
2385         count -= len;
2386         if (count == 0)
2387             return qiov->size;
2388         sector_num++;
2389     }
2390 
2391     /* write the sectors "in place" */
2392     nb_sectors = count >> BDRV_SECTOR_BITS;
2393     if (nb_sectors > 0) {
2394         QEMUIOVector qiov_inplace;
2395 
2396         qemu_iovec_init(&qiov_inplace, qiov->niov);
2397         qemu_iovec_concat(&qiov_inplace, qiov, len,
2398                           nb_sectors << BDRV_SECTOR_BITS);
2399         ret = bdrv_writev(bs, sector_num, &qiov_inplace);
2400         qemu_iovec_destroy(&qiov_inplace);
2401         if (ret < 0) {
2402             return ret;
2403         }
2404 
2405         sector_num += nb_sectors;
2406         len = nb_sectors << BDRV_SECTOR_BITS;
2407         count -= len;
2408     }
2409 
2410     /* add data from the last sector */
2411     if (count > 0) {
2412         if ((ret = bdrv_read(bs, sector_num, tmp_buf, 1)) < 0)
2413             return ret;
2414         qemu_iovec_to_buf(qiov, qiov->size - count, tmp_buf, count);
2415         if ((ret = bdrv_write(bs, sector_num, tmp_buf, 1)) < 0)
2416             return ret;
2417     }
2418     return qiov->size;
2419 }
2420 
2421 int bdrv_pwrite(BlockDriverState *bs, int64_t offset,
2422                 const void *buf, int count1)
2423 {
2424     QEMUIOVector qiov;
2425     struct iovec iov = {
2426         .iov_base   = (void *) buf,
2427         .iov_len    = count1,
2428     };
2429 
2430     qemu_iovec_init_external(&qiov, &iov, 1);
2431     return bdrv_pwritev(bs, offset, &qiov);
2432 }
2433 
2434 /*
2435  * Writes to the file and ensures that no writes are reordered across this
2436  * request (acts as a barrier)
2437  *
2438  * Returns 0 on success, -errno in error cases.
2439  */
2440 int bdrv_pwrite_sync(BlockDriverState *bs, int64_t offset,
2441     const void *buf, int count)
2442 {
2443     int ret;
2444 
2445     ret = bdrv_pwrite(bs, offset, buf, count);
2446     if (ret < 0) {
2447         return ret;
2448     }
2449 
2450     /* No flush needed for cache modes that already do it */
2451     if (bs->enable_write_cache) {
2452         bdrv_flush(bs);
2453     }
2454 
2455     return 0;
2456 }
2457 
2458 static int coroutine_fn bdrv_co_do_copy_on_readv(BlockDriverState *bs,
2459         int64_t sector_num, int nb_sectors, QEMUIOVector *qiov)
2460 {
2461     /* Perform I/O through a temporary buffer so that users who scribble over
2462      * their read buffer while the operation is in progress do not end up
2463      * modifying the image file.  This is critical for zero-copy guest I/O
2464      * where anything might happen inside guest memory.
2465      */
2466     void *bounce_buffer;
2467 
2468     BlockDriver *drv = bs->drv;
2469     struct iovec iov;
2470     QEMUIOVector bounce_qiov;
2471     int64_t cluster_sector_num;
2472     int cluster_nb_sectors;
2473     size_t skip_bytes;
2474     int ret;
2475 
2476     /* Cover entire cluster so no additional backing file I/O is required when
2477      * allocating cluster in the image file.
2478      */
2479     bdrv_round_to_clusters(bs, sector_num, nb_sectors,
2480                            &cluster_sector_num, &cluster_nb_sectors);
2481 
2482     trace_bdrv_co_do_copy_on_readv(bs, sector_num, nb_sectors,
2483                                    cluster_sector_num, cluster_nb_sectors);
2484 
2485     iov.iov_len = cluster_nb_sectors * BDRV_SECTOR_SIZE;
2486     iov.iov_base = bounce_buffer = qemu_blockalign(bs, iov.iov_len);
2487     qemu_iovec_init_external(&bounce_qiov, &iov, 1);
2488 
2489     ret = drv->bdrv_co_readv(bs, cluster_sector_num, cluster_nb_sectors,
2490                              &bounce_qiov);
2491     if (ret < 0) {
2492         goto err;
2493     }
2494 
2495     if (drv->bdrv_co_write_zeroes &&
2496         buffer_is_zero(bounce_buffer, iov.iov_len)) {
2497         ret = bdrv_co_do_write_zeroes(bs, cluster_sector_num,
2498                                       cluster_nb_sectors);
2499     } else {
2500         /* This does not change the data on the disk, it is not necessary
2501          * to flush even in cache=writethrough mode.
2502          */
2503         ret = drv->bdrv_co_writev(bs, cluster_sector_num, cluster_nb_sectors,
2504                                   &bounce_qiov);
2505     }
2506 
2507     if (ret < 0) {
2508         /* It might be okay to ignore write errors for guest requests.  If this
2509          * is a deliberate copy-on-read then we don't want to ignore the error.
2510          * Simply report it in all cases.
2511          */
2512         goto err;
2513     }
2514 
2515     skip_bytes = (sector_num - cluster_sector_num) * BDRV_SECTOR_SIZE;
2516     qemu_iovec_from_buf(qiov, 0, bounce_buffer + skip_bytes,
2517                         nb_sectors * BDRV_SECTOR_SIZE);
2518 
2519 err:
2520     qemu_vfree(bounce_buffer);
2521     return ret;
2522 }
2523 
2524 /*
2525  * Handle a read request in coroutine context
2526  */
2527 static int coroutine_fn bdrv_co_do_readv(BlockDriverState *bs,
2528     int64_t sector_num, int nb_sectors, QEMUIOVector *qiov,
2529     BdrvRequestFlags flags)
2530 {
2531     BlockDriver *drv = bs->drv;
2532     BdrvTrackedRequest req;
2533     int ret;
2534 
2535     if (!drv) {
2536         return -ENOMEDIUM;
2537     }
2538     if (bdrv_check_request(bs, sector_num, nb_sectors)) {
2539         return -EIO;
2540     }
2541 
2542     /* throttling disk read I/O */
2543     if (bs->io_limits_enabled) {
2544         bdrv_io_limits_intercept(bs, false, nb_sectors);
2545     }
2546 
2547     if (bs->copy_on_read) {
2548         flags |= BDRV_REQ_COPY_ON_READ;
2549     }
2550     if (flags & BDRV_REQ_COPY_ON_READ) {
2551         bs->copy_on_read_in_flight++;
2552     }
2553 
2554     if (bs->copy_on_read_in_flight) {
2555         wait_for_overlapping_requests(bs, sector_num, nb_sectors);
2556     }
2557 
2558     tracked_request_begin(&req, bs, sector_num, nb_sectors, false);
2559 
2560     if (flags & BDRV_REQ_COPY_ON_READ) {
2561         int pnum;
2562 
2563         ret = bdrv_co_is_allocated(bs, sector_num, nb_sectors, &pnum);
2564         if (ret < 0) {
2565             goto out;
2566         }
2567 
2568         if (!ret || pnum != nb_sectors) {
2569             ret = bdrv_co_do_copy_on_readv(bs, sector_num, nb_sectors, qiov);
2570             goto out;
2571         }
2572     }
2573 
2574     if (!(bs->zero_beyond_eof && bs->growable)) {
2575         ret = drv->bdrv_co_readv(bs, sector_num, nb_sectors, qiov);
2576     } else {
2577         /* Read zeros after EOF of growable BDSes */
2578         int64_t len, total_sectors, max_nb_sectors;
2579 
2580         len = bdrv_getlength(bs);
2581         if (len < 0) {
2582             ret = len;
2583             goto out;
2584         }
2585 
2586         total_sectors = len >> BDRV_SECTOR_BITS;
2587         max_nb_sectors = MAX(0, total_sectors - sector_num);
2588         if (max_nb_sectors > 0) {
2589             ret = drv->bdrv_co_readv(bs, sector_num,
2590                                      MIN(nb_sectors, max_nb_sectors), qiov);
2591         } else {
2592             ret = 0;
2593         }
2594 
2595         /* Reading beyond end of file is supposed to produce zeroes */
2596         if (ret == 0 && total_sectors < sector_num + nb_sectors) {
2597             uint64_t offset = MAX(0, total_sectors - sector_num);
2598             uint64_t bytes = (sector_num + nb_sectors - offset) *
2599                               BDRV_SECTOR_SIZE;
2600             qemu_iovec_memset(qiov, offset * BDRV_SECTOR_SIZE, 0, bytes);
2601         }
2602     }
2603 
2604 out:
2605     tracked_request_end(&req);
2606 
2607     if (flags & BDRV_REQ_COPY_ON_READ) {
2608         bs->copy_on_read_in_flight--;
2609     }
2610 
2611     return ret;
2612 }
2613 
2614 int coroutine_fn bdrv_co_readv(BlockDriverState *bs, int64_t sector_num,
2615     int nb_sectors, QEMUIOVector *qiov)
2616 {
2617     trace_bdrv_co_readv(bs, sector_num, nb_sectors);
2618 
2619     return bdrv_co_do_readv(bs, sector_num, nb_sectors, qiov, 0);
2620 }
2621 
2622 int coroutine_fn bdrv_co_copy_on_readv(BlockDriverState *bs,
2623     int64_t sector_num, int nb_sectors, QEMUIOVector *qiov)
2624 {
2625     trace_bdrv_co_copy_on_readv(bs, sector_num, nb_sectors);
2626 
2627     return bdrv_co_do_readv(bs, sector_num, nb_sectors, qiov,
2628                             BDRV_REQ_COPY_ON_READ);
2629 }
2630 
2631 static int coroutine_fn bdrv_co_do_write_zeroes(BlockDriverState *bs,
2632     int64_t sector_num, int nb_sectors)
2633 {
2634     BlockDriver *drv = bs->drv;
2635     QEMUIOVector qiov;
2636     struct iovec iov;
2637     int ret;
2638 
2639     /* TODO Emulate only part of misaligned requests instead of letting block
2640      * drivers return -ENOTSUP and emulate everything */
2641 
2642     /* First try the efficient write zeroes operation */
2643     if (drv->bdrv_co_write_zeroes) {
2644         ret = drv->bdrv_co_write_zeroes(bs, sector_num, nb_sectors);
2645         if (ret != -ENOTSUP) {
2646             return ret;
2647         }
2648     }
2649 
2650     /* Fall back to bounce buffer if write zeroes is unsupported */
2651     iov.iov_len  = nb_sectors * BDRV_SECTOR_SIZE;
2652     iov.iov_base = qemu_blockalign(bs, iov.iov_len);
2653     memset(iov.iov_base, 0, iov.iov_len);
2654     qemu_iovec_init_external(&qiov, &iov, 1);
2655 
2656     ret = drv->bdrv_co_writev(bs, sector_num, nb_sectors, &qiov);
2657 
2658     qemu_vfree(iov.iov_base);
2659     return ret;
2660 }
2661 
2662 /*
2663  * Handle a write request in coroutine context
2664  */
2665 static int coroutine_fn bdrv_co_do_writev(BlockDriverState *bs,
2666     int64_t sector_num, int nb_sectors, QEMUIOVector *qiov,
2667     BdrvRequestFlags flags)
2668 {
2669     BlockDriver *drv = bs->drv;
2670     BdrvTrackedRequest req;
2671     int ret;
2672 
2673     if (!bs->drv) {
2674         return -ENOMEDIUM;
2675     }
2676     if (bs->read_only) {
2677         return -EACCES;
2678     }
2679     if (bdrv_check_request(bs, sector_num, nb_sectors)) {
2680         return -EIO;
2681     }
2682 
2683     /* throttling disk write I/O */
2684     if (bs->io_limits_enabled) {
2685         bdrv_io_limits_intercept(bs, true, nb_sectors);
2686     }
2687 
2688     if (bs->copy_on_read_in_flight) {
2689         wait_for_overlapping_requests(bs, sector_num, nb_sectors);
2690     }
2691 
2692     tracked_request_begin(&req, bs, sector_num, nb_sectors, true);
2693 
2694     ret = notifier_with_return_list_notify(&bs->before_write_notifiers, &req);
2695 
2696     if (ret < 0) {
2697         /* Do nothing, write notifier decided to fail this request */
2698     } else if (flags & BDRV_REQ_ZERO_WRITE) {
2699         ret = bdrv_co_do_write_zeroes(bs, sector_num, nb_sectors);
2700     } else {
2701         ret = drv->bdrv_co_writev(bs, sector_num, nb_sectors, qiov);
2702     }
2703 
2704     if (ret == 0 && !bs->enable_write_cache) {
2705         ret = bdrv_co_flush(bs);
2706     }
2707 
2708     if (bs->dirty_bitmap) {
2709         bdrv_set_dirty(bs, sector_num, nb_sectors);
2710     }
2711 
2712     if (bs->wr_highest_sector < sector_num + nb_sectors - 1) {
2713         bs->wr_highest_sector = sector_num + nb_sectors - 1;
2714     }
2715 
2716     tracked_request_end(&req);
2717 
2718     return ret;
2719 }
2720 
2721 int coroutine_fn bdrv_co_writev(BlockDriverState *bs, int64_t sector_num,
2722     int nb_sectors, QEMUIOVector *qiov)
2723 {
2724     trace_bdrv_co_writev(bs, sector_num, nb_sectors);
2725 
2726     return bdrv_co_do_writev(bs, sector_num, nb_sectors, qiov, 0);
2727 }
2728 
2729 int coroutine_fn bdrv_co_write_zeroes(BlockDriverState *bs,
2730                                       int64_t sector_num, int nb_sectors)
2731 {
2732     trace_bdrv_co_write_zeroes(bs, sector_num, nb_sectors);
2733 
2734     return bdrv_co_do_writev(bs, sector_num, nb_sectors, NULL,
2735                              BDRV_REQ_ZERO_WRITE);
2736 }
2737 
2738 /**
2739  * Truncate file to 'offset' bytes (needed only for file protocols)
2740  */
2741 int bdrv_truncate(BlockDriverState *bs, int64_t offset)
2742 {
2743     BlockDriver *drv = bs->drv;
2744     int ret;
2745     if (!drv)
2746         return -ENOMEDIUM;
2747     if (!drv->bdrv_truncate)
2748         return -ENOTSUP;
2749     if (bs->read_only)
2750         return -EACCES;
2751     if (bdrv_in_use(bs))
2752         return -EBUSY;
2753     ret = drv->bdrv_truncate(bs, offset);
2754     if (ret == 0) {
2755         ret = refresh_total_sectors(bs, offset >> BDRV_SECTOR_BITS);
2756         bdrv_dev_resize_cb(bs);
2757     }
2758     return ret;
2759 }
2760 
2761 /**
2762  * Length of a allocated file in bytes. Sparse files are counted by actual
2763  * allocated space. Return < 0 if error or unknown.
2764  */
2765 int64_t bdrv_get_allocated_file_size(BlockDriverState *bs)
2766 {
2767     BlockDriver *drv = bs->drv;
2768     if (!drv) {
2769         return -ENOMEDIUM;
2770     }
2771     if (drv->bdrv_get_allocated_file_size) {
2772         return drv->bdrv_get_allocated_file_size(bs);
2773     }
2774     if (bs->file) {
2775         return bdrv_get_allocated_file_size(bs->file);
2776     }
2777     return -ENOTSUP;
2778 }
2779 
2780 /**
2781  * Length of a file in bytes. Return < 0 if error or unknown.
2782  */
2783 int64_t bdrv_getlength(BlockDriverState *bs)
2784 {
2785     BlockDriver *drv = bs->drv;
2786     if (!drv)
2787         return -ENOMEDIUM;
2788 
2789     if (bs->growable || bdrv_dev_has_removable_media(bs)) {
2790         if (drv->bdrv_getlength) {
2791             return drv->bdrv_getlength(bs);
2792         }
2793     }
2794     return bs->total_sectors * BDRV_SECTOR_SIZE;
2795 }
2796 
2797 /* return 0 as number of sectors if no device present or error */
2798 void bdrv_get_geometry(BlockDriverState *bs, uint64_t *nb_sectors_ptr)
2799 {
2800     int64_t length;
2801     length = bdrv_getlength(bs);
2802     if (length < 0)
2803         length = 0;
2804     else
2805         length = length >> BDRV_SECTOR_BITS;
2806     *nb_sectors_ptr = length;
2807 }
2808 
2809 /* throttling disk io limits */
2810 void bdrv_set_io_limits(BlockDriverState *bs,
2811                         BlockIOLimit *io_limits)
2812 {
2813     bs->io_limits = *io_limits;
2814     bs->io_limits_enabled = bdrv_io_limits_enabled(bs);
2815 }
2816 
2817 void bdrv_set_on_error(BlockDriverState *bs, BlockdevOnError on_read_error,
2818                        BlockdevOnError on_write_error)
2819 {
2820     bs->on_read_error = on_read_error;
2821     bs->on_write_error = on_write_error;
2822 }
2823 
2824 BlockdevOnError bdrv_get_on_error(BlockDriverState *bs, bool is_read)
2825 {
2826     return is_read ? bs->on_read_error : bs->on_write_error;
2827 }
2828 
2829 BlockErrorAction bdrv_get_error_action(BlockDriverState *bs, bool is_read, int error)
2830 {
2831     BlockdevOnError on_err = is_read ? bs->on_read_error : bs->on_write_error;
2832 
2833     switch (on_err) {
2834     case BLOCKDEV_ON_ERROR_ENOSPC:
2835         return (error == ENOSPC) ? BDRV_ACTION_STOP : BDRV_ACTION_REPORT;
2836     case BLOCKDEV_ON_ERROR_STOP:
2837         return BDRV_ACTION_STOP;
2838     case BLOCKDEV_ON_ERROR_REPORT:
2839         return BDRV_ACTION_REPORT;
2840     case BLOCKDEV_ON_ERROR_IGNORE:
2841         return BDRV_ACTION_IGNORE;
2842     default:
2843         abort();
2844     }
2845 }
2846 
2847 /* This is done by device models because, while the block layer knows
2848  * about the error, it does not know whether an operation comes from
2849  * the device or the block layer (from a job, for example).
2850  */
2851 void bdrv_error_action(BlockDriverState *bs, BlockErrorAction action,
2852                        bool is_read, int error)
2853 {
2854     assert(error >= 0);
2855     bdrv_emit_qmp_error_event(bs, QEVENT_BLOCK_IO_ERROR, action, is_read);
2856     if (action == BDRV_ACTION_STOP) {
2857         vm_stop(RUN_STATE_IO_ERROR);
2858         bdrv_iostatus_set_err(bs, error);
2859     }
2860 }
2861 
2862 int bdrv_is_read_only(BlockDriverState *bs)
2863 {
2864     return bs->read_only;
2865 }
2866 
2867 int bdrv_is_sg(BlockDriverState *bs)
2868 {
2869     return bs->sg;
2870 }
2871 
2872 int bdrv_enable_write_cache(BlockDriverState *bs)
2873 {
2874     return bs->enable_write_cache;
2875 }
2876 
2877 void bdrv_set_enable_write_cache(BlockDriverState *bs, bool wce)
2878 {
2879     bs->enable_write_cache = wce;
2880 
2881     /* so a reopen() will preserve wce */
2882     if (wce) {
2883         bs->open_flags |= BDRV_O_CACHE_WB;
2884     } else {
2885         bs->open_flags &= ~BDRV_O_CACHE_WB;
2886     }
2887 }
2888 
2889 int bdrv_is_encrypted(BlockDriverState *bs)
2890 {
2891     if (bs->backing_hd && bs->backing_hd->encrypted)
2892         return 1;
2893     return bs->encrypted;
2894 }
2895 
2896 int bdrv_key_required(BlockDriverState *bs)
2897 {
2898     BlockDriverState *backing_hd = bs->backing_hd;
2899 
2900     if (backing_hd && backing_hd->encrypted && !backing_hd->valid_key)
2901         return 1;
2902     return (bs->encrypted && !bs->valid_key);
2903 }
2904 
2905 int bdrv_set_key(BlockDriverState *bs, const char *key)
2906 {
2907     int ret;
2908     if (bs->backing_hd && bs->backing_hd->encrypted) {
2909         ret = bdrv_set_key(bs->backing_hd, key);
2910         if (ret < 0)
2911             return ret;
2912         if (!bs->encrypted)
2913             return 0;
2914     }
2915     if (!bs->encrypted) {
2916         return -EINVAL;
2917     } else if (!bs->drv || !bs->drv->bdrv_set_key) {
2918         return -ENOMEDIUM;
2919     }
2920     ret = bs->drv->bdrv_set_key(bs, key);
2921     if (ret < 0) {
2922         bs->valid_key = 0;
2923     } else if (!bs->valid_key) {
2924         bs->valid_key = 1;
2925         /* call the change callback now, we skipped it on open */
2926         bdrv_dev_change_media_cb(bs, true);
2927     }
2928     return ret;
2929 }
2930 
2931 const char *bdrv_get_format_name(BlockDriverState *bs)
2932 {
2933     return bs->drv ? bs->drv->format_name : NULL;
2934 }
2935 
2936 void bdrv_iterate_format(void (*it)(void *opaque, const char *name),
2937                          void *opaque)
2938 {
2939     BlockDriver *drv;
2940 
2941     QLIST_FOREACH(drv, &bdrv_drivers, list) {
2942         it(opaque, drv->format_name);
2943     }
2944 }
2945 
2946 BlockDriverState *bdrv_find(const char *name)
2947 {
2948     BlockDriverState *bs;
2949 
2950     QTAILQ_FOREACH(bs, &bdrv_states, list) {
2951         if (!strcmp(name, bs->device_name)) {
2952             return bs;
2953         }
2954     }
2955     return NULL;
2956 }
2957 
2958 BlockDriverState *bdrv_next(BlockDriverState *bs)
2959 {
2960     if (!bs) {
2961         return QTAILQ_FIRST(&bdrv_states);
2962     }
2963     return QTAILQ_NEXT(bs, list);
2964 }
2965 
2966 void bdrv_iterate(void (*it)(void *opaque, BlockDriverState *bs), void *opaque)
2967 {
2968     BlockDriverState *bs;
2969 
2970     QTAILQ_FOREACH(bs, &bdrv_states, list) {
2971         it(opaque, bs);
2972     }
2973 }
2974 
2975 const char *bdrv_get_device_name(BlockDriverState *bs)
2976 {
2977     return bs->device_name;
2978 }
2979 
2980 int bdrv_get_flags(BlockDriverState *bs)
2981 {
2982     return bs->open_flags;
2983 }
2984 
2985 int bdrv_flush_all(void)
2986 {
2987     BlockDriverState *bs;
2988     int result = 0;
2989 
2990     QTAILQ_FOREACH(bs, &bdrv_states, list) {
2991         int ret = bdrv_flush(bs);
2992         if (ret < 0 && !result) {
2993             result = ret;
2994         }
2995     }
2996 
2997     return result;
2998 }
2999 
3000 int bdrv_has_zero_init_1(BlockDriverState *bs)
3001 {
3002     return 1;
3003 }
3004 
3005 int bdrv_has_zero_init(BlockDriverState *bs)
3006 {
3007     assert(bs->drv);
3008 
3009     if (bs->drv->bdrv_has_zero_init) {
3010         return bs->drv->bdrv_has_zero_init(bs);
3011     }
3012 
3013     /* safe default */
3014     return 0;
3015 }
3016 
3017 typedef struct BdrvCoIsAllocatedData {
3018     BlockDriverState *bs;
3019     BlockDriverState *base;
3020     int64_t sector_num;
3021     int nb_sectors;
3022     int *pnum;
3023     int ret;
3024     bool done;
3025 } BdrvCoIsAllocatedData;
3026 
3027 /*
3028  * Returns true iff the specified sector is present in the disk image. Drivers
3029  * not implementing the functionality are assumed to not support backing files,
3030  * hence all their sectors are reported as allocated.
3031  *
3032  * If 'sector_num' is beyond the end of the disk image the return value is 0
3033  * and 'pnum' is set to 0.
3034  *
3035  * 'pnum' is set to the number of sectors (including and immediately following
3036  * the specified sector) that are known to be in the same
3037  * allocated/unallocated state.
3038  *
3039  * 'nb_sectors' is the max value 'pnum' should be set to.  If nb_sectors goes
3040  * beyond the end of the disk image it will be clamped.
3041  */
3042 int coroutine_fn bdrv_co_is_allocated(BlockDriverState *bs, int64_t sector_num,
3043                                       int nb_sectors, int *pnum)
3044 {
3045     int64_t n;
3046 
3047     if (sector_num >= bs->total_sectors) {
3048         *pnum = 0;
3049         return 0;
3050     }
3051 
3052     n = bs->total_sectors - sector_num;
3053     if (n < nb_sectors) {
3054         nb_sectors = n;
3055     }
3056 
3057     if (!bs->drv->bdrv_co_is_allocated) {
3058         *pnum = nb_sectors;
3059         return 1;
3060     }
3061 
3062     return bs->drv->bdrv_co_is_allocated(bs, sector_num, nb_sectors, pnum);
3063 }
3064 
3065 /* Coroutine wrapper for bdrv_is_allocated() */
3066 static void coroutine_fn bdrv_is_allocated_co_entry(void *opaque)
3067 {
3068     BdrvCoIsAllocatedData *data = opaque;
3069     BlockDriverState *bs = data->bs;
3070 
3071     data->ret = bdrv_co_is_allocated(bs, data->sector_num, data->nb_sectors,
3072                                      data->pnum);
3073     data->done = true;
3074 }
3075 
3076 /*
3077  * Synchronous wrapper around bdrv_co_is_allocated().
3078  *
3079  * See bdrv_co_is_allocated() for details.
3080  */
3081 int bdrv_is_allocated(BlockDriverState *bs, int64_t sector_num, int nb_sectors,
3082                       int *pnum)
3083 {
3084     Coroutine *co;
3085     BdrvCoIsAllocatedData data = {
3086         .bs = bs,
3087         .sector_num = sector_num,
3088         .nb_sectors = nb_sectors,
3089         .pnum = pnum,
3090         .done = false,
3091     };
3092 
3093     co = qemu_coroutine_create(bdrv_is_allocated_co_entry);
3094     qemu_coroutine_enter(co, &data);
3095     while (!data.done) {
3096         qemu_aio_wait();
3097     }
3098     return data.ret;
3099 }
3100 
3101 /*
3102  * Given an image chain: ... -> [BASE] -> [INTER1] -> [INTER2] -> [TOP]
3103  *
3104  * Return true if the given sector is allocated in any image between
3105  * BASE and TOP (inclusive).  BASE can be NULL to check if the given
3106  * sector is allocated in any image of the chain.  Return false otherwise.
3107  *
3108  * 'pnum' is set to the number of sectors (including and immediately following
3109  *  the specified sector) that are known to be in the same
3110  *  allocated/unallocated state.
3111  *
3112  */
3113 int coroutine_fn bdrv_co_is_allocated_above(BlockDriverState *top,
3114                                             BlockDriverState *base,
3115                                             int64_t sector_num,
3116                                             int nb_sectors, int *pnum)
3117 {
3118     BlockDriverState *intermediate;
3119     int ret, n = nb_sectors;
3120 
3121     intermediate = top;
3122     while (intermediate && intermediate != base) {
3123         int pnum_inter;
3124         ret = bdrv_co_is_allocated(intermediate, sector_num, nb_sectors,
3125                                    &pnum_inter);
3126         if (ret < 0) {
3127             return ret;
3128         } else if (ret) {
3129             *pnum = pnum_inter;
3130             return 1;
3131         }
3132 
3133         /*
3134          * [sector_num, nb_sectors] is unallocated on top but intermediate
3135          * might have
3136          *
3137          * [sector_num+x, nr_sectors] allocated.
3138          */
3139         if (n > pnum_inter &&
3140             (intermediate == top ||
3141              sector_num + pnum_inter < intermediate->total_sectors)) {
3142             n = pnum_inter;
3143         }
3144 
3145         intermediate = intermediate->backing_hd;
3146     }
3147 
3148     *pnum = n;
3149     return 0;
3150 }
3151 
3152 /* Coroutine wrapper for bdrv_is_allocated_above() */
3153 static void coroutine_fn bdrv_is_allocated_above_co_entry(void *opaque)
3154 {
3155     BdrvCoIsAllocatedData *data = opaque;
3156     BlockDriverState *top = data->bs;
3157     BlockDriverState *base = data->base;
3158 
3159     data->ret = bdrv_co_is_allocated_above(top, base, data->sector_num,
3160                                            data->nb_sectors, data->pnum);
3161     data->done = true;
3162 }
3163 
3164 /*
3165  * Synchronous wrapper around bdrv_co_is_allocated_above().
3166  *
3167  * See bdrv_co_is_allocated_above() for details.
3168  */
3169 int bdrv_is_allocated_above(BlockDriverState *top, BlockDriverState *base,
3170                             int64_t sector_num, int nb_sectors, int *pnum)
3171 {
3172     Coroutine *co;
3173     BdrvCoIsAllocatedData data = {
3174         .bs = top,
3175         .base = base,
3176         .sector_num = sector_num,
3177         .nb_sectors = nb_sectors,
3178         .pnum = pnum,
3179         .done = false,
3180     };
3181 
3182     co = qemu_coroutine_create(bdrv_is_allocated_above_co_entry);
3183     qemu_coroutine_enter(co, &data);
3184     while (!data.done) {
3185         qemu_aio_wait();
3186     }
3187     return data.ret;
3188 }
3189 
3190 const char *bdrv_get_encrypted_filename(BlockDriverState *bs)
3191 {
3192     if (bs->backing_hd && bs->backing_hd->encrypted)
3193         return bs->backing_file;
3194     else if (bs->encrypted)
3195         return bs->filename;
3196     else
3197         return NULL;
3198 }
3199 
3200 void bdrv_get_backing_filename(BlockDriverState *bs,
3201                                char *filename, int filename_size)
3202 {
3203     pstrcpy(filename, filename_size, bs->backing_file);
3204 }
3205 
3206 int bdrv_write_compressed(BlockDriverState *bs, int64_t sector_num,
3207                           const uint8_t *buf, int nb_sectors)
3208 {
3209     BlockDriver *drv = bs->drv;
3210     if (!drv)
3211         return -ENOMEDIUM;
3212     if (!drv->bdrv_write_compressed)
3213         return -ENOTSUP;
3214     if (bdrv_check_request(bs, sector_num, nb_sectors))
3215         return -EIO;
3216 
3217     assert(!bs->dirty_bitmap);
3218 
3219     return drv->bdrv_write_compressed(bs, sector_num, buf, nb_sectors);
3220 }
3221 
3222 int bdrv_get_info(BlockDriverState *bs, BlockDriverInfo *bdi)
3223 {
3224     BlockDriver *drv = bs->drv;
3225     if (!drv)
3226         return -ENOMEDIUM;
3227     if (!drv->bdrv_get_info)
3228         return -ENOTSUP;
3229     memset(bdi, 0, sizeof(*bdi));
3230     return drv->bdrv_get_info(bs, bdi);
3231 }
3232 
3233 int bdrv_save_vmstate(BlockDriverState *bs, const uint8_t *buf,
3234                       int64_t pos, int size)
3235 {
3236     QEMUIOVector qiov;
3237     struct iovec iov = {
3238         .iov_base   = (void *) buf,
3239         .iov_len    = size,
3240     };
3241 
3242     qemu_iovec_init_external(&qiov, &iov, 1);
3243     return bdrv_writev_vmstate(bs, &qiov, pos);
3244 }
3245 
3246 int bdrv_writev_vmstate(BlockDriverState *bs, QEMUIOVector *qiov, int64_t pos)
3247 {
3248     BlockDriver *drv = bs->drv;
3249 
3250     if (!drv) {
3251         return -ENOMEDIUM;
3252     } else if (drv->bdrv_save_vmstate) {
3253         return drv->bdrv_save_vmstate(bs, qiov, pos);
3254     } else if (bs->file) {
3255         return bdrv_writev_vmstate(bs->file, qiov, pos);
3256     }
3257 
3258     return -ENOTSUP;
3259 }
3260 
3261 int bdrv_load_vmstate(BlockDriverState *bs, uint8_t *buf,
3262                       int64_t pos, int size)
3263 {
3264     BlockDriver *drv = bs->drv;
3265     if (!drv)
3266         return -ENOMEDIUM;
3267     if (drv->bdrv_load_vmstate)
3268         return drv->bdrv_load_vmstate(bs, buf, pos, size);
3269     if (bs->file)
3270         return bdrv_load_vmstate(bs->file, buf, pos, size);
3271     return -ENOTSUP;
3272 }
3273 
3274 void bdrv_debug_event(BlockDriverState *bs, BlkDebugEvent event)
3275 {
3276     if (!bs || !bs->drv || !bs->drv->bdrv_debug_event) {
3277         return;
3278     }
3279 
3280     bs->drv->bdrv_debug_event(bs, event);
3281 }
3282 
3283 int bdrv_debug_breakpoint(BlockDriverState *bs, const char *event,
3284                           const char *tag)
3285 {
3286     while (bs && bs->drv && !bs->drv->bdrv_debug_breakpoint) {
3287         bs = bs->file;
3288     }
3289 
3290     if (bs && bs->drv && bs->drv->bdrv_debug_breakpoint) {
3291         return bs->drv->bdrv_debug_breakpoint(bs, event, tag);
3292     }
3293 
3294     return -ENOTSUP;
3295 }
3296 
3297 int bdrv_debug_resume(BlockDriverState *bs, const char *tag)
3298 {
3299     while (bs && bs->drv && !bs->drv->bdrv_debug_resume) {
3300         bs = bs->file;
3301     }
3302 
3303     if (bs && bs->drv && bs->drv->bdrv_debug_resume) {
3304         return bs->drv->bdrv_debug_resume(bs, tag);
3305     }
3306 
3307     return -ENOTSUP;
3308 }
3309 
3310 bool bdrv_debug_is_suspended(BlockDriverState *bs, const char *tag)
3311 {
3312     while (bs && bs->drv && !bs->drv->bdrv_debug_is_suspended) {
3313         bs = bs->file;
3314     }
3315 
3316     if (bs && bs->drv && bs->drv->bdrv_debug_is_suspended) {
3317         return bs->drv->bdrv_debug_is_suspended(bs, tag);
3318     }
3319 
3320     return false;
3321 }
3322 
3323 int bdrv_is_snapshot(BlockDriverState *bs)
3324 {
3325     return !!(bs->open_flags & BDRV_O_SNAPSHOT);
3326 }
3327 
3328 /* backing_file can either be relative, or absolute, or a protocol.  If it is
3329  * relative, it must be relative to the chain.  So, passing in bs->filename
3330  * from a BDS as backing_file should not be done, as that may be relative to
3331  * the CWD rather than the chain. */
3332 BlockDriverState *bdrv_find_backing_image(BlockDriverState *bs,
3333         const char *backing_file)
3334 {
3335     char *filename_full = NULL;
3336     char *backing_file_full = NULL;
3337     char *filename_tmp = NULL;
3338     int is_protocol = 0;
3339     BlockDriverState *curr_bs = NULL;
3340     BlockDriverState *retval = NULL;
3341 
3342     if (!bs || !bs->drv || !backing_file) {
3343         return NULL;
3344     }
3345 
3346     filename_full     = g_malloc(PATH_MAX);
3347     backing_file_full = g_malloc(PATH_MAX);
3348     filename_tmp      = g_malloc(PATH_MAX);
3349 
3350     is_protocol = path_has_protocol(backing_file);
3351 
3352     for (curr_bs = bs; curr_bs->backing_hd; curr_bs = curr_bs->backing_hd) {
3353 
3354         /* If either of the filename paths is actually a protocol, then
3355          * compare unmodified paths; otherwise make paths relative */
3356         if (is_protocol || path_has_protocol(curr_bs->backing_file)) {
3357             if (strcmp(backing_file, curr_bs->backing_file) == 0) {
3358                 retval = curr_bs->backing_hd;
3359                 break;
3360             }
3361         } else {
3362             /* If not an absolute filename path, make it relative to the current
3363              * image's filename path */
3364             path_combine(filename_tmp, PATH_MAX, curr_bs->filename,
3365                          backing_file);
3366 
3367             /* We are going to compare absolute pathnames */
3368             if (!realpath(filename_tmp, filename_full)) {
3369                 continue;
3370             }
3371 
3372             /* We need to make sure the backing filename we are comparing against
3373              * is relative to the current image filename (or absolute) */
3374             path_combine(filename_tmp, PATH_MAX, curr_bs->filename,
3375                          curr_bs->backing_file);
3376 
3377             if (!realpath(filename_tmp, backing_file_full)) {
3378                 continue;
3379             }
3380 
3381             if (strcmp(backing_file_full, filename_full) == 0) {
3382                 retval = curr_bs->backing_hd;
3383                 break;
3384             }
3385         }
3386     }
3387 
3388     g_free(filename_full);
3389     g_free(backing_file_full);
3390     g_free(filename_tmp);
3391     return retval;
3392 }
3393 
3394 int bdrv_get_backing_file_depth(BlockDriverState *bs)
3395 {
3396     if (!bs->drv) {
3397         return 0;
3398     }
3399 
3400     if (!bs->backing_hd) {
3401         return 0;
3402     }
3403 
3404     return 1 + bdrv_get_backing_file_depth(bs->backing_hd);
3405 }
3406 
3407 BlockDriverState *bdrv_find_base(BlockDriverState *bs)
3408 {
3409     BlockDriverState *curr_bs = NULL;
3410 
3411     if (!bs) {
3412         return NULL;
3413     }
3414 
3415     curr_bs = bs;
3416 
3417     while (curr_bs->backing_hd) {
3418         curr_bs = curr_bs->backing_hd;
3419     }
3420     return curr_bs;
3421 }
3422 
3423 /**************************************************************/
3424 /* async I/Os */
3425 
3426 BlockDriverAIOCB *bdrv_aio_readv(BlockDriverState *bs, int64_t sector_num,
3427                                  QEMUIOVector *qiov, int nb_sectors,
3428                                  BlockDriverCompletionFunc *cb, void *opaque)
3429 {
3430     trace_bdrv_aio_readv(bs, sector_num, nb_sectors, opaque);
3431 
3432     return bdrv_co_aio_rw_vector(bs, sector_num, qiov, nb_sectors,
3433                                  cb, opaque, false);
3434 }
3435 
3436 BlockDriverAIOCB *bdrv_aio_writev(BlockDriverState *bs, int64_t sector_num,
3437                                   QEMUIOVector *qiov, int nb_sectors,
3438                                   BlockDriverCompletionFunc *cb, void *opaque)
3439 {
3440     trace_bdrv_aio_writev(bs, sector_num, nb_sectors, opaque);
3441 
3442     return bdrv_co_aio_rw_vector(bs, sector_num, qiov, nb_sectors,
3443                                  cb, opaque, true);
3444 }
3445 
3446 
3447 typedef struct MultiwriteCB {
3448     int error;
3449     int num_requests;
3450     int num_callbacks;
3451     struct {
3452         BlockDriverCompletionFunc *cb;
3453         void *opaque;
3454         QEMUIOVector *free_qiov;
3455     } callbacks[];
3456 } MultiwriteCB;
3457 
3458 static void multiwrite_user_cb(MultiwriteCB *mcb)
3459 {
3460     int i;
3461 
3462     for (i = 0; i < mcb->num_callbacks; i++) {
3463         mcb->callbacks[i].cb(mcb->callbacks[i].opaque, mcb->error);
3464         if (mcb->callbacks[i].free_qiov) {
3465             qemu_iovec_destroy(mcb->callbacks[i].free_qiov);
3466         }
3467         g_free(mcb->callbacks[i].free_qiov);
3468     }
3469 }
3470 
3471 static void multiwrite_cb(void *opaque, int ret)
3472 {
3473     MultiwriteCB *mcb = opaque;
3474 
3475     trace_multiwrite_cb(mcb, ret);
3476 
3477     if (ret < 0 && !mcb->error) {
3478         mcb->error = ret;
3479     }
3480 
3481     mcb->num_requests--;
3482     if (mcb->num_requests == 0) {
3483         multiwrite_user_cb(mcb);
3484         g_free(mcb);
3485     }
3486 }
3487 
3488 static int multiwrite_req_compare(const void *a, const void *b)
3489 {
3490     const BlockRequest *req1 = a, *req2 = b;
3491 
3492     /*
3493      * Note that we can't simply subtract req2->sector from req1->sector
3494      * here as that could overflow the return value.
3495      */
3496     if (req1->sector > req2->sector) {
3497         return 1;
3498     } else if (req1->sector < req2->sector) {
3499         return -1;
3500     } else {
3501         return 0;
3502     }
3503 }
3504 
3505 /*
3506  * Takes a bunch of requests and tries to merge them. Returns the number of
3507  * requests that remain after merging.
3508  */
3509 static int multiwrite_merge(BlockDriverState *bs, BlockRequest *reqs,
3510     int num_reqs, MultiwriteCB *mcb)
3511 {
3512     int i, outidx;
3513 
3514     // Sort requests by start sector
3515     qsort(reqs, num_reqs, sizeof(*reqs), &multiwrite_req_compare);
3516 
3517     // Check if adjacent requests touch the same clusters. If so, combine them,
3518     // filling up gaps with zero sectors.
3519     outidx = 0;
3520     for (i = 1; i < num_reqs; i++) {
3521         int merge = 0;
3522         int64_t oldreq_last = reqs[outidx].sector + reqs[outidx].nb_sectors;
3523 
3524         // Handle exactly sequential writes and overlapping writes.
3525         if (reqs[i].sector <= oldreq_last) {
3526             merge = 1;
3527         }
3528 
3529         if (reqs[outidx].qiov->niov + reqs[i].qiov->niov + 1 > IOV_MAX) {
3530             merge = 0;
3531         }
3532 
3533         if (merge) {
3534             size_t size;
3535             QEMUIOVector *qiov = g_malloc0(sizeof(*qiov));
3536             qemu_iovec_init(qiov,
3537                 reqs[outidx].qiov->niov + reqs[i].qiov->niov + 1);
3538 
3539             // Add the first request to the merged one. If the requests are
3540             // overlapping, drop the last sectors of the first request.
3541             size = (reqs[i].sector - reqs[outidx].sector) << 9;
3542             qemu_iovec_concat(qiov, reqs[outidx].qiov, 0, size);
3543 
3544             // We should need to add any zeros between the two requests
3545             assert (reqs[i].sector <= oldreq_last);
3546 
3547             // Add the second request
3548             qemu_iovec_concat(qiov, reqs[i].qiov, 0, reqs[i].qiov->size);
3549 
3550             reqs[outidx].nb_sectors = qiov->size >> 9;
3551             reqs[outidx].qiov = qiov;
3552 
3553             mcb->callbacks[i].free_qiov = reqs[outidx].qiov;
3554         } else {
3555             outidx++;
3556             reqs[outidx].sector     = reqs[i].sector;
3557             reqs[outidx].nb_sectors = reqs[i].nb_sectors;
3558             reqs[outidx].qiov       = reqs[i].qiov;
3559         }
3560     }
3561 
3562     return outidx + 1;
3563 }
3564 
3565 /*
3566  * Submit multiple AIO write requests at once.
3567  *
3568  * On success, the function returns 0 and all requests in the reqs array have
3569  * been submitted. In error case this function returns -1, and any of the
3570  * requests may or may not be submitted yet. In particular, this means that the
3571  * callback will be called for some of the requests, for others it won't. The
3572  * caller must check the error field of the BlockRequest to wait for the right
3573  * callbacks (if error != 0, no callback will be called).
3574  *
3575  * The implementation may modify the contents of the reqs array, e.g. to merge
3576  * requests. However, the fields opaque and error are left unmodified as they
3577  * are used to signal failure for a single request to the caller.
3578  */
3579 int bdrv_aio_multiwrite(BlockDriverState *bs, BlockRequest *reqs, int num_reqs)
3580 {
3581     MultiwriteCB *mcb;
3582     int i;
3583 
3584     /* don't submit writes if we don't have a medium */
3585     if (bs->drv == NULL) {
3586         for (i = 0; i < num_reqs; i++) {
3587             reqs[i].error = -ENOMEDIUM;
3588         }
3589         return -1;
3590     }
3591 
3592     if (num_reqs == 0) {
3593         return 0;
3594     }
3595 
3596     // Create MultiwriteCB structure
3597     mcb = g_malloc0(sizeof(*mcb) + num_reqs * sizeof(*mcb->callbacks));
3598     mcb->num_requests = 0;
3599     mcb->num_callbacks = num_reqs;
3600 
3601     for (i = 0; i < num_reqs; i++) {
3602         mcb->callbacks[i].cb = reqs[i].cb;
3603         mcb->callbacks[i].opaque = reqs[i].opaque;
3604     }
3605 
3606     // Check for mergable requests
3607     num_reqs = multiwrite_merge(bs, reqs, num_reqs, mcb);
3608 
3609     trace_bdrv_aio_multiwrite(mcb, mcb->num_callbacks, num_reqs);
3610 
3611     /* Run the aio requests. */
3612     mcb->num_requests = num_reqs;
3613     for (i = 0; i < num_reqs; i++) {
3614         bdrv_aio_writev(bs, reqs[i].sector, reqs[i].qiov,
3615             reqs[i].nb_sectors, multiwrite_cb, mcb);
3616     }
3617 
3618     return 0;
3619 }
3620 
3621 void bdrv_aio_cancel(BlockDriverAIOCB *acb)
3622 {
3623     acb->aiocb_info->cancel(acb);
3624 }
3625 
3626 /* block I/O throttling */
3627 static bool bdrv_exceed_bps_limits(BlockDriverState *bs, int nb_sectors,
3628                  bool is_write, double elapsed_time, uint64_t *wait)
3629 {
3630     uint64_t bps_limit = 0;
3631     uint64_t extension;
3632     double   bytes_limit, bytes_base, bytes_res;
3633     double   slice_time, wait_time;
3634 
3635     if (bs->io_limits.bps[BLOCK_IO_LIMIT_TOTAL]) {
3636         bps_limit = bs->io_limits.bps[BLOCK_IO_LIMIT_TOTAL];
3637     } else if (bs->io_limits.bps[is_write]) {
3638         bps_limit = bs->io_limits.bps[is_write];
3639     } else {
3640         if (wait) {
3641             *wait = 0;
3642         }
3643 
3644         return false;
3645     }
3646 
3647     slice_time = bs->slice_end - bs->slice_start;
3648     slice_time /= (NANOSECONDS_PER_SECOND);
3649     bytes_limit = bps_limit * slice_time;
3650     bytes_base  = bs->slice_submitted.bytes[is_write];
3651     if (bs->io_limits.bps[BLOCK_IO_LIMIT_TOTAL]) {
3652         bytes_base += bs->slice_submitted.bytes[!is_write];
3653     }
3654 
3655     /* bytes_base: the bytes of data which have been read/written; and
3656      *             it is obtained from the history statistic info.
3657      * bytes_res: the remaining bytes of data which need to be read/written.
3658      * (bytes_base + bytes_res) / bps_limit: used to calcuate
3659      *             the total time for completing reading/writting all data.
3660      */
3661     bytes_res   = (unsigned) nb_sectors * BDRV_SECTOR_SIZE;
3662 
3663     if (bytes_base + bytes_res <= bytes_limit) {
3664         if (wait) {
3665             *wait = 0;
3666         }
3667 
3668         return false;
3669     }
3670 
3671     /* Calc approx time to dispatch */
3672     wait_time = (bytes_base + bytes_res) / bps_limit - elapsed_time;
3673 
3674     /* When the I/O rate at runtime exceeds the limits,
3675      * bs->slice_end need to be extended in order that the current statistic
3676      * info can be kept until the timer fire, so it is increased and tuned
3677      * based on the result of experiment.
3678      */
3679     extension = wait_time * NANOSECONDS_PER_SECOND;
3680     extension = DIV_ROUND_UP(extension, BLOCK_IO_SLICE_TIME) *
3681                 BLOCK_IO_SLICE_TIME;
3682     bs->slice_end += extension;
3683     if (wait) {
3684         *wait = wait_time * NANOSECONDS_PER_SECOND;
3685     }
3686 
3687     return true;
3688 }
3689 
3690 static bool bdrv_exceed_iops_limits(BlockDriverState *bs, bool is_write,
3691                              double elapsed_time, uint64_t *wait)
3692 {
3693     uint64_t iops_limit = 0;
3694     double   ios_limit, ios_base;
3695     double   slice_time, wait_time;
3696 
3697     if (bs->io_limits.iops[BLOCK_IO_LIMIT_TOTAL]) {
3698         iops_limit = bs->io_limits.iops[BLOCK_IO_LIMIT_TOTAL];
3699     } else if (bs->io_limits.iops[is_write]) {
3700         iops_limit = bs->io_limits.iops[is_write];
3701     } else {
3702         if (wait) {
3703             *wait = 0;
3704         }
3705 
3706         return false;
3707     }
3708 
3709     slice_time = bs->slice_end - bs->slice_start;
3710     slice_time /= (NANOSECONDS_PER_SECOND);
3711     ios_limit  = iops_limit * slice_time;
3712     ios_base   = bs->slice_submitted.ios[is_write];
3713     if (bs->io_limits.iops[BLOCK_IO_LIMIT_TOTAL]) {
3714         ios_base += bs->slice_submitted.ios[!is_write];
3715     }
3716 
3717     if (ios_base + 1 <= ios_limit) {
3718         if (wait) {
3719             *wait = 0;
3720         }
3721 
3722         return false;
3723     }
3724 
3725     /* Calc approx time to dispatch, in seconds */
3726     wait_time = (ios_base + 1) / iops_limit;
3727     if (wait_time > elapsed_time) {
3728         wait_time = wait_time - elapsed_time;
3729     } else {
3730         wait_time = 0;
3731     }
3732 
3733     /* Exceeded current slice, extend it by another slice time */
3734     bs->slice_end += BLOCK_IO_SLICE_TIME;
3735     if (wait) {
3736         *wait = wait_time * NANOSECONDS_PER_SECOND;
3737     }
3738 
3739     return true;
3740 }
3741 
3742 static bool bdrv_exceed_io_limits(BlockDriverState *bs, int nb_sectors,
3743                            bool is_write, int64_t *wait)
3744 {
3745     int64_t  now, max_wait;
3746     uint64_t bps_wait = 0, iops_wait = 0;
3747     double   elapsed_time;
3748     int      bps_ret, iops_ret;
3749 
3750     now = qemu_get_clock_ns(vm_clock);
3751     if (now > bs->slice_end) {
3752         bs->slice_start = now;
3753         bs->slice_end   = now + BLOCK_IO_SLICE_TIME;
3754         memset(&bs->slice_submitted, 0, sizeof(bs->slice_submitted));
3755     }
3756 
3757     elapsed_time  = now - bs->slice_start;
3758     elapsed_time  /= (NANOSECONDS_PER_SECOND);
3759 
3760     bps_ret  = bdrv_exceed_bps_limits(bs, nb_sectors,
3761                                       is_write, elapsed_time, &bps_wait);
3762     iops_ret = bdrv_exceed_iops_limits(bs, is_write,
3763                                       elapsed_time, &iops_wait);
3764     if (bps_ret || iops_ret) {
3765         max_wait = bps_wait > iops_wait ? bps_wait : iops_wait;
3766         if (wait) {
3767             *wait = max_wait;
3768         }
3769 
3770         now = qemu_get_clock_ns(vm_clock);
3771         if (bs->slice_end < now + max_wait) {
3772             bs->slice_end = now + max_wait;
3773         }
3774 
3775         return true;
3776     }
3777 
3778     if (wait) {
3779         *wait = 0;
3780     }
3781 
3782     bs->slice_submitted.bytes[is_write] += (int64_t)nb_sectors *
3783                                            BDRV_SECTOR_SIZE;
3784     bs->slice_submitted.ios[is_write]++;
3785 
3786     return false;
3787 }
3788 
3789 /**************************************************************/
3790 /* async block device emulation */
3791 
3792 typedef struct BlockDriverAIOCBSync {
3793     BlockDriverAIOCB common;
3794     QEMUBH *bh;
3795     int ret;
3796     /* vector translation state */
3797     QEMUIOVector *qiov;
3798     uint8_t *bounce;
3799     int is_write;
3800 } BlockDriverAIOCBSync;
3801 
3802 static void bdrv_aio_cancel_em(BlockDriverAIOCB *blockacb)
3803 {
3804     BlockDriverAIOCBSync *acb =
3805         container_of(blockacb, BlockDriverAIOCBSync, common);
3806     qemu_bh_delete(acb->bh);
3807     acb->bh = NULL;
3808     qemu_aio_release(acb);
3809 }
3810 
3811 static const AIOCBInfo bdrv_em_aiocb_info = {
3812     .aiocb_size         = sizeof(BlockDriverAIOCBSync),
3813     .cancel             = bdrv_aio_cancel_em,
3814 };
3815 
3816 static void bdrv_aio_bh_cb(void *opaque)
3817 {
3818     BlockDriverAIOCBSync *acb = opaque;
3819 
3820     if (!acb->is_write)
3821         qemu_iovec_from_buf(acb->qiov, 0, acb->bounce, acb->qiov->size);
3822     qemu_vfree(acb->bounce);
3823     acb->common.cb(acb->common.opaque, acb->ret);
3824     qemu_bh_delete(acb->bh);
3825     acb->bh = NULL;
3826     qemu_aio_release(acb);
3827 }
3828 
3829 static BlockDriverAIOCB *bdrv_aio_rw_vector(BlockDriverState *bs,
3830                                             int64_t sector_num,
3831                                             QEMUIOVector *qiov,
3832                                             int nb_sectors,
3833                                             BlockDriverCompletionFunc *cb,
3834                                             void *opaque,
3835                                             int is_write)
3836 
3837 {
3838     BlockDriverAIOCBSync *acb;
3839 
3840     acb = qemu_aio_get(&bdrv_em_aiocb_info, bs, cb, opaque);
3841     acb->is_write = is_write;
3842     acb->qiov = qiov;
3843     acb->bounce = qemu_blockalign(bs, qiov->size);
3844     acb->bh = qemu_bh_new(bdrv_aio_bh_cb, acb);
3845 
3846     if (is_write) {
3847         qemu_iovec_to_buf(acb->qiov, 0, acb->bounce, qiov->size);
3848         acb->ret = bs->drv->bdrv_write(bs, sector_num, acb->bounce, nb_sectors);
3849     } else {
3850         acb->ret = bs->drv->bdrv_read(bs, sector_num, acb->bounce, nb_sectors);
3851     }
3852 
3853     qemu_bh_schedule(acb->bh);
3854 
3855     return &acb->common;
3856 }
3857 
3858 static BlockDriverAIOCB *bdrv_aio_readv_em(BlockDriverState *bs,
3859         int64_t sector_num, QEMUIOVector *qiov, int nb_sectors,
3860         BlockDriverCompletionFunc *cb, void *opaque)
3861 {
3862     return bdrv_aio_rw_vector(bs, sector_num, qiov, nb_sectors, cb, opaque, 0);
3863 }
3864 
3865 static BlockDriverAIOCB *bdrv_aio_writev_em(BlockDriverState *bs,
3866         int64_t sector_num, QEMUIOVector *qiov, int nb_sectors,
3867         BlockDriverCompletionFunc *cb, void *opaque)
3868 {
3869     return bdrv_aio_rw_vector(bs, sector_num, qiov, nb_sectors, cb, opaque, 1);
3870 }
3871 
3872 
3873 typedef struct BlockDriverAIOCBCoroutine {
3874     BlockDriverAIOCB common;
3875     BlockRequest req;
3876     bool is_write;
3877     bool *done;
3878     QEMUBH* bh;
3879 } BlockDriverAIOCBCoroutine;
3880 
3881 static void bdrv_aio_co_cancel_em(BlockDriverAIOCB *blockacb)
3882 {
3883     BlockDriverAIOCBCoroutine *acb =
3884         container_of(blockacb, BlockDriverAIOCBCoroutine, common);
3885     bool done = false;
3886 
3887     acb->done = &done;
3888     while (!done) {
3889         qemu_aio_wait();
3890     }
3891 }
3892 
3893 static const AIOCBInfo bdrv_em_co_aiocb_info = {
3894     .aiocb_size         = sizeof(BlockDriverAIOCBCoroutine),
3895     .cancel             = bdrv_aio_co_cancel_em,
3896 };
3897 
3898 static void bdrv_co_em_bh(void *opaque)
3899 {
3900     BlockDriverAIOCBCoroutine *acb = opaque;
3901 
3902     acb->common.cb(acb->common.opaque, acb->req.error);
3903 
3904     if (acb->done) {
3905         *acb->done = true;
3906     }
3907 
3908     qemu_bh_delete(acb->bh);
3909     qemu_aio_release(acb);
3910 }
3911 
3912 /* Invoke bdrv_co_do_readv/bdrv_co_do_writev */
3913 static void coroutine_fn bdrv_co_do_rw(void *opaque)
3914 {
3915     BlockDriverAIOCBCoroutine *acb = opaque;
3916     BlockDriverState *bs = acb->common.bs;
3917 
3918     if (!acb->is_write) {
3919         acb->req.error = bdrv_co_do_readv(bs, acb->req.sector,
3920             acb->req.nb_sectors, acb->req.qiov, 0);
3921     } else {
3922         acb->req.error = bdrv_co_do_writev(bs, acb->req.sector,
3923             acb->req.nb_sectors, acb->req.qiov, 0);
3924     }
3925 
3926     acb->bh = qemu_bh_new(bdrv_co_em_bh, acb);
3927     qemu_bh_schedule(acb->bh);
3928 }
3929 
3930 static BlockDriverAIOCB *bdrv_co_aio_rw_vector(BlockDriverState *bs,
3931                                                int64_t sector_num,
3932                                                QEMUIOVector *qiov,
3933                                                int nb_sectors,
3934                                                BlockDriverCompletionFunc *cb,
3935                                                void *opaque,
3936                                                bool is_write)
3937 {
3938     Coroutine *co;
3939     BlockDriverAIOCBCoroutine *acb;
3940 
3941     acb = qemu_aio_get(&bdrv_em_co_aiocb_info, bs, cb, opaque);
3942     acb->req.sector = sector_num;
3943     acb->req.nb_sectors = nb_sectors;
3944     acb->req.qiov = qiov;
3945     acb->is_write = is_write;
3946     acb->done = NULL;
3947 
3948     co = qemu_coroutine_create(bdrv_co_do_rw);
3949     qemu_coroutine_enter(co, acb);
3950 
3951     return &acb->common;
3952 }
3953 
3954 static void coroutine_fn bdrv_aio_flush_co_entry(void *opaque)
3955 {
3956     BlockDriverAIOCBCoroutine *acb = opaque;
3957     BlockDriverState *bs = acb->common.bs;
3958 
3959     acb->req.error = bdrv_co_flush(bs);
3960     acb->bh = qemu_bh_new(bdrv_co_em_bh, acb);
3961     qemu_bh_schedule(acb->bh);
3962 }
3963 
3964 BlockDriverAIOCB *bdrv_aio_flush(BlockDriverState *bs,
3965         BlockDriverCompletionFunc *cb, void *opaque)
3966 {
3967     trace_bdrv_aio_flush(bs, opaque);
3968 
3969     Coroutine *co;
3970     BlockDriverAIOCBCoroutine *acb;
3971 
3972     acb = qemu_aio_get(&bdrv_em_co_aiocb_info, bs, cb, opaque);
3973     acb->done = NULL;
3974 
3975     co = qemu_coroutine_create(bdrv_aio_flush_co_entry);
3976     qemu_coroutine_enter(co, acb);
3977 
3978     return &acb->common;
3979 }
3980 
3981 static void coroutine_fn bdrv_aio_discard_co_entry(void *opaque)
3982 {
3983     BlockDriverAIOCBCoroutine *acb = opaque;
3984     BlockDriverState *bs = acb->common.bs;
3985 
3986     acb->req.error = bdrv_co_discard(bs, acb->req.sector, acb->req.nb_sectors);
3987     acb->bh = qemu_bh_new(bdrv_co_em_bh, acb);
3988     qemu_bh_schedule(acb->bh);
3989 }
3990 
3991 BlockDriverAIOCB *bdrv_aio_discard(BlockDriverState *bs,
3992         int64_t sector_num, int nb_sectors,
3993         BlockDriverCompletionFunc *cb, void *opaque)
3994 {
3995     Coroutine *co;
3996     BlockDriverAIOCBCoroutine *acb;
3997 
3998     trace_bdrv_aio_discard(bs, sector_num, nb_sectors, opaque);
3999 
4000     acb = qemu_aio_get(&bdrv_em_co_aiocb_info, bs, cb, opaque);
4001     acb->req.sector = sector_num;
4002     acb->req.nb_sectors = nb_sectors;
4003     acb->done = NULL;
4004     co = qemu_coroutine_create(bdrv_aio_discard_co_entry);
4005     qemu_coroutine_enter(co, acb);
4006 
4007     return &acb->common;
4008 }
4009 
4010 void bdrv_init(void)
4011 {
4012     module_call_init(MODULE_INIT_BLOCK);
4013 }
4014 
4015 void bdrv_init_with_whitelist(void)
4016 {
4017     use_bdrv_whitelist = 1;
4018     bdrv_init();
4019 }
4020 
4021 void *qemu_aio_get(const AIOCBInfo *aiocb_info, BlockDriverState *bs,
4022                    BlockDriverCompletionFunc *cb, void *opaque)
4023 {
4024     BlockDriverAIOCB *acb;
4025 
4026     acb = g_slice_alloc(aiocb_info->aiocb_size);
4027     acb->aiocb_info = aiocb_info;
4028     acb->bs = bs;
4029     acb->cb = cb;
4030     acb->opaque = opaque;
4031     return acb;
4032 }
4033 
4034 void qemu_aio_release(void *p)
4035 {
4036     BlockDriverAIOCB *acb = p;
4037     g_slice_free1(acb->aiocb_info->aiocb_size, acb);
4038 }
4039 
4040 /**************************************************************/
4041 /* Coroutine block device emulation */
4042 
4043 typedef struct CoroutineIOCompletion {
4044     Coroutine *coroutine;
4045     int ret;
4046 } CoroutineIOCompletion;
4047 
4048 static void bdrv_co_io_em_complete(void *opaque, int ret)
4049 {
4050     CoroutineIOCompletion *co = opaque;
4051 
4052     co->ret = ret;
4053     qemu_coroutine_enter(co->coroutine, NULL);
4054 }
4055 
4056 static int coroutine_fn bdrv_co_io_em(BlockDriverState *bs, int64_t sector_num,
4057                                       int nb_sectors, QEMUIOVector *iov,
4058                                       bool is_write)
4059 {
4060     CoroutineIOCompletion co = {
4061         .coroutine = qemu_coroutine_self(),
4062     };
4063     BlockDriverAIOCB *acb;
4064 
4065     if (is_write) {
4066         acb = bs->drv->bdrv_aio_writev(bs, sector_num, iov, nb_sectors,
4067                                        bdrv_co_io_em_complete, &co);
4068     } else {
4069         acb = bs->drv->bdrv_aio_readv(bs, sector_num, iov, nb_sectors,
4070                                       bdrv_co_io_em_complete, &co);
4071     }
4072 
4073     trace_bdrv_co_io_em(bs, sector_num, nb_sectors, is_write, acb);
4074     if (!acb) {
4075         return -EIO;
4076     }
4077     qemu_coroutine_yield();
4078 
4079     return co.ret;
4080 }
4081 
4082 static int coroutine_fn bdrv_co_readv_em(BlockDriverState *bs,
4083                                          int64_t sector_num, int nb_sectors,
4084                                          QEMUIOVector *iov)
4085 {
4086     return bdrv_co_io_em(bs, sector_num, nb_sectors, iov, false);
4087 }
4088 
4089 static int coroutine_fn bdrv_co_writev_em(BlockDriverState *bs,
4090                                          int64_t sector_num, int nb_sectors,
4091                                          QEMUIOVector *iov)
4092 {
4093     return bdrv_co_io_em(bs, sector_num, nb_sectors, iov, true);
4094 }
4095 
4096 static void coroutine_fn bdrv_flush_co_entry(void *opaque)
4097 {
4098     RwCo *rwco = opaque;
4099 
4100     rwco->ret = bdrv_co_flush(rwco->bs);
4101 }
4102 
4103 int coroutine_fn bdrv_co_flush(BlockDriverState *bs)
4104 {
4105     int ret;
4106 
4107     if (!bs || !bdrv_is_inserted(bs) || bdrv_is_read_only(bs)) {
4108         return 0;
4109     }
4110 
4111     /* Write back cached data to the OS even with cache=unsafe */
4112     BLKDBG_EVENT(bs->file, BLKDBG_FLUSH_TO_OS);
4113     if (bs->drv->bdrv_co_flush_to_os) {
4114         ret = bs->drv->bdrv_co_flush_to_os(bs);
4115         if (ret < 0) {
4116             return ret;
4117         }
4118     }
4119 
4120     /* But don't actually force it to the disk with cache=unsafe */
4121     if (bs->open_flags & BDRV_O_NO_FLUSH) {
4122         goto flush_parent;
4123     }
4124 
4125     BLKDBG_EVENT(bs->file, BLKDBG_FLUSH_TO_DISK);
4126     if (bs->drv->bdrv_co_flush_to_disk) {
4127         ret = bs->drv->bdrv_co_flush_to_disk(bs);
4128     } else if (bs->drv->bdrv_aio_flush) {
4129         BlockDriverAIOCB *acb;
4130         CoroutineIOCompletion co = {
4131             .coroutine = qemu_coroutine_self(),
4132         };
4133 
4134         acb = bs->drv->bdrv_aio_flush(bs, bdrv_co_io_em_complete, &co);
4135         if (acb == NULL) {
4136             ret = -EIO;
4137         } else {
4138             qemu_coroutine_yield();
4139             ret = co.ret;
4140         }
4141     } else {
4142         /*
4143          * Some block drivers always operate in either writethrough or unsafe
4144          * mode and don't support bdrv_flush therefore. Usually qemu doesn't
4145          * know how the server works (because the behaviour is hardcoded or
4146          * depends on server-side configuration), so we can't ensure that
4147          * everything is safe on disk. Returning an error doesn't work because
4148          * that would break guests even if the server operates in writethrough
4149          * mode.
4150          *
4151          * Let's hope the user knows what he's doing.
4152          */
4153         ret = 0;
4154     }
4155     if (ret < 0) {
4156         return ret;
4157     }
4158 
4159     /* Now flush the underlying protocol.  It will also have BDRV_O_NO_FLUSH
4160      * in the case of cache=unsafe, so there are no useless flushes.
4161      */
4162 flush_parent:
4163     return bdrv_co_flush(bs->file);
4164 }
4165 
4166 void bdrv_invalidate_cache(BlockDriverState *bs)
4167 {
4168     if (bs->drv && bs->drv->bdrv_invalidate_cache) {
4169         bs->drv->bdrv_invalidate_cache(bs);
4170     }
4171 }
4172 
4173 void bdrv_invalidate_cache_all(void)
4174 {
4175     BlockDriverState *bs;
4176 
4177     QTAILQ_FOREACH(bs, &bdrv_states, list) {
4178         bdrv_invalidate_cache(bs);
4179     }
4180 }
4181 
4182 void bdrv_clear_incoming_migration_all(void)
4183 {
4184     BlockDriverState *bs;
4185 
4186     QTAILQ_FOREACH(bs, &bdrv_states, list) {
4187         bs->open_flags = bs->open_flags & ~(BDRV_O_INCOMING);
4188     }
4189 }
4190 
4191 int bdrv_flush(BlockDriverState *bs)
4192 {
4193     Coroutine *co;
4194     RwCo rwco = {
4195         .bs = bs,
4196         .ret = NOT_DONE,
4197     };
4198 
4199     if (qemu_in_coroutine()) {
4200         /* Fast-path if already in coroutine context */
4201         bdrv_flush_co_entry(&rwco);
4202     } else {
4203         co = qemu_coroutine_create(bdrv_flush_co_entry);
4204         qemu_coroutine_enter(co, &rwco);
4205         while (rwco.ret == NOT_DONE) {
4206             qemu_aio_wait();
4207         }
4208     }
4209 
4210     return rwco.ret;
4211 }
4212 
4213 static void coroutine_fn bdrv_discard_co_entry(void *opaque)
4214 {
4215     RwCo *rwco = opaque;
4216 
4217     rwco->ret = bdrv_co_discard(rwco->bs, rwco->sector_num, rwco->nb_sectors);
4218 }
4219 
4220 int coroutine_fn bdrv_co_discard(BlockDriverState *bs, int64_t sector_num,
4221                                  int nb_sectors)
4222 {
4223     if (!bs->drv) {
4224         return -ENOMEDIUM;
4225     } else if (bdrv_check_request(bs, sector_num, nb_sectors)) {
4226         return -EIO;
4227     } else if (bs->read_only) {
4228         return -EROFS;
4229     }
4230 
4231     if (bs->dirty_bitmap) {
4232         bdrv_reset_dirty(bs, sector_num, nb_sectors);
4233     }
4234 
4235     /* Do nothing if disabled.  */
4236     if (!(bs->open_flags & BDRV_O_UNMAP)) {
4237         return 0;
4238     }
4239 
4240     if (bs->drv->bdrv_co_discard) {
4241         return bs->drv->bdrv_co_discard(bs, sector_num, nb_sectors);
4242     } else if (bs->drv->bdrv_aio_discard) {
4243         BlockDriverAIOCB *acb;
4244         CoroutineIOCompletion co = {
4245             .coroutine = qemu_coroutine_self(),
4246         };
4247 
4248         acb = bs->drv->bdrv_aio_discard(bs, sector_num, nb_sectors,
4249                                         bdrv_co_io_em_complete, &co);
4250         if (acb == NULL) {
4251             return -EIO;
4252         } else {
4253             qemu_coroutine_yield();
4254             return co.ret;
4255         }
4256     } else {
4257         return 0;
4258     }
4259 }
4260 
4261 int bdrv_discard(BlockDriverState *bs, int64_t sector_num, int nb_sectors)
4262 {
4263     Coroutine *co;
4264     RwCo rwco = {
4265         .bs = bs,
4266         .sector_num = sector_num,
4267         .nb_sectors = nb_sectors,
4268         .ret = NOT_DONE,
4269     };
4270 
4271     if (qemu_in_coroutine()) {
4272         /* Fast-path if already in coroutine context */
4273         bdrv_discard_co_entry(&rwco);
4274     } else {
4275         co = qemu_coroutine_create(bdrv_discard_co_entry);
4276         qemu_coroutine_enter(co, &rwco);
4277         while (rwco.ret == NOT_DONE) {
4278             qemu_aio_wait();
4279         }
4280     }
4281 
4282     return rwco.ret;
4283 }
4284 
4285 /**************************************************************/
4286 /* removable device support */
4287 
4288 /**
4289  * Return TRUE if the media is present
4290  */
4291 int bdrv_is_inserted(BlockDriverState *bs)
4292 {
4293     BlockDriver *drv = bs->drv;
4294 
4295     if (!drv)
4296         return 0;
4297     if (!drv->bdrv_is_inserted)
4298         return 1;
4299     return drv->bdrv_is_inserted(bs);
4300 }
4301 
4302 /**
4303  * Return whether the media changed since the last call to this
4304  * function, or -ENOTSUP if we don't know.  Most drivers don't know.
4305  */
4306 int bdrv_media_changed(BlockDriverState *bs)
4307 {
4308     BlockDriver *drv = bs->drv;
4309 
4310     if (drv && drv->bdrv_media_changed) {
4311         return drv->bdrv_media_changed(bs);
4312     }
4313     return -ENOTSUP;
4314 }
4315 
4316 /**
4317  * If eject_flag is TRUE, eject the media. Otherwise, close the tray
4318  */
4319 void bdrv_eject(BlockDriverState *bs, bool eject_flag)
4320 {
4321     BlockDriver *drv = bs->drv;
4322 
4323     if (drv && drv->bdrv_eject) {
4324         drv->bdrv_eject(bs, eject_flag);
4325     }
4326 
4327     if (bs->device_name[0] != '\0') {
4328         bdrv_emit_qmp_eject_event(bs, eject_flag);
4329     }
4330 }
4331 
4332 /**
4333  * Lock or unlock the media (if it is locked, the user won't be able
4334  * to eject it manually).
4335  */
4336 void bdrv_lock_medium(BlockDriverState *bs, bool locked)
4337 {
4338     BlockDriver *drv = bs->drv;
4339 
4340     trace_bdrv_lock_medium(bs, locked);
4341 
4342     if (drv && drv->bdrv_lock_medium) {
4343         drv->bdrv_lock_medium(bs, locked);
4344     }
4345 }
4346 
4347 /* needed for generic scsi interface */
4348 
4349 int bdrv_ioctl(BlockDriverState *bs, unsigned long int req, void *buf)
4350 {
4351     BlockDriver *drv = bs->drv;
4352 
4353     if (drv && drv->bdrv_ioctl)
4354         return drv->bdrv_ioctl(bs, req, buf);
4355     return -ENOTSUP;
4356 }
4357 
4358 BlockDriverAIOCB *bdrv_aio_ioctl(BlockDriverState *bs,
4359         unsigned long int req, void *buf,
4360         BlockDriverCompletionFunc *cb, void *opaque)
4361 {
4362     BlockDriver *drv = bs->drv;
4363 
4364     if (drv && drv->bdrv_aio_ioctl)
4365         return drv->bdrv_aio_ioctl(bs, req, buf, cb, opaque);
4366     return NULL;
4367 }
4368 
4369 void bdrv_set_buffer_alignment(BlockDriverState *bs, int align)
4370 {
4371     bs->buffer_alignment = align;
4372 }
4373 
4374 void *qemu_blockalign(BlockDriverState *bs, size_t size)
4375 {
4376     return qemu_memalign((bs && bs->buffer_alignment) ? bs->buffer_alignment : 512, size);
4377 }
4378 
4379 /*
4380  * Check if all memory in this vector is sector aligned.
4381  */
4382 bool bdrv_qiov_is_aligned(BlockDriverState *bs, QEMUIOVector *qiov)
4383 {
4384     int i;
4385 
4386     for (i = 0; i < qiov->niov; i++) {
4387         if ((uintptr_t) qiov->iov[i].iov_base % bs->buffer_alignment) {
4388             return false;
4389         }
4390     }
4391 
4392     return true;
4393 }
4394 
4395 void bdrv_set_dirty_tracking(BlockDriverState *bs, int granularity)
4396 {
4397     int64_t bitmap_size;
4398 
4399     assert((granularity & (granularity - 1)) == 0);
4400 
4401     if (granularity) {
4402         granularity >>= BDRV_SECTOR_BITS;
4403         assert(!bs->dirty_bitmap);
4404         bitmap_size = (bdrv_getlength(bs) >> BDRV_SECTOR_BITS);
4405         bs->dirty_bitmap = hbitmap_alloc(bitmap_size, ffs(granularity) - 1);
4406     } else {
4407         if (bs->dirty_bitmap) {
4408             hbitmap_free(bs->dirty_bitmap);
4409             bs->dirty_bitmap = NULL;
4410         }
4411     }
4412 }
4413 
4414 int bdrv_get_dirty(BlockDriverState *bs, int64_t sector)
4415 {
4416     if (bs->dirty_bitmap) {
4417         return hbitmap_get(bs->dirty_bitmap, sector);
4418     } else {
4419         return 0;
4420     }
4421 }
4422 
4423 void bdrv_dirty_iter_init(BlockDriverState *bs, HBitmapIter *hbi)
4424 {
4425     hbitmap_iter_init(hbi, bs->dirty_bitmap, 0);
4426 }
4427 
4428 void bdrv_set_dirty(BlockDriverState *bs, int64_t cur_sector,
4429                     int nr_sectors)
4430 {
4431     hbitmap_set(bs->dirty_bitmap, cur_sector, nr_sectors);
4432 }
4433 
4434 void bdrv_reset_dirty(BlockDriverState *bs, int64_t cur_sector,
4435                       int nr_sectors)
4436 {
4437     hbitmap_reset(bs->dirty_bitmap, cur_sector, nr_sectors);
4438 }
4439 
4440 int64_t bdrv_get_dirty_count(BlockDriverState *bs)
4441 {
4442     if (bs->dirty_bitmap) {
4443         return hbitmap_count(bs->dirty_bitmap);
4444     } else {
4445         return 0;
4446     }
4447 }
4448 
4449 void bdrv_set_in_use(BlockDriverState *bs, int in_use)
4450 {
4451     assert(bs->in_use != in_use);
4452     bs->in_use = in_use;
4453 }
4454 
4455 int bdrv_in_use(BlockDriverState *bs)
4456 {
4457     return bs->in_use;
4458 }
4459 
4460 void bdrv_iostatus_enable(BlockDriverState *bs)
4461 {
4462     bs->iostatus_enabled = true;
4463     bs->iostatus = BLOCK_DEVICE_IO_STATUS_OK;
4464 }
4465 
4466 /* The I/O status is only enabled if the drive explicitly
4467  * enables it _and_ the VM is configured to stop on errors */
4468 bool bdrv_iostatus_is_enabled(const BlockDriverState *bs)
4469 {
4470     return (bs->iostatus_enabled &&
4471            (bs->on_write_error == BLOCKDEV_ON_ERROR_ENOSPC ||
4472             bs->on_write_error == BLOCKDEV_ON_ERROR_STOP   ||
4473             bs->on_read_error == BLOCKDEV_ON_ERROR_STOP));
4474 }
4475 
4476 void bdrv_iostatus_disable(BlockDriverState *bs)
4477 {
4478     bs->iostatus_enabled = false;
4479 }
4480 
4481 void bdrv_iostatus_reset(BlockDriverState *bs)
4482 {
4483     if (bdrv_iostatus_is_enabled(bs)) {
4484         bs->iostatus = BLOCK_DEVICE_IO_STATUS_OK;
4485         if (bs->job) {
4486             block_job_iostatus_reset(bs->job);
4487         }
4488     }
4489 }
4490 
4491 void bdrv_iostatus_set_err(BlockDriverState *bs, int error)
4492 {
4493     assert(bdrv_iostatus_is_enabled(bs));
4494     if (bs->iostatus == BLOCK_DEVICE_IO_STATUS_OK) {
4495         bs->iostatus = error == ENOSPC ? BLOCK_DEVICE_IO_STATUS_NOSPACE :
4496                                          BLOCK_DEVICE_IO_STATUS_FAILED;
4497     }
4498 }
4499 
4500 void
4501 bdrv_acct_start(BlockDriverState *bs, BlockAcctCookie *cookie, int64_t bytes,
4502         enum BlockAcctType type)
4503 {
4504     assert(type < BDRV_MAX_IOTYPE);
4505 
4506     cookie->bytes = bytes;
4507     cookie->start_time_ns = get_clock();
4508     cookie->type = type;
4509 }
4510 
4511 void
4512 bdrv_acct_done(BlockDriverState *bs, BlockAcctCookie *cookie)
4513 {
4514     assert(cookie->type < BDRV_MAX_IOTYPE);
4515 
4516     bs->nr_bytes[cookie->type] += cookie->bytes;
4517     bs->nr_ops[cookie->type]++;
4518     bs->total_time_ns[cookie->type] += get_clock() - cookie->start_time_ns;
4519 }
4520 
4521 void bdrv_img_create(const char *filename, const char *fmt,
4522                      const char *base_filename, const char *base_fmt,
4523                      char *options, uint64_t img_size, int flags,
4524                      Error **errp, bool quiet)
4525 {
4526     QEMUOptionParameter *param = NULL, *create_options = NULL;
4527     QEMUOptionParameter *backing_fmt, *backing_file, *size;
4528     BlockDriverState *bs = NULL;
4529     BlockDriver *drv, *proto_drv;
4530     BlockDriver *backing_drv = NULL;
4531     int ret = 0;
4532 
4533     /* Find driver and parse its options */
4534     drv = bdrv_find_format(fmt);
4535     if (!drv) {
4536         error_setg(errp, "Unknown file format '%s'", fmt);
4537         return;
4538     }
4539 
4540     proto_drv = bdrv_find_protocol(filename, true);
4541     if (!proto_drv) {
4542         error_setg(errp, "Unknown protocol '%s'", filename);
4543         return;
4544     }
4545 
4546     create_options = append_option_parameters(create_options,
4547                                               drv->create_options);
4548     create_options = append_option_parameters(create_options,
4549                                               proto_drv->create_options);
4550 
4551     /* Create parameter list with default values */
4552     param = parse_option_parameters("", create_options, param);
4553 
4554     set_option_parameter_int(param, BLOCK_OPT_SIZE, img_size);
4555 
4556     /* Parse -o options */
4557     if (options) {
4558         param = parse_option_parameters(options, create_options, param);
4559         if (param == NULL) {
4560             error_setg(errp, "Invalid options for file format '%s'.", fmt);
4561             goto out;
4562         }
4563     }
4564 
4565     if (base_filename) {
4566         if (set_option_parameter(param, BLOCK_OPT_BACKING_FILE,
4567                                  base_filename)) {
4568             error_setg(errp, "Backing file not supported for file format '%s'",
4569                        fmt);
4570             goto out;
4571         }
4572     }
4573 
4574     if (base_fmt) {
4575         if (set_option_parameter(param, BLOCK_OPT_BACKING_FMT, base_fmt)) {
4576             error_setg(errp, "Backing file format not supported for file "
4577                              "format '%s'", fmt);
4578             goto out;
4579         }
4580     }
4581 
4582     backing_file = get_option_parameter(param, BLOCK_OPT_BACKING_FILE);
4583     if (backing_file && backing_file->value.s) {
4584         if (!strcmp(filename, backing_file->value.s)) {
4585             error_setg(errp, "Error: Trying to create an image with the "
4586                              "same filename as the backing file");
4587             goto out;
4588         }
4589     }
4590 
4591     backing_fmt = get_option_parameter(param, BLOCK_OPT_BACKING_FMT);
4592     if (backing_fmt && backing_fmt->value.s) {
4593         backing_drv = bdrv_find_format(backing_fmt->value.s);
4594         if (!backing_drv) {
4595             error_setg(errp, "Unknown backing file format '%s'",
4596                        backing_fmt->value.s);
4597             goto out;
4598         }
4599     }
4600 
4601     // The size for the image must always be specified, with one exception:
4602     // If we are using a backing file, we can obtain the size from there
4603     size = get_option_parameter(param, BLOCK_OPT_SIZE);
4604     if (size && size->value.n == -1) {
4605         if (backing_file && backing_file->value.s) {
4606             uint64_t size;
4607             char buf[32];
4608             int back_flags;
4609 
4610             /* backing files always opened read-only */
4611             back_flags =
4612                 flags & ~(BDRV_O_RDWR | BDRV_O_SNAPSHOT | BDRV_O_NO_BACKING);
4613 
4614             bs = bdrv_new("");
4615 
4616             ret = bdrv_open(bs, backing_file->value.s, NULL, back_flags,
4617                             backing_drv);
4618             if (ret < 0) {
4619                 error_setg_errno(errp, -ret, "Could not open '%s'",
4620                                  backing_file->value.s);
4621                 goto out;
4622             }
4623             bdrv_get_geometry(bs, &size);
4624             size *= 512;
4625 
4626             snprintf(buf, sizeof(buf), "%" PRId64, size);
4627             set_option_parameter(param, BLOCK_OPT_SIZE, buf);
4628         } else {
4629             error_setg(errp, "Image creation needs a size parameter");
4630             goto out;
4631         }
4632     }
4633 
4634     if (!quiet) {
4635         printf("Formatting '%s', fmt=%s ", filename, fmt);
4636         print_option_parameters(param);
4637         puts("");
4638     }
4639     ret = bdrv_create(drv, filename, param);
4640     if (ret < 0) {
4641         if (ret == -ENOTSUP) {
4642             error_setg(errp,"Formatting or formatting option not supported for "
4643                             "file format '%s'", fmt);
4644         } else if (ret == -EFBIG) {
4645             const char *cluster_size_hint = "";
4646             if (get_option_parameter(create_options, BLOCK_OPT_CLUSTER_SIZE)) {
4647                 cluster_size_hint = " (try using a larger cluster size)";
4648             }
4649             error_setg(errp, "The image size is too large for file format '%s'%s",
4650                        fmt, cluster_size_hint);
4651         } else {
4652             error_setg(errp, "%s: error while creating %s: %s", filename, fmt,
4653                        strerror(-ret));
4654         }
4655     }
4656 
4657 out:
4658     free_option_parameters(create_options);
4659     free_option_parameters(param);
4660 
4661     if (bs) {
4662         bdrv_delete(bs);
4663     }
4664 }
4665 
4666 AioContext *bdrv_get_aio_context(BlockDriverState *bs)
4667 {
4668     /* Currently BlockDriverState always uses the main loop AioContext */
4669     return qemu_get_aio_context();
4670 }
4671 
4672 void bdrv_add_before_write_notifier(BlockDriverState *bs,
4673                                     NotifierWithReturn *notifier)
4674 {
4675     notifier_with_return_list_add(&bs->before_write_notifiers, notifier);
4676 }
4677