Re: [PATCH v9 20/25] block/rnbd: server: main functionality

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 2020-02-21 02:47, Jack Wang wrote:
> +static int dev_search_path_set(const char *val, const struct kernel_param *kp)
> +{
> +	char *dup;
> +
> +	if (strlen(val) >= sizeof(dev_search_path))
> +		return -EINVAL;
> +
> +	dup = kstrdup(val, GFP_KERNEL);
> +
> +	if (dup[strlen(dup) - 1] == '\n')
> +		dup[strlen(dup) - 1] = '\0';
> +
> +	strlcpy(dev_search_path, dup, sizeof(dev_search_path));
> +
> +	kfree(dup);
> +	pr_info("dev_search_path changed to '%s'\n", dev_search_path);
> +
> +	return 0;
> +}

It is not necessary in this function to do memory allocation. Something
like the following (untested) code should be sufficient:

	const char *p = strrchr(val, '\n') ? : val + strlen(val);

	snprintf(dev_search_path, sizeof(dev_search_path), "%.*s",
		(int)(p - val), val);

How are concurrent attempts to change dev_search_path serialized?

Thanks,

Bart.



[Index of Archives]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Photo]     [Yosemite News]     [Yosemite Photos]     [Linux Kernel]     [Linux SCSI]     [XFree86]

  Powered by Linux