[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PATCH] net: delete QemuOpts when net_client_init() fails.
From: |
Yoshiaki Tamura |
Subject: |
[Qemu-devel] [PATCH] net: delete QemuOpts when net_client_init() fails. |
Date: |
Mon, 21 Jun 2010 10:41:36 +0900 |
This fixes the following scenario using QMP.
First, put a bogus argument "foo" to "type", which results in an error.
{"execute": "netdev_add", "arguments": { "type": "foo", "id": "netdev1" } }
Then, call it again with correct argument "user".
{"execute": "netdev_add", "arguments": { "type": "user", "id": "netdev1" } }
This results in "DuplicatedId" error.
Because the first command was invalid, it should be able to reuse the
same "id", and the second command should work.
Reported-by: Luiz Capitulino <address@hidden>
Signed-off-by: Yoshiaki Tamura <address@hidden>
---
net.c | 4 ++++
1 files changed, 4 insertions(+), 0 deletions(-)
diff --git a/net.c b/net.c
index 0703698..a6b75f3 100644
--- a/net.c
+++ b/net.c
@@ -1208,6 +1208,10 @@ int do_netdev_add(Monitor *mon, const QDict *qdict,
QObject **ret_data)
}
res = net_client_init(mon, opts, 1);
+ if (res < 0) {
+ qemu_opts_del(opts);
+ }
+
return res;
}
--
1.7.0.31.g1df487
- [Qemu-devel] [PATCH] net: delete QemuOpts when net_client_init() fails.,
Yoshiaki Tamura <=