From: "Andreas Färber" <afaerber@suse.de>
To: Amos Kong <akong@redhat.com>, qemu-devel@nongnu.org
Cc: stefanha@gmail.com, arei.gonglei@huawei.com
Subject: Re: [Qemu-devel] [PATCH v4 3/4] virtio-blk-test.c: add hotplug subtest
Date: Tue, 17 Jun 2014 15:25:34 +0200 [thread overview]
Message-ID: <53A041CE.1060408@suse.de> (raw)
In-Reply-To: <1402065233-31894-4-git-send-email-akong@redhat.com>
Am 06.06.2014 16:33, schrieb Amos Kong:
> This patch adds a new subtest, it hotplugs 29 * 8 = 232 virtio-blk
> devices to guest, and try to hot-unplug them.
>
> Note: the hot-unplug can't work without cooperation of guest OS.
>
> Signed-off-by: Amos Kong <akong@redhat.com>
> Reviewed-by: Stefan Hajnoczi <stefanha@redhat.com>
> ---
> tests/virtio-blk-test.c | 31 +++++++++++++++++++++++++++++++
> 1 file changed, 31 insertions(+)
>
> diff --git a/tests/virtio-blk-test.c b/tests/virtio-blk-test.c
> index 0fdec01..7358203 100644
> --- a/tests/virtio-blk-test.c
> +++ b/tests/virtio-blk-test.c
> @@ -7,11 +7,41 @@
> * See the COPYING file in the top-level directory.
> */
>
> +#include <stdio.h>
> #include <glib.h>
> #include <string.h>
> #include "libqtest.h"
> #include "qemu/osdep.h"
>
> +static void test_blk_hotplug(void)
> +{
> + int i, j;
> +
> + /* start with no network/block device, slots 3~0x1f are free */
"3-0x1f" or "3 to 0x1f"?
> + qtest_start("-net none");
> +
> + for (i = 3; i <= 0x1f; i++) {
> + for (j = 7; j >= 0; j--) {
> + qmp_exec_hmp_cmd("OK\r\n",
> + "drive_add 0 if=none,file=/dev/null,id=drv-%x.%x",
> + i, j);
> + qmp_exec_hmp_cmd("",
> + "device_add virtio-blk-pci,id=dev-%x.%x,drive=drv-%x.%x,"
> + "addr=0x%x.%x,multifunction=on", i, j, i, j, i, j);
Why are you using HMP-via-QMP here and not QMP directly?
> + }
> + }
> +
> + /* hot-unplug doesn't work without cooperation of guest OS */
> + for (i = 3; i <= 0x1f; i++) {
> + for (j = 7; j >= 0; j--) {
While the function is still small, using a define or static const would
be a small improvement. :) Could be a follow-up of course.
Test looks good, thanks for your effort.
Regards,
Andreas
> + qmp_exec_hmp_cmd("", "drive_del drv-%x.%x", i, j);
> + qmp_exec_hmp_cmd("", "device_del dev-%x.%x", i, j);
> + }
> + }
> +
> + qtest_end();
> +}
> +
> /* Tests only initialization */
> static void virtblk_init(void)
> {
> @@ -26,6 +56,7 @@ int main(int argc, char **argv)
>
> g_test_init(&argc, &argv, NULL);
> qtest_add_func("/virtio/blk/pci/init", virtblk_init);
> + qtest_add_func("/virtio/blk/pci/hotplug", test_blk_hotplug);
>
> ret = g_test_run();
>
>
--
SUSE LINUX Products GmbH, Maxfeldstr. 5, 90409 Nürnberg, Germany
GF: Jeff Hawn, Jennifer Guild, Felix Imendörffer; HRB 16746 AG Nürnberg
next prev parent reply other threads:[~2014-06-17 13:25 UTC|newest]
Thread overview: 19+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-06-06 14:33 [Qemu-devel] [PATCH v4 0/4] test virtio-blk hotplug Amos Kong
2014-06-06 14:33 ` [Qemu-devel] [PATCH v4 1/4] virtio-blk-test.c: change pci_nop() to virtblk_init() Amos Kong
2014-06-06 14:33 ` [Qemu-devel] [PATCH v4 2/4] qtest: introduce qmp_exec_hmp_cmd() Amos Kong
2014-06-17 13:16 ` Andreas Färber
2014-06-17 17:37 ` Paolo Bonzini
2014-06-18 6:29 ` Amos Kong
2014-06-18 7:05 ` Paolo Bonzini
2014-06-06 14:33 ` [Qemu-devel] [PATCH v4 3/4] virtio-blk-test.c: add hotplug subtest Amos Kong
2014-06-17 13:25 ` Andreas Färber [this message]
2014-06-18 6:40 ` Amos Kong
2014-06-18 10:26 ` Andreas Färber
2014-06-06 14:33 ` [Qemu-devel] [PATCH v4 4/4] qtest: use qmp_exec_hmp_cmd() in blockdev-test Amos Kong
2014-06-17 13:28 ` Andreas Färber
2014-06-09 13:22 ` [Qemu-devel] [PATCH v4 0/4] test virtio-blk hotplug Stefan Hajnoczi
2014-06-17 12:54 ` Amos Kong
2014-06-17 13:37 ` Andreas Färber
2014-06-18 2:58 ` Amos Kong
2014-06-18 3:04 ` Stefan Hajnoczi
2014-06-18 5:46 ` Amos Kong
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=53A041CE.1060408@suse.de \
--to=afaerber@suse.de \
--cc=akong@redhat.com \
--cc=arei.gonglei@huawei.com \
--cc=qemu-devel@nongnu.org \
--cc=stefanha@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.