Page MenuHomeFreeBSD

xen/intr: allow xen_intr_release_isrc() to reuse lock
AbandonedPublic

Authored by ehem_freebsd_m5p.com on Nov 7 2021, 4:25 AM.
Tags
None
Referenced Files
Unknown Object (File)
Wed, Mar 25, 5:34 AM
Unknown Object (File)
Tue, Mar 24, 12:48 PM
Unknown Object (File)
Sun, Mar 22, 9:57 PM
Unknown Object (File)
Fri, Mar 20, 9:57 PM
Unknown Object (File)
Fri, Mar 20, 7:56 AM
Unknown Object (File)
Sun, Mar 15, 2:57 PM
Unknown Object (File)
Tue, Mar 10, 2:26 AM
Unknown Object (File)
Mar 1 2026, 8:40 PM
Subscribers

Details

Reviewers
royger
mhorne
Summary

Calling mtx_unlock() only to immediately call mtx_lock() isn't so great.
Since xen_intr_unbind() already has the main lock held before calling
xen_intr_release_isrc(), avoid the back to back unlock then lock.

Diff Detail

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

Event Timeline

Kind of a "Hey, look what D32876 allows us to do!"

Yes, this got into Phabricator before final testing. Indeed, it is broken. The fix is pretty obvious.

Upon examination I suspect things may head in a different direction.

This isn't even the slightest bit of a priority. Worse, this does indeed make locking harrier.