From c320ce032e27323c11039e357b8caf3c07404b49 Mon Sep 17 00:00:00 2001 From: "Ruben S. Montero" Date: Mon, 4 May 2020 12:41:36 +0200 Subject: [PATCH] M #-: Check qemu-nbd support for --fork --- src/vmm_mad/remotes/lib/lxd/mapper/qcow2.rb | 30 ++++++++++++++++++++- 1 file changed, 29 insertions(+), 1 deletion(-) diff --git a/src/vmm_mad/remotes/lib/lxd/mapper/qcow2.rb b/src/vmm_mad/remotes/lib/lxd/mapper/qcow2.rb index aa76ce8ef4..1041178791 100644 --- a/src/vmm_mad/remotes/lib/lxd/mapper/qcow2.rb +++ b/src/vmm_mad/remotes/lib/lxd/mapper/qcow2.rb @@ -23,6 +23,9 @@ require 'mapper' # Block device mapping for qcow2 disks, backed by nbd kernel module class Qcow2Mapper < Mapper + # Version --fork option was introduced in qemu-nbd command + QEMU_NBD_FORK_VERSION = "2.8.0" + def do_map(one_vm, disk, _directory) device = nbd_device @@ -31,7 +34,10 @@ class Qcow2Mapper < Mapper dsrc = one_vm.disk_source(disk) File.chmod(0o664, dsrc) if File.symlink?(one_vm.sysds_path) - map = "#{COMMANDS[:nbd]} --fork -c #{device} #{dsrc}" + map = "#{COMMANDS[:nbd]}" + map.concat(" --fork") if fork_supported + map.concat(" -c #{device} #{dsrc}") + rc, _out, err = Command.execute(map, true) unless rc.zero? @@ -64,6 +70,28 @@ class Qcow2Mapper < Mapper private + def fork_supported + tgt_ver = nbd_version + + return false if tgt_ver == "0.0.0" + + Gem::Version.new(tgt_ver) >= Gem::Version.new(QEMU_NBD_FORK_VERSION) + end + + def nbd_version + cmd = "#{COMMANDS[:nbd]} -V" + + rc, out, _err = Command.execute(cmd, false) + + return "0.0.0" unless rc.zero? + + match_v = out.match(/qemu-nbd version (.*)$/) + + return "0.0.0" if match_v.nil? + + match_v[1] + end + # Detects Max number of block devices def nbds_max File.read('/sys/module/nbd/parameters/nbds_max').chomp.to_i