glebius
8c3b1b83f9
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
2009-11-20 21:12:40 +00:00
2009-11-20 18:49:20 +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
2009-08-23 20:40:19 +00:00
2009-04-16 20:30:28 +00:00
2009-06-21 10:29:31 +00:00
2009-06-21 10:29:31 +00:00
2011-01-06 22:17:07 +00:00
2010-05-16 21:48:39 +00:00
2009-04-30 14:25:44 +00:00
2009-06-21 10:29:31 +00:00
2009-06-21 10:29:31 +00:00
2011-03-21 09:40:01 +00:00
2009-04-16 20:30:28 +00:00
2009-06-05 14:55:22 +00:00
2010-08-11 20:18:19 +00:00
2010-11-22 19:32:54 +00:00
2009-07-23 20:46:49 +00:00
2009-11-30 21:25:57 +00:00
2010-10-25 08:30:19 +00:00
2009-04-16 20:30:28 +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
2009-08-01 19:26:27 +00:00
2009-06-24 10:32:44 +00:00
2009-06-21 10:29:31 +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
2009-06-21 10:29:31 +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
2009-08-01 19:26:27 +00:00
2009-08-01 19:26:27 +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
2009-06-21 10:29:31 +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
2009-10-19 15:19:14 +00:00
2010-07-15 14:41:06 +00:00
2009-06-12 15:44:35 +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
2009-08-01 19:26:27 +00:00
2009-07-16 21:13:04 +00:00
2009-08-01 19:26:27 +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