mirror of
				git://git.yoctoproject.org/linux-yocto.git
				synced 2025-10-22 23:13:01 +02:00 
			
		
		
		
	mbcache: Avoid nesting of cache->c_list_lock under bit locks
Commit307af6c879("mbcache: automatically delete entries from cache on freeing") started nesting cache->c_list_lock under the bit locks protecting hash buckets of the mbcache hash table in mb_cache_entry_create(). This causes problems for real-time kernels because there spinlocks are sleeping locks while bitlocks stay atomic. Luckily the nesting is easy to avoid by holding entry reference until the entry is added to the LRU list. This makes sure we cannot race with entry deletion. Cc: stable@kernel.org Fixes:307af6c879("mbcache: automatically delete entries from cache on freeing") Reported-by: Mike Galbraith <efault@gmx.de> Signed-off-by: Jan Kara <jack@suse.cz> Link: https://lore.kernel.org/r/20220908091032.10513-1-jack@suse.cz Signed-off-by: Theodore Ts'o <tytso@mit.edu>
This commit is contained in:
		
							parent
							
								
									34fc8768ec
								
							
						
					
					
						commit
						5fc4cbd9fd
					
				
							
								
								
									
										17
									
								
								fs/mbcache.c
									
									
									
									
									
								
							
							
						
						
									
										17
									
								
								fs/mbcache.c
									
									
									
									
									
								
							|  | @ -90,8 +90,14 @@ int mb_cache_entry_create(struct mb_cache *cache, gfp_t mask, u32 key, | |||
| 		return -ENOMEM; | ||||
| 
 | ||||
| 	INIT_LIST_HEAD(&entry->e_list); | ||||
| 	/* Initial hash reference */ | ||||
| 	atomic_set(&entry->e_refcnt, 1); | ||||
| 	/*
 | ||||
| 	 * We create entry with two references. One reference is kept by the | ||||
| 	 * hash table, the other reference is used to protect us from | ||||
| 	 * mb_cache_entry_delete_or_get() until the entry is fully setup. This | ||||
| 	 * avoids nesting of cache->c_list_lock into hash table bit locks which | ||||
| 	 * is problematic for RT. | ||||
| 	 */ | ||||
| 	atomic_set(&entry->e_refcnt, 2); | ||||
| 	entry->e_key = key; | ||||
| 	entry->e_value = value; | ||||
| 	entry->e_reusable = reusable; | ||||
|  | @ -106,15 +112,12 @@ int mb_cache_entry_create(struct mb_cache *cache, gfp_t mask, u32 key, | |||
| 		} | ||||
| 	} | ||||
| 	hlist_bl_add_head(&entry->e_hash_list, head); | ||||
| 	/*
 | ||||
| 	 * Add entry to LRU list before it can be found by | ||||
| 	 * mb_cache_entry_delete() to avoid races | ||||
| 	 */ | ||||
| 	hlist_bl_unlock(head); | ||||
| 	spin_lock(&cache->c_list_lock); | ||||
| 	list_add_tail(&entry->e_list, &cache->c_list); | ||||
| 	cache->c_entry_count++; | ||||
| 	spin_unlock(&cache->c_list_lock); | ||||
| 	hlist_bl_unlock(head); | ||||
| 	mb_cache_entry_put(cache, entry); | ||||
| 
 | ||||
| 	return 0; | ||||
| } | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Jan Kara
						Jan Kara