]> www.infradead.org Git - users/dwmw2/qemu.git/commitdiff
include/block/block_int: Document protocol related functions
authorFabiano Rosas <farosas@linux.vnet.ibm.com>
Mon, 12 Mar 2018 22:07:53 +0000 (19:07 -0300)
committerKevin Wolf <kwolf@redhat.com>
Mon, 26 Mar 2018 10:16:00 +0000 (12:16 +0200)
Clarify that:

- for protocols the brdv_file_open function is used instead
of bdrv_open;

- when protocol_name is set, a driver should expect
to be given only a filename and no other options.

Signed-off-by: Fabiano Rosas <farosas@linux.vnet.ibm.com>
Signed-off-by: Kevin Wolf <kwolf@redhat.com>
include/block/block_int.h

index 27e17addba95cf4ae908ff02bb2bbbbecde7962d..c4dd1d4bb8ac644cd5279bedd9688742b1704b17 100644 (file)
@@ -126,6 +126,8 @@ struct BlockDriver {
 
     int (*bdrv_open)(BlockDriverState *bs, QDict *options, int flags,
                      Error **errp);
+
+    /* Protocol drivers should implement this instead of bdrv_open */
     int (*bdrv_file_open)(BlockDriverState *bs, QDict *options, int flags,
                           Error **errp);
     void (*bdrv_close)(BlockDriverState *bs);
@@ -251,6 +253,12 @@ struct BlockDriver {
      */
     int coroutine_fn (*bdrv_co_flush_to_os)(BlockDriverState *bs);
 
+    /*
+     * Drivers setting this field must be able to work with just a plain
+     * filename with '<protocol_name>:' as a prefix, and no other options.
+     * Options may be extracted from the filename by implementing
+     * bdrv_parse_filename.
+     */
     const char *protocol_name;
     int (*bdrv_truncate)(BlockDriverState *bs, int64_t offset,
                          PreallocMode prealloc, Error **errp);