]> git.openfabrics.org - ~shefty/rdma-dev.git/commitdiff
slub: enforce MAX_ORDER
authorDavid Rientjes <rientjes@google.com>
Thu, 23 Apr 2009 06:58:22 +0000 (09:58 +0300)
committerPekka Enberg <penberg@cs.helsinki.fi>
Thu, 23 Apr 2009 06:58:22 +0000 (09:58 +0300)
slub_max_order may not be equal to or greater than MAX_ORDER.

Additionally, if a single object cannot be placed in a slab of
slub_max_order, it still must allocate slabs below MAX_ORDER.

Acked-by: Christoph Lameter <cl@linux-foundation.org>
Signed-off-by: David Rientjes <rientjes@google.com>
Signed-off-by: Pekka Enberg <penberg@cs.helsinki.fi>
mm/slub.c

index 7ab54ecbd3f3a5abe50eba2c0a5dc035bf4d5efc..0e1247ed2a0625c9fdcb6790bd71fb6e9116bc7e 100644 (file)
--- a/mm/slub.c
+++ b/mm/slub.c
@@ -1909,7 +1909,7 @@ static inline int calculate_order(int size)
         * Doh this slab cannot be placed using slub_max_order.
         */
        order = slab_order(size, 1, MAX_ORDER, 1);
-       if (order <= MAX_ORDER)
+       if (order < MAX_ORDER)
                return order;
        return -ENOSYS;
 }
@@ -2522,6 +2522,7 @@ __setup("slub_min_order=", setup_slub_min_order);
 static int __init setup_slub_max_order(char *str)
 {
        get_option(&str, &slub_max_order);
+       slub_max_order = min(slub_max_order, MAX_ORDER - 1);
 
        return 1;
 }