mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-18 22:14:16 +00:00 
			
		
		
		
	bcachefs: eliminate the uninitialized compilation warning in bch2_reconstruct_snapshots
When compiling the bcachefs-tools, the following compilation warning
is reported:
    libbcachefs/snapshot.c: In function ‘bch2_reconstruct_snapshots’:
    libbcachefs/snapshot.c:915:19: warning: ‘tree_id’ may be used uninitialized in this function [-Wmaybe-uninitialized]
      915 |  snapshot->v.tree = cpu_to_le32(tree_id);
    libbcachefs/snapshot.c:903:6: note: ‘tree_id’ was declared here
      903 |  u32 tree_id;
       |      ^~~~~~~
This is a false alert, because @tree_id is changed in
bch2_snapshot_tree_create after it returns 0. And if this function
returns other value, @tree_id wouldn't be used. Thus there should
be nothing wrong in logical.
Although the report itself is a false alert, we can still make it more
explicit by setting the initial value of @tree_id to 0 (an invalid
tree ID).
Fixes: a292be3b68 ("bcachefs: Reconstruct missing snapshot nodes")
Signed-off-by: Hongbo Li <lihongbo22@huawei.com>
Signed-off-by: Kent Overstreet <kent.overstreet@linux.dev>
			
			
This commit is contained in:
		
							parent
							
								
									56522d7276
								
							
						
					
					
						commit
						0af0b963b5
					
				
					 1 changed files with 2 additions and 1 deletions
				
			
		|  | @ -900,7 +900,8 @@ static int check_snapshot_exists(struct btree_trans *trans, u32 id) | |||
| 	if (bch2_snapshot_equiv(c, id)) | ||||
| 		return 0; | ||||
| 
 | ||||
| 	u32 tree_id; | ||||
| 	/* 0 is an invalid tree ID */ | ||||
| 	u32 tree_id = 0; | ||||
| 	int ret = bch2_snapshot_tree_create(trans, id, 0, &tree_id); | ||||
| 	if (ret) | ||||
| 		return ret; | ||||
|  |  | |||
		Loading…
	
	Add table
		
		Reference in a new issue
	
	 Hongbo Li
						Hongbo Li