Page MenuHomeFreeBSD

vtblk: Requeue inside vtblk_request_execute
ClosedPublic

Authored by cperciva on Sep 22 2022, 7:00 AM.
Tags
None
Referenced Files
Unknown Object (File)
Thu, Jun 4, 7:06 AM
Unknown Object (File)
Thu, Jun 4, 7:06 AM
Unknown Object (File)
Thu, May 28, 10:49 PM
Unknown Object (File)
Thu, May 28, 8:44 PM
Unknown Object (File)
Fri, May 22, 8:17 PM
Unknown Object (File)
Fri, May 15, 9:24 AM
Unknown Object (File)
May 15 2026, 4:28 AM
Unknown Object (File)
May 14 2026, 10:40 PM
Subscribers

Details

Summary

Most virtio_blk requests are launched from vtblk_startio; prior to this
commit, if vtblk_request_execute failed (e.g. due to a lack of space on
the virtio queue) vtblk_startio would requeue the request to be
reattempted later.

Add a flag "vbr_requeue_on_error" to requests and perform the requeuing
from inside vtblk_request_execute instead.

No functional change intended.

Diff Detail

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

Event Timeline

This revision is now accepted and ready to land.Oct 3 2022, 3:19 AM
imp added inline comments.
sys/dev/virtio/block/virtio_blk.c
1139

One can quibble over whether we should transition to bool for these, but the driver already has a few in the old-style.

This revision was automatically updated to reflect the committed changes.