/Linux-v5.15/fs/nfs/ |
D | unlink.c | 261 struct inode *old_dir = data->old_dir; in nfs_async_rename_done() local 265 trace_nfs_sillyrename_rename(old_dir, old_dentry, in nfs_async_rename_done() 267 if (!NFS_PROTO(old_dir)->rename_done(task, old_dir, new_dir)) { in nfs_async_rename_done() 283 struct super_block *sb = data->old_dir->i_sb; in nfs_async_rename_release() 291 spin_lock(&data->old_dir->i_lock); in nfs_async_rename_release() 292 nfs_force_lookup_revalidate(data->old_dir); in nfs_async_rename_release() 293 spin_unlock(&data->old_dir->i_lock); in nfs_async_rename_release() 294 if (data->new_dir != data->old_dir) { in nfs_async_rename_release() 303 iput(data->old_dir); in nfs_async_rename_release() 313 NFS_PROTO(data->old_dir)->rename_rpc_prepare(task, data); in nfs_rename_prepare() [all …]
|
D | nfstrace.h | 744 const struct inode *old_dir, 750 TP_ARGS(old_dir, old_dentry, new_dir, new_dentry), 754 __field(u64, old_dir) 761 __entry->dev = old_dir->i_sb->s_dev; 762 __entry->old_dir = NFS_FILEID(old_dir); 771 (unsigned long long)__entry->old_dir, 781 const struct inode *old_dir, \ 786 TP_ARGS(old_dir, old_dentry, new_dir, new_dentry)) 790 const struct inode *old_dir, 797 TP_ARGS(old_dir, old_dentry, new_dir, new_dentry, error), [all …]
|
/Linux-v5.15/fs/affs/ |
D | namei.c | 405 affs_rename(struct inode *old_dir, struct dentry *old_dentry, in affs_rename() argument 408 struct super_block *sb = old_dir->i_sb; in affs_rename() 431 affs_lock_dir(old_dir); in affs_rename() 432 retval = affs_remove_hash(old_dir, bh); in affs_rename() 433 affs_unlock_dir(old_dir); in affs_rename() 446 mark_buffer_dirty_inode(bh, retval ? old_dir : new_dir); in affs_rename() 452 affs_xrename(struct inode *old_dir, struct dentry *old_dentry, in affs_xrename() argument 456 struct super_block *sb = old_dir->i_sb; in affs_xrename() 472 affs_lock_dir(old_dir); in affs_xrename() 473 retval = affs_remove_hash(old_dir, bh_old); in affs_xrename() [all …]
|
/Linux-v5.15/fs/fat/ |
D | namei_msdos.c | 428 static int do_msdos_rename(struct inode *old_dir, unsigned char *old_name, in do_msdos_rename() argument 445 err = fat_scan(old_dir, old_name, &old_sinfo); in do_msdos_rename() 452 update_dotdot = (is_dir && old_dir != new_dir); in do_msdos_rename() 473 if (IS_DIRSYNC(old_dir)) { in do_msdos_rename() 482 inode_inc_iversion(old_dir); in do_msdos_rename() 483 fat_truncate_time(old_dir, NULL, S_CTIME|S_MTIME); in do_msdos_rename() 484 if (IS_DIRSYNC(old_dir)) in do_msdos_rename() 485 (void)fat_sync_inode(old_dir); in do_msdos_rename() 487 mark_inode_dirty(old_dir); in do_msdos_rename() 533 drop_nlink(old_dir); in do_msdos_rename() [all …]
|
D | namei_vfat.c | 896 static int vfat_rename(struct user_namespace *mnt_userns, struct inode *old_dir, in vfat_rename() argument 907 struct super_block *sb = old_dir->i_sb; in vfat_rename() 916 err = vfat_find(old_dir, &old_dentry->d_name, &old_sinfo); in vfat_rename() 921 update_dotdot = (is_dir && old_dir != new_dir); in vfat_rename() 929 ts = current_time(old_dir); in vfat_rename() 964 drop_nlink(old_dir); in vfat_rename() 969 err = fat_remove_entries(old_dir, &old_sinfo); /* and releases bh */ in vfat_rename() 973 inode_inc_iversion(old_dir); in vfat_rename() 974 fat_truncate_time(old_dir, &ts, S_CTIME|S_MTIME); in vfat_rename() 975 if (IS_DIRSYNC(old_dir)) in vfat_rename() [all …]
|
/Linux-v5.15/fs/ubifs/ |
D | dir.c | 1250 static int do_rename(struct inode *old_dir, struct dentry *old_dentry, in do_rename() argument 1254 struct ubifs_info *c = old_dir->i_sb->s_fs_info; in do_rename() 1260 int err, release, sync = 0, move = (new_dir != old_dir); in do_rename() 1281 old_dentry, old_inode->i_ino, old_dir->i_ino, in do_rename() 1298 err = fscrypt_setup_filename(old_dir, &old_dentry->d_name, 0, &old_nm); in do_rename() 1334 err = do_tmpfile(old_dir, old_dentry, S_IFCHR | WHITEOUT_MODE, &whiteout); in do_rename() 1350 lock_4_inodes(old_dir, new_dir, new_inode, whiteout); in do_rename() 1356 time = current_time(old_dir); in do_rename() 1366 drop_nlink(old_dir); in do_rename() 1380 drop_nlink(old_dir); in do_rename() [all …]
|
/Linux-v5.15/fs/f2fs/ |
D | namei.c | 923 static int f2fs_rename(struct inode *old_dir, struct dentry *old_dentry, in f2fs_rename() argument 927 struct f2fs_sb_info *sbi = F2FS_I_SB(old_dir); in f2fs_rename() 956 if (old_dir == new_dir && !new_inode) { in f2fs_rename() 957 err = f2fs_try_convert_inline_dir(old_dir, new_dentry); in f2fs_rename() 963 err = f2fs_create_whiteout(old_dir, &whiteout); in f2fs_rename() 968 err = dquot_initialize(old_dir); in f2fs_rename() 983 old_entry = f2fs_find_entry(old_dir, &old_dentry->d_name, &old_page); in f2fs_rename() 1062 f2fs_delete_entry(old_entry, old_page, old_dir, NULL); in f2fs_rename() 1079 if (old_dir != new_dir && !whiteout) in f2fs_rename() 1084 f2fs_i_links_write(old_dir, false); in f2fs_rename() [all …]
|
/Linux-v5.15/fs/reiserfs/ |
D | namei.c | 1311 struct inode *old_dir, struct dentry *old_dentry, in reiserfs_rename() argument 1343 4 * REISERFS_QUOTA_TRANS_BLOCKS(old_dir->i_sb); in reiserfs_rename() 1345 retval = dquot_initialize(old_dir); in reiserfs_rename() 1360 reiserfs_write_lock(old_dir->i_sb); in reiserfs_rename() 1362 reiserfs_find_entry(old_dir, old_dentry->d_name.name, in reiserfs_rename() 1367 reiserfs_write_unlock(old_dir->i_sb); in reiserfs_rename() 1372 reiserfs_write_unlock(old_dir->i_sb); in reiserfs_rename() 1385 reiserfs_write_unlock(old_dir->i_sb); in reiserfs_rename() 1400 reiserfs_write_unlock(old_dir->i_sb); in reiserfs_rename() 1405 if (dot_dot_de.de_objectid != old_dir->i_ino) { in reiserfs_rename() [all …]
|
/Linux-v5.15/fs/jfs/ |
D | namei.c | 1062 static int jfs_rename(struct user_namespace *mnt_userns, struct inode *old_dir, in jfs_rename() argument 1088 rc = dquot_initialize(old_dir); in jfs_rename() 1107 rc = dtSearch(old_dir, &old_dname, &ino, &btstack, JFS_LOOKUP); in jfs_rename() 1158 if (old_dir != new_dir) in jfs_rename() 1159 mutex_lock_nested(&JFS_IP(old_dir)->commit_mutex, in jfs_rename() 1178 if (old_dir != new_dir) in jfs_rename() 1179 mutex_unlock(&JFS_IP(old_dir)->commit_mutex); in jfs_rename() 1233 rc = dtDelete(tid, old_dir, &old_dname, &ino, JFS_REMOVE); in jfs_rename() 1241 drop_nlink(old_dir); in jfs_rename() 1242 if (old_dir != new_dir) { in jfs_rename() [all …]
|
/Linux-v5.15/fs/debugfs/ |
D | inode.c | 756 struct dentry *debugfs_rename(struct dentry *old_dir, struct dentry *old_dentry, in debugfs_rename() argument 763 if (IS_ERR(old_dir)) in debugfs_rename() 764 return old_dir; in debugfs_rename() 770 trap = lock_rename(new_dir, old_dir); in debugfs_rename() 772 if (d_really_is_negative(old_dir) || d_really_is_negative(new_dir)) in debugfs_rename() 785 error = simple_rename(&init_user_ns, d_inode(old_dir), old_dentry, in debugfs_rename() 792 fsnotify_move(d_inode(old_dir), d_inode(new_dir), &old_name.name, in debugfs_rename() 796 unlock_rename(new_dir, old_dir); in debugfs_rename() 802 unlock_rename(new_dir, old_dir); in debugfs_rename()
|
/Linux-v5.15/fs/bfs/ |
D | dir.c | 202 static int bfs_rename(struct user_namespace *mnt_userns, struct inode *old_dir, in bfs_rename() argument 223 old_bh = bfs_find_entry(old_dir, &old_dentry->d_name, &old_de); in bfs_rename() 243 old_dir->i_ctime = old_dir->i_mtime = current_time(old_dir); in bfs_rename() 244 mark_inode_dirty(old_dir); in bfs_rename() 249 mark_buffer_dirty_inode(old_bh, old_dir); in bfs_rename()
|
/Linux-v5.15/fs/hpfs/ |
D | namei.c | 514 static int hpfs_rename(struct user_namespace *mnt_userns, struct inode *old_dir, in hpfs_rename() argument 549 if (!(dep = map_dirent(old_dir, hpfs_i(old_dir)->i_dno, old_name, old_len, &dno, &qbh))) { in hpfs_rename() 559 if ((r = hpfs_remove_dirent(old_dir, dno, dep, &qbh, 1)) != 2) { in hpfs_rename() 576 if (new_dir == old_dir) hpfs_brelse4(&qbh); in hpfs_rename() 581 if (new_dir != old_dir) hpfs_brelse4(&qbh); in hpfs_rename() 585 if (new_dir == old_dir) in hpfs_rename() 586 if (!(dep = map_dirent(old_dir, hpfs_i(old_dir)->i_dno, old_name, old_len, &dno, &qbh))) { in hpfs_rename() 592 if ((r = hpfs_remove_dirent(old_dir, dno, dep, &qbh, 0))) { in hpfs_rename() 602 drop_nlink(old_dir); in hpfs_rename() 614 hpfs_update_directory_times(old_dir); in hpfs_rename()
|
/Linux-v5.15/fs/ocfs2/ |
D | namei.c | 687 struct inode *old_dir = d_inode(old_dentry->d_parent); in ocfs2_link() local 711 err = ocfs2_double_lock(osb, &old_dir_bh, old_dir, in ocfs2_link() 737 err = ocfs2_lookup_ino_from_name(old_dir, old_dentry->d_name.name, in ocfs2_link() 830 ocfs2_double_unlock(old_dir, dir); in ocfs2_link() 1201 struct inode *old_dir, in ocfs2_rename() argument 1221 u32 old_dir_nlink = old_dir->i_nlink; in ocfs2_rename() 1236 trace_ocfs2_rename(old_dir, old_dentry, new_dir, new_dentry, in ocfs2_rename() 1240 status = dquot_initialize(old_dir); in ocfs2_rename() 1251 osb = OCFS2_SB(old_dir->i_sb); in ocfs2_rename() 1269 if (old_dir != new_dir && S_ISDIR(old_inode->i_mode)) { in ocfs2_rename() [all …]
|
D | dcache.c | 441 struct inode *old_dir, struct inode *new_dir) in ocfs2_dentry_move() argument 444 struct ocfs2_super *osb = OCFS2_SB(old_dir->i_sb); in ocfs2_dentry_move() 453 if (old_dir == new_dir) in ocfs2_dentry_move()
|
D | dcache.h | 38 struct inode *old_dir, struct inode *new_dir);
|
/Linux-v5.15/fs/ufs/ |
D | namei.c | 246 static int ufs_rename(struct user_namespace *mnt_userns, struct inode *old_dir, in ufs_rename() argument 261 old_de = ufs_find_entry(old_dir, &old_dentry->d_name, &old_page); in ufs_rename() 303 ufs_delete_entry(old_dir, old_de, old_page); in ufs_rename() 307 if (old_dir != new_dir) in ufs_rename() 313 inode_dec_link_count(old_dir); in ufs_rename()
|
/Linux-v5.15/fs/nilfs2/ |
D | namei.c | 344 struct inode *old_dir, struct dentry *old_dentry, in nilfs_rename() argument 360 err = nilfs_transaction_begin(old_dir->i_sb, &ti, 1); in nilfs_rename() 365 old_de = nilfs_find_entry(old_dir, &old_dentry->d_name, &old_page); in nilfs_rename() 415 drop_nlink(old_dir); in nilfs_rename() 417 nilfs_mark_inode_dirty(old_dir); in nilfs_rename() 420 err = nilfs_transaction_commit(old_dir->i_sb); in nilfs_rename() 432 nilfs_transaction_abort(old_dir->i_sb); in nilfs_rename()
|
/Linux-v5.15/fs/crypto/ |
D | hooks.c | 71 int __fscrypt_prepare_rename(struct inode *old_dir, struct dentry *old_dentry, in __fscrypt_prepare_rename() argument 83 if (old_dir != new_dir) { in __fscrypt_prepare_rename() 90 IS_ENCRYPTED(old_dir) && in __fscrypt_prepare_rename() 91 !fscrypt_has_permitted_context(old_dir, in __fscrypt_prepare_rename()
|
/Linux-v5.15/fs/ext2/ |
D | namei.c | 325 struct inode * old_dir, struct dentry * old_dentry, in ext2_rename() argument 342 err = dquot_initialize(old_dir); in ext2_rename() 350 old_de = ext2_find_entry(old_dir, &old_dentry->d_name, &old_page, in ext2_rename() 403 if (old_dir != new_dir) in ext2_rename() 408 inode_dec_link_count(old_dir); in ext2_rename()
|
/Linux-v5.15/fs/coda/ |
D | dir.c | 298 static int coda_rename(struct user_namespace *mnt_userns, struct inode *old_dir, in coda_rename() argument 311 error = venus_rename(old_dir->i_sb, coda_i2f(old_dir), in coda_rename() 317 coda_dir_drop_nlink(old_dir); in coda_rename() 320 coda_dir_update_mtime(old_dir); in coda_rename() 324 coda_flag_inode(old_dir, C_VATTR); in coda_rename()
|
/Linux-v5.15/include/linux/ |
D | fsnotify.h | 138 static inline void fsnotify_move(struct inode *old_dir, struct inode *new_dir, in fsnotify_move() argument 149 if (old_dir == new_dir) in fsnotify_move() 157 fsnotify_name(old_dir, old_dir_mask, source, old_name, fs_cookie); in fsnotify_move()
|
D | fscrypt.h | 340 int __fscrypt_prepare_rename(struct inode *old_dir, struct dentry *old_dentry, 623 static inline int __fscrypt_prepare_rename(struct inode *old_dir, in __fscrypt_prepare_rename() argument 843 static inline int fscrypt_prepare_rename(struct inode *old_dir, in fscrypt_prepare_rename() argument 849 if (IS_ENCRYPTED(old_dir) || IS_ENCRYPTED(new_dir)) in fscrypt_prepare_rename() 850 return __fscrypt_prepare_rename(old_dir, old_dentry, in fscrypt_prepare_rename()
|
/Linux-v5.15/fs/exfat/ |
D | namei.c | 1330 struct inode *old_dir, struct dentry *old_dentry, in exfat_rename() argument 1335 struct super_block *sb = old_dir->i_sb; in exfat_rename() 1351 err = __exfat_rename(old_dir, EXFAT_I(old_inode), new_dir, new_dentry); in exfat_rename() 1373 if (S_ISDIR(old_inode->i_mode) && old_dir != new_dir) { in exfat_rename() 1374 drop_nlink(old_dir); in exfat_rename() 1379 inode_inc_iversion(old_dir); in exfat_rename() 1380 old_dir->i_ctime = old_dir->i_mtime = current_time(old_dir); in exfat_rename() 1381 if (IS_DIRSYNC(old_dir)) in exfat_rename() 1382 exfat_sync_inode(old_dir); in exfat_rename() 1384 mark_inode_dirty(old_dir); in exfat_rename()
|
/Linux-v5.15/fs/hfs/ |
D | dir.c | 283 static int hfs_rename(struct user_namespace *mnt_userns, struct inode *old_dir, in hfs_rename() argument 300 old_dir, &old_dentry->d_name, in hfs_rename() 303 hfs_cat_build_key(old_dir->i_sb, in hfs_rename()
|
/Linux-v5.15/fs/udf/ |
D | namei.c | 1073 static int udf_rename(struct user_namespace *mnt_userns, struct inode *old_dir, in udf_rename() argument 1090 ofi = udf_find_entry(old_dir, &old_dentry->d_name, &ofibh, &ocfi); in udf_rename() 1101 if (!ofi || udf_get_lb_pblock(old_dir->i_sb, &tloc, 0) in udf_rename() 1143 old_dir->i_ino) in udf_rename() 1169 ofi = udf_find_entry(old_dir, &old_dentry->d_name, &ofibh, &ocfi); in udf_rename() 1170 udf_delete_entry(old_dir, ofi, &ofibh, &ocfi); in udf_rename() 1176 old_dir->i_ctime = old_dir->i_mtime = current_time(old_dir); in udf_rename() 1178 mark_inode_dirty(old_dir); in udf_rename() 1189 inode_dec_link_count(old_dir); in udf_rename()
|