|
@@ -606,8 +606,8 @@ static int ubifs_readdir(struct file *file, struct dir_context *ctx)
|
|
|
}
|
|
|
|
|
|
while (1) {
|
|
|
- dbg_gen("feed '%s', ino %llu, new f_pos %#x",
|
|
|
- dent->name, (unsigned long long)le64_to_cpu(dent->inum),
|
|
|
+ dbg_gen("ino %llu, new f_pos %#x",
|
|
|
+ (unsigned long long)le64_to_cpu(dent->inum),
|
|
|
key_hash_flash(c, &dent->key));
|
|
|
ubifs_assert(le64_to_cpu(dent->ch.sqnum) >
|
|
|
ubifs_inode(dir)->creat_sqnum);
|
|
@@ -748,6 +748,11 @@ static int ubifs_link(struct dentry *old_dentry, struct inode *dir,
|
|
|
goto out_fname;
|
|
|
|
|
|
lock_2_inodes(dir, inode);
|
|
|
+
|
|
|
+ /* Handle O_TMPFILE corner case, it is allowed to link a O_TMPFILE. */
|
|
|
+ if (inode->i_nlink == 0)
|
|
|
+ ubifs_delete_orphan(c, inode->i_ino);
|
|
|
+
|
|
|
inc_nlink(inode);
|
|
|
ihold(inode);
|
|
|
inode->i_ctime = ubifs_current_time(inode);
|
|
@@ -768,6 +773,8 @@ out_cancel:
|
|
|
dir->i_size -= sz_change;
|
|
|
dir_ui->ui_size = dir->i_size;
|
|
|
drop_nlink(inode);
|
|
|
+ if (inode->i_nlink == 0)
|
|
|
+ ubifs_add_orphan(c, inode->i_ino);
|
|
|
unlock_2_inodes(dir, inode);
|
|
|
ubifs_release_budget(c, &req);
|
|
|
iput(inode);
|
|
@@ -1068,8 +1075,10 @@ static int ubifs_mknod(struct inode *dir, struct dentry *dentry,
|
|
|
}
|
|
|
|
|
|
err = fscrypt_setup_filename(dir, &dentry->d_name, 0, &nm);
|
|
|
- if (err)
|
|
|
+ if (err) {
|
|
|
+ kfree(dev);
|
|
|
goto out_budg;
|
|
|
+ }
|
|
|
|
|
|
sz_change = CALC_DENT_SIZE(fname_len(&nm));
|
|
|
|
|
@@ -1316,9 +1325,6 @@ static int do_rename(struct inode *old_dir, struct dentry *old_dentry,
|
|
|
unsigned int uninitialized_var(saved_nlink);
|
|
|
struct fscrypt_name old_nm, new_nm;
|
|
|
|
|
|
- if (flags & ~RENAME_NOREPLACE)
|
|
|
- return -EINVAL;
|
|
|
-
|
|
|
/*
|
|
|
* Budget request settings: deletion direntry, new direntry, removing
|
|
|
* the old inode, and changing old and new parent directory inodes.
|