From: Aya Levin Date: Thu, 28 Feb 2019 12:13:02 +0000 (+0200) Subject: devlink: Add devlink health dump clear command X-Git-Tag: v5.4.0~141^2~2 X-Git-Url: https://git.proxmox.com/?p=mirror_iproute2.git;a=commitdiff_plain;h=04b583d0fff3496c5f5cd9aa3b2fb1fc23398909 devlink: Add devlink health dump clear command Add devlink dump clear command which deletes the last saved dump file. Clearing the last saved dump enables a new dump file to be saved. Example: $ devlink health dump clear pci/0000:00:09.0 reporter tx Signed-off-by: Aya Levin Reviewed-by: Moshe Shemesh Acked-by: Jiri Pirko Signed-off-by: David Ahern --- diff --git a/devlink/devlink.c b/devlink/devlink.c index 30076d25..f6405824 100644 --- a/devlink/devlink.c +++ b/devlink/devlink.c @@ -5816,6 +5816,23 @@ static int cmd_region(struct dl *dl) return -ENOENT; } +static int cmd_health_dump_clear(struct dl *dl) +{ + struct nlmsghdr *nlh; + int err; + + nlh = mnlg_msg_prepare(dl->nlg, DEVLINK_CMD_HEALTH_REPORTER_DUMP_CLEAR, + NLM_F_REQUEST | NLM_F_ACK); + + err = dl_argv_parse_put(nlh, dl, + DL_OPT_HANDLE | DL_OPT_HEALTH_REPORTER_NAME, 0); + if (err) + return err; + + dl_opts_put(nlh, dl); + return _mnlg_socket_sndrcv(dl->nlg, nlh, NULL, NULL); +} + static int fmsg_value_show(struct dl *dl, int type, struct nlattr *nl_data) { uint8_t *data; @@ -6162,6 +6179,7 @@ static void cmd_health_help(void) pr_err(" devlink health recover DEV reporter REPORTER_NAME\n"); pr_err(" devlink health diagnose DEV reporter REPORTER_NAME\n"); pr_err(" devlink health dump show DEV reporter REPORTER_NAME\n"); + pr_err(" devlink health dump clear DEV reporter REPORTER_NAME\n"); } static int cmd_health(struct dl *dl) @@ -6184,6 +6202,9 @@ static int cmd_health(struct dl *dl) if (dl_argv_match(dl, "show")) { dl_arg_inc(dl); return cmd_health_dump_show(dl); + } else if (dl_argv_match(dl, "clear")) { + dl_arg_inc(dl); + return cmd_health_dump_clear(dl); } } pr_err("Command \"%s\" not found\n", dl_argv(dl));