tree: https://github.com/ammarfaizi2/linux-block dhowells/linux-fs/netfs-maple head: 931e50676c6598d0eda1954ead465519ff91874d commit: 6c45be03ed6456efda93c06956d586eecae0e51a [19/44] Maple Tree: add new data structure config: arc-randconfig-s032-20220422 (https://download.01.org/0day-ci/archive/20220423/202204231903.VFCpjd8T-lkp@xxxxxxxxx/config) compiler: arc-elf-gcc (GCC) 11.2.0 reproduce: wget https://raw.githubusercontent.com/intel/lkp-tests/master/sbin/make.cross -O ~/bin/make.cross chmod +x ~/bin/make.cross # apt-get install sparse # sparse version: v0.6.4-dirty # https://github.com/ammarfaizi2/linux-block/commit/6c45be03ed6456efda93c06956d586eecae0e51a git remote add ammarfaizi2-block https://github.com/ammarfaizi2/linux-block git fetch --no-tags ammarfaizi2-block dhowells/linux-fs/netfs-maple git checkout 6c45be03ed6456efda93c06956d586eecae0e51a # save the config file mkdir build_dir && cp config build_dir/.config COMPILER_INSTALL_PATH=$HOME/0day COMPILER=gcc-11.2.0 make.cross C=1 CF='-fdiagnostic-prefix -D__CHECK_ENDIAN__' O=build_dir ARCH=arc SHELL=/bin/bash If you fix the issue, kindly add following tag as appropriate Reported-by: kernel test robot <lkp@xxxxxxxxx> sparse warnings: (new ones prefixed by >>) >> lib/maple_tree.c:5317:23: sparse: sparse: incorrect type in assignment (different address spaces) @@ expected void **slots @@ got void [noderef] __rcu ** @@ lib/maple_tree.c:5317:23: sparse: expected void **slots lib/maple_tree.c:5317:23: sparse: got void [noderef] __rcu ** >> lib/maple_tree.c:5318:45: sparse: sparse: incorrect type in argument 2 (different address spaces) @@ expected void [noderef] __rcu **slots @@ got void **slots @@ lib/maple_tree.c:5318:45: sparse: expected void [noderef] __rcu **slots lib/maple_tree.c:5318:45: sparse: got void **slots >> lib/maple_tree.c:5343:15: sparse: sparse: incorrect type in assignment (different address spaces) @@ expected void [noderef] __rcu **slots @@ got void ** @@ lib/maple_tree.c:5343:15: sparse: expected void [noderef] __rcu **slots lib/maple_tree.c:5343:15: sparse: got void ** >> lib/maple_tree.c:5355:31: sparse: sparse: incorrect type in assignment (different address spaces) @@ expected void [noderef] __rcu **[assigned] slots @@ got void ** @@ lib/maple_tree.c:5355:31: sparse: expected void [noderef] __rcu **[assigned] slots lib/maple_tree.c:5355:31: sparse: got void ** >> lib/maple_tree.c:5425:34: sparse: sparse: incorrect type in assignment (different address spaces) @@ expected struct maple_enode *[addressable] [assigned] node @@ got void [noderef] __rcu * @@ lib/maple_tree.c:5425:34: sparse: expected struct maple_enode *[addressable] [assigned] node lib/maple_tree.c:5425:34: sparse: got void [noderef] __rcu * lib/maple_tree.c:5365:9: sparse: sparse: context imbalance in 'mt_free_walk' - different lock contexts for basic block vim +5317 lib/maple_tree.c 5307 5308 static void **mas_dead_walk(struct ma_state *mas, unsigned char offset) 5309 { 5310 struct maple_node *node, *next; 5311 void **slots = NULL; 5312 5313 next = mas_mn(mas); 5314 do { 5315 mas->node = ma_enode_ptr(next); 5316 node = mas_mn(mas); > 5317 slots = ma_slots(node, node->type); > 5318 next = mas_slot_locked(mas, slots, offset); 5319 offset = 0; 5320 } while (!ma_is_leaf(next->type)); 5321 5322 return slots; 5323 } 5324 5325 static void mt_free_walk(struct rcu_head *head) 5326 { 5327 void __rcu **slots; 5328 struct maple_node *node, *start; 5329 struct maple_tree mt; 5330 unsigned char offset; 5331 enum maple_type type; 5332 MA_STATE(mas, &mt, 0, 0); 5333 5334 node = container_of(head, struct maple_node, rcu); 5335 5336 if (ma_is_leaf(node->type)) 5337 goto free_leaf; 5338 5339 mt_init_flags(&mt, node->ma_flags); 5340 mas_lock(&mas); 5341 start = node; 5342 mas.node = mt_mk_node(node, node->type); > 5343 slots = mas_dead_walk(&mas, 0); 5344 node = mas_mn(&mas); 5345 do { 5346 mt_free_bulk(node->slot_len, slots); 5347 offset = node->parent_slot + 1; 5348 mas.node = node->piv_parent; 5349 if (mas_mn(&mas) == node) 5350 goto start_slots_free; 5351 5352 type = mte_node_type(mas.node); 5353 slots = ma_slots(mte_to_node(mas.node), type); 5354 if ((offset < mt_slots[type]) && (slots[offset])) > 5355 slots = mas_dead_walk(&mas, offset); 5356 5357 node = mas_mn(&mas); 5358 } while ((node != start) || (node->slot_len < offset)); 5359 5360 slots = ma_slots(node, node->type); 5361 mt_free_bulk(node->slot_len, slots); 5362 5363 start_slots_free: 5364 free_leaf: 5365 mt_free_rcu(&node->rcu); 5366 } 5367 5368 static inline void __rcu **mas_destroy_descend(struct ma_state *mas, 5369 struct maple_enode *prev, unsigned char offset) 5370 { 5371 struct maple_node *node; 5372 struct maple_enode *next = mas->node; 5373 void __rcu **slots = NULL; 5374 5375 do { 5376 mas->node = next; 5377 node = mas_mn(mas); 5378 slots = ma_slots(node, mte_node_type(mas->node)); 5379 next = mas_slot_locked(mas, slots, 0); 5380 mte_set_node_dead(mas->node); 5381 node->type = mte_node_type(mas->node); 5382 node->piv_parent = prev; 5383 node->parent_slot = offset; 5384 offset = 0; 5385 prev = mas->node; 5386 } while (!mte_is_leaf(next)); 5387 return slots; 5388 } 5389 5390 static void mt_destroy_walk(struct maple_enode *enode, unsigned char ma_flags, 5391 bool free) 5392 { 5393 void __rcu **slots; 5394 struct maple_node *node = mte_to_node(enode); 5395 struct maple_enode *start; 5396 struct maple_tree mt; 5397 5398 MA_STATE(mas, &mt, 0, 0); 5399 5400 if (mte_is_leaf(enode)) 5401 goto free_leaf; 5402 5403 mt_init_flags(&mt, ma_flags); 5404 mas_lock(&mas); 5405 5406 mas.node = start = enode; 5407 slots = mas_destroy_descend(&mas, start, 0); 5408 node = mas_mn(&mas); 5409 do { 5410 enum maple_type type; 5411 unsigned char offset; 5412 5413 node->slot_len = mas_dead_leaves(&mas, slots); 5414 if (free) 5415 mt_free_bulk(node->slot_len, slots); 5416 offset = node->parent_slot + 1; 5417 mas.node = node->piv_parent; 5418 if (mas_mn(&mas) == node) 5419 goto start_slots_free; 5420 type = mte_node_type(mas.node); 5421 slots = ma_slots(mte_to_node(mas.node), type); 5422 if ((offset < mt_slots[type]) && (slots[offset])) { 5423 struct maple_enode *parent = mas.node; 5424 > 5425 mas.node = slots[offset]; 5426 slots = mas_destroy_descend(&mas, parent, offset); 5427 } 5428 node = mas_mn(&mas); 5429 } while (start != mas.node); 5430 5431 node = mas_mn(&mas); 5432 node->slot_len = mas_dead_leaves(&mas, slots); 5433 if (free) 5434 mt_free_bulk(node->slot_len, slots); 5435 5436 start_slots_free: 5437 mas_unlock(&mas); 5438 5439 free_leaf: 5440 if (free) 5441 mt_free_rcu(&node->rcu); 5442 } 5443 -- 0-DAY CI Kernel Test Service https://01.org/lkp