Re: [PATCH 04/12] mkfs: merge tables for opts parsing into one table

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

 




On 4/25/17 2:45 AM, Jan Tulak wrote:
> On Tue, Apr 25, 2017 at 5:04 AM, Luis R. Rodriguez <mcgrof@xxxxxxxxxx> wrote:
>> On Sun, Apr 23, 2017 at 08:54:55PM +0200, Jan Tulak wrote:
>>> Merge separate instances of opt_params into one indexable table. Git
>>> makes this patch looks a bit more complicated, but it does not change
>>> values or structure of anything else. It only moves all the "struct
>>> opt_params dopts = {...}", changes indentation for these substructures
>>> and replaces their usage (dopts -> opts[OPT_D]).
>>>
>>> Signed-off-by: Jan Tulak <jtulak@xxxxxxxxxx>
>>> ---
>>>  mkfs/xfs_mkfs.c | 1316 +++++++++++++++++++++++++++++--------------------------
>>>  1 file changed, 683 insertions(+), 633 deletions(-)
>>>
>>> diff --git a/mkfs/xfs_mkfs.c b/mkfs/xfs_mkfs.c
>>> index 7a72b11..513e106 100644
>>> --- a/mkfs/xfs_mkfs.c
>>> +++ b/mkfs/xfs_mkfs.c
>>> @@ -42,6 +42,7 @@ static int  ispow2(unsigned int i);
>>>  uint64_t             blocksize;
>>>  uint64_t             sectorsize;
>>>
>>> +#define MAX_OPTS     16
>>
>> This is fragile, every time a new opt is added this needs to be updated

<pedantic>There are only 8 now, so there are still 8 free slots</pedantic>

>> and so is the index, and we should be pedantic over not going out of bounds.
>> We could instead use a flexible array and compute the max opts at run time
>> as a global. This way the max opts is always updated automatically.

I don't think it's all that fragile; this is used only for a global structure
declaration & initialization. If you add too many new members to opt_params,
compilation will issue warnings:

xfs_mkfs.c:342: warning: excess elements in array initializer
xfs_mkfs.c:342: warning: (near initialization for ‘opts’)
xfs_mkfs.c:424: warning: excess elements in array initializer
xfs_mkfs.c:424: warning: (near initialization for ‘opts’)
xfs_mkfs.c:543: warning: excess elements in array initializer
xfs_mkfs.c:543: warning: (near initialization for ‘opts’)
...

and it will be quite obvious, at which point you can bump it up before
you send that patch.  ;)

Anyway, because the the definition is never used at runtime, there's
no need to be computing it at runtime, either.

> Mmm, that is a good idea and I see no issue with it. But I'm not sure
> if it is worth of rewriting this patch as we already use MAX_SUBOPTS
> anyway. Rather I see it as a standalone patch in the next set. What do
> you think?

I think that given how it's used, there is no real need for any extra
complexity.  In any case, any changes around this behavior would certainly
be part of a different patch, because you'd want to be consistent with all
the other structure initializers, and it would be a functionally separate
change if it is warranted at all.

Thanks,
-Eric
--
To unsubscribe from this list: send the line "unsubscribe linux-xfs" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html



[Index of Archives]     [XFS Filesystem Development (older mail)]     [Linux Filesystem Development]     [Linux Audio Users]     [Yosemite Trails]     [Linux Kernel]     [Linux RAID]     [Linux SCSI]


  Powered by Linux