Page MenuHomeFreeBSD

ufs: a fix for sync write
AbandonedPublic

Authored by kib on Jun 23 2020, 4:13 AM.
Tags
None
Referenced Files
Unknown Object (File)
Mon, Dec 30, 6:28 PM
Unknown Object (File)
Sun, Dec 29, 6:31 PM
Unknown Object (File)
Sat, Dec 28, 7:22 PM
Unknown Object (File)
Fri, Dec 27, 5:36 AM
Unknown Object (File)
Tue, Dec 10, 11:12 AM
Unknown Object (File)
Nov 30 2024, 7:37 PM
Unknown Object (File)
Nov 25 2024, 1:04 PM
Unknown Object (File)
Oct 24 2024, 1:10 AM
Subscribers

Details

Reviewers
mckusick
Summary

If doing sync write, we should update the inode block not only when the inode size increased, but also in case the hole was filled that caused allocation of the direct blocks.

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 31885

Event Timeline

kib requested review of this revision.Jun 23 2020, 4:13 AM

I believe that the existing test already has this covered. The test (resid > uio->uio_resid) is checking that any data has been written. In the typical case this is at the end of the file and the size will have increased. But if the write was in the middle of a file filling in a hole then this test will catch that and cause the inode to be written.

Agreed, sorry for the noise.