[PATCH 19/35] fabrics: use "const char *" in struct config
Hannes Reinecke
hare at suse.de
Thu Feb 4 02:20:11 EST 2021
On 1/26/21 9:33 PM, mwilck at suse.com wrote:
> From: Martin Wilck <mwilck at suse.com>
>
> This is easily done, and allows passing in some const char* pointers
> that would otherwise need to be strdup()d first.
>
> constifying cfg->device requires changes in the ctrl_instance()
> function, because basename() can't be used.
>
> Signed-off-by: Martin Wilck <mwilck at suse.com>
> ---
> fabrics.c | 23 ++++++++++++++---------
> fabrics.h | 17 +++++++++--------
> 2 files changed, 23 insertions(+), 17 deletions(-)
>
> diff --git a/fabrics.c b/fabrics.c
> index c1a4bb5..e3d2a3a 100644
> --- a/fabrics.c
> +++ b/fabrics.c
> @@ -252,17 +252,22 @@ empty_field:
> return strdup("\0");
> }
>
> -static int ctrl_instance(char *device)
> +int ctrl_instance(const char *device)
> {
> char d[64];
> + const char *p;
> int ret, instance;
>
> - device = basename(device);
> - ret = sscanf(device, "nvme%d", &instance);
> + p = strrchr(device, '/');
> + if (p == NULL)
> + p = device;
> + else
> + p++;
> + ret = sscanf(p, "nvme%d", &instance);
> if (ret <= 0)
> return -EINVAL;
> if (snprintf(d, sizeof(d), "nvme%d", instance) <= 0 ||
> - strcmp(device, d))
> + strcmp(p, d))
> return -EINVAL;
> return instance;
> }
> @@ -273,7 +278,7 @@ static int ctrl_instance(char *device)
> * given.
> * Return true/false based on whether it matches
> */
> -static bool ctrl_matches_connectargs(char *name, struct connect_args *args)
> +static bool ctrl_matches_connectargs(const char *name, struct connect_args *args)
> {
> struct connect_args cargs;
> bool found = false;
> @@ -815,7 +820,7 @@ add_int_argument(char **argstr, int *max_len, char *arg_str, int arg,
> }
>
> static int
> -add_argument(char **argstr, int *max_len, char *arg_str, char *arg)
> +add_argument(char **argstr, int *max_len, char *arg_str, const char *arg)
> {
> int len;
>
> @@ -1541,7 +1546,7 @@ static int scan_sys_nvme_filter(const struct dirent *d)
> /*
> * Returns 1 if disconnect occurred, 0 otherwise.
> */
> -static int disconnect_subsys(char *nqn, char *ctrl)
> +static int disconnect_subsys(const char *nqn, char *ctrl)
> {
> char *sysfs_nqn_path = NULL, *sysfs_del_path = NULL;
> char subsysnqn[NVMF_NQN_SIZE] = {};
> @@ -1579,7 +1584,7 @@ static int disconnect_subsys(char *nqn, char *ctrl)
> /*
> * Returns the number of controllers successfully disconnected.
> */
> -static int disconnect_by_nqn(char *nqn)
> +static int disconnect_by_nqn(const char *nqn)
> {
> struct dirent **devices = NULL;
> int i, n, ret = 0;
> @@ -1601,7 +1606,7 @@ static int disconnect_by_nqn(char *nqn)
> return ret;
> }
>
> -static int disconnect_by_device(char *device)
> +static int disconnect_by_device(const char *device)
> {
> int instance;
>
> diff --git a/fabrics.h b/fabrics.h
> index ce965a3..1dfbd67 100644
> --- a/fabrics.h
> +++ b/fabrics.h
> @@ -13,13 +13,13 @@ extern int fabrics_disconnect_all(const char *desc, int argc, char **argv);
> /* Symbols used by monitor.c */
>
> struct config {
> - char *nqn;
> - char *transport;
> - char *traddr;
> - char *trsvcid;
> - char *host_traddr;
> - char *hostnqn;
> - char *hostid;
> + const char *nqn;
> + const char *transport;
> + const char *traddr;
> + const char *trsvcid;
> + const char *host_traddr;
> + const char *hostnqn;
> + const char *hostid;
> int nr_io_queues;
> int nr_write_queues;
> int nr_poll_queues;
> @@ -29,7 +29,7 @@ struct config {
> int ctrl_loss_tmo;
> int tos;
> char *raw;
> - char *device;
> + const char *device;
> int duplicate_connect;
> int disable_sqflow;
> int hdr_digest;
> @@ -43,5 +43,6 @@ extern struct config cfg;
>
> int build_options(char *argstr, int max_len, bool discover);
> int do_discover(char *argstr, bool connect);
> +int ctrl_instance(const char *device);
>
> #endif
>
This really is independent on the monitor code, and should be moved to
the beginning of the patch series.
Other than that:
Reviewed-by: Hannes Reinecke <hare at suse.de>
Cheers,
Hannes
--
Dr. Hannes Reinecke Kernel Storage Architect
hare at suse.de +49 911 74053 688
SUSE Software Solutions GmbH, Maxfeldstr. 5, 90409 Nürnberg
HRB 36809 (AG Nürnberg), Geschäftsführer: Felix Imendörffer
More information about the Linux-nvme
mailing list