Re: [PATCH v2 6/5] statx: add STATX_RESULT_MASK flag

From: Miklos Szeredi
Date: Fri Oct 19 2018 - 13:42:31 EST


On Fri, Oct 19, 2018 at 5:59 PM, David Howells <dhowells@xxxxxxxxxx> wrote:
> Miklos Szeredi <mszeredi@xxxxxxxxxx> wrote:
>
>> FUSE needs this, because it uses legacy inode initialization, that doesn't
>> return a result_mask, so needs a refresh when caller asks for it with
>> statx().
>
> Can't you just make it up in fuse? Presumably, fuse doesn't support any of
> the non-basic statx fields either?

This is very much about the basic statx fields. I.e. what does
result_mask == STATX_BASIC_STATS means?

a) this is a legacy stat() implementation that doesn't fill in the
result_mask properly

b) this is an up-todate stat() implementation that does fill the
result_mask properly and all fields are valid

There's no way to tell which one it is, and no way to request that
filesystem try b) even if it's more costly.

>> It might make sense later to promote this to a proper statx mask flag and
>> return it in stx_mask to userspace.
>
> That sounds kind of recursive - a bit in stx_mask would be saying whether or
> not stx_mask can be used.

Yes. See above.

>> +#define STATX_RESULT_MASK STATX__RESERVED
>
> Please don't use that bit.

Using it internally is perfectly harmless. If we'll need to extend
statx in the future and make use of this flag externally, then we can
easily move the internal flag somewhere else (e.g. extend request_mask
to 64bit, which we'll probably need to do anyway in that case).

Thanks,
Miklos