mirror of
				https://git.proxmox.com/git/mirror_zfs.git
				synced 2025-10-25 01:14:59 +03:00 
			
		
		
		
	Fix memory leaks in zfsvfs_create_impl()
This patch simply fixes some small memory leaks that can happen during error handling in zfsvfs_create_impl(). If the function fails, it frees all the memory / references it created. Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Reviewed-by: Tony Hutter <hutter2@llnl.gov> Signed-off-by: Tom Caputi <tcaputi@datto.com> Closes #8490
This commit is contained in:
		
							parent
							
								
									c742bf1e68
								
							
						
					
					
						commit
						04a3b0796c
					
				| @ -1035,14 +1035,6 @@ zfsvfs_init(zfsvfs_t *zfsvfs, objset_t *os) | ||||
| 			zfsvfs->z_xattr_sa = B_TRUE; | ||||
| 	} | ||||
| 
 | ||||
| 	error = sa_setup(os, sa_obj, zfs_attr_table, ZPL_END, | ||||
| 	    &zfsvfs->z_attr_table); | ||||
| 	if (error != 0) | ||||
| 		return (error); | ||||
| 
 | ||||
| 	if (zfsvfs->z_version >= ZPL_VERSION_SA) | ||||
| 		sa_register_update_callback(os, zfs_sa_upgrade); | ||||
| 
 | ||||
| 	error = zap_lookup(os, MASTER_NODE_OBJ, ZFS_ROOT_OBJ, 8, 1, | ||||
| 	    &zfsvfs->z_root); | ||||
| 	if (error != 0) | ||||
| @ -1116,6 +1108,14 @@ zfsvfs_init(zfsvfs_t *zfsvfs, objset_t *os) | ||||
| 	else if (error != 0) | ||||
| 		return (error); | ||||
| 
 | ||||
| 	error = sa_setup(os, sa_obj, zfs_attr_table, ZPL_END, | ||||
| 	    &zfsvfs->z_attr_table); | ||||
| 	if (error != 0) | ||||
| 		return (error); | ||||
| 
 | ||||
| 	if (zfsvfs->z_version >= ZPL_VERSION_SA) | ||||
| 		sa_register_update_callback(os, zfs_sa_upgrade); | ||||
| 
 | ||||
| 	return (0); | ||||
| } | ||||
| 
 | ||||
| @ -1142,6 +1142,11 @@ zfsvfs_create(const char *osname, boolean_t readonly, zfsvfs_t **zfvp) | ||||
| 	return (error); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| /*
 | ||||
|  * Note: zfsvfs is assumed to be malloc'd, and will be freed by this function | ||||
|  * on a failure.  Do not pass in a statically allocated zfsvfs. | ||||
|  */ | ||||
| int | ||||
| zfsvfs_create_impl(zfsvfs_t **zfvp, zfsvfs_t *zfsvfs, objset_t *os) | ||||
| { | ||||
| @ -1174,7 +1179,7 @@ zfsvfs_create_impl(zfsvfs_t **zfvp, zfsvfs_t *zfsvfs, objset_t *os) | ||||
| 	error = zfsvfs_init(zfsvfs, os); | ||||
| 	if (error != 0) { | ||||
| 		*zfvp = NULL; | ||||
| 		kmem_free(zfsvfs, sizeof (zfsvfs_t)); | ||||
| 		zfsvfs_free(zfsvfs); | ||||
| 		return (error); | ||||
| 	} | ||||
| 
 | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Tom Caputi
						Tom Caputi