Re: [RFC][PATCH] slub: Check for page NULL before doing thenode_match check

From: Steven Rostedt
Date: Thu Jan 17 2013 - 17:07:14 EST


On Thu, 2013-01-17 at 21:51 +0000, Christoph Lameter wrote:

> Ditto which leaves us with:

Except...

>
> Index: linux/mm/slub.c
> ===================================================================
> --- linux.orig/mm/slub.c 2013-01-17 15:49:57.417491975 -0600
> +++ linux/mm/slub.c 2013-01-17 15:50:49.010287150 -0600
> @@ -1993,8 +1993,9 @@ static inline void flush_slab(struct kme
> deactivate_slab(s, c->page, c->freelist);
>
> c->tid = next_tid(c->tid);
> - c->page = NULL;
> c->freelist = NULL;

+ /*
+ * Preemption may be enabled here, and if the task is preempted
+ * other tasks require that freelist is NULL if page is NULL.
+ */

> + barrier();
> + c->page = NULL;
> }
>
> /*

-- Steve


--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/