Re: [Qemu-devel] [PATCH] block: Fail if requested driver is not available

2013-11-14 Thread Stefan Hajnoczi
On Mon, Nov 11, 2013 at 02:54:59PM +0100, Kevin Wolf wrote:
 If an explicit driver option is present, but doesn't specify a valid
 driver, then bdrv_open() should fail instead of probing the format.
 
 Signed-off-by: Kevin Wolf kw...@redhat.com
 ---
  block.c| 5 +
  tests/qemu-iotests/051 | 7 +++
  tests/qemu-iotests/051.out | 9 +
  3 files changed, 21 insertions(+)

Reviewed-by: Stefan Hajnoczi stefa...@redhat.com



[Qemu-devel] [PATCH] block: Fail if requested driver is not available

2013-11-11 Thread Kevin Wolf
If an explicit driver option is present, but doesn't specify a valid
driver, then bdrv_open() should fail instead of probing the format.

Signed-off-by: Kevin Wolf kw...@redhat.com
---
 block.c| 5 +
 tests/qemu-iotests/051 | 7 +++
 tests/qemu-iotests/051.out | 9 +
 3 files changed, 21 insertions(+)

diff --git a/block.c b/block.c
index d7de89d..6256b09 100644
--- a/block.c
+++ b/block.c
@@ -1130,6 +1130,11 @@ int bdrv_open(BlockDriverState *bs, const char 
*filename, QDict *options,
 if (drvname) {
 drv = bdrv_find_format(drvname);
 qdict_del(options, driver);
+if (!drv) {
+error_setg(errp, Invalid driver: '%s', drvname);
+ret = -EINVAL;
+goto unlink_and_fail;
+}
 }
 
 if (!drv) {
diff --git a/tests/qemu-iotests/051 b/tests/qemu-iotests/051
index b1480a8..4df8058 100755
--- a/tests/qemu-iotests/051
+++ b/tests/qemu-iotests/051
@@ -78,6 +78,13 @@ run_qemu -drive 
file=$TEST_IMG,format=qcow2,unknown_opt=1234
 run_qemu -drive file=$TEST_IMG,format=qcow2,unknown_opt=foo
 
 echo
+echo === Invalid format ===
+echo
+
+run_qemu -drive file=$TEST_IMG,format=foo
+run_qemu -drive file=$TEST_IMG,driver=foo
+
+echo
 echo === Overriding backing file ===
 echo
 
diff --git a/tests/qemu-iotests/051.out b/tests/qemu-iotests/051.out
index 1ee010d..088735a 100644
--- a/tests/qemu-iotests/051.out
+++ b/tests/qemu-iotests/051.out
@@ -17,6 +17,15 @@ Testing: -drive 
file=TEST_DIR/t.qcow2,format=qcow2,unknown_opt=foo
 QEMU_PROG: -drive file=TEST_DIR/t.qcow2,format=qcow2,unknown_opt=foo: could 
not open disk image TEST_DIR/t.qcow2: Block format 'qcow2' used by device 
'ide0-hd0' doesn't support the option 'unknown_opt'
 
 
+=== Invalid format ===
+
+Testing: -drive file=TEST_DIR/t.qcow2,format=foo
+QEMU_PROG: -drive file=TEST_DIR/t.qcow2,format=foo: 'foo' invalid format
+
+Testing: -drive file=TEST_DIR/t.qcow2,driver=foo
+QEMU_PROG: -drive file=TEST_DIR/t.qcow2,driver=foo: could not open disk image 
TEST_DIR/t.qcow2: Invalid driver: 'foo'
+
+
 === Overriding backing file ===
 
 Testing: -drive 
file=TEST_DIR/t.qcow2,driver=qcow2,backing.file.filename=TEST_DIR/t.qcow2.orig 
-nodefaults
-- 
1.8.1.4




Re: [Qemu-devel] [PATCH] block: Fail if requested driver is not available

2013-11-11 Thread Jeff Cody
On Mon, Nov 11, 2013 at 02:54:59PM +0100, Kevin Wolf wrote:
 If an explicit driver option is present, but doesn't specify a valid
 driver, then bdrv_open() should fail instead of probing the format.
 
 Signed-off-by: Kevin Wolf kw...@redhat.com
 ---
  block.c| 5 +
  tests/qemu-iotests/051 | 7 +++
  tests/qemu-iotests/051.out | 9 +
  3 files changed, 21 insertions(+)
 
 diff --git a/block.c b/block.c
 index d7de89d..6256b09 100644
 --- a/block.c
 +++ b/block.c
 @@ -1130,6 +1130,11 @@ int bdrv_open(BlockDriverState *bs, const char 
 *filename, QDict *options,
  if (drvname) {
  drv = bdrv_find_format(drvname);
  qdict_del(options, driver);
 +if (!drv) {
 +error_setg(errp, Invalid driver: '%s', drvname);
 +ret = -EINVAL;
 +goto unlink_and_fail;
 +}
  }
  
  if (!drv) {
 diff --git a/tests/qemu-iotests/051 b/tests/qemu-iotests/051
 index b1480a8..4df8058 100755
 --- a/tests/qemu-iotests/051
 +++ b/tests/qemu-iotests/051
 @@ -78,6 +78,13 @@ run_qemu -drive 
 file=$TEST_IMG,format=qcow2,unknown_opt=1234
  run_qemu -drive file=$TEST_IMG,format=qcow2,unknown_opt=foo
  
  echo
 +echo === Invalid format ===
 +echo
 +
 +run_qemu -drive file=$TEST_IMG,format=foo
 +run_qemu -drive file=$TEST_IMG,driver=foo
 +
 +echo
  echo === Overriding backing file ===
  echo
  
 diff --git a/tests/qemu-iotests/051.out b/tests/qemu-iotests/051.out
 index 1ee010d..088735a 100644
 --- a/tests/qemu-iotests/051.out
 +++ b/tests/qemu-iotests/051.out
 @@ -17,6 +17,15 @@ Testing: -drive 
 file=TEST_DIR/t.qcow2,format=qcow2,unknown_opt=foo
  QEMU_PROG: -drive file=TEST_DIR/t.qcow2,format=qcow2,unknown_opt=foo: could 
 not open disk image TEST_DIR/t.qcow2: Block format 'qcow2' used by device 
 'ide0-hd0' doesn't support the option 'unknown_opt'
  
  
 +=== Invalid format ===
 +
 +Testing: -drive file=TEST_DIR/t.qcow2,format=foo
 +QEMU_PROG: -drive file=TEST_DIR/t.qcow2,format=foo: 'foo' invalid format
 +
 +Testing: -drive file=TEST_DIR/t.qcow2,driver=foo
 +QEMU_PROG: -drive file=TEST_DIR/t.qcow2,driver=foo: could not open disk 
 image TEST_DIR/t.qcow2: Invalid driver: 'foo'
 +
 +
  === Overriding backing file ===
  
  Testing: -drive 
 file=TEST_DIR/t.qcow2,driver=qcow2,backing.file.filename=TEST_DIR/t.qcow2.orig
  -nodefaults
 -- 
 1.8.1.4
 


Reviewed-by: Jeff Cody jc...@redhat.com