/* * Human Monitor Interface commands * * Copyright IBM, Corp. 2011 * * Authors: * Anthony Liguori * * This work is licensed under the terms of the GNU GPL, version 2. See * the COPYING file in the top-level directory. * * Contributions after 2012-01-13 are licensed under the terms of the * GNU GPL, version 2 or (at your option) any later version. */ #include "qemu/osdep.h" #include "migration/misc.h" #include "monitor/hmp.h" #include "monitor/monitor.h" #include "net/net.h" #include "net/hub.h" #include "qapi/clone-visitor.h" #include "qapi/qapi-commands-net.h" #include "qapi/qapi-visit-net.h" #include "qapi/qmp/qdict.h" #include "qemu/config-file.h" #include "qemu/help_option.h" #include "qemu/option.h" void hmp_info_network(Monitor *mon, const QDict *qdict) { NetClientState *nc, *peer; NetClientDriver type; net_hub_info(mon); QTAILQ_FOREACH(nc, &net_clients, next) { peer = nc->peer; type = nc->info->type; /* Skip if already printed in hub info */ if (net_hub_id_for_client(nc, NULL) == 0) { continue; } if (!peer || type == NET_CLIENT_DRIVER_NIC) { print_net_client(mon, nc); } /* else it's a netdev connected to a NIC, printed with the NIC */ if (peer && type == NET_CLIENT_DRIVER_NIC) { monitor_printf(mon, " \\ "); print_net_client(mon, peer); } } } void hmp_set_link(Monitor *mon, const QDict *qdict) { const char *name = qdict_get_str(qdict, "name"); bool up = qdict_get_bool(qdict, "up"); Error *err = NULL; qmp_set_link(name, up, &err); hmp_handle_error(mon, err); } void hmp_announce_self(Monitor *mon, const QDict *qdict) { const char *interfaces_str = qdict_get_try_str(qdict, "interfaces"); const char *id = qdict_get_try_str(qdict, "id"); AnnounceParameters *params = QAPI_CLONE(AnnounceParameters, migrate_announce_params()); qapi_free_strList(params->interfaces); params->interfaces = hmp_split_at_comma(interfaces_str); params->has_interfaces = params->interfaces != NULL; params->id = g_strdup(id); qmp_announce_self(params, NULL); qapi_free_AnnounceParameters(params); } void hmp_netdev_add(Monitor *mon, const QDict *qdict) { Error *err = NULL; QemuOpts *opts; const char *type = qdict_get_try_str(qdict, "type"); if (type && is_help_option(type)) { show_netdevs(); return; } opts = qemu_opts_from_qdict(qemu_find_opts("netdev"), qdict, &err); if (err) { goto out; } netdev_add(opts, &err); if (err) { qemu_opts_del(opts); } out: hmp_handle_error(mon, err); } void hmp_netdev_del(Monitor *mon, const QDict *qdict) { const char *id = qdict_get_str(qdict, "id"); Error *err = NULL; qmp_netdev_del(id, &err); hmp_handle_error(mon, err); } void netdev_add_completion(ReadLineState *rs, int nb_args, const char *str) { size_t len; int i; if (nb_args != 2) { return; } len = strlen(str); readline_set_completion_index(rs, len); for (i = 0; i < NET_CLIENT_DRIVER__MAX; i++) { readline_add_completion_of(rs, str, NetClientDriver_str(i)); } } void set_link_completion(ReadLineState *rs, int nb_args, const char *str) { size_t len; len = strlen(str); readline_set_completion_index(rs, len); if (nb_args == 2) { NetClientState *ncs[MAX_QUEUE_NUM]; int count, i; count = qemu_find_net_clients_except(NULL, ncs, NET_CLIENT_DRIVER_NONE, MAX_QUEUE_NUM); for (i = 0; i < MIN(count, MAX_QUEUE_NUM); i++) { readline_add_completion_of(rs, str, ncs[i]->name); } } else if (nb_args == 3) { readline_add_completion_of(rs, str, "on"); readline_add_completion_of(rs, str, "off"); } } void netdev_del_completion(ReadLineState *rs, int nb_args, const char *str) { int len, count, i; NetClientState *ncs[MAX_QUEUE_NUM]; if (nb_args != 2) { return; } len = strlen(str); readline_set_completion_index(rs, len); count = qemu_find_net_clients_except(NULL, ncs, NET_CLIENT_DRIVER_NIC, MAX_QUEUE_NUM); for (i = 0; i < MIN(count, MAX_QUEUE_NUM); i++) { if (ncs[i]->is_netdev) { readline_add_completion_of(rs, str, ncs[i]->name); } } }