Page MenuHomeFreeBSD

Use atomic load and stores to ensure that the compiler doesn't optimize away these loops.
ClosedPublic

Authored by imp on Jan 25 2018, 10:17 PM.
Tags
None
Referenced Files
Unknown Object (File)
Thu, Jan 16, 11:11 AM
Unknown Object (File)
Mon, Jan 13, 11:37 PM
Unknown Object (File)
Thu, Jan 9, 3:17 AM
Unknown Object (File)
Dec 5 2024, 4:44 PM
Unknown Object (File)
Nov 17 2024, 9:07 AM
Unknown Object (File)
Nov 12 2024, 3:46 AM
Unknown Object (File)
Nov 10 2024, 11:03 AM
Unknown Object (File)
Nov 10 2024, 10:05 AM
Subscribers
None

Details

Summary

Use atomic load and stores to ensure that the compiler doesn't optimize away these loops. Change boolean to int to match what atomic API supplies. Remove wmb() since the atomic_store_rel() on status.done ensure the prior writes to status.

Coverity caught this, and kib@ suggested these changes. They supposedly also use fewer cycles.

Test Plan

Booted on two different machines.

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

imp retitled this revision from Use atomic load and stores to ensure that the compiler doesn't optimize away these loops. Change boolean to int to match what atomic API supplies. Remove wmb() since the atomic_store_rel() on status.done ensure the prior writes to status. to Use atomic load and stores to ensure that the compiler doesn't optimize away these loops..Jan 25 2018, 10:19 PM
imp edited the summary of this revision. (Show Details)
imp added reviewers: kib, scottl, jimharris.

This also fixes a bug that rmb() was missed between read of status.done and accessing the controller data.

This revision is now accepted and ready to land.Jan 25 2018, 10:27 PM
This revision was automatically updated to reflect the committed changes.