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)
Fri, Oct 10, 10:19 AM
Unknown Object (File)
Thu, Oct 9, 6:37 PM
Unknown Object (File)
Sat, Sep 27, 4:37 PM
Unknown Object (File)
Thu, Sep 25, 8:51 PM
Unknown Object (File)
Thu, Sep 25, 4:28 PM
Unknown Object (File)
Wed, Sep 17, 12:42 PM
Unknown Object (File)
Sep 13 2025, 6:18 AM
Unknown Object (File)
Sep 12 2025, 1:46 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.