On 9/12/19 7:20 PM, Chaitanya Kulkarni wrote: > On 09/12/2019 03:09 PM, André Almeida wrote: >> Hello Matthew, >> >> On 9/12/19 1:19 PM, Matthew Wilcox wrote: >>> On Wed, Sep 11, 2019 at 11:46:36AM -0300, André Almeida wrote: >>>> >>>> -static int nr_devices = 1; >>>> +static unsigned int nr_devices = 1; >>>> module_param(nr_devices, int, 0444); >>> >>> ^^^ you forgot to change the module_param to match >>> >>>> + if (!nr_devices) { >>>> + pr_err("null_blk: invalid number of devices\n"); >>>> + return -EINVAL; >>>> + } >>> >>> I don't think this is necessary. >>> >> >> Could you explain why you don't think is necessary? As I see, the module >> can't be used without any /dev/nullb* device, so why we should load it? >> >> Thanks, >> André >> > > I think Matthew is right here. I think module can be loaded with > nr_devices=0. > > Did you get a chance to test nr_device=0 condition ? > Yes. It says "module loaded" and lsmod shows that it is loaded indeed. But you don't have any /dev/nullb*, so you can't do much with the module. With this patch, it refuses to load the module. > Also, did you get a chance to test this patch with all the > possible conditions ? > I did not tested with all possible conditions, but I tested with the following ones: * Using a negative number of devices: - Previously, it would alloc and add a huge number of devices until the system gets out of memory - With module_param as uint, it will throw a "invalid for parameter `nr_devices'" and refuse to load * Using a range of values (1, 10, 100, 1000): - It will works as expect, creating some /dev/nullbX accordingly with your parameter. Works fine with and without this patch.