Re: [PATCH 2/5] new fscache interface to check cache consistency

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

 



David,

If the cache is withdrawn and we're starting anew I would consider
that to okay. I would consider an empty page cache for a cookie to be
consistent since there's nothing stale that I can read. Unless there's
another synchronization issue that I'm missing in fscache.

Thanks,
- Milosz

On Wed, Sep 4, 2013 at 12:24 PM, David Howells <dhowells@xxxxxxxxxx> wrote:
> Hongyi Jia <jiayisuse@xxxxxxxxx> wrote:
>
>> +bool __fscache_check_consistency(struct fscache_cookie *cookie)
>> +{
>> +     struct fscache_object *object;
>> +
>> +     if (cookie->def->type != FSCACHE_COOKIE_TYPE_DATAFILE)
>> +             return false;
>> +
>> +     if (hlist_empty(&cookie->backing_objects))
>> +             return false;
>> +
>> +     object = hlist_entry(cookie->backing_objects.first,
>> +                     struct fscache_object, cookie_link);
>> +
>> +     return object->cache->ops->check_consistency(object);
>> +}
>
> Hmmm...  This isn't actually safe.  You have to either:
>
>  (1) hold cookie->lock whilst touching the object pointer when coming from the
>      netfs side, or:
>
>  (2) set up an operation to do this (as, say, __fscache_alloc_page() does).
>
> The problem is that you have nothing to defend against the object being
> withdrawn by the cache under you.
>
> David
--
To unsubscribe from this list: send the line "unsubscribe linux-fsdevel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html




[Index of Archives]     [Linux Ext4 Filesystem]     [Union Filesystem]     [Filesystem Testing]     [Ceph Users]     [Ecryptfs]     [AutoFS]     [Kernel Newbies]     [Share Photos]     [Security]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux Cachefs]     [Reiser Filesystem]     [Linux RAID]     [Samba]     [Device Mapper]     [CEPH Development]
  Powered by Linux