mirror of
				https://git.proxmox.com/git/mirror_zfs.git
				synced 2025-10-25 01:14:59 +03:00 
			
		
		
		
	Fix NULL pointer dereference in dbuf_prefetch_indirect_done()
When ZFS is built with assertions, a prefetch is done on a redacted blkptr and `dpa->dpa_dnode` is NULL, we will have a NULL pointer dereference in `dbuf_prefetch_indirect_done()`. Both Coverity and Clang's Static Analyzer caught this. Reported-by: Coverity (CID 1524671) Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Reviewed-by: Ryan Moeller <ryan@iXsystems.com> Signed-off-by: Richard Yao <richard.yao@alumni.stonybrook.edu> Closes #14210
This commit is contained in:
		
							parent
							
								
									887fb37843
								
							
						
					
					
						commit
						97fac0fb70
					
				| @ -3322,10 +3322,10 @@ dbuf_prefetch_indirect_done(zio_t *zio, const zbookmark_phys_t *zb, | |||||||
| 	blkptr_t *bp = ((blkptr_t *)abuf->b_data) + | 	blkptr_t *bp = ((blkptr_t *)abuf->b_data) + | ||||||
| 	    P2PHASE(nextblkid, 1ULL << dpa->dpa_epbs); | 	    P2PHASE(nextblkid, 1ULL << dpa->dpa_epbs); | ||||||
| 
 | 
 | ||||||
| 	ASSERT(!BP_IS_REDACTED(bp) || | 	ASSERT(!BP_IS_REDACTED(bp) || (dpa->dpa_dnode && | ||||||
| 	    dsl_dataset_feature_is_active( | 	    dsl_dataset_feature_is_active( | ||||||
| 	    dpa->dpa_dnode->dn_objset->os_dsl_dataset, | 	    dpa->dpa_dnode->dn_objset->os_dsl_dataset, | ||||||
| 	    SPA_FEATURE_REDACTED_DATASETS)); | 	    SPA_FEATURE_REDACTED_DATASETS))); | ||||||
| 	if (BP_IS_HOLE(bp) || BP_IS_REDACTED(bp)) { | 	if (BP_IS_HOLE(bp) || BP_IS_REDACTED(bp)) { | ||||||
| 		arc_buf_destroy(abuf, private); | 		arc_buf_destroy(abuf, private); | ||||||
| 		dbuf_prefetch_fini(dpa, B_TRUE); | 		dbuf_prefetch_fini(dpa, B_TRUE); | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Richard Yao
						Richard Yao