From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([208.118.235.92]:55375) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1TkUTP-0002sE-QC for qemu-devel@nongnu.org; Mon, 17 Dec 2012 01:47:53 -0500 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1TkUPa-0002UZ-UD for qemu-devel@nongnu.org; Mon, 17 Dec 2012 01:46:47 -0500 Received: from mail-ie0-f173.google.com ([209.85.223.173]:62381) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1TkUPa-0002UU-MT for qemu-devel@nongnu.org; Mon, 17 Dec 2012 01:42:50 -0500 Received: by mail-ie0-f173.google.com with SMTP id e13so8782660iej.4 for ; Sun, 16 Dec 2012 22:42:50 -0800 (PST) Sender: Dong Xu Wang From: Dong Xu Wang Date: Mon, 17 Dec 2012 14:42:25 +0800 Message-Id: <1355726549-5980-1-git-send-email-wdongxu@linux.vnet.ibm.com> Subject: [Qemu-devel] [PATCH V9 0/4] replace QEMUOptionParameter with QemuOpts parser List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: qemu-devel@nongnu.org Cc: kwolf@redhat.com, Dong Xu Wang Patch 1-3 are from Luiz, added Markus's comments, discussion could be found here: http://lists.nongnu.org/archive/html/qemu-devel/2012-07/msg02716.html Patch 3 was changed according Paolo's comments. Patch 4-5: because qemu_opts_create can not fail while id is null, so create function qemu_opts_create_nofail and use it. Patch 6: create function qemu_opt_set_number, like qemu_opt_set_bool. Patch 7: add def_value and use it in qemu_opts_print. Patch 8: Create functions to pair with QEMUOptionParameter parser. Patch 9: Use QemuOpts parser in Block. Patch 10: Remove QEMUOptionParameter parser related code. Patches 1 - 6 have been merged into block branch, so only patches 8 to 10 are included. v8->v9) 1) add qemu_ prefix to gluster_create_opts. 2) fix bug: bdrv_gluster_unix and bdrv_gluster_rdma should also be converted. v7->v8) 1) print "elements => accept any params" while opts_accepts_any() == true. 2) since def_print_str is the default value if an option isn't set, so rename it to def_value_str. 3) rebase to upstream source tree. 4) add gluster.c, raw-win32.c, and rbd.c. v6->v7: 1) Fix typo: enouth->enough. 2) use osdep.h:stringify(), not redefining new macro. 3) preserve TODO comment. 4) fix typo: BLOCK_OPT_ENCRYPT->BLOCK_OPT_STATIC. 5) initialize disk_type even when opts is NULL. v5->v6: 1) allocate enough space in append_opts_list function. 2) judge if opts == NULL in block layer create functions. 3) use bdrv_create_file(filename, NULL) in qcow_create funtion. 4) made more readable while using qemu_opt_get_number funtion. v4->v5: 1) Rewrite qemu_opts_create_nofail function based on Peter Maydell's comments. 2) Use g_strdup_printf in qemu_opt_set_number. 3) Rewrite qemu_opts_print. 4) .bdrv_create_options returns pointer directly. Fix a bug about "encryption". 5) Check qemu_opt_get_number in raw-posix.c. v3->v4: 1) Rebased to the newest source tree. 2) Remove redundant "#include "block-cache.h" 3) Other small changes. v2->v3: 1) rewrite qemu_opt_set_bool and qemu_opt_set_number according Paolo's coments. 2) split patches to make review easier. v1->v2: 1) add Luiz's patches. 2) create qemu_opt_set_number() and qemu_opts_create_nofail() functions. 3) add QemuOptsList map to drivers. 4) use original opts parser, not creating new ones. 5) fix other bugs. Dong Xu Wang (4): add def_print_str and use it in qemu_opts_print. Create four opts list related functions Use QemuOpts support in block layer remove QEMUOptionParameter related functions and struct block.c | 91 ++++++------- block.h | 4 +- block/cow.c | 46 +++--- block/gluster.c | 37 +++--- block/qcow.c | 60 ++++---- block/qcow2.c | 171 ++++++++++++----------- block/qed.c | 86 ++++++------ block/raw-posix.c | 65 ++++----- block/raw-win32.c | 30 ++-- block/raw.c | 30 +++-- block/rbd.c | 63 ++++---- block/sheepdog.c | 75 +++++----- block/vdi.c | 69 +++++----- block/vmdk.c | 74 +++++----- block/vpc.c | 67 +++++---- block/vvfat.c | 11 +- block_int.h | 6 +- qemu-img.c | 61 ++++---- qemu-option.c | 406 +++++++++++++++-------------------------------------- qemu-option.h | 37 +---- 20 files changed, 641 insertions(+), 848 deletions(-)