aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--mm/slab.c11
1 files changed, 4 insertions, 7 deletions
diff --git a/mm/slab.c b/mm/slab.c
index 34eb1152aba4..71ba8f53f9b7 100644
--- a/mm/slab.c
+++ b/mm/slab.c
@@ -222,7 +222,6 @@ struct slab {
222 void *s_mem; /* including colour offset */ 222 void *s_mem; /* including colour offset */
223 unsigned int inuse; /* num of objs active in slab */ 223 unsigned int inuse; /* num of objs active in slab */
224 kmem_bufctl_t free; 224 kmem_bufctl_t free;
225 unsigned short nodeid;
226 }; 225 };
227 struct slab_rcu __slab_cover_slab_rcu; 226 struct slab_rcu __slab_cover_slab_rcu;
228 }; 227 };
@@ -1099,8 +1098,7 @@ static void drain_alien_cache(struct kmem_cache *cachep,
1099 1098
1100static inline int cache_free_alien(struct kmem_cache *cachep, void *objp) 1099static inline int cache_free_alien(struct kmem_cache *cachep, void *objp)
1101{ 1100{
1102 struct slab *slabp = virt_to_slab(objp); 1101 int nodeid = page_to_nid(virt_to_page(objp));
1103 int nodeid = slabp->nodeid;
1104 struct kmem_cache_node *n; 1102 struct kmem_cache_node *n;
1105 struct array_cache *alien = NULL; 1103 struct array_cache *alien = NULL;
1106 int node; 1104 int node;
@@ -1111,7 +1109,7 @@ static inline int cache_free_alien(struct kmem_cache *cachep, void *objp)
1111 * Make sure we are not freeing a object from another node to the array 1109 * Make sure we are not freeing a object from another node to the array
1112 * cache on this cpu. 1110 * cache on this cpu.
1113 */ 1111 */
1114 if (likely(slabp->nodeid == node)) 1112 if (likely(nodeid == node))
1115 return 0; 1113 return 0;
1116 1114
1117 n = cachep->node[node]; 1115 n = cachep->node[node];
@@ -2630,7 +2628,6 @@ static struct slab *alloc_slabmgmt(struct kmem_cache *cachep,
2630 } 2628 }
2631 slabp->inuse = 0; 2629 slabp->inuse = 0;
2632 slabp->s_mem = addr + colour_off; 2630 slabp->s_mem = addr + colour_off;
2633 slabp->nodeid = nodeid;
2634 slabp->free = 0; 2631 slabp->free = 0;
2635 return slabp; 2632 return slabp;
2636} 2633}
@@ -2707,7 +2704,7 @@ static void *slab_get_obj(struct kmem_cache *cachep, struct slab *slabp,
2707 next = slab_bufctl(slabp)[slabp->free]; 2704 next = slab_bufctl(slabp)[slabp->free];
2708#if DEBUG 2705#if DEBUG
2709 slab_bufctl(slabp)[slabp->free] = BUFCTL_FREE; 2706 slab_bufctl(slabp)[slabp->free] = BUFCTL_FREE;
2710 WARN_ON(slabp->nodeid != nodeid); 2707 WARN_ON(page_to_nid(virt_to_page(objp)) != nodeid);
2711#endif 2708#endif
2712 slabp->free = next; 2709 slabp->free = next;
2713 2710
@@ -2721,7 +2718,7 @@ static void slab_put_obj(struct kmem_cache *cachep, struct slab *slabp,
2721 2718
2722#if DEBUG 2719#if DEBUG
2723 /* Verify that the slab belongs to the intended node */ 2720 /* Verify that the slab belongs to the intended node */
2724 WARN_ON(slabp->nodeid != nodeid); 2721 WARN_ON(page_to_nid(virt_to_page(objp)) != nodeid);
2725 2722
2726 if (slab_bufctl(slabp)[objnr] + 1 <= SLAB_LIMIT + 1) { 2723 if (slab_bufctl(slabp)[objnr] + 1 <= SLAB_LIMIT + 1) {
2727 printk(KERN_ERR "slab: double free detected in cache " 2724 printk(KERN_ERR "slab: double free detected in cache "