Tuan Hoang
2019-Nov-05 08:49 UTC
[Libguestfs] [PATCH v2 RESEND] direct, fish: add command launch_blocksize
Add a new launch command for direct backend, which allows specifying the blocksize to the disks. The name is `launch_blocksize`, accompanied alias is `run-blocksize`. Example: $ guestfish --listen -a raw.img $ guestfish --remote -- launch_blocksize 4096 The actual qemu command is: [...] -device virtio-scsi-ccw,id=scsi -drive file=raw.img,cache=writeback,id=hd0,if=none -device scsi-hd,drive=hd0,physical_block_size=4096,logical_block_size=4096 [...] Ideally it would be better to invoke optional option to `launch` command like: $ guestfish --remote -- launch --blocksize 4096 Signed-off-by: Tuan Hoang <tmhoang@linux.ibm.com> --- generator/actions_core.ml | 11 +++++++++++ lib/guestfs-internal.h | 3 +++ lib/launch-direct.c | 6 ++++++ lib/launch.c | 14 ++++++++++++++ 4 files changed, 34 insertions(+) diff --git a/generator/actions_core.ml b/generator/actions_core.ml index 7b6568b..cfe735a 100644 --- a/generator/actions_core.ml +++ b/generator/actions_core.ml @@ -38,6 +38,17 @@ it will not give an error (for historical reasons), the precise behaviour when you do this is not well defined. Handles are very cheap to create, so create a new one for each launch." }; + { defaults with + name = "launch_blocksize"; added = (1, 40, 2); + style = RErr, [Int "blocksize"], []; + fish_alias = ["run-blocksize"]; progress = true; config_only = true; + shortdesc = "launch the backend with blocksize for disks"; + longdesc = "\ +Similar to \"launch\" call, but requires an integer as blocksize for disks. + +A call of \"launch_blocksize 512\" is equivalent of \"launch\" since the +default blocksize for qemu is 512." }; + { defaults with name = "add_drive_ro"; added = (1, 0, 38); style = RErr, [String (PlainString, "filename")], []; diff --git a/lib/guestfs-internal.h b/lib/guestfs-internal.h index 75b8a5c..e9b7057 100644 --- a/lib/guestfs-internal.h +++ b/lib/guestfs-internal.h @@ -513,6 +513,9 @@ struct guestfs_h { /* Used by lib/info.c. -1 = not tested or error; else 0 or 1. */ int qemu_img_supports_U_option; + + /* Used by guestfish's launch_blocksize call */ + int blocksize; }; /** diff --git a/lib/launch-direct.c b/lib/launch-direct.c index ee2dcb8..54cd8c6 100644 --- a/lib/launch-direct.c +++ b/lib/launch-direct.c @@ -315,6 +315,12 @@ add_drive (guestfs_h *g, struct backend_direct_data *data, start_list ("-device") { append_list ("scsi-hd"); append_list_format ("drive=hd%zu", i); + if (g->blocksize >= 512 && g->blocksize <= 32768 + && (g->blocksize & (g->blocksize-1)) == 0) + { + append_list_format ("physical_block_size=%d", g->blocksize); + append_list_format ("logical_block_size=%d", g->blocksize); + } if (drv->disk_label) append_list_format ("serial=%s", drv->disk_label); } end_list (); diff --git a/lib/launch.c b/lib/launch.c index eb7f85c..8edf7b1 100644 --- a/lib/launch.c +++ b/lib/launch.c @@ -53,6 +53,20 @@ static struct backend { const struct backend_ops *ops; } *backends = NULL; +int +guestfs_impl_launch_blocksize (guestfs_h *g, int blocksize) +{ + if (blocksize >= 512 && blocksize <= 32768 + && (blocksize & (blocksize-1)) == 0) { + g->blocksize = blocksize; + return guestfs_impl_launch (g); + } + else { + error (g, _("blocksize must be a power of 2 between 512 and 32768")); + return -1; + } +} + int guestfs_impl_launch (guestfs_h *g) { -- 2.21.0
Richard W.M. Jones
2019-Nov-12 09:11 UTC
Re: [Libguestfs] [PATCH v2 RESEND] direct, fish: add command launch_blocksize
On Tue, Nov 05, 2019 at 09:49:08AM +0100, Tuan Hoang wrote:> Add a new launch command for direct backend, which allows specifying the > blocksize to the disks. The name is `launch_blocksize`, accompanied alias is > `run-blocksize`. > > Example: > > $ guestfish --listen -a raw.img > $ guestfish --remote -- launch_blocksize 4096NACK TBH, I don't understand why this new command is needed. A considerably simpler and more obvious way is to follow what the --format option does already. Rich. -- Richard Jones, Virtualization Group, Red Hat http://people.redhat.com/~rjones Read my programming and virtualization blog: http://rwmj.wordpress.com libguestfs lets you edit virtual machines. Supports shell scripting, bindings from many languages. http://libguestfs.org
Reasonably Related Threads
- [PATCH v3 RESEND] direct, fish: add blocksize as optional argument for launch command
- Re: [RFC] lib: allow to specify physical/logical block size for disks
- [RFC] lib: allow to specify physical/logical block size for disks
- [PATCH v2] lib: add support for disks with 4096 bytes sector size
- [PATCH] lib: allow to specify physical/logical block size for disks