[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Xen-devel] [PATCH 1/3] libxl:refactor stdvga option support v2



On Thu, 2012-06-28 at 08:56 +0100, ZhouPeng wrote:
> version 4
> 
> Thanks.
> --
> 
> tools:libxl: refactor stdvga opinon support.
> 
> Be ready to add and describe new vga interface
> 
> Signed-off-by: Zhou Peng <ailvpeng25@xxxxxxxxx>

Acked-by: Ian Campbell <ian.campbell@xxxxxxxxxx>

> 
> diff -r 592d15bd4d5e tools/libxl/libxl_create.c
> --- a/tools/libxl/libxl_create.c      Fri May 18 16:19:21 2012 +0100
> +++ b/tools/libxl/libxl_create.c      Thu Jun 28 15:50:10 2012 +0800
> @@ -189,7 +189,8 @@ int libxl__domain_build_info_setdefault(
>              if (!b_info->u.hvm.boot) return ERROR_NOMEM;
>          }
> 
> -        libxl_defbool_setdefault(&b_info->u.hvm.stdvga, false);
> +        if (!b_info->u.hvm.vga.kind)
> +            b_info->u.hvm.vga.kind = LIBXL_VGA_INTERFACE_TYPE_CIRRUS;
>          libxl_defbool_setdefault(&b_info->u.hvm.vnc.enable, true);
>          if (libxl_defbool_val(b_info->u.hvm.vnc.enable)) {
>              libxl_defbool_setdefault(&b_info->u.hvm.vnc.findunused, true);
> diff -r 592d15bd4d5e tools/libxl/libxl_dm.c
> --- a/tools/libxl/libxl_dm.c  Fri May 18 16:19:21 2012 +0100
> +++ b/tools/libxl/libxl_dm.c  Thu Jun 28 15:50:10 2012 +0800
> @@ -175,8 +175,13 @@ static char ** libxl__build_device_model
>                                     libxl__sizekb_to_mb(b_info->video_memkb)),
>                      NULL);
>          }
> -        if (libxl_defbool_val(b_info->u.hvm.stdvga)) {
> +
> +        switch (b_info->u.hvm.vga.kind) {
> +        case LIBXL_VGA_INTERFACE_TYPE_STD:
>              flexarray_append(dm_args, "-std-vga");
> +            break;
> +        case LIBXL_VGA_INTERFACE_TYPE_CIRRUS:
> +            break;
>          }
> 
>          if (b_info->u.hvm.boot) {
> @@ -418,8 +423,13 @@ static char ** libxl__build_device_model
>              flexarray_append(dm_args, spiceoptions);
>          }
> 
> -        if (libxl_defbool_val(b_info->u.hvm.stdvga)) {
> -                flexarray_vappend(dm_args, "-vga", "std", NULL);
> +        switch (b_info->u.hvm.vga.kind) {
> +        case LIBXL_VGA_INTERFACE_TYPE_STD:
> +            flexarray_vappend(dm_args, "-vga", "std", NULL);
> +            break;
> +        case LIBXL_VGA_INTERFACE_TYPE_CIRRUS:
> +            flexarray_vappend(dm_args, "-vga", "cirrus", NULL);
> +            break;
>          }
> 
>          if (b_info->u.hvm.boot) {
> diff -r 592d15bd4d5e tools/libxl/libxl_types.idl
> --- a/tools/libxl/libxl_types.idl     Fri May 18 16:19:21 2012 +0100
> +++ b/tools/libxl/libxl_types.idl     Thu Jun 28 15:50:10 2012 +0800
> @@ -125,9 +125,19 @@ libxl_shutdown_reason = Enumeration("shu
>      (4, "watchdog"),
>      ])
> 
> +libxl_vga_interface_type = Enumeration("vga_interface_type", [
> +    (1, "CIRRUS"),
> +    (2, "STD"),
> +    ], init_val = 0)
> +
>  #
>  # Complex libxl types
>  #
> +
> +libxl_vga_interface_info = Struct("vga_interface_info", [
> +    ("kind",    libxl_vga_interface_type),
> +    ])
> +
>  libxl_vnc_info = Struct("vnc_info", [
>      ("enable",        libxl_defbool),
>      # "address:port" that should be listened on
> @@ -286,7 +296,7 @@ libxl_domain_build_info = Struct("domain
>                                         ("nested_hvm",       libxl_defbool),
>                                         ("incr_generationid",libxl_defbool),
>                                         ("nographic",        libxl_defbool),
> -                                       ("stdvga",           libxl_defbool),
> +                                       ("vga",
> libxl_vga_interface_info),
>                                         ("vnc",              libxl_vnc_info),
>                                         # keyboard layout, default is
> en-us keyboard
>                                         ("keymap",           string),
> diff -r 592d15bd4d5e tools/libxl/xl_cmdimpl.c
> --- a/tools/libxl/xl_cmdimpl.c        Fri May 18 16:19:21 2012 +0100
> +++ b/tools/libxl/xl_cmdimpl.c        Thu Jun 28 15:50:10 2012 +0800
> @@ -1256,7 +1256,10 @@ skip_vfb:
>  #undef parse_extra_args
> 
>      if (c_info->type == LIBXL_DOMAIN_TYPE_HVM) {
> -        xlu_cfg_get_defbool(config, "stdvga", &b_info->u.hvm.stdvga, 0);
> +        if (!xlu_cfg_get_long(config, "stdvga", &l, 0))
> +            b_info->u.hvm.vga.kind = l ? LIBXL_VGA_INTERFACE_TYPE_STD :
> +                                         LIBXL_VGA_INTERFACE_TYPE_CIRRUS;
> +
>          xlu_cfg_get_defbool(config, "vnc", &b_info->u.hvm.vnc.enable, 0);
>          xlu_cfg_replace_string (config, "vnclisten",
>                                  &b_info->u.hvm.vnc.listen, 0);
> diff -r 592d15bd4d5e tools/libxl/xl_sxp.c
> --- a/tools/libxl/xl_sxp.c    Fri May 18 16:19:21 2012 +0100
> +++ b/tools/libxl/xl_sxp.c    Thu Jun 28 15:50:10 2012 +0800
> @@ -110,8 +110,9 @@ void printf_info_sexp(int domid, libxl_d
>                 libxl_defbool_to_string(b_info->u.hvm.nested_hvm));
>          printf("\t\t\t(no_incr_generationid %s)\n",
>                 libxl_defbool_to_string(b_info->u.hvm.incr_generationid));
> -        printf("\t\t\t(stdvga %s)\n",
> -               libxl_defbool_to_string(b_info->u.hvm.stdvga));
> +        printf("\t\t\t(stdvga %s)\n", b_info->u.hvm.vga.kind ==
> +                                      LIBXL_VGA_INTERFACE_TYPE_STD ?
> +                                      "True" : "False");
>          printf("\t\t\t(vnc %s)\n",
>                 libxl_defbool_to_string(b_info->u.hvm.vnc.enable));
>          printf("\t\t\t(vnclisten %s)\n", b_info->u.hvm.vnc.listen);
> 
> On Thu, Jun 28, 2012 at 1:33 PM, Ian Campbell <Ian.Campbell@xxxxxxxxxx> wrote:
> > On Thu, 2012-06-28 at 02:42 +0100, ZhouPeng wrote:
> >> On Wed, Jun 27, 2012 at 11:28 PM, Ian Campbell <Ian.Campbell@xxxxxxxxxx> 
> >> wrote:
> >> >> diff -r 592d15bd4d5e tools/libxl/xl_cmdimpl.c
> >> >> --- a/tools/libxl/xl_cmdimpl.c  Fri May 18 16:19:21 2012 +0100
> >> >> +++ b/tools/libxl/xl_cmdimpl.c  Wed Jun 27 20:06:39 2012 +0800
> >> >> @@ -1256,7 +1256,10 @@ skip_vfb:
> >> >>  #undef parse_extra_args
> >> >>
> >> >>      if (c_info->type == LIBXL_DOMAIN_TYPE_HVM) {
> >> >> -        xlu_cfg_get_defbool(config, "stdvga", &b_info->u.hvm.stdvga, 
> >> >> 0);
> >> >> +        if (!xlu_cfg_get_long(config, "stdvga", &l, 0))
> >> >> +            if (l)
> >> >> +                b_info->u.hvm.vga.kind = LIBXL_VGA_INTERFACE_TYPE_STD;
> >> >
> >> > I think this needs to be:
> >> >          if (!xlu_cfg_get_long(config, "stdvga", &l, 0))
> >> >                b_info->u.hvm.vga.kind = l ? \
> >> >                                         LIBXL_VGA_INTERFACE_TYPE_STD : \
> >> >                                         LIBXL_VGA_INTERFACE_TYPE_CIRRUS;
> >> >
> >> > so that both "stdvga=0" and "stdvga=1" result in what the user asked for
> >> > without relying on the libxl default remaining CIRRUS.
> >>
> >> IMHO, this make simple to be complex.
> >>
> >> I think the check  and set-default later in libxl_create.c as a whole is 
> >> enough.
> >
> > This is in libxl, as I said above xl should not rely on the default
> > remaining CIRRUS.
> >
> > If the user says "stdvga=0" then xl needs to explicitly ask for CIRRUS,
> > despite the fact that it currently happens to be the default.
> >
> > If we make the libxl default BLARGLE in the future then stdvga=0 still
> > needs to mean CIRRUS.
> >
> >> +        if (!b_info->u.hvm.vga.kind)
> >> +            b_info->u.hvm.vga.kind = LIBXL_VGA_INTERFACE_TYPE_CIRRUS;
> >>
> >> 'as a whole' here, I means if more vga type added in the future, we
> >> don't need to set the default one by one, redundantly.
> >
> 
> 
> 



_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxx
http://lists.xen.org/xen-devel


 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.