Page MenuHomeFreeBSD

e6000sw: fix incorrect locking
ClosedPublic

Authored by kp on Aug 10 2022, 4:40 PM.
Tags
None
Referenced Files
F83183220: D36117.diff
Tue, May 7, 10:24 AM
Unknown Object (File)
Wed, May 1, 1:54 AM
Unknown Object (File)
Wed, May 1, 1:54 AM
Unknown Object (File)
Wed, May 1, 1:53 AM
Unknown Object (File)
Tue, Apr 30, 11:24 PM
Unknown Object (File)
Fri, Apr 26, 10:53 PM
Unknown Object (File)
Mar 12 2024, 11:00 PM
Unknown Object (File)
Mar 12 2024, 11:00 PM
Subscribers

Details

Summary

During attach we release the lock to call e6000sw_attach_miibus(), which
calls mii_attach(). The mii_attach() function calls miibus_readreg() /
miibus_writereg(). However, these are set to be
e6000sw_readphy_locked().

That is, the read/write phy functions do not acquire the lock, but
expect to be called while locked. Simply do not unlock and relock while
calling mii_attach().

Sponsored by: Rubicon Communications, LLC ("Netgate")

Diff Detail

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

Event Timeline

kp requested review of this revision.Aug 10 2022, 4:40 PM
This revision was not accepted when it landed; it landed in state Needs Review.Aug 19 2022, 9:10 PM
This revision was automatically updated to reflect the committed changes.