diff options
Diffstat (limited to 'fs/ubifs/lpt_commit.c')
-rw-r--r-- | fs/ubifs/lpt_commit.c | 55 |
1 files changed, 28 insertions, 27 deletions
diff --git a/fs/ubifs/lpt_commit.c b/fs/ubifs/lpt_commit.c index a41434b42785..1aefab9f0b5e 100644 --- a/fs/ubifs/lpt_commit.c +++ b/fs/ubifs/lpt_commit.c | |||
@@ -1602,7 +1602,7 @@ static int dbg_check_ltab_lnum(struct ubifs_info *c, int lnum) | |||
1602 | { | 1602 | { |
1603 | int err, len = c->leb_size, dirty = 0, node_type, node_num, node_len; | 1603 | int err, len = c->leb_size, dirty = 0, node_type, node_num, node_len; |
1604 | int ret; | 1604 | int ret; |
1605 | void *buf = c->dbg_buf; | 1605 | void *buf = c->dbg->buf; |
1606 | 1606 | ||
1607 | dbg_lp("LEB %d", lnum); | 1607 | dbg_lp("LEB %d", lnum); |
1608 | err = ubi_read(c->ubi, lnum, buf, 0, c->leb_size); | 1608 | err = ubi_read(c->ubi, lnum, buf, 0, c->leb_size); |
@@ -1731,15 +1731,16 @@ int dbg_chk_lpt_free_spc(struct ubifs_info *c) | |||
1731 | */ | 1731 | */ |
1732 | int dbg_chk_lpt_sz(struct ubifs_info *c, int action, int len) | 1732 | int dbg_chk_lpt_sz(struct ubifs_info *c, int action, int len) |
1733 | { | 1733 | { |
1734 | struct ubifs_debug_info *d = c->dbg; | ||
1734 | long long chk_lpt_sz, lpt_sz; | 1735 | long long chk_lpt_sz, lpt_sz; |
1735 | int err = 0; | 1736 | int err = 0; |
1736 | 1737 | ||
1737 | switch (action) { | 1738 | switch (action) { |
1738 | case 0: | 1739 | case 0: |
1739 | c->chk_lpt_sz = 0; | 1740 | d->chk_lpt_sz = 0; |
1740 | c->chk_lpt_sz2 = 0; | 1741 | d->chk_lpt_sz2 = 0; |
1741 | c->chk_lpt_lebs = 0; | 1742 | d->chk_lpt_lebs = 0; |
1742 | c->chk_lpt_wastage = 0; | 1743 | d->chk_lpt_wastage = 0; |
1743 | if (c->dirty_pn_cnt > c->pnode_cnt) { | 1744 | if (c->dirty_pn_cnt > c->pnode_cnt) { |
1744 | dbg_err("dirty pnodes %d exceed max %d", | 1745 | dbg_err("dirty pnodes %d exceed max %d", |
1745 | c->dirty_pn_cnt, c->pnode_cnt); | 1746 | c->dirty_pn_cnt, c->pnode_cnt); |
@@ -1752,35 +1753,35 @@ int dbg_chk_lpt_sz(struct ubifs_info *c, int action, int len) | |||
1752 | } | 1753 | } |
1753 | return err; | 1754 | return err; |
1754 | case 1: | 1755 | case 1: |
1755 | c->chk_lpt_sz += len; | 1756 | d->chk_lpt_sz += len; |
1756 | return 0; | 1757 | return 0; |
1757 | case 2: | 1758 | case 2: |
1758 | c->chk_lpt_sz += len; | 1759 | d->chk_lpt_sz += len; |
1759 | c->chk_lpt_wastage += len; | 1760 | d->chk_lpt_wastage += len; |
1760 | c->chk_lpt_lebs += 1; | 1761 | d->chk_lpt_lebs += 1; |
1761 | return 0; | 1762 | return 0; |
1762 | case 3: | 1763 | case 3: |
1763 | chk_lpt_sz = c->leb_size; | 1764 | chk_lpt_sz = c->leb_size; |
1764 | chk_lpt_sz *= c->chk_lpt_lebs; | 1765 | chk_lpt_sz *= d->chk_lpt_lebs; |
1765 | chk_lpt_sz += len - c->nhead_offs; | 1766 | chk_lpt_sz += len - c->nhead_offs; |
1766 | if (c->chk_lpt_sz != chk_lpt_sz) { | 1767 | if (d->chk_lpt_sz != chk_lpt_sz) { |
1767 | dbg_err("LPT wrote %lld but space used was %lld", | 1768 | dbg_err("LPT wrote %lld but space used was %lld", |
1768 | c->chk_lpt_sz, chk_lpt_sz); | 1769 | d->chk_lpt_sz, chk_lpt_sz); |
1769 | err = -EINVAL; | 1770 | err = -EINVAL; |
1770 | } | 1771 | } |
1771 | if (c->chk_lpt_sz > c->lpt_sz) { | 1772 | if (d->chk_lpt_sz > c->lpt_sz) { |
1772 | dbg_err("LPT wrote %lld but lpt_sz is %lld", | 1773 | dbg_err("LPT wrote %lld but lpt_sz is %lld", |
1773 | c->chk_lpt_sz, c->lpt_sz); | 1774 | d->chk_lpt_sz, c->lpt_sz); |
1774 | err = -EINVAL; | 1775 | err = -EINVAL; |
1775 | } | 1776 | } |
1776 | if (c->chk_lpt_sz2 && c->chk_lpt_sz != c->chk_lpt_sz2) { | 1777 | if (d->chk_lpt_sz2 && d->chk_lpt_sz != d->chk_lpt_sz2) { |
1777 | dbg_err("LPT layout size %lld but wrote %lld", | 1778 | dbg_err("LPT layout size %lld but wrote %lld", |
1778 | c->chk_lpt_sz, c->chk_lpt_sz2); | 1779 | d->chk_lpt_sz, d->chk_lpt_sz2); |
1779 | err = -EINVAL; | 1780 | err = -EINVAL; |
1780 | } | 1781 | } |
1781 | if (c->chk_lpt_sz2 && c->new_nhead_offs != len) { | 1782 | if (d->chk_lpt_sz2 && d->new_nhead_offs != len) { |
1782 | dbg_err("LPT new nhead offs: expected %d was %d", | 1783 | dbg_err("LPT new nhead offs: expected %d was %d", |
1783 | c->new_nhead_offs, len); | 1784 | d->new_nhead_offs, len); |
1784 | err = -EINVAL; | 1785 | err = -EINVAL; |
1785 | } | 1786 | } |
1786 | lpt_sz = (long long)c->pnode_cnt * c->pnode_sz; | 1787 | lpt_sz = (long long)c->pnode_cnt * c->pnode_sz; |
@@ -1788,22 +1789,22 @@ int dbg_chk_lpt_sz(struct ubifs_info *c, int action, int len) | |||
1788 | lpt_sz += c->ltab_sz; | 1789 | lpt_sz += c->ltab_sz; |
1789 | if (c->big_lpt) | 1790 | if (c->big_lpt) |
1790 | lpt_sz += c->lsave_sz; | 1791 | lpt_sz += c->lsave_sz; |
1791 | if (c->chk_lpt_sz - c->chk_lpt_wastage > lpt_sz) { | 1792 | if (d->chk_lpt_sz - d->chk_lpt_wastage > lpt_sz) { |
1792 | dbg_err("LPT chk_lpt_sz %lld + waste %lld exceeds %lld", | 1793 | dbg_err("LPT chk_lpt_sz %lld + waste %lld exceeds %lld", |
1793 | c->chk_lpt_sz, c->chk_lpt_wastage, lpt_sz); | 1794 | d->chk_lpt_sz, d->chk_lpt_wastage, lpt_sz); |
1794 | err = -EINVAL; | 1795 | err = -EINVAL; |
1795 | } | 1796 | } |
1796 | if (err) | 1797 | if (err) |
1797 | dbg_dump_lpt_info(c); | 1798 | dbg_dump_lpt_info(c); |
1798 | c->chk_lpt_sz2 = c->chk_lpt_sz; | 1799 | d->chk_lpt_sz2 = d->chk_lpt_sz; |
1799 | c->chk_lpt_sz = 0; | 1800 | d->chk_lpt_sz = 0; |
1800 | c->chk_lpt_wastage = 0; | 1801 | d->chk_lpt_wastage = 0; |
1801 | c->chk_lpt_lebs = 0; | 1802 | d->chk_lpt_lebs = 0; |
1802 | c->new_nhead_offs = len; | 1803 | d->new_nhead_offs = len; |
1803 | return err; | 1804 | return err; |
1804 | case 4: | 1805 | case 4: |
1805 | c->chk_lpt_sz += len; | 1806 | d->chk_lpt_sz += len; |
1806 | c->chk_lpt_wastage += len; | 1807 | d->chk_lpt_wastage += len; |
1807 | return 0; | 1808 | return 0; |
1808 | default: | 1809 | default: |
1809 | return -EINVAL; | 1810 | return -EINVAL; |