Skip to content

Commit

Permalink
qapi: convert netdev_del
Browse files Browse the repository at this point in the history
Signed-off-by: Anthony Liguori <[email protected]>
Signed-off-by: Luiz Capitulino <[email protected]>
Reviewed-By: Laszlo Ersek <[email protected]>
  • Loading branch information
Luiz Capitulino committed Jun 4, 2012
1 parent 928059a commit 5f96415
Show file tree
Hide file tree
Showing 7 changed files with 31 additions and 13 deletions.
3 changes: 1 addition & 2 deletions hmp-commands.hx
Original file line number Diff line number Diff line change
Expand Up @@ -1051,8 +1051,7 @@ ETEXI
.args_type = "id:s",
.params = "id",
.help = "remove host network device",
.user_print = monitor_user_noop,
.mhandler.cmd_new = do_netdev_del,
.mhandler.cmd = hmp_netdev_del,
},

STEXI
Expand Down
9 changes: 9 additions & 0 deletions hmp.c
Original file line number Diff line number Diff line change
Expand Up @@ -990,3 +990,12 @@ void hmp_netdev_add(Monitor *mon, const QDict *qdict)
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);
}
1 change: 1 addition & 0 deletions hmp.h
Original file line number Diff line number Diff line change
Expand Up @@ -63,5 +63,6 @@ void hmp_migrate(Monitor *mon, const QDict *qdict);
void hmp_device_del(Monitor *mon, const QDict *qdict);
void hmp_dump_guest_memory(Monitor *mon, const QDict *qdict);
void hmp_netdev_add(Monitor *mon, const QDict *qdict);
void hmp_netdev_del(Monitor *mon, const QDict *qdict);

#endif
11 changes: 5 additions & 6 deletions net.c
Original file line number Diff line number Diff line change
Expand Up @@ -1269,19 +1269,18 @@ int qmp_netdev_add(Monitor *mon, const QDict *qdict, QObject **ret)
return -1;
}

int do_netdev_del(Monitor *mon, const QDict *qdict, QObject **ret_data)
void qmp_netdev_del(const char *id, Error **errp)
{
const char *id = qdict_get_str(qdict, "id");
VLANClientState *vc;

vc = qemu_find_netdev(id);
if (!vc) {
qerror_report(QERR_DEVICE_NOT_FOUND, id);
return -1;
error_set(errp, QERR_DEVICE_NOT_FOUND, id);
return;
}

qemu_del_vlan_client(vc);
qemu_opts_del(qemu_opts_find(qemu_find_opts("netdev"), id));
return 0;
qemu_opts_del(qemu_opts_find(qemu_find_opts_err("netdev", errp), id));
}

static void print_net_client(Monitor *mon, VLANClientState *vc)
Expand Down
1 change: 0 additions & 1 deletion net.h
Original file line number Diff line number Diff line change
Expand Up @@ -172,7 +172,6 @@ void net_host_device_add(Monitor *mon, const QDict *qdict);
void net_host_device_remove(Monitor *mon, const QDict *qdict);
void netdev_add(QemuOpts *opts, Error **errp);
int qmp_netdev_add(Monitor *mon, const QDict *qdict, QObject **ret);
int do_netdev_del(Monitor *mon, const QDict *qdict, QObject **ret_data);

#define DEFAULT_NETWORK_SCRIPT "/etc/qemu-ifup"
#define DEFAULT_NETWORK_DOWN_SCRIPT "/etc/qemu-ifdown"
Expand Down
14 changes: 14 additions & 0 deletions qapi-schema.json
Original file line number Diff line number Diff line change
Expand Up @@ -1826,3 +1826,17 @@
{ 'command': 'netdev_add',
'data': {'type': 'str', 'id': 'str', '*props': '**'},
'gen': 'no' }

##
# @netdev_del:
#
# Remove a network backend.
#
# @id: the name of the network backend to remove
#
# Returns: Nothing on success
# If @id is not a valid network backend, DeviceNotFound
#
# Since: 0.14.0
##
{ 'command': 'netdev_del', 'data': {'id': 'str'} }
5 changes: 1 addition & 4 deletions qmp-commands.hx
Original file line number Diff line number Diff line change
Expand Up @@ -671,10 +671,7 @@ EQMP
{
.name = "netdev_del",
.args_type = "id:s",
.params = "id",
.help = "remove host network device",
.user_print = monitor_user_noop,
.mhandler.cmd_new = do_netdev_del,
.mhandler.cmd_new = qmp_marshal_input_netdev_del,
},

SQMP
Expand Down

0 comments on commit 5f96415

Please sign in to comment.