Konstantin Belousov 14df601e47 When mnt_vnode_next_active iterator cannot lock the next vnode and
yields, specify the user priority for the yield.  Otherwise, a
higher-priority (kernel) thread could fall into the priority-inversion
with the thread owning the mutex lock.

On single-processor machines or UP kernels, do not loop adaptively
when the next vnode cannot be locked, instead yield unconditionally.

Restructure the iteration initializer and the iterator to remove code
duplication.  Put the code to fetch and lock a vnode next to the
current marker, into the mnt_vnode_next_active() function, and use it
instead of repeating the loop.

Reported by:	hrs, rmacklem
Tested by:	pho
Sponsored by:	The FreeBSD Foundation
MFC after:	3 days
2012-12-15 02:04:46 +00:00
..
2012-11-11 23:25:47 +00:00
2012-11-11 23:25:47 +00:00
2009-11-28 23:50:48 +00:00
2012-01-15 13:23:18 +00:00
2012-01-15 13:23:18 +00:00
2011-06-18 13:56:33 +00:00
2012-01-15 13:23:18 +00:00
2009-01-01 02:08:56 +00:00
2009-01-01 02:08:56 +00:00
2011-04-04 17:39:30 +00:00
2010-09-28 03:24:53 +00:00
2012-09-04 12:07:33 +00:00
2012-01-15 13:23:18 +00:00
2009-05-09 19:01:24 +00:00
2012-12-10 23:12:51 +00:00
2012-11-13 18:24:47 +00:00
2011-01-23 12:44:17 +00:00
2012-03-28 20:58:30 +00:00
2012-02-27 18:28:31 +00:00
2011-05-05 02:35:25 +00:00
2012-11-13 12:53:41 +00:00
2012-11-13 12:53:41 +00:00
2012-11-13 12:53:41 +00:00
2009-11-28 23:50:48 +00:00
2010-04-20 17:57:43 +00:00
2011-07-14 21:02:15 +00:00
2009-03-01 04:57:23 +00:00
2012-11-03 22:21:37 +00:00
2009-08-23 08:04:40 +00:00
2012-08-21 17:06:36 +00:00