Page MenuHomeFreeBSD

vnode_pager_input: return runningbufspace back
ClosedPublic

Authored by kib on Mar 24 2023, 9:59 PM.
Tags
None
Referenced Files
Unknown Object (File)
Thu, Jan 9, 7:38 AM
Unknown Object (File)
Wed, Jan 8, 3:47 PM
Unknown Object (File)
Nov 20 2024, 4:11 PM
Unknown Object (File)
Nov 6 2024, 4:00 PM
Unknown Object (File)
Nov 6 2024, 3:59 PM
Unknown Object (File)
Nov 6 2024, 3:57 PM
Unknown Object (File)
Nov 5 2024, 3:11 AM
Unknown Object (File)
Nov 4 2024, 2:50 AM
Subscribers

Details

Summary
Both vnode_pager_input_smlfs() and vnode_pager_generic_getpages()
increment runningbufspace, but also both delegate io completion handling
on the pbuf to either plain bdone() or filesystem-specific strategy
routine. Accidentally, for e.g. UFS it is g_vfs_strategy()/g_vfs_done().
The later calls bufdone() which handles runningbufspace reclamation.

For plain bdone io done handler, nothing would return
accounted b_runningbufspace back. Do it in the new
helper vnode_pager_input_bdone(), as well as in
vnode_pager_generic_getpages_done() explicitly.

Note that potential multiple calls to runningbufwakeup() for the same
pbuf or buf completion are safe. runningbufwakeup() clears accounting
for the buffer, so second and later calls are nop.

The problem was found due to tarfs using small vnode pager input but not
g_vfs_strategy().

Reported by:    des

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped