Gleb Smirnoff
4c506522c1
When removing ifnets, we should first remove the reference to ifnet
...
from the interface index, then decrease refcount, not vice versa.
Otherwise there is a race (reproducible) when if_free_internal()
contests on IFNET_WLOCK(), and we got a zero-refed ifnet in the
index for a long time. It may be picked by some other thread,
that runs ifnet_byindex_ref(), who takes the ifnet from index,
and bumps refcount. When reader drops the lock, if_free_internal()
proceeds with free. Then reader tries to free it a second time.
2011-04-04 07:45:08 +00:00
..
2010-11-24 05:50:19 +00:00
2010-12-25 21:26:56 +00:00
2010-09-16 18:37:33 +00:00
2010-10-29 18:41:09 +00:00
2010-06-15 19:28:44 +00:00
2011-01-06 22:17:07 +00:00
2010-05-16 21:48:39 +00:00
2011-03-21 09:40:01 +00:00
2010-08-11 20:18:19 +00:00
2010-11-22 19:32:54 +00:00
2010-10-25 08:30:19 +00:00
2010-05-03 07:32:50 +00:00
2011-01-19 17:04:07 +00:00
2010-11-21 19:33:19 +00:00
2010-11-22 19:32:54 +00:00
2011-03-02 21:39:08 +00:00
2010-04-29 11:52:42 +00:00
2011-03-02 21:39:08 +00:00
2010-03-01 17:05:46 +00:00
2011-03-04 20:37:38 +00:00
2010-02-06 13:49:35 +00:00
2010-11-22 19:32:54 +00:00
2011-03-21 09:40:01 +00:00
2010-11-22 19:32:54 +00:00
2011-02-21 09:01:34 +00:00
2011-01-05 15:28:30 +00:00
2010-05-03 07:32:50 +00:00
2010-09-22 21:02:43 +00:00
2010-10-01 15:14:14 +00:00
2011-03-21 09:40:01 +00:00
2011-03-21 09:40:01 +00:00
2011-03-21 09:40:01 +00:00
2011-03-21 09:40:01 +00:00
2011-04-04 07:45:08 +00:00
2010-12-07 20:31:04 +00:00
2010-03-01 00:42:36 +00:00
2011-02-11 13:27:00 +00:00
2010-03-01 00:43:05 +00:00
2010-07-15 14:41:06 +00:00
2010-03-09 01:11:45 +00:00
2010-07-15 14:41:59 +00:00
2010-03-07 15:37:58 +00:00
2011-03-19 21:10:57 +00:00
2011-03-20 08:35:00 +00:00
2011-02-10 01:24:09 +00:00
2011-01-11 13:59:06 +00:00
2011-02-11 14:17:58 +00:00
2010-03-02 06:58:58 +00:00
2010-03-02 06:58:58 +00:00