radix tree test suite: record order in each item
authorMatthew Wilcox <mawilcox@microsoft.com>
Wed, 14 Dec 2016 23:08:23 +0000 (15:08 -0800)
committerLinus Torvalds <torvalds@linux-foundation.org>
Thu, 15 Dec 2016 00:04:10 +0000 (16:04 -0800)
This probably doubles the size of each item allocated by the test suite
but it lets us check a few more things, and may be needed for upcoming
API changes that require the caller pass in the order of the entry.

Link: http://lkml.kernel.org/r/1480369871-5271-46-git-send-email-mawilcox@linuxonhyperv.com
Signed-off-by: Matthew Wilcox <mawilcox@microsoft.com>
Tested-by: Kirill A. Shutemov <kirill.shutemov@linux.intel.com>
Cc: Konstantin Khlebnikov <koct9i@gmail.com>
Cc: Ross Zwisler <ross.zwisler@linux.intel.com>
Cc: Matthew Wilcox <mawilcox@microsoft.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
tools/testing/radix-tree/multiorder.c
tools/testing/radix-tree/test.c
tools/testing/radix-tree/test.h

index d1be94667a30cdcbad8a2dca86832bc73d5ed70d..8d5865c95664584fd5c8cfa4304f49fd1bdd8f2e 100644 (file)
@@ -125,7 +125,7 @@ static void multiorder_check(unsigned long index, int order)
        unsigned long min = index & ~((1UL << order) - 1);
        unsigned long max = min + (1UL << order);
        void **slot;
-       struct item *item2 = item_create(min);
+       struct item *item2 = item_create(min, order);
        RADIX_TREE(tree, GFP_KERNEL);
 
        printf("Multiorder index %ld, order %d\n", index, order);
index 6f8dafc797ce84e8988abed16aba785d938be95c..0de548939a2e92fda3991ad205beef2a5d49ec06 100644 (file)
@@ -24,21 +24,29 @@ int item_tag_get(struct radix_tree_root *root, unsigned long index, int tag)
        return radix_tree_tag_get(root, index, tag);
 }
 
-int __item_insert(struct radix_tree_root *root, struct item *item,
-                       unsigned order)
+int __item_insert(struct radix_tree_root *root, struct item *item)
 {
-       return __radix_tree_insert(root, item->index, order, item);
+       return __radix_tree_insert(root, item->index, item->order, item);
 }
 
 int item_insert(struct radix_tree_root *root, unsigned long index)
 {
-       return __item_insert(root, item_create(index), 0);
+       return __item_insert(root, item_create(index, 0));
 }
 
 int item_insert_order(struct radix_tree_root *root, unsigned long index,
                        unsigned order)
 {
-       return __item_insert(root, item_create(index), order);
+       return __item_insert(root, item_create(index, order));
+}
+
+void item_sanity(struct item *item, unsigned long index)
+{
+       unsigned long mask;
+       assert(!radix_tree_is_internal_node(item));
+       assert(item->order < BITS_PER_LONG);
+       mask = (1UL << item->order) - 1;
+       assert((item->index | mask) == (index | mask));
 }
 
 int item_delete(struct radix_tree_root *root, unsigned long index)
@@ -46,18 +54,19 @@ int item_delete(struct radix_tree_root *root, unsigned long index)
        struct item *item = radix_tree_delete(root, index);
 
        if (item) {
-               assert(item->index == index);
+               item_sanity(item, index);
                free(item);
                return 1;
        }
        return 0;
 }
 
-struct item *item_create(unsigned long index)
+struct item *item_create(unsigned long index, unsigned int order)
 {
        struct item *ret = malloc(sizeof(*ret));
 
        ret->index = index;
+       ret->order = order;
        return ret;
 }
 
@@ -66,8 +75,8 @@ void item_check_present(struct radix_tree_root *root, unsigned long index)
        struct item *item;
 
        item = radix_tree_lookup(root, index);
-       assert(item != 0);
-       assert(item->index == index);
+       assert(item != NULL);
+       item_sanity(item, index);
 }
 
 struct item *item_lookup(struct radix_tree_root *root, unsigned long index)
@@ -80,7 +89,7 @@ void item_check_absent(struct radix_tree_root *root, unsigned long index)
        struct item *item;
 
        item = radix_tree_lookup(root, index);
-       assert(item == 0);
+       assert(item == NULL);
 }
 
 /*
index 215ab77a56e385747d480d09de4c4d850b182304..423c528aaee93577fa06cab3a76044eabf7d2759 100644 (file)
@@ -5,11 +5,11 @@
 
 struct item {
        unsigned long index;
+       unsigned int order;
 };
 
-struct item *item_create(unsigned long index);
-int __item_insert(struct radix_tree_root *root, struct item *item,
-                       unsigned order);
+struct item *item_create(unsigned long index, unsigned int order);
+int __item_insert(struct radix_tree_root *root, struct item *item);
 int item_insert(struct radix_tree_root *root, unsigned long index);
 int item_insert_order(struct radix_tree_root *root, unsigned long index,
                        unsigned order);