提交 86c562a9 编写于 作者: C Christoph Lameter 提交者: Linus Torvalds

[PATCH] mm: optimize numa policy handling in slab allocator

Move the interrupt check from slab_node into ___cache_alloc and adds an
"unlikely()" to avoid pipeline stalls on some architectures.
Signed-off-by: NChristoph Lameter <clameter@sgi.com>
Signed-off-by: NAndrew Morton <akpm@osdl.org>
Signed-off-by: NLinus Torvalds <torvalds@osdl.org>
上级 dc85da15
...@@ -982,9 +982,6 @@ static unsigned interleave_nodes(struct mempolicy *policy) ...@@ -982,9 +982,6 @@ static unsigned interleave_nodes(struct mempolicy *policy)
*/ */
unsigned slab_node(struct mempolicy *policy) unsigned slab_node(struct mempolicy *policy)
{ {
if (in_interrupt())
return numa_node_id();
switch (policy->policy) { switch (policy->policy) {
case MPOL_INTERLEAVE: case MPOL_INTERLEAVE:
return interleave_nodes(policy); return interleave_nodes(policy);
......
...@@ -2574,7 +2574,7 @@ static inline void *____cache_alloc(kmem_cache_t *cachep, gfp_t flags) ...@@ -2574,7 +2574,7 @@ static inline void *____cache_alloc(kmem_cache_t *cachep, gfp_t flags)
struct array_cache *ac; struct array_cache *ac;
#ifdef CONFIG_NUMA #ifdef CONFIG_NUMA
if (current->mempolicy) { if (unlikely(current->mempolicy && !in_interrupt())) {
int nid = slab_node(current->mempolicy); int nid = slab_node(current->mempolicy);
if (nid != numa_node_id()) if (nid != numa_node_id())
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册