Page MenuHomeFreeBSD

fusefs: avoid cache corruption with buggy fuse servers
ClosedPublic

Authored by asomers on Mar 10 2020, 4:00 AM.
Tags
None
Referenced Files
F108199499: D24012.diff
Wed, Jan 22, 1:36 PM
Unknown Object (File)
Dec 8 2024, 10:56 PM
Unknown Object (File)
Dec 4 2024, 5:33 AM
Unknown Object (File)
Nov 13 2024, 3:47 AM
Unknown Object (File)
Oct 28 2024, 7:26 AM
Unknown Object (File)
Oct 10 2024, 1:40 AM
Unknown Object (File)
Oct 5 2024, 4:02 AM
Unknown Object (File)
Sep 26 2024, 7:36 PM
Subscribers

Details

Summary

fusefs: avoid cache corruption with buggy fuse servers

The FUSE protocol allows the client (kernel) to cache a file's size, if the
server (userspace daemon) allows it. A well-behaved daemon obviously should
not change a file's size while a client has it cached. But a buggy daemon
might. If the kernel ever detects that that has happened, then it should
invalidate the entire cache for that file. Previously, we would not only
cache stale data, but in the case of a file extension while we had the size
cached, we accidentally extended the cache with zeros.

Reported by: Ben RUBSON <ben.rubson@gmx.com>

Test Plan

Tests added

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 29858
Build 27680: arc lint + arc unit

Event Timeline

I'm not familiar with GoogleTest/C++ and didn't look at that bit.

sys/fs/fuse/fuse_internal.c
914

I would probably be even more explicit "this fuse fileserver is buggy and must be mounted with -o direct_io" or something like that. We're very much papering over possible corruption here and it is easy for it to go undetected if a file is not extended or truncated.

sys/fs/fuse/fuse_node.h
137

style(9) static inline bool on its own line.

asomers marked 2 inline comments as done.

Make a warning message scarier, and fix a style nit

This revision is now accepted and ready to land.Mar 11 2020, 4:18 AM

Thanks for such a speedy review!