[PATCH v5 5/5] maple_tree: add a test checking storing null

Wei Yang richard.weiyang at gmail.com
Sun Nov 3 14:46:08 PST 2024


On Thu, Oct 31, 2024 at 08:37:57PM -0700, Andrew Morton wrote:
>On Thu, 31 Oct 2024 23:16:27 +0000 Wei Yang <richard.weiyang at gmail.com> wrote:
>
>> Add a test to assert that, when storing null to am empty tree or a
>> single entry tree it will not result into:
>> 
>>   * a root node with range [0, ULONG_MAX] set to NULL
>>   * a root node with consecutive slot set to NULL
>> 
>
>I don't get it.
>

For example, if we store NULL to [3, 10] currently, we will have a root node
like this.

maple_tree(0x7fff2b797170) flags 5, height 1 root 0x615000000d0e
0-18446744073709551615: node 0x615000000d00 depth 0 type 1 parent 0x7fff2b797171 contents: (nil) 2 (nil) 10 (nil) 18446744073709551615 (nil) 0 (nil) 0 (nil) 0 (nil) 0 (nil) 0 (nil) 0 (nil) 0 (nil) 0 (nil) 0 (nil) 0 (nil) 0 (nil) 0 0x2
  0-2: (nil)
  3-10: (nil)
  11-18446744073709551615: (nil)

Slot 0, 1 is consecutively set to NULL. This is not expected.

>> --- a/lib/test_maple_tree.c
>> +++ b/lib/test_maple_tree.c
>> @@ -1387,6 +1387,92 @@ static noinline void __init check_prev_entry(struct maple_tree *mt)
>>  	mas_unlock(&mas);
>>  }
>>  
>> +static noinline void __init check_store_null(struct maple_tree *mt)
>> +{
>> +	MA_STATE(mas, mt, 0, ULONG_MAX);
>> +
>>
>> ...
>>
>> +	MT_BUG_ON(mt, !xa_is_node(mas_root(&mas)));
>> ...
>>
>
>mas_root() is private to lib/maple_tree.c.  I'll do this for now:

Oh, thanks.

>
>--- a/lib/test_maple_tree.c~maple_tree-add-a-test-checking-storing-null-fix
>+++ a/lib/test_maple_tree.c
>@@ -1453,7 +1453,7 @@ static noinline void __init check_store_
> 	mas_set_range(&mas, 2, 5);
> 	mas_store_gfp(&mas, NULL, GFP_KERNEL);
> 	MT_BUG_ON(mt, mtree_empty(mt));
>-	MT_BUG_ON(mt, xa_is_node(mas_root(&mas)));
>+//	MT_BUG_ON(mt, xa_is_node(mas_root(&mas)));
> 	mas_unlock(&mas);
> 	mtree_destroy(mt);
> 
>@@ -1465,7 +1465,7 @@ static noinline void __init check_store_
> 	mas_lock(&mas);
> 	mas_set_range(&mas, 1, 3);
> 	mas_store_gfp(&mas, &mas, GFP_KERNEL);
>-	MT_BUG_ON(mt, !xa_is_node(mas_root(&mas)));
>+//	MT_BUG_ON(mt, !xa_is_node(mas_root(&mas)));
> 	mas_set_range(&mas, 0, ULONG_MAX);
> 	mas_store_gfp(&mas, NULL, GFP_KERNEL);
> 	MT_BUG_ON(mt, !mtree_empty(mt));
>_

-- 
Wei Yang
Help you, Help me



More information about the maple-tree mailing list