Page MenuHomeFreeBSD

buf_ring: Use atomic operations with br_prod_tail
ClosedPublic

Authored by andrew on Jul 26 2024, 8:56 AM.
Tags
None
Referenced Files
Unknown Object (File)
Thu, Jan 9, 7:24 PM
Unknown Object (File)
Thu, Dec 19, 7:17 AM
Unknown Object (File)
Dec 7 2024, 8:21 PM
Unknown Object (File)
Dec 7 2024, 8:04 PM
Unknown Object (File)
Nov 21 2024, 2:59 PM
Unknown Object (File)
Oct 14 2024, 1:01 PM
Unknown Object (File)
Oct 13 2024, 12:15 PM
Unknown Object (File)
Oct 1 2024, 1:40 PM
Subscribers

Details

Summary

As with br_cons_tail use an atomic load acquire to read br_prod_tail
in buf_ring_dequeue_mc and buf_ring_peek*.

On dequeue we need to ensure we don't read the entry from the buf_ring
until it is available and prod_tail has updated. There is already an
appropriate store in the enqueue path and an appropriate load in the
single consumer dequeue, we just need one in the other functions that
read from the buf_ring.

Sponsored by: Arm Ltd

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 58849
Build 55736: arc lint + arc unit

Event Timeline

This revision is now accepted and ready to land.Jul 27 2024, 4:11 AM
sys/sys/buf_ring.h
142

I think the same question holds about this acq