mirror of
				https://git.proxmox.com/git/mirror_zfs.git
				synced 2025-10-25 01:14:59 +03:00 
			
		
		
		
	rmdir(2) should return ENOTEMPTY
Under Solaris the behavior for rmdir(2) is to return EEXIST when a directory still contains entries. However, on Linux ENOTEMPTY is the expected return value with EEXIST being technically allowed. According to rmdir(2): ENOTEMPTY pathname contains entries other than . and .. ; or, pathname has .. as its final component. POSIX.1-2001 also allows EEXIST for this condition. Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov> Closes #895
This commit is contained in:
		
							parent
							
								
									c90ea65511
								
							
						
					
					
						commit
						cd38ac58a3
					
				| @ -837,8 +837,8 @@ zfs_dropname(zfs_dirlock_t *dl, znode_t *zp, znode_t *dzp, dmu_tx_t *tx, | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /*
 | /*
 | ||||||
|  * Unlink zp from dl, and mark zp for deletion if this was the last link. |  * Unlink zp from dl, and mark zp for deletion if this was the last link. Can | ||||||
|  * Can fail if zp is a mount point (EBUSY) or a non-empty directory (EEXIST). |  * fail if zp is a mount point (EBUSY) or a non-empty directory (ENOTEMPTY). | ||||||
|  * If 'unlinkedp' is NULL, we put unlinked znodes on the unlinked list. |  * If 'unlinkedp' is NULL, we put unlinked znodes on the unlinked list. | ||||||
|  * If it's non-NULL, we use it to indicate whether the znode needs deletion, |  * If it's non-NULL, we use it to indicate whether the znode needs deletion, | ||||||
|  * and it's the caller's job to do it. |  * and it's the caller's job to do it. | ||||||
| @ -865,7 +865,7 @@ zfs_link_destroy(zfs_dirlock_t *dl, znode_t *zp, dmu_tx_t *tx, int flag, | |||||||
| 
 | 
 | ||||||
| 		if (zp_is_dir && !zfs_dirempty(zp)) { | 		if (zp_is_dir && !zfs_dirempty(zp)) { | ||||||
| 			mutex_exit(&zp->z_lock); | 			mutex_exit(&zp->z_lock); | ||||||
| 			return (EEXIST); | 			return (ENOTEMPTY); | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		/*
 | 		/*
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Brian Behlendorf
						Brian Behlendorf