Page MenuHomeFreeBSD

vinvalbuf: do not panic if we were unable to flush dirty buffers
ClosedPublic

Authored by kib on May 30 2021, 5:13 PM.
Tags
None
Referenced Files
F81643318: D30555.id.diff
Fri, Apr 19, 10:00 AM
Unknown Object (File)
Feb 8 2024, 6:15 AM
Unknown Object (File)
Feb 7 2024, 10:54 PM
Unknown Object (File)
Jan 12 2024, 5:36 PM
Unknown Object (File)
Dec 20 2023, 2:36 AM
Unknown Object (File)
Dec 14 2023, 9:50 AM
Unknown Object (File)
Dec 13 2023, 8:25 AM
Unknown Object (File)
Nov 28 2023, 8:50 PM
Subscribers

Details

Summary

Return EBUSY instead and let caller to handle the issue.

For vgone()/vnode reclamation, caller first does vinvalbuf(V_SAVE), which return EBUSY in case dirty buffers where not flushed. Then caller calls vinvalbuf(0) due to non-zero return, which gets rid of all dirty buffers without dependencies.

PR: 238565

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

kib requested review of this revision.May 30 2021, 5:13 PM
kib created this revision.

Works for me. You should also reenable the test in tests/sys/fs/fusefs/write.cc.

This revision is now accepted and ready to land.May 30 2021, 6:35 PM

You should also reenable the test in tests/sys/fs/fusefs/write.cc.

Please do it yourself after my change.