[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-devel] [PATCH 2/2] xl: split out vnc and console related code
The new file also contains code for channel, which is just a console in disguise. Replace the call to vncviewer() with libxl_vncviewer_exec() directly in main_vncviewer. Signed-off-by: Wei Liu <wei.liu2@xxxxxxxxxx> --- tools/xl/Makefile | 2 +- tools/xl/xl_cmdimpl.c | 99 -------------------------------------- tools/xl/xl_console.c | 130 ++++++++++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 131 insertions(+), 100 deletions(-) create mode 100644 tools/xl/xl_console.c diff --git a/tools/xl/Makefile b/tools/xl/Makefile index bc8cfb3de9..7375d2bfda 100644 --- a/tools/xl/Makefile +++ b/tools/xl/Makefile @@ -19,7 +19,7 @@ XL_OBJS = xl.o xl_cmdimpl.o xl_cmdtable.o xl_sxp.o xl_utils.o XL_OBJS += xl_tmem.o xl_parse.o xl_cpupool.o xl_flask.o XL_OBJS += xl_vtpm.o xl_block.o xl_nic.o xl_usb.o XL_OBJS += xl_sched.o xl_pci.o xl_vcpu.o xl_cdrom.o xl_mem.o -XL_OBJS += xl_psr.o xl_info.o +XL_OBJS += xl_psr.o xl_info.o xl_console.o $(XL_OBJS): CFLAGS += $(CFLAGS_libxentoollog) $(XL_OBJS): CFLAGS += $(CFLAGS_XL) diff --git a/tools/xl/xl_cmdimpl.c b/tools/xl/xl_cmdimpl.c index a42b972d60..958058cadb 100644 --- a/tools/xl/xl_cmdimpl.c +++ b/tools/xl/xl_cmdimpl.c @@ -1071,61 +1071,6 @@ void help(const char *command) } } -int main_console(int argc, char **argv) -{ - uint32_t domid; - int opt = 0, num = 0; - libxl_console_type type = 0; - - SWITCH_FOREACH_OPT(opt, "n:t:", NULL, "console", 1) { - case 't': - if (!strcmp(optarg, "pv")) - type = LIBXL_CONSOLE_TYPE_PV; - else if (!strcmp(optarg, "serial")) - type = LIBXL_CONSOLE_TYPE_SERIAL; - else { - fprintf(stderr, "console type supported are: pv, serial\n"); - return EXIT_FAILURE; - } - break; - case 'n': - num = atoi(optarg); - break; - } - - domid = find_domain(argv[optind]); - if (!type) - libxl_primary_console_exec(ctx, domid, -1); - else - libxl_console_exec(ctx, domid, num, type, -1); - fprintf(stderr, "Unable to attach console\n"); - return EXIT_FAILURE; -} - -int main_vncviewer(int argc, char **argv) -{ - static const struct option opts[] = { - {"autopass", 0, 0, 'a'}, - {"vncviewer-autopass", 0, 0, 'a'}, - COMMON_LONG_OPTS - }; - uint32_t domid; - int opt, autopass = 0; - - SWITCH_FOREACH_OPT(opt, "a", opts, "vncviewer", 1) { - case 'a': - autopass = 1; - break; - } - - domid = find_domain(argv[optind]); - - libxl_vncviewer_exec(ctx, domid, autopass); - fprintf(stderr, "Unable to execute vncviewer\n"); - - return EXIT_FAILURE; -} - static void pause_domain(uint32_t domid) { libxl_domain_pause(ctx, domid); @@ -2515,50 +2460,6 @@ int main_debug_keys(int argc, char **argv) return EXIT_SUCCESS; } -int main_channellist(int argc, char **argv) -{ - int opt; - libxl_device_channel *channels; - libxl_channelinfo channelinfo; - int nb, i; - - SWITCH_FOREACH_OPT(opt, "", NULL, "channel-list", 1) { - /* No options */ - } - - /* Idx BE state evt-ch ring-ref connection params*/ - printf("%-3s %-2s %-5s %-6s %8s %-10s %-30s\n", - "Idx", "BE", "state", "evt-ch", "ring-ref", "connection", ""); - for (argv += optind, argc -= optind; argc > 0; --argc, ++argv) { - uint32_t domid = find_domain(*argv); - channels = libxl_device_channel_list(ctx, domid, &nb); - if (!channels) - continue; - for (i = 0; i < nb; ++i) { - if (!libxl_device_channel_getinfo(ctx, domid, &channels[i], - &channelinfo)) { - printf("%-3d %-2d ", channels[i].devid, channelinfo.backend_id); - printf("%-5d ", channelinfo.state); - printf("%-6d %-8d ", channelinfo.evtch, channelinfo.rref); - printf("%-10s ", libxl_channel_connection_to_string( - channels[i].connection)); - switch (channels[i].connection) { - case LIBXL_CHANNEL_CONNECTION_PTY: - printf("%-30s ", channelinfo.u.pty.path); - break; - default: - break; - } - printf("\n"); - libxl_channelinfo_dispose(&channelinfo); - } - libxl_device_channel_dispose(&channels[i]); - } - free(channels); - } - return 0; -} - #ifndef LIBXL_HAVE_NO_SUSPEND_RESUME int main_remus(int argc, char **argv) { diff --git a/tools/xl/xl_console.c b/tools/xl/xl_console.c new file mode 100644 index 0000000000..0508ddaa32 --- /dev/null +++ b/tools/xl/xl_console.c @@ -0,0 +1,130 @@ +/* + * Copyright 2009-2017 Citrix Ltd and other contributors + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU Lesser General Public License as published + * by the Free Software Foundation; version 2.1 only. with the special + * exception on linking described in file LICENSE. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Lesser General Public License for more details. + */ + +#include <stdlib.h> + +#include <libxl.h> +#include <libxl_utils.h> +#include <libxlutil.h> + +#include "xl.h" +#include "xl_utils.h" +#include "xl_parse.h" + +int main_console(int argc, char **argv) +{ + uint32_t domid; + int opt = 0, num = 0; + libxl_console_type type = 0; + + SWITCH_FOREACH_OPT(opt, "n:t:", NULL, "console", 1) { + case 't': + if (!strcmp(optarg, "pv")) + type = LIBXL_CONSOLE_TYPE_PV; + else if (!strcmp(optarg, "serial")) + type = LIBXL_CONSOLE_TYPE_SERIAL; + else { + fprintf(stderr, "console type supported are: pv, serial\n"); + return EXIT_FAILURE; + } + break; + case 'n': + num = atoi(optarg); + break; + } + + domid = find_domain(argv[optind]); + if (!type) + libxl_primary_console_exec(ctx, domid, -1); + else + libxl_console_exec(ctx, domid, num, type, -1); + fprintf(stderr, "Unable to attach console\n"); + return EXIT_FAILURE; +} + +int main_vncviewer(int argc, char **argv) +{ + static const struct option opts[] = { + {"autopass", 0, 0, 'a'}, + {"vncviewer-autopass", 0, 0, 'a'}, + COMMON_LONG_OPTS + }; + uint32_t domid; + int opt, autopass = 0; + + SWITCH_FOREACH_OPT(opt, "a", opts, "vncviewer", 1) { + case 'a': + autopass = 1; + break; + } + + domid = find_domain(argv[optind]); + + libxl_vncviewer_exec(ctx, domid, autopass); + + return EXIT_FAILURE; +} + +/* Channel is just a console in disguise, so put it here */ +int main_channellist(int argc, char **argv) +{ + int opt; + libxl_device_channel *channels; + libxl_channelinfo channelinfo; + int nb, i; + + SWITCH_FOREACH_OPT(opt, "", NULL, "channel-list", 1) { + /* No options */ + } + + /* Idx BE state evt-ch ring-ref connection params*/ + printf("%-3s %-2s %-5s %-6s %8s %-10s %-30s\n", + "Idx", "BE", "state", "evt-ch", "ring-ref", "connection", ""); + for (argv += optind, argc -= optind; argc > 0; --argc, ++argv) { + uint32_t domid = find_domain(*argv); + channels = libxl_device_channel_list(ctx, domid, &nb); + if (!channels) + continue; + for (i = 0; i < nb; ++i) { + if (!libxl_device_channel_getinfo(ctx, domid, &channels[i], + &channelinfo)) { + printf("%-3d %-2d ", channels[i].devid, channelinfo.backend_id); + printf("%-5d ", channelinfo.state); + printf("%-6d %-8d ", channelinfo.evtch, channelinfo.rref); + printf("%-10s ", libxl_channel_connection_to_string( + channels[i].connection)); + switch (channels[i].connection) { + case LIBXL_CHANNEL_CONNECTION_PTY: + printf("%-30s ", channelinfo.u.pty.path); + break; + default: + break; + } + printf("\n"); + libxl_channelinfo_dispose(&channelinfo); + } + libxl_device_channel_dispose(&channels[i]); + } + free(channels); + } + return 0; +} + +/* + * Local variables: + * mode: C + * c-basic-offset: 4 + * indent-tabs-mode: nil + * End: + */ -- 2.11.0 _______________________________________________ Xen-devel mailing list Xen-devel@xxxxxxxxxxxxx https://lists.xen.org/xen-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |