mirror_zfs/include
Brian Behlendorf ed3163484d Track emergency object in rbtree
In the initial implementation emergency objects were tracked on a
per-cache list.  The assumption was that under normal operation we
would never allocate more than a handful of these objects.  So the
cost of walking the list during free was expected to be negligible.

However real world usage has shown that emergency objects tend to
be allocated in batches.  A deadlock will be detected and several
thousand emergency objects will be allocated before the original
blocked slab allocation can complete.

Therefore the original list has been replaced by a red black tree
which is sorted by the memory address of each allocated object.
This bounds the worst case insertion and removal time to O(log n)
which minimize contention on the assoicated spin lock.

Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
2012-11-06 14:54:19 -08:00
..
fs Remove autotools products 2012-08-27 11:46:23 -07:00
linux Linux 3.7 compat, __clear_close_on_exec() removed 2012-10-18 13:36:44 -07:00
rpc Remove autotools products 2012-08-27 11:46:23 -07:00
sharefs Remove autotools products 2012-08-27 11:46:23 -07:00
sys Track emergency object in rbtree 2012-11-06 14:54:19 -08:00
util Remove autotools products 2012-08-27 11:46:23 -07:00
vm Remove autotools products 2012-08-27 11:46:23 -07:00
Makefile.am Add the release component to headers 2012-01-18 11:06:26 -08:00
spl-ctl.h Public Release Prep 2010-05-17 15:18:00 -07:00
spl-debug.h Add missing spl_debug_* helpers 2012-02-09 16:41:46 -08:00
spl-device.h Public Release Prep 2010-05-17 15:18:00 -07:00
spl-trace.h Split <sys/debug.h> header 2010-07-20 13:29:35 -07:00
splat-ctl.h Add linux compatibility tests 2011-06-21 14:02:46 -07:00
strings.h Public Release Prep 2010-05-17 15:18:00 -07:00
unistd.h Public Release Prep 2010-05-17 15:18:00 -07:00