Page MenuHomeFreeBSD

Remove KN_HASKQLOCK.
ClosedPublic

Authored by markj on Nov 20 2018, 9:33 PM.
Tags
None
Referenced Files
Unknown Object (File)
Thu, Jan 23, 6:56 PM
Unknown Object (File)
Sat, Jan 18, 6:24 AM
Unknown Object (File)
Mon, Jan 6, 8:35 PM
Unknown Object (File)
Oct 4 2024, 4:42 PM
Unknown Object (File)
Oct 3 2024, 4:05 PM
Unknown Object (File)
Oct 3 2024, 9:44 AM
Unknown Object (File)
Oct 3 2024, 5:35 AM
Unknown Object (File)
Oct 3 2024, 12:24 AM
Subscribers

Details

Summary

The last use was removed in r302235.

Diff Detail

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

Event Timeline

This revision is now accepted and ready to land.Nov 21 2018, 1:07 PM
This revision was automatically updated to reflect the committed changes.

why was this removed? This was necessary to prevent lock inversion due to a kq being in another kq...

In D18059#389031, @jmg wrote:

why was this removed?

Because it is unused.

This was necessary to prevent lock inversion due to a kq being in another kq...

Could you elaborate? I don't see why it's needed given the current implementation of filt_kqueue().

Yeah, after a bit of splunking after writing that comment, I discovered that it was unused.

Because in the normal case, the object and kq locks are of different class, and you never have to worry about locking two objects of the same type. When you have kq in kq, now the object lock is the same as kq, and now you can enter into a lock order reversal, because you are locking kq and kq locks together. If kib and or you are confident that this case is handled, that you can have kq in kq w/o issues. Then guess that's good enough, but that none of these comments talk about this case is a bit worrisome to me..