|
@@ -222,15 +222,18 @@ static int jffs2_create(struct inode *dir_i, struct dentry *dentry, int mode,
|
|
|
dir_i->i_mtime = dir_i->i_ctime = ITIME(je32_to_cpu(ri->ctime));
|
|
|
|
|
|
jffs2_free_raw_inode(ri);
|
|
|
- d_instantiate(dentry, inode);
|
|
|
|
|
|
D1(printk(KERN_DEBUG "jffs2_create: Created ino #%lu with mode %o, nlink %d(%d). nrpages %ld\n",
|
|
|
inode->i_ino, inode->i_mode, inode->i_nlink,
|
|
|
f->inocache->pino_nlink, inode->i_mapping->nrpages));
|
|
|
+
|
|
|
+ d_instantiate(dentry, inode);
|
|
|
+ unlock_new_inode(inode);
|
|
|
return 0;
|
|
|
|
|
|
fail:
|
|
|
make_bad_inode(inode);
|
|
|
+ unlock_new_inode(inode);
|
|
|
iput(inode);
|
|
|
jffs2_free_raw_inode(ri);
|
|
|
return ret;
|
|
@@ -360,8 +363,8 @@ static int jffs2_symlink (struct inode *dir_i, struct dentry *dentry, const char
|
|
|
/* Eeek. Wave bye bye */
|
|
|
mutex_unlock(&f->sem);
|
|
|
jffs2_complete_reservation(c);
|
|
|
- jffs2_clear_inode(inode);
|
|
|
- return PTR_ERR(fn);
|
|
|
+ ret = PTR_ERR(fn);
|
|
|
+ goto fail;
|
|
|
}
|
|
|
|
|
|
/* We use f->target field to store the target path. */
|
|
@@ -370,8 +373,8 @@ static int jffs2_symlink (struct inode *dir_i, struct dentry *dentry, const char
|
|
|
printk(KERN_WARNING "Can't allocate %d bytes of memory\n", targetlen + 1);
|
|
|
mutex_unlock(&f->sem);
|
|
|
jffs2_complete_reservation(c);
|
|
|
- jffs2_clear_inode(inode);
|
|
|
- return -ENOMEM;
|
|
|
+ ret = -ENOMEM;
|
|
|
+ goto fail;
|
|
|
}
|
|
|
|
|
|
memcpy(f->target, target, targetlen + 1);
|
|
@@ -386,30 +389,24 @@ static int jffs2_symlink (struct inode *dir_i, struct dentry *dentry, const char
|
|
|
jffs2_complete_reservation(c);
|
|
|
|
|
|
ret = jffs2_init_security(inode, dir_i);
|
|
|
- if (ret) {
|
|
|
- jffs2_clear_inode(inode);
|
|
|
- return ret;
|
|
|
- }
|
|
|
+ if (ret)
|
|
|
+ goto fail;
|
|
|
+
|
|
|
ret = jffs2_init_acl_post(inode);
|
|
|
- if (ret) {
|
|
|
- jffs2_clear_inode(inode);
|
|
|
- return ret;
|
|
|
- }
|
|
|
+ if (ret)
|
|
|
+ goto fail;
|
|
|
|
|
|
ret = jffs2_reserve_space(c, sizeof(*rd)+namelen, &alloclen,
|
|
|
ALLOC_NORMAL, JFFS2_SUMMARY_DIRENT_SIZE(namelen));
|
|
|
- if (ret) {
|
|
|
- /* Eep. */
|
|
|
- jffs2_clear_inode(inode);
|
|
|
- return ret;
|
|
|
- }
|
|
|
+ if (ret)
|
|
|
+ goto fail;
|
|
|
|
|
|
rd = jffs2_alloc_raw_dirent();
|
|
|
if (!rd) {
|
|
|
/* Argh. Now we treat it like a normal delete */
|
|
|
jffs2_complete_reservation(c);
|
|
|
- jffs2_clear_inode(inode);
|
|
|
- return -ENOMEM;
|
|
|
+ ret = -ENOMEM;
|
|
|
+ goto fail;
|
|
|
}
|
|
|
|
|
|
dir_f = JFFS2_INODE_INFO(dir_i);
|
|
@@ -437,8 +434,8 @@ static int jffs2_symlink (struct inode *dir_i, struct dentry *dentry, const char
|
|
|
jffs2_complete_reservation(c);
|
|
|
jffs2_free_raw_dirent(rd);
|
|
|
mutex_unlock(&dir_f->sem);
|
|
|
- jffs2_clear_inode(inode);
|
|
|
- return PTR_ERR(fd);
|
|
|
+ ret = PTR_ERR(fd);
|
|
|
+ goto fail;
|
|
|
}
|
|
|
|
|
|
dir_i->i_mtime = dir_i->i_ctime = ITIME(je32_to_cpu(rd->mctime));
|
|
@@ -453,7 +450,14 @@ static int jffs2_symlink (struct inode *dir_i, struct dentry *dentry, const char
|
|
|
jffs2_complete_reservation(c);
|
|
|
|
|
|
d_instantiate(dentry, inode);
|
|
|
+ unlock_new_inode(inode);
|
|
|
return 0;
|
|
|
+
|
|
|
+ fail:
|
|
|
+ make_bad_inode(inode);
|
|
|
+ unlock_new_inode(inode);
|
|
|
+ iput(inode);
|
|
|
+ return ret;
|
|
|
}
|
|
|
|
|
|
|
|
@@ -519,8 +523,8 @@ static int jffs2_mkdir (struct inode *dir_i, struct dentry *dentry, int mode)
|
|
|
/* Eeek. Wave bye bye */
|
|
|
mutex_unlock(&f->sem);
|
|
|
jffs2_complete_reservation(c);
|
|
|
- jffs2_clear_inode(inode);
|
|
|
- return PTR_ERR(fn);
|
|
|
+ ret = PTR_ERR(fn);
|
|
|
+ goto fail;
|
|
|
}
|
|
|
/* No data here. Only a metadata node, which will be
|
|
|
obsoleted by the first data write
|
|
@@ -531,30 +535,24 @@ static int jffs2_mkdir (struct inode *dir_i, struct dentry *dentry, int mode)
|
|
|
jffs2_complete_reservation(c);
|
|
|
|
|
|
ret = jffs2_init_security(inode, dir_i);
|
|
|
- if (ret) {
|
|
|
- jffs2_clear_inode(inode);
|
|
|
- return ret;
|
|
|
- }
|
|
|
+ if (ret)
|
|
|
+ goto fail;
|
|
|
+
|
|
|
ret = jffs2_init_acl_post(inode);
|
|
|
- if (ret) {
|
|
|
- jffs2_clear_inode(inode);
|
|
|
- return ret;
|
|
|
- }
|
|
|
+ if (ret)
|
|
|
+ goto fail;
|
|
|
|
|
|
ret = jffs2_reserve_space(c, sizeof(*rd)+namelen, &alloclen,
|
|
|
ALLOC_NORMAL, JFFS2_SUMMARY_DIRENT_SIZE(namelen));
|
|
|
- if (ret) {
|
|
|
- /* Eep. */
|
|
|
- jffs2_clear_inode(inode);
|
|
|
- return ret;
|
|
|
- }
|
|
|
+ if (ret)
|
|
|
+ goto fail;
|
|
|
|
|
|
rd = jffs2_alloc_raw_dirent();
|
|
|
if (!rd) {
|
|
|
/* Argh. Now we treat it like a normal delete */
|
|
|
jffs2_complete_reservation(c);
|
|
|
- jffs2_clear_inode(inode);
|
|
|
- return -ENOMEM;
|
|
|
+ ret = -ENOMEM;
|
|
|
+ goto fail;
|
|
|
}
|
|
|
|
|
|
dir_f = JFFS2_INODE_INFO(dir_i);
|
|
@@ -582,8 +580,8 @@ static int jffs2_mkdir (struct inode *dir_i, struct dentry *dentry, int mode)
|
|
|
jffs2_complete_reservation(c);
|
|
|
jffs2_free_raw_dirent(rd);
|
|
|
mutex_unlock(&dir_f->sem);
|
|
|
- jffs2_clear_inode(inode);
|
|
|
- return PTR_ERR(fd);
|
|
|
+ ret = PTR_ERR(fd);
|
|
|
+ goto fail;
|
|
|
}
|
|
|
|
|
|
dir_i->i_mtime = dir_i->i_ctime = ITIME(je32_to_cpu(rd->mctime));
|
|
@@ -599,7 +597,14 @@ static int jffs2_mkdir (struct inode *dir_i, struct dentry *dentry, int mode)
|
|
|
jffs2_complete_reservation(c);
|
|
|
|
|
|
d_instantiate(dentry, inode);
|
|
|
+ unlock_new_inode(inode);
|
|
|
return 0;
|
|
|
+
|
|
|
+ fail:
|
|
|
+ make_bad_inode(inode);
|
|
|
+ unlock_new_inode(inode);
|
|
|
+ iput(inode);
|
|
|
+ return ret;
|
|
|
}
|
|
|
|
|
|
static int jffs2_rmdir (struct inode *dir_i, struct dentry *dentry)
|
|
@@ -693,8 +698,8 @@ static int jffs2_mknod (struct inode *dir_i, struct dentry *dentry, int mode, de
|
|
|
/* Eeek. Wave bye bye */
|
|
|
mutex_unlock(&f->sem);
|
|
|
jffs2_complete_reservation(c);
|
|
|
- jffs2_clear_inode(inode);
|
|
|
- return PTR_ERR(fn);
|
|
|
+ ret = PTR_ERR(fn);
|
|
|
+ goto fail;
|
|
|
}
|
|
|
/* No data here. Only a metadata node, which will be
|
|
|
obsoleted by the first data write
|
|
@@ -705,30 +710,24 @@ static int jffs2_mknod (struct inode *dir_i, struct dentry *dentry, int mode, de
|
|
|
jffs2_complete_reservation(c);
|
|
|
|
|
|
ret = jffs2_init_security(inode, dir_i);
|
|
|
- if (ret) {
|
|
|
- jffs2_clear_inode(inode);
|
|
|
- return ret;
|
|
|
- }
|
|
|
+ if (ret)
|
|
|
+ goto fail;
|
|
|
+
|
|
|
ret = jffs2_init_acl_post(inode);
|
|
|
- if (ret) {
|
|
|
- jffs2_clear_inode(inode);
|
|
|
- return ret;
|
|
|
- }
|
|
|
+ if (ret)
|
|
|
+ goto fail;
|
|
|
|
|
|
ret = jffs2_reserve_space(c, sizeof(*rd)+namelen, &alloclen,
|
|
|
ALLOC_NORMAL, JFFS2_SUMMARY_DIRENT_SIZE(namelen));
|
|
|
- if (ret) {
|
|
|
- /* Eep. */
|
|
|
- jffs2_clear_inode(inode);
|
|
|
- return ret;
|
|
|
- }
|
|
|
+ if (ret)
|
|
|
+ goto fail;
|
|
|
|
|
|
rd = jffs2_alloc_raw_dirent();
|
|
|
if (!rd) {
|
|
|
/* Argh. Now we treat it like a normal delete */
|
|
|
jffs2_complete_reservation(c);
|
|
|
- jffs2_clear_inode(inode);
|
|
|
- return -ENOMEM;
|
|
|
+ ret = -ENOMEM;
|
|
|
+ goto fail;
|
|
|
}
|
|
|
|
|
|
dir_f = JFFS2_INODE_INFO(dir_i);
|
|
@@ -759,8 +758,8 @@ static int jffs2_mknod (struct inode *dir_i, struct dentry *dentry, int mode, de
|
|
|
jffs2_complete_reservation(c);
|
|
|
jffs2_free_raw_dirent(rd);
|
|
|
mutex_unlock(&dir_f->sem);
|
|
|
- jffs2_clear_inode(inode);
|
|
|
- return PTR_ERR(fd);
|
|
|
+ ret = PTR_ERR(fd);
|
|
|
+ goto fail;
|
|
|
}
|
|
|
|
|
|
dir_i->i_mtime = dir_i->i_ctime = ITIME(je32_to_cpu(rd->mctime));
|
|
@@ -775,8 +774,14 @@ static int jffs2_mknod (struct inode *dir_i, struct dentry *dentry, int mode, de
|
|
|
jffs2_complete_reservation(c);
|
|
|
|
|
|
d_instantiate(dentry, inode);
|
|
|
-
|
|
|
+ unlock_new_inode(inode);
|
|
|
return 0;
|
|
|
+
|
|
|
+ fail:
|
|
|
+ make_bad_inode(inode);
|
|
|
+ unlock_new_inode(inode);
|
|
|
+ iput(inode);
|
|
|
+ return ret;
|
|
|
}
|
|
|
|
|
|
static int jffs2_rename (struct inode *old_dir_i, struct dentry *old_dentry,
|