On Tue 23-07-13 15:11:57, Randy Dunlap wrote: > On 07/23/13 15:04, Jan Kara wrote: > s/sence/sense/ please. Thanks. I keep getting this wrong... I've updated the patch locally but I won't resend it just for this spellcheck fix (yet). Honza > > diff --git a/lib/radix-tree.c b/lib/radix-tree.c > > index e796429..7811ed3 100644 > > --- a/lib/radix-tree.c > > +++ b/lib/radix-tree.c > > @@ -32,6 +32,7 @@ > > #include <linux/string.h> > > #include <linux/bitops.h> > > #include <linux/rcupdate.h> > > +#include <linux/hardirq.h> /* in_interrupt() */ > > > > > > #ifdef __KERNEL__ > > @@ -207,7 +208,12 @@ radix_tree_node_alloc(struct radix_tree_root *root) > > struct radix_tree_node *ret = NULL; > > gfp_t gfp_mask = root_gfp_mask(root); > > > > - if (!(gfp_mask & __GFP_WAIT)) { > > + /* > > + * Preload code isn't irq safe and it doesn't make sence to use > > sense > > > + * preloading in the interrupt anyway as all the allocations have to > > + * be atomic. So just do normal allocation when in interrupt. > > + */ > > + if (!(gfp_mask & __GFP_WAIT) && !in_interrupt()) { > > struct radix_tree_preload *rtp; > > > > /* > > @@ -264,7 +270,7 @@ radix_tree_node_free(struct radix_tree_node *node) > > * To make use of this facility, the radix tree must be initialised without > > * __GFP_WAIT being passed to INIT_RADIX_TREE(). > > */ > > -int radix_tree_preload(gfp_t gfp_mask) > > +static int __radix_tree_preload(gfp_t gfp_mask) > > { > > struct radix_tree_preload *rtp; > > struct radix_tree_node *node; > > @@ -288,9 +294,40 @@ int radix_tree_preload(gfp_t gfp_mask) > > out: > > return ret; > > } > > + > > +/* > > + * Load up this CPU's radix_tree_node buffer with sufficient objects to > > + * ensure that the addition of a single element in the tree cannot fail. On > > + * success, return zero, with preemption disabled. On error, return -ENOMEM > > + * with preemption not disabled. > > + * > > + * To make use of this facility, the radix tree must be initialised without > > + * __GFP_WAIT being passed to INIT_RADIX_TREE(). > > + */ > > +int radix_tree_preload(gfp_t gfp_mask) > > +{ > > + /* Warn on non-sensical use... */ > > + WARN_ON_ONCE(!(gfp_mask & __GFP_WAIT)); > > + return __radix_tree_preload(gfp_mask); > > +} > > EXPORT_SYMBOL(radix_tree_preload); > > > > /* > > + * The same as above function, except we don't guarantee preloading happens. > > + * We do it, if we decide it helps. On success, return zero with preemption > > + * disabled. On error, return -ENOMEM with preemption not disabled. > > + */ > > +int radix_tree_maybe_preload(gfp_t gfp_mask) > > +{ > > + if (gfp_mask & __GFP_WAIT) > > + return __radix_tree_preload(gfp_mask); > > + /* Preloading doesn't help anything with this gfp mask, skip it */ > > + preempt_disable(); > > + return 0; > > +} > > +EXPORT_SYMBOL(radix_tree_maybe_preload); > > + > > +/* > > * Return the maximum key which can be store into a > > stored > > > * radix tree with height HEIGHT. > > */ > > -- > ~Randy -- Jan Kara <jack@xxxxxxx> SUSE Labs, CR -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@xxxxxxxxx. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: <a href=mailto:"dont@xxxxxxxxx"> email@xxxxxxxxx </a>