diff options
Diffstat (limited to 'fs/ubifs/journal.c')
-rw-r--r-- | fs/ubifs/journal.c | 30 |
1 files changed, 14 insertions, 16 deletions
diff --git a/fs/ubifs/journal.c b/fs/ubifs/journal.c index 666ad82ec51a..3bc3fc947099 100644 --- a/fs/ubifs/journal.c +++ b/fs/ubifs/journal.c | |||
@@ -447,13 +447,11 @@ static int get_dent_type(int mode) | |||
447 | * @ino: buffer in which to pack inode node | 447 | * @ino: buffer in which to pack inode node |
448 | * @inode: inode to pack | 448 | * @inode: inode to pack |
449 | * @last: indicates the last node of the group | 449 | * @last: indicates the last node of the group |
450 | * @last_reference: non-zero if this is a deletion inode | ||
451 | */ | 450 | */ |
452 | static void pack_inode(struct ubifs_info *c, struct ubifs_ino_node *ino, | 451 | static void pack_inode(struct ubifs_info *c, struct ubifs_ino_node *ino, |
453 | const struct inode *inode, int last, | 452 | const struct inode *inode, int last) |
454 | int last_reference) | ||
455 | { | 453 | { |
456 | int data_len = 0; | 454 | int data_len = 0, last_reference = !inode->i_nlink; |
457 | struct ubifs_inode *ui = ubifs_inode(inode); | 455 | struct ubifs_inode *ui = ubifs_inode(inode); |
458 | 456 | ||
459 | ino->ch.node_type = UBIFS_INO_NODE; | 457 | ino->ch.node_type = UBIFS_INO_NODE; |
@@ -596,9 +594,9 @@ int ubifs_jnl_update(struct ubifs_info *c, const struct inode *dir, | |||
596 | ubifs_prep_grp_node(c, dent, dlen, 0); | 594 | ubifs_prep_grp_node(c, dent, dlen, 0); |
597 | 595 | ||
598 | ino = (void *)dent + aligned_dlen; | 596 | ino = (void *)dent + aligned_dlen; |
599 | pack_inode(c, ino, inode, 0, last_reference); | 597 | pack_inode(c, ino, inode, 0); |
600 | ino = (void *)ino + aligned_ilen; | 598 | ino = (void *)ino + aligned_ilen; |
601 | pack_inode(c, ino, dir, 1, 0); | 599 | pack_inode(c, ino, dir, 1); |
602 | 600 | ||
603 | if (last_reference) { | 601 | if (last_reference) { |
604 | err = ubifs_add_orphan(c, inode->i_ino); | 602 | err = ubifs_add_orphan(c, inode->i_ino); |
@@ -781,7 +779,7 @@ int ubifs_jnl_write_inode(struct ubifs_info *c, const struct inode *inode) | |||
781 | if (err) | 779 | if (err) |
782 | goto out_free; | 780 | goto out_free; |
783 | 781 | ||
784 | pack_inode(c, ino, inode, 1, last_reference); | 782 | pack_inode(c, ino, inode, 1); |
785 | err = write_head(c, BASEHD, ino, len, &lnum, &offs, sync); | 783 | err = write_head(c, BASEHD, ino, len, &lnum, &offs, sync); |
786 | if (err) | 784 | if (err) |
787 | goto out_release; | 785 | goto out_release; |
@@ -912,16 +910,16 @@ int ubifs_jnl_rename(struct ubifs_info *c, const struct inode *old_dir, | |||
912 | 910 | ||
913 | p = (void *)dent2 + aligned_dlen2; | 911 | p = (void *)dent2 + aligned_dlen2; |
914 | if (new_inode) { | 912 | if (new_inode) { |
915 | pack_inode(c, p, new_inode, 0, last_reference); | 913 | pack_inode(c, p, new_inode, 0); |
916 | p += ALIGN(ilen, 8); | 914 | p += ALIGN(ilen, 8); |
917 | } | 915 | } |
918 | 916 | ||
919 | if (!move) | 917 | if (!move) |
920 | pack_inode(c, p, old_dir, 1, 0); | 918 | pack_inode(c, p, old_dir, 1); |
921 | else { | 919 | else { |
922 | pack_inode(c, p, old_dir, 0, 0); | 920 | pack_inode(c, p, old_dir, 0); |
923 | p += ALIGN(plen, 8); | 921 | p += ALIGN(plen, 8); |
924 | pack_inode(c, p, new_dir, 1, 0); | 922 | pack_inode(c, p, new_dir, 1); |
925 | } | 923 | } |
926 | 924 | ||
927 | if (last_reference) { | 925 | if (last_reference) { |
@@ -1126,7 +1124,7 @@ int ubifs_jnl_truncate(struct ubifs_info *c, const struct inode *inode, | |||
1126 | if (err) | 1124 | if (err) |
1127 | goto out_free; | 1125 | goto out_free; |
1128 | 1126 | ||
1129 | pack_inode(c, ino, inode, 0, 0); | 1127 | pack_inode(c, ino, inode, 0); |
1130 | ubifs_prep_grp_node(c, trun, UBIFS_TRUN_NODE_SZ, dlen ? 0 : 1); | 1128 | ubifs_prep_grp_node(c, trun, UBIFS_TRUN_NODE_SZ, dlen ? 0 : 1); |
1131 | if (dlen) | 1129 | if (dlen) |
1132 | ubifs_prep_grp_node(c, dn, dlen, 1); | 1130 | ubifs_prep_grp_node(c, dn, dlen, 1); |
@@ -1246,9 +1244,9 @@ int ubifs_jnl_delete_xattr(struct ubifs_info *c, const struct inode *host, | |||
1246 | ubifs_prep_grp_node(c, xent, xlen, 0); | 1244 | ubifs_prep_grp_node(c, xent, xlen, 0); |
1247 | 1245 | ||
1248 | ino = (void *)xent + aligned_xlen; | 1246 | ino = (void *)xent + aligned_xlen; |
1249 | pack_inode(c, ino, inode, 0, 1); | 1247 | pack_inode(c, ino, inode, 0); |
1250 | ino = (void *)ino + UBIFS_INO_NODE_SZ; | 1248 | ino = (void *)ino + UBIFS_INO_NODE_SZ; |
1251 | pack_inode(c, ino, host, 1, 0); | 1249 | pack_inode(c, ino, host, 1); |
1252 | 1250 | ||
1253 | err = write_head(c, BASEHD, xent, len, &lnum, &xent_offs, sync); | 1251 | err = write_head(c, BASEHD, xent, len, &lnum, &xent_offs, sync); |
1254 | if (!sync && !err) | 1252 | if (!sync && !err) |
@@ -1339,8 +1337,8 @@ int ubifs_jnl_change_xattr(struct ubifs_info *c, const struct inode *inode, | |||
1339 | if (err) | 1337 | if (err) |
1340 | goto out_free; | 1338 | goto out_free; |
1341 | 1339 | ||
1342 | pack_inode(c, ino, host, 0, 0); | 1340 | pack_inode(c, ino, host, 0); |
1343 | pack_inode(c, (void *)ino + aligned_len1, inode, 1, 0); | 1341 | pack_inode(c, (void *)ino + aligned_len1, inode, 1); |
1344 | 1342 | ||
1345 | err = write_head(c, BASEHD, ino, aligned_len, &lnum, &offs, 0); | 1343 | err = write_head(c, BASEHD, ino, aligned_len, &lnum, &offs, 0); |
1346 | if (!sync && !err) { | 1344 | if (!sync && !err) { |