UBIFS: comply with coding style
Join all the split printk lines in order to stop checkpatch complaining. Signed-off-by: Artem Bityutskiy <artem.bityutskiy@linux.intel.com>
This commit is contained in:
parent
43457c60c8
commit
79fda5179a
|
@ -342,9 +342,8 @@ static int do_budget_space(struct ubifs_info *c)
|
||||||
lebs = c->lst.empty_lebs + c->freeable_cnt + c->idx_gc_cnt -
|
lebs = c->lst.empty_lebs + c->freeable_cnt + c->idx_gc_cnt -
|
||||||
c->lst.taken_empty_lebs;
|
c->lst.taken_empty_lebs;
|
||||||
if (unlikely(rsvd_idx_lebs > lebs)) {
|
if (unlikely(rsvd_idx_lebs > lebs)) {
|
||||||
dbg_budg("out of indexing space: min_idx_lebs %d (old %d), "
|
dbg_budg("out of indexing space: min_idx_lebs %d (old %d), rsvd_idx_lebs %d",
|
||||||
"rsvd_idx_lebs %d", min_idx_lebs, c->bi.min_idx_lebs,
|
min_idx_lebs, c->bi.min_idx_lebs, rsvd_idx_lebs);
|
||||||
rsvd_idx_lebs);
|
|
||||||
return -ENOSPC;
|
return -ENOSPC;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -112,8 +112,7 @@ void ubifs_compress(const void *in_buf, int in_len, void *out_buf, int *out_len,
|
||||||
if (compr->comp_mutex)
|
if (compr->comp_mutex)
|
||||||
mutex_unlock(compr->comp_mutex);
|
mutex_unlock(compr->comp_mutex);
|
||||||
if (unlikely(err)) {
|
if (unlikely(err)) {
|
||||||
ubifs_warn("cannot compress %d bytes, compressor %s, "
|
ubifs_warn("cannot compress %d bytes, compressor %s, error %d, leave data uncompressed",
|
||||||
"error %d, leave data uncompressed",
|
|
||||||
in_len, compr->name, err);
|
in_len, compr->name, err);
|
||||||
goto no_compr;
|
goto no_compr;
|
||||||
}
|
}
|
||||||
|
@ -176,8 +175,8 @@ int ubifs_decompress(const void *in_buf, int in_len, void *out_buf,
|
||||||
if (compr->decomp_mutex)
|
if (compr->decomp_mutex)
|
||||||
mutex_unlock(compr->decomp_mutex);
|
mutex_unlock(compr->decomp_mutex);
|
||||||
if (err)
|
if (err)
|
||||||
ubifs_err("cannot decompress %d bytes, compressor %s, "
|
ubifs_err("cannot decompress %d bytes, compressor %s, error %d",
|
||||||
"error %d", in_len, compr->name, err);
|
in_len, compr->name, err);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
153
fs/ubifs/debug.c
153
fs/ubifs/debug.c
|
@ -509,8 +509,7 @@ void ubifs_dump_node(const struct ubifs_info *c, const void *node)
|
||||||
printk(KERN_ERR "\tname ");
|
printk(KERN_ERR "\tname ");
|
||||||
|
|
||||||
if (nlen > UBIFS_MAX_NLEN)
|
if (nlen > UBIFS_MAX_NLEN)
|
||||||
printk(KERN_ERR "(bad name length, not printing, "
|
printk(KERN_ERR "(bad name length, not printing, bad or corrupted node)");
|
||||||
"bad or corrupted node)");
|
|
||||||
else {
|
else {
|
||||||
for (i = 0; i < nlen && dent->name[i]; i++)
|
for (i = 0; i < nlen && dent->name[i]; i++)
|
||||||
printk(KERN_CONT "%c", dent->name[i]);
|
printk(KERN_CONT "%c", dent->name[i]);
|
||||||
|
@ -618,14 +617,12 @@ void ubifs_dump_budget_req(const struct ubifs_budget_req *req)
|
||||||
void ubifs_dump_lstats(const struct ubifs_lp_stats *lst)
|
void ubifs_dump_lstats(const struct ubifs_lp_stats *lst)
|
||||||
{
|
{
|
||||||
spin_lock(&dbg_lock);
|
spin_lock(&dbg_lock);
|
||||||
printk(KERN_ERR "(pid %d) Lprops statistics: empty_lebs %d, "
|
printk(KERN_ERR "(pid %d) Lprops statistics: empty_lebs %d, idx_lebs %d\n",
|
||||||
"idx_lebs %d\n", current->pid, lst->empty_lebs, lst->idx_lebs);
|
current->pid, lst->empty_lebs, lst->idx_lebs);
|
||||||
printk(KERN_ERR "\ttaken_empty_lebs %d, total_free %lld, "
|
printk(KERN_ERR "\ttaken_empty_lebs %d, total_free %lld, total_dirty %lld\n",
|
||||||
"total_dirty %lld\n", lst->taken_empty_lebs, lst->total_free,
|
lst->taken_empty_lebs, lst->total_free, lst->total_dirty);
|
||||||
lst->total_dirty);
|
printk(KERN_ERR "\ttotal_used %lld, total_dark %lld, total_dead %lld\n",
|
||||||
printk(KERN_ERR "\ttotal_used %lld, total_dark %lld, "
|
lst->total_used, lst->total_dark, lst->total_dead);
|
||||||
"total_dead %lld\n", lst->total_used, lst->total_dark,
|
|
||||||
lst->total_dead);
|
|
||||||
spin_unlock(&dbg_lock);
|
spin_unlock(&dbg_lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -639,16 +636,13 @@ void ubifs_dump_budg(struct ubifs_info *c, const struct ubifs_budg_info *bi)
|
||||||
|
|
||||||
spin_lock(&c->space_lock);
|
spin_lock(&c->space_lock);
|
||||||
spin_lock(&dbg_lock);
|
spin_lock(&dbg_lock);
|
||||||
printk(KERN_ERR "(pid %d) Budgeting info: data budget sum %lld, "
|
printk(KERN_ERR "(pid %d) Budgeting info: data budget sum %lld, total budget sum %lld\n",
|
||||||
"total budget sum %lld\n", current->pid,
|
current->pid, bi->data_growth + bi->dd_growth,
|
||||||
bi->data_growth + bi->dd_growth,
|
|
||||||
bi->data_growth + bi->dd_growth + bi->idx_growth);
|
bi->data_growth + bi->dd_growth + bi->idx_growth);
|
||||||
printk(KERN_ERR "\tbudg_data_growth %lld, budg_dd_growth %lld, "
|
printk(KERN_ERR "\tbudg_data_growth %lld, budg_dd_growth %lld, budg_idx_growth %lld\n",
|
||||||
"budg_idx_growth %lld\n", bi->data_growth, bi->dd_growth,
|
bi->data_growth, bi->dd_growth, bi->idx_growth);
|
||||||
bi->idx_growth);
|
printk(KERN_ERR "\tmin_idx_lebs %d, old_idx_sz %llu, uncommitted_idx %lld\n",
|
||||||
printk(KERN_ERR "\tmin_idx_lebs %d, old_idx_sz %llu, "
|
bi->min_idx_lebs, bi->old_idx_sz, bi->uncommitted_idx);
|
||||||
"uncommitted_idx %lld\n", bi->min_idx_lebs, bi->old_idx_sz,
|
|
||||||
bi->uncommitted_idx);
|
|
||||||
printk(KERN_ERR "\tpage_budget %d, inode_budget %d, dent_budget %d\n",
|
printk(KERN_ERR "\tpage_budget %d, inode_budget %d, dent_budget %d\n",
|
||||||
bi->page_budget, bi->inode_budget, bi->dent_budget);
|
bi->page_budget, bi->inode_budget, bi->dent_budget);
|
||||||
printk(KERN_ERR "\tnospace %u, nospace_rp %u\n",
|
printk(KERN_ERR "\tnospace %u, nospace_rp %u\n",
|
||||||
|
@ -666,8 +660,8 @@ void ubifs_dump_budg(struct ubifs_info *c, const struct ubifs_budg_info *bi)
|
||||||
|
|
||||||
printk(KERN_ERR "\tfreeable_cnt %d, calc_idx_sz %lld, idx_gc_cnt %d\n",
|
printk(KERN_ERR "\tfreeable_cnt %d, calc_idx_sz %lld, idx_gc_cnt %d\n",
|
||||||
c->freeable_cnt, c->calc_idx_sz, c->idx_gc_cnt);
|
c->freeable_cnt, c->calc_idx_sz, c->idx_gc_cnt);
|
||||||
printk(KERN_ERR "\tdirty_pg_cnt %ld, dirty_zn_cnt %ld, "
|
printk(KERN_ERR "\tdirty_pg_cnt %ld, dirty_zn_cnt %ld, clean_zn_cnt %ld\n",
|
||||||
"clean_zn_cnt %ld\n", atomic_long_read(&c->dirty_pg_cnt),
|
atomic_long_read(&c->dirty_pg_cnt),
|
||||||
atomic_long_read(&c->dirty_zn_cnt),
|
atomic_long_read(&c->dirty_zn_cnt),
|
||||||
atomic_long_read(&c->clean_zn_cnt));
|
atomic_long_read(&c->clean_zn_cnt));
|
||||||
printk(KERN_ERR "\tgc_lnum %d, ihead_lnum %d\n",
|
printk(KERN_ERR "\tgc_lnum %d, ihead_lnum %d\n",
|
||||||
|
@ -715,15 +709,13 @@ void ubifs_dump_lprop(const struct ubifs_info *c, const struct ubifs_lprops *lp)
|
||||||
dark = ubifs_calc_dark(c, spc);
|
dark = ubifs_calc_dark(c, spc);
|
||||||
|
|
||||||
if (lp->flags & LPROPS_INDEX)
|
if (lp->flags & LPROPS_INDEX)
|
||||||
printk(KERN_ERR "LEB %-7d free %-8d dirty %-8d used %-8d "
|
printk(KERN_ERR "LEB %-7d free %-8d dirty %-8d used %-8d free + dirty %-8d flags %#x (",
|
||||||
"free + dirty %-8d flags %#x (", lp->lnum, lp->free,
|
lp->lnum, lp->free, lp->dirty, c->leb_size - spc, spc,
|
||||||
lp->dirty, c->leb_size - spc, spc, lp->flags);
|
lp->flags);
|
||||||
else
|
else
|
||||||
printk(KERN_ERR "LEB %-7d free %-8d dirty %-8d used %-8d "
|
printk(KERN_ERR "LEB %-7d free %-8d dirty %-8d used %-8d free + dirty %-8d dark %-4d dead %-4d nodes fit %-3d flags %#-4x (",
|
||||||
"free + dirty %-8d dark %-4d dead %-4d nodes fit %-3d "
|
lp->lnum, lp->free, lp->dirty, c->leb_size - spc, spc,
|
||||||
"flags %#-4x (", lp->lnum, lp->free, lp->dirty,
|
dark, dead, (int)(spc / UBIFS_MAX_NODE_SZ), lp->flags);
|
||||||
c->leb_size - spc, spc, dark, dead,
|
|
||||||
(int)(spc / UBIFS_MAX_NODE_SZ), lp->flags);
|
|
||||||
|
|
||||||
if (lp->flags & LPROPS_TAKEN) {
|
if (lp->flags & LPROPS_TAKEN) {
|
||||||
if (lp->flags & LPROPS_INDEX)
|
if (lp->flags & LPROPS_INDEX)
|
||||||
|
@ -851,9 +843,9 @@ void ubifs_dump_lpt_info(struct ubifs_info *c)
|
||||||
printk(KERN_ERR "\tLPT lsave is at %d:%d\n",
|
printk(KERN_ERR "\tLPT lsave is at %d:%d\n",
|
||||||
c->lsave_lnum, c->lsave_offs);
|
c->lsave_lnum, c->lsave_offs);
|
||||||
for (i = 0; i < c->lpt_lebs; i++)
|
for (i = 0; i < c->lpt_lebs; i++)
|
||||||
printk(KERN_ERR "\tLPT LEB %d free %d dirty %d tgc %d "
|
printk(KERN_ERR "\tLPT LEB %d free %d dirty %d tgc %d cmt %d\n",
|
||||||
"cmt %d\n", i + c->lpt_first, c->ltab[i].free,
|
i + c->lpt_first, c->ltab[i].free, c->ltab[i].dirty,
|
||||||
c->ltab[i].dirty, c->ltab[i].tgc, c->ltab[i].cmt);
|
c->ltab[i].tgc, c->ltab[i].cmt);
|
||||||
spin_unlock(&dbg_lock);
|
spin_unlock(&dbg_lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -867,8 +859,8 @@ void ubifs_dump_sleb(const struct ubifs_info *c,
|
||||||
|
|
||||||
list_for_each_entry(snod, &sleb->nodes, list) {
|
list_for_each_entry(snod, &sleb->nodes, list) {
|
||||||
cond_resched();
|
cond_resched();
|
||||||
printk(KERN_ERR "Dumping node at LEB %d:%d len %d\n", sleb->lnum,
|
printk(KERN_ERR "Dumping node at LEB %d:%d len %d\n",
|
||||||
snod->offs, snod->len);
|
sleb->lnum, snod->offs, snod->len);
|
||||||
ubifs_dump_node(c, snod->node);
|
ubifs_dump_node(c, snod->node);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -926,10 +918,9 @@ void ubifs_dump_znode(const struct ubifs_info *c,
|
||||||
else
|
else
|
||||||
zbr = &c->zroot;
|
zbr = &c->zroot;
|
||||||
|
|
||||||
printk(KERN_ERR "znode %p, LEB %d:%d len %d parent %p iip %d level %d"
|
printk(KERN_ERR "znode %p, LEB %d:%d len %d parent %p iip %d level %d child_cnt %d flags %lx\n",
|
||||||
" child_cnt %d flags %lx\n", znode, zbr->lnum, zbr->offs,
|
znode, zbr->lnum, zbr->offs, zbr->len, znode->parent, znode->iip,
|
||||||
zbr->len, znode->parent, znode->iip, znode->level,
|
znode->level, znode->child_cnt, znode->flags);
|
||||||
znode->child_cnt, znode->flags);
|
|
||||||
|
|
||||||
if (znode->child_cnt <= 0 || znode->child_cnt > c->fanout) {
|
if (znode->child_cnt <= 0 || znode->child_cnt > c->fanout) {
|
||||||
spin_unlock(&dbg_lock);
|
spin_unlock(&dbg_lock);
|
||||||
|
@ -940,18 +931,14 @@ void ubifs_dump_znode(const struct ubifs_info *c,
|
||||||
for (n = 0; n < znode->child_cnt; n++) {
|
for (n = 0; n < znode->child_cnt; n++) {
|
||||||
zbr = &znode->zbranch[n];
|
zbr = &znode->zbranch[n];
|
||||||
if (znode->level > 0)
|
if (znode->level > 0)
|
||||||
printk(KERN_ERR "\t%d: znode %p LEB %d:%d len %d key "
|
printk(KERN_ERR "\t%d: znode %p LEB %d:%d len %d key %s\n",
|
||||||
"%s\n", n, zbr->znode, zbr->lnum,
|
n, zbr->znode, zbr->lnum, zbr->offs, zbr->len,
|
||||||
zbr->offs, zbr->len,
|
dbg_snprintf_key(c, &zbr->key, key_buf,
|
||||||
dbg_snprintf_key(c, &zbr->key,
|
|
||||||
key_buf,
|
|
||||||
DBG_KEY_BUF_LEN));
|
DBG_KEY_BUF_LEN));
|
||||||
else
|
else
|
||||||
printk(KERN_ERR "\t%d: LNC %p LEB %d:%d len %d key "
|
printk(KERN_ERR "\t%d: LNC %p LEB %d:%d len %d key %s\n",
|
||||||
"%s\n", n, zbr->znode, zbr->lnum,
|
n, zbr->znode, zbr->lnum, zbr->offs, zbr->len,
|
||||||
zbr->offs, zbr->len,
|
dbg_snprintf_key(c, &zbr->key, key_buf,
|
||||||
dbg_snprintf_key(c, &zbr->key,
|
|
||||||
key_buf,
|
|
||||||
DBG_KEY_BUF_LEN));
|
DBG_KEY_BUF_LEN));
|
||||||
}
|
}
|
||||||
spin_unlock(&dbg_lock);
|
spin_unlock(&dbg_lock);
|
||||||
|
@ -966,9 +953,9 @@ void ubifs_dump_heap(struct ubifs_info *c, struct ubifs_lpt_heap *heap, int cat)
|
||||||
for (i = 0; i < heap->cnt; i++) {
|
for (i = 0; i < heap->cnt; i++) {
|
||||||
struct ubifs_lprops *lprops = heap->arr[i];
|
struct ubifs_lprops *lprops = heap->arr[i];
|
||||||
|
|
||||||
printk(KERN_ERR "\t%d. LEB %d hpos %d free %d dirty %d "
|
printk(KERN_ERR "\t%d. LEB %d hpos %d free %d dirty %d flags %d\n",
|
||||||
"flags %d\n", i, lprops->lnum, lprops->hpos,
|
i, lprops->lnum, lprops->hpos, lprops->free,
|
||||||
lprops->free, lprops->dirty, lprops->flags);
|
lprops->dirty, lprops->flags);
|
||||||
}
|
}
|
||||||
printk(KERN_ERR "(pid %d) finish dumping heap\n", current->pid);
|
printk(KERN_ERR "(pid %d) finish dumping heap\n", current->pid);
|
||||||
}
|
}
|
||||||
|
@ -1148,8 +1135,8 @@ int dbg_check_synced_i_size(const struct ubifs_info *c, struct inode *inode)
|
||||||
mutex_lock(&ui->ui_mutex);
|
mutex_lock(&ui->ui_mutex);
|
||||||
spin_lock(&ui->ui_lock);
|
spin_lock(&ui->ui_lock);
|
||||||
if (ui->ui_size != ui->synced_i_size && !ui->dirty) {
|
if (ui->ui_size != ui->synced_i_size && !ui->dirty) {
|
||||||
ubifs_err("ui_size is %lld, synced_i_size is %lld, but inode "
|
ubifs_err("ui_size is %lld, synced_i_size is %lld, but inode is clean",
|
||||||
"is clean", ui->ui_size, ui->synced_i_size);
|
ui->ui_size, ui->synced_i_size);
|
||||||
ubifs_err("i_ino %lu, i_mode %#x, i_size %lld", inode->i_ino,
|
ubifs_err("i_ino %lu, i_mode %#x, i_size %lld", inode->i_ino,
|
||||||
inode->i_mode, i_size_read(inode));
|
inode->i_mode, i_size_read(inode));
|
||||||
dump_stack();
|
dump_stack();
|
||||||
|
@ -1211,17 +1198,16 @@ int dbg_check_dir(struct ubifs_info *c, const struct inode *dir)
|
||||||
kfree(pdent);
|
kfree(pdent);
|
||||||
|
|
||||||
if (i_size_read(dir) != size) {
|
if (i_size_read(dir) != size) {
|
||||||
ubifs_err("directory inode %lu has size %llu, "
|
ubifs_err("directory inode %lu has size %llu, but calculated size is %llu",
|
||||||
"but calculated size is %llu", dir->i_ino,
|
dir->i_ino, (unsigned long long)i_size_read(dir),
|
||||||
(unsigned long long)i_size_read(dir),
|
|
||||||
(unsigned long long)size);
|
(unsigned long long)size);
|
||||||
ubifs_dump_inode(c, dir);
|
ubifs_dump_inode(c, dir);
|
||||||
dump_stack();
|
dump_stack();
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
if (dir->i_nlink != nlink) {
|
if (dir->i_nlink != nlink) {
|
||||||
ubifs_err("directory inode %lu has nlink %u, but calculated "
|
ubifs_err("directory inode %lu has nlink %u, but calculated nlink is %u",
|
||||||
"nlink is %u", dir->i_ino, dir->i_nlink, nlink);
|
dir->i_ino, dir->i_nlink, nlink);
|
||||||
ubifs_dump_inode(c, dir);
|
ubifs_dump_inode(c, dir);
|
||||||
dump_stack();
|
dump_stack();
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
@ -1680,8 +1666,8 @@ int dbg_walk_index(struct ubifs_info *c, dbg_leaf_callback leaf_cb,
|
||||||
if (znode_cb) {
|
if (znode_cb) {
|
||||||
err = znode_cb(c, znode, priv);
|
err = znode_cb(c, znode, priv);
|
||||||
if (err) {
|
if (err) {
|
||||||
ubifs_err("znode checking function returned "
|
ubifs_err("znode checking function returned error %d",
|
||||||
"error %d", err);
|
err);
|
||||||
ubifs_dump_znode(c, znode);
|
ubifs_dump_znode(c, znode);
|
||||||
goto out_dump;
|
goto out_dump;
|
||||||
}
|
}
|
||||||
|
@ -1691,9 +1677,7 @@ int dbg_walk_index(struct ubifs_info *c, dbg_leaf_callback leaf_cb,
|
||||||
zbr = &znode->zbranch[idx];
|
zbr = &znode->zbranch[idx];
|
||||||
err = leaf_cb(c, zbr, priv);
|
err = leaf_cb(c, zbr, priv);
|
||||||
if (err) {
|
if (err) {
|
||||||
ubifs_err("leaf checking function "
|
ubifs_err("leaf checking function returned error %d, for leaf at LEB %d:%d",
|
||||||
"returned error %d, for leaf "
|
|
||||||
"at LEB %d:%d",
|
|
||||||
err, zbr->lnum, zbr->offs);
|
err, zbr->lnum, zbr->offs);
|
||||||
goto out_dump;
|
goto out_dump;
|
||||||
}
|
}
|
||||||
|
@ -1801,8 +1785,8 @@ int dbg_check_idx_size(struct ubifs_info *c, long long idx_size)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (calc != idx_size) {
|
if (calc != idx_size) {
|
||||||
ubifs_err("index size check failed: calculated size is %lld, "
|
ubifs_err("index size check failed: calculated size is %lld, should be %lld",
|
||||||
"should be %lld", calc, idx_size);
|
calc, idx_size);
|
||||||
dump_stack();
|
dump_stack();
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
@ -2114,8 +2098,7 @@ static int check_leaf(struct ubifs_info *c, struct ubifs_zbranch *zbr,
|
||||||
fscki = read_add_inode(c, priv, inum);
|
fscki = read_add_inode(c, priv, inum);
|
||||||
if (IS_ERR(fscki)) {
|
if (IS_ERR(fscki)) {
|
||||||
err = PTR_ERR(fscki);
|
err = PTR_ERR(fscki);
|
||||||
ubifs_err("error %d while processing data node and "
|
ubifs_err("error %d while processing data node and trying to find inode node %lu",
|
||||||
"trying to find inode node %lu",
|
|
||||||
err, (unsigned long)inum);
|
err, (unsigned long)inum);
|
||||||
goto out_dump;
|
goto out_dump;
|
||||||
}
|
}
|
||||||
|
@ -2125,9 +2108,8 @@ static int check_leaf(struct ubifs_info *c, struct ubifs_zbranch *zbr,
|
||||||
blk_offs <<= UBIFS_BLOCK_SHIFT;
|
blk_offs <<= UBIFS_BLOCK_SHIFT;
|
||||||
blk_offs += le32_to_cpu(dn->size);
|
blk_offs += le32_to_cpu(dn->size);
|
||||||
if (blk_offs > fscki->size) {
|
if (blk_offs > fscki->size) {
|
||||||
ubifs_err("data node at LEB %d:%d is not within inode "
|
ubifs_err("data node at LEB %d:%d is not within inode size %lld",
|
||||||
"size %lld", zbr->lnum, zbr->offs,
|
zbr->lnum, zbr->offs, fscki->size);
|
||||||
fscki->size);
|
|
||||||
err = -EINVAL;
|
err = -EINVAL;
|
||||||
goto out_dump;
|
goto out_dump;
|
||||||
}
|
}
|
||||||
|
@ -2148,8 +2130,7 @@ static int check_leaf(struct ubifs_info *c, struct ubifs_zbranch *zbr,
|
||||||
fscki = read_add_inode(c, priv, inum);
|
fscki = read_add_inode(c, priv, inum);
|
||||||
if (IS_ERR(fscki)) {
|
if (IS_ERR(fscki)) {
|
||||||
err = PTR_ERR(fscki);
|
err = PTR_ERR(fscki);
|
||||||
ubifs_err("error %d while processing entry node and "
|
ubifs_err("error %d while processing entry node and trying to find inode node %lu",
|
||||||
"trying to find inode node %lu",
|
|
||||||
err, (unsigned long)inum);
|
err, (unsigned long)inum);
|
||||||
goto out_dump;
|
goto out_dump;
|
||||||
}
|
}
|
||||||
|
@ -2161,8 +2142,7 @@ static int check_leaf(struct ubifs_info *c, struct ubifs_zbranch *zbr,
|
||||||
fscki1 = read_add_inode(c, priv, inum);
|
fscki1 = read_add_inode(c, priv, inum);
|
||||||
if (IS_ERR(fscki1)) {
|
if (IS_ERR(fscki1)) {
|
||||||
err = PTR_ERR(fscki1);
|
err = PTR_ERR(fscki1);
|
||||||
ubifs_err("error %d while processing entry node and "
|
ubifs_err("error %d while processing entry node and trying to find parent inode node %lu",
|
||||||
"trying to find parent inode node %lu",
|
|
||||||
err, (unsigned long)inum);
|
err, (unsigned long)inum);
|
||||||
goto out_dump;
|
goto out_dump;
|
||||||
}
|
}
|
||||||
|
@ -2252,61 +2232,52 @@ static int check_inodes(struct ubifs_info *c, struct fsck_data *fsckd)
|
||||||
*/
|
*/
|
||||||
if (fscki->inum != UBIFS_ROOT_INO &&
|
if (fscki->inum != UBIFS_ROOT_INO &&
|
||||||
fscki->references != 1) {
|
fscki->references != 1) {
|
||||||
ubifs_err("directory inode %lu has %d "
|
ubifs_err("directory inode %lu has %d direntries which refer it, but should be 1",
|
||||||
"direntries which refer it, but "
|
|
||||||
"should be 1",
|
|
||||||
(unsigned long)fscki->inum,
|
(unsigned long)fscki->inum,
|
||||||
fscki->references);
|
fscki->references);
|
||||||
goto out_dump;
|
goto out_dump;
|
||||||
}
|
}
|
||||||
if (fscki->inum == UBIFS_ROOT_INO &&
|
if (fscki->inum == UBIFS_ROOT_INO &&
|
||||||
fscki->references != 0) {
|
fscki->references != 0) {
|
||||||
ubifs_err("root inode %lu has non-zero (%d) "
|
ubifs_err("root inode %lu has non-zero (%d) direntries which refer it",
|
||||||
"direntries which refer it",
|
|
||||||
(unsigned long)fscki->inum,
|
(unsigned long)fscki->inum,
|
||||||
fscki->references);
|
fscki->references);
|
||||||
goto out_dump;
|
goto out_dump;
|
||||||
}
|
}
|
||||||
if (fscki->calc_sz != fscki->size) {
|
if (fscki->calc_sz != fscki->size) {
|
||||||
ubifs_err("directory inode %lu size is %lld, "
|
ubifs_err("directory inode %lu size is %lld, but calculated size is %lld",
|
||||||
"but calculated size is %lld",
|
|
||||||
(unsigned long)fscki->inum,
|
(unsigned long)fscki->inum,
|
||||||
fscki->size, fscki->calc_sz);
|
fscki->size, fscki->calc_sz);
|
||||||
goto out_dump;
|
goto out_dump;
|
||||||
}
|
}
|
||||||
if (fscki->calc_cnt != fscki->nlink) {
|
if (fscki->calc_cnt != fscki->nlink) {
|
||||||
ubifs_err("directory inode %lu nlink is %d, "
|
ubifs_err("directory inode %lu nlink is %d, but calculated nlink is %d",
|
||||||
"but calculated nlink is %d",
|
|
||||||
(unsigned long)fscki->inum,
|
(unsigned long)fscki->inum,
|
||||||
fscki->nlink, fscki->calc_cnt);
|
fscki->nlink, fscki->calc_cnt);
|
||||||
goto out_dump;
|
goto out_dump;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (fscki->references != fscki->nlink) {
|
if (fscki->references != fscki->nlink) {
|
||||||
ubifs_err("inode %lu nlink is %d, but "
|
ubifs_err("inode %lu nlink is %d, but calculated nlink is %d",
|
||||||
"calculated nlink is %d",
|
|
||||||
(unsigned long)fscki->inum,
|
(unsigned long)fscki->inum,
|
||||||
fscki->nlink, fscki->references);
|
fscki->nlink, fscki->references);
|
||||||
goto out_dump;
|
goto out_dump;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (fscki->xattr_sz != fscki->calc_xsz) {
|
if (fscki->xattr_sz != fscki->calc_xsz) {
|
||||||
ubifs_err("inode %lu has xattr size %u, but "
|
ubifs_err("inode %lu has xattr size %u, but calculated size is %lld",
|
||||||
"calculated size is %lld",
|
|
||||||
(unsigned long)fscki->inum, fscki->xattr_sz,
|
(unsigned long)fscki->inum, fscki->xattr_sz,
|
||||||
fscki->calc_xsz);
|
fscki->calc_xsz);
|
||||||
goto out_dump;
|
goto out_dump;
|
||||||
}
|
}
|
||||||
if (fscki->xattr_cnt != fscki->calc_xcnt) {
|
if (fscki->xattr_cnt != fscki->calc_xcnt) {
|
||||||
ubifs_err("inode %lu has %u xattrs, but "
|
ubifs_err("inode %lu has %u xattrs, but calculated count is %lld",
|
||||||
"calculated count is %lld",
|
|
||||||
(unsigned long)fscki->inum,
|
(unsigned long)fscki->inum,
|
||||||
fscki->xattr_cnt, fscki->calc_xcnt);
|
fscki->xattr_cnt, fscki->calc_xcnt);
|
||||||
goto out_dump;
|
goto out_dump;
|
||||||
}
|
}
|
||||||
if (fscki->xattr_nms != fscki->calc_xnms) {
|
if (fscki->xattr_nms != fscki->calc_xnms) {
|
||||||
ubifs_err("inode %lu has xattr names' size %u, but "
|
ubifs_err("inode %lu has xattr names' size %u, but calculated names' size is %lld",
|
||||||
"calculated names' size is %lld",
|
|
||||||
(unsigned long)fscki->inum, fscki->xattr_nms,
|
(unsigned long)fscki->inum, fscki->xattr_nms,
|
||||||
fscki->calc_xnms);
|
fscki->calc_xnms);
|
||||||
goto out_dump;
|
goto out_dump;
|
||||||
|
|
|
@ -980,8 +980,8 @@ static int ubifs_rename(struct inode *old_dir, struct dentry *old_dentry,
|
||||||
* separately.
|
* separately.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
dbg_gen("dent '%.*s' ino %lu in dir ino %lu to dent '%.*s' in "
|
dbg_gen("dent '%.*s' ino %lu in dir ino %lu to dent '%.*s' in dir ino %lu",
|
||||||
"dir ino %lu", old_dentry->d_name.len, old_dentry->d_name.name,
|
old_dentry->d_name.len, old_dentry->d_name.name,
|
||||||
old_inode->i_ino, old_dir->i_ino, new_dentry->d_name.len,
|
old_inode->i_ino, old_dir->i_ino, new_dentry->d_name.len,
|
||||||
new_dentry->d_name.name, new_dir->i_ino);
|
new_dentry->d_name.name, new_dir->i_ino);
|
||||||
ubifs_assert(mutex_is_locked(&old_dir->i_mutex));
|
ubifs_assert(mutex_is_locked(&old_dir->i_mutex));
|
||||||
|
|
|
@ -1486,8 +1486,8 @@ static int ubifs_vm_page_mkwrite(struct vm_area_struct *vma,
|
||||||
err = ubifs_budget_space(c, &req);
|
err = ubifs_budget_space(c, &req);
|
||||||
if (unlikely(err)) {
|
if (unlikely(err)) {
|
||||||
if (err == -ENOSPC)
|
if (err == -ENOSPC)
|
||||||
ubifs_warn("out of space for mmapped file "
|
ubifs_warn("out of space for mmapped file (inode number %lu)",
|
||||||
"(inode number %lu)", inode->i_ino);
|
inode->i_ino);
|
||||||
return VM_FAULT_SIGBUS;
|
return VM_FAULT_SIGBUS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -714,9 +714,9 @@ int ubifs_garbage_collect(struct ubifs_info *c, int anyway)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
dbg_gc("found LEB %d: free %d, dirty %d, sum %d "
|
dbg_gc("found LEB %d: free %d, dirty %d, sum %d (min. space %d)",
|
||||||
"(min. space %d)", lp.lnum, lp.free, lp.dirty,
|
lp.lnum, lp.free, lp.dirty, lp.free + lp.dirty,
|
||||||
lp.free + lp.dirty, min_space);
|
min_space);
|
||||||
|
|
||||||
space_before = c->leb_size - wbuf->offs - wbuf->used;
|
space_before = c->leb_size - wbuf->offs - wbuf->used;
|
||||||
if (wbuf->lnum == -1)
|
if (wbuf->lnum == -1)
|
||||||
|
|
|
@ -315,17 +315,15 @@ static void remove_buds(struct ubifs_info *c)
|
||||||
* heads (non-closed buds).
|
* heads (non-closed buds).
|
||||||
*/
|
*/
|
||||||
c->cmt_bud_bytes += wbuf->offs - bud->start;
|
c->cmt_bud_bytes += wbuf->offs - bud->start;
|
||||||
dbg_log("preserve %d:%d, jhead %s, bud bytes %d, "
|
dbg_log("preserve %d:%d, jhead %s, bud bytes %d, cmt_bud_bytes %lld",
|
||||||
"cmt_bud_bytes %lld", bud->lnum, bud->start,
|
bud->lnum, bud->start, dbg_jhead(bud->jhead),
|
||||||
dbg_jhead(bud->jhead), wbuf->offs - bud->start,
|
wbuf->offs - bud->start, c->cmt_bud_bytes);
|
||||||
c->cmt_bud_bytes);
|
|
||||||
bud->start = wbuf->offs;
|
bud->start = wbuf->offs;
|
||||||
} else {
|
} else {
|
||||||
c->cmt_bud_bytes += c->leb_size - bud->start;
|
c->cmt_bud_bytes += c->leb_size - bud->start;
|
||||||
dbg_log("remove %d:%d, jhead %s, bud bytes %d, "
|
dbg_log("remove %d:%d, jhead %s, bud bytes %d, cmt_bud_bytes %lld",
|
||||||
"cmt_bud_bytes %lld", bud->lnum, bud->start,
|
bud->lnum, bud->start, dbg_jhead(bud->jhead),
|
||||||
dbg_jhead(bud->jhead), c->leb_size - bud->start,
|
c->leb_size - bud->start, c->cmt_bud_bytes);
|
||||||
c->cmt_bud_bytes);
|
|
||||||
rb_erase(p1, &c->buds);
|
rb_erase(p1, &c->buds);
|
||||||
/*
|
/*
|
||||||
* If the commit does not finish, the recovery will need
|
* If the commit does not finish, the recovery will need
|
||||||
|
|
|
@ -867,15 +867,15 @@ int dbg_check_cats(struct ubifs_info *c)
|
||||||
|
|
||||||
list_for_each_entry(lprops, &c->empty_list, list) {
|
list_for_each_entry(lprops, &c->empty_list, list) {
|
||||||
if (lprops->free != c->leb_size) {
|
if (lprops->free != c->leb_size) {
|
||||||
ubifs_err("non-empty LEB %d on empty list "
|
ubifs_err("non-empty LEB %d on empty list (free %d dirty %d flags %d)",
|
||||||
"(free %d dirty %d flags %d)", lprops->lnum,
|
lprops->lnum, lprops->free, lprops->dirty,
|
||||||
lprops->free, lprops->dirty, lprops->flags);
|
lprops->flags);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
if (lprops->flags & LPROPS_TAKEN) {
|
if (lprops->flags & LPROPS_TAKEN) {
|
||||||
ubifs_err("taken LEB %d on empty list "
|
ubifs_err("taken LEB %d on empty list (free %d dirty %d flags %d)",
|
||||||
"(free %d dirty %d flags %d)", lprops->lnum,
|
lprops->lnum, lprops->free, lprops->dirty,
|
||||||
lprops->free, lprops->dirty, lprops->flags);
|
lprops->flags);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -883,15 +883,15 @@ int dbg_check_cats(struct ubifs_info *c)
|
||||||
i = 0;
|
i = 0;
|
||||||
list_for_each_entry(lprops, &c->freeable_list, list) {
|
list_for_each_entry(lprops, &c->freeable_list, list) {
|
||||||
if (lprops->free + lprops->dirty != c->leb_size) {
|
if (lprops->free + lprops->dirty != c->leb_size) {
|
||||||
ubifs_err("non-freeable LEB %d on freeable list "
|
ubifs_err("non-freeable LEB %d on freeable list (free %d dirty %d flags %d)",
|
||||||
"(free %d dirty %d flags %d)", lprops->lnum,
|
lprops->lnum, lprops->free, lprops->dirty,
|
||||||
lprops->free, lprops->dirty, lprops->flags);
|
lprops->flags);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
if (lprops->flags & LPROPS_TAKEN) {
|
if (lprops->flags & LPROPS_TAKEN) {
|
||||||
ubifs_err("taken LEB %d on freeable list "
|
ubifs_err("taken LEB %d on freeable list (free %d dirty %d flags %d)",
|
||||||
"(free %d dirty %d flags %d)", lprops->lnum,
|
lprops->lnum, lprops->free, lprops->dirty,
|
||||||
lprops->free, lprops->dirty, lprops->flags);
|
lprops->flags);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
i += 1;
|
i += 1;
|
||||||
|
@ -913,21 +913,21 @@ int dbg_check_cats(struct ubifs_info *c)
|
||||||
|
|
||||||
list_for_each_entry(lprops, &c->frdi_idx_list, list) {
|
list_for_each_entry(lprops, &c->frdi_idx_list, list) {
|
||||||
if (lprops->free + lprops->dirty != c->leb_size) {
|
if (lprops->free + lprops->dirty != c->leb_size) {
|
||||||
ubifs_err("non-freeable LEB %d on frdi_idx list "
|
ubifs_err("non-freeable LEB %d on frdi_idx list (free %d dirty %d flags %d)",
|
||||||
"(free %d dirty %d flags %d)", lprops->lnum,
|
lprops->lnum, lprops->free, lprops->dirty,
|
||||||
lprops->free, lprops->dirty, lprops->flags);
|
lprops->flags);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
if (lprops->flags & LPROPS_TAKEN) {
|
if (lprops->flags & LPROPS_TAKEN) {
|
||||||
ubifs_err("taken LEB %d on frdi_idx list "
|
ubifs_err("taken LEB %d on frdi_idx list (free %d dirty %d flags %d)",
|
||||||
"(free %d dirty %d flags %d)", lprops->lnum,
|
lprops->lnum, lprops->free, lprops->dirty,
|
||||||
lprops->free, lprops->dirty, lprops->flags);
|
lprops->flags);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
if (!(lprops->flags & LPROPS_INDEX)) {
|
if (!(lprops->flags & LPROPS_INDEX)) {
|
||||||
ubifs_err("non-index LEB %d on frdi_idx list "
|
ubifs_err("non-index LEB %d on frdi_idx list (free %d dirty %d flags %d)",
|
||||||
"(free %d dirty %d flags %d)", lprops->lnum,
|
lprops->lnum, lprops->free, lprops->dirty,
|
||||||
lprops->free, lprops->dirty, lprops->flags);
|
lprops->flags);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1153,8 +1153,8 @@ static int scan_check_cb(struct ubifs_info *c,
|
||||||
|
|
||||||
if (free > c->leb_size || free < 0 || dirty > c->leb_size ||
|
if (free > c->leb_size || free < 0 || dirty > c->leb_size ||
|
||||||
dirty < 0) {
|
dirty < 0) {
|
||||||
ubifs_err("bad calculated accounting for LEB %d: "
|
ubifs_err("bad calculated accounting for LEB %d: free %d, dirty %d",
|
||||||
"free %d, dirty %d", lnum, free, dirty);
|
lnum, free, dirty);
|
||||||
goto out_destroy;
|
goto out_destroy;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1200,8 +1200,7 @@ static int scan_check_cb(struct ubifs_info *c,
|
||||||
/* Free but not unmapped LEB, it's fine */
|
/* Free but not unmapped LEB, it's fine */
|
||||||
is_idx = 0;
|
is_idx = 0;
|
||||||
else {
|
else {
|
||||||
ubifs_err("indexing node without indexing "
|
ubifs_err("indexing node without indexing flag");
|
||||||
"flag");
|
|
||||||
goto out_print;
|
goto out_print;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1236,8 +1235,7 @@ static int scan_check_cb(struct ubifs_info *c,
|
||||||
return LPT_SCAN_CONTINUE;
|
return LPT_SCAN_CONTINUE;
|
||||||
|
|
||||||
out_print:
|
out_print:
|
||||||
ubifs_err("bad accounting of LEB %d: free %d, dirty %d flags %#x, "
|
ubifs_err("bad accounting of LEB %d: free %d, dirty %d flags %#x, should be free %d, dirty %d",
|
||||||
"should be free %d, dirty %d",
|
|
||||||
lnum, lp->free, lp->dirty, lp->flags, free, dirty);
|
lnum, lp->free, lp->dirty, lp->flags, free, dirty);
|
||||||
ubifs_dump_leb(c, lnum);
|
ubifs_dump_leb(c, lnum);
|
||||||
out_destroy:
|
out_destroy:
|
||||||
|
@ -1290,12 +1288,10 @@ int dbg_check_lprops(struct ubifs_info *c)
|
||||||
lst.total_dirty != c->lst.total_dirty ||
|
lst.total_dirty != c->lst.total_dirty ||
|
||||||
lst.total_used != c->lst.total_used) {
|
lst.total_used != c->lst.total_used) {
|
||||||
ubifs_err("bad overall accounting");
|
ubifs_err("bad overall accounting");
|
||||||
ubifs_err("calculated: empty_lebs %d, idx_lebs %d, "
|
ubifs_err("calculated: empty_lebs %d, idx_lebs %d, total_free %lld, total_dirty %lld, total_used %lld",
|
||||||
"total_free %lld, total_dirty %lld, total_used %lld",
|
|
||||||
lst.empty_lebs, lst.idx_lebs, lst.total_free,
|
lst.empty_lebs, lst.idx_lebs, lst.total_free,
|
||||||
lst.total_dirty, lst.total_used);
|
lst.total_dirty, lst.total_used);
|
||||||
ubifs_err("read from lprops: empty_lebs %d, idx_lebs %d, "
|
ubifs_err("read from lprops: empty_lebs %d, idx_lebs %d, total_free %lld, total_dirty %lld, total_used %lld",
|
||||||
"total_free %lld, total_dirty %lld, total_used %lld",
|
|
||||||
c->lst.empty_lebs, c->lst.idx_lebs, c->lst.total_free,
|
c->lst.empty_lebs, c->lst.idx_lebs, c->lst.total_free,
|
||||||
c->lst.total_dirty, c->lst.total_used);
|
c->lst.total_dirty, c->lst.total_used);
|
||||||
err = -EINVAL;
|
err = -EINVAL;
|
||||||
|
|
|
@ -2237,8 +2237,7 @@ int dbg_check_lpt_nodes(struct ubifs_info *c, struct ubifs_cnode *cnode,
|
||||||
/* cnode is a nnode */
|
/* cnode is a nnode */
|
||||||
num = calc_nnode_num(row, col);
|
num = calc_nnode_num(row, col);
|
||||||
if (cnode->num != num) {
|
if (cnode->num != num) {
|
||||||
ubifs_err("nnode num %d expected %d "
|
ubifs_err("nnode num %d expected %d parent num %d iip %d",
|
||||||
"parent num %d iip %d",
|
|
||||||
cnode->num, num,
|
cnode->num, num,
|
||||||
(nnode ? nnode->num : 0), cnode->iip);
|
(nnode ? nnode->num : 0), cnode->iip);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
|
@ -320,8 +320,8 @@ static int layout_cnodes(struct ubifs_info *c)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
no_space:
|
no_space:
|
||||||
ubifs_err("LPT out of space at LEB %d:%d needing %d, done_ltab %d, "
|
ubifs_err("LPT out of space at LEB %d:%d needing %d, done_ltab %d, done_lsave %d",
|
||||||
"done_lsave %d", lnum, offs, len, done_ltab, done_lsave);
|
lnum, offs, len, done_ltab, done_lsave);
|
||||||
ubifs_dump_lpt_info(c);
|
ubifs_dump_lpt_info(c);
|
||||||
ubifs_dump_lpt_lebs(c);
|
ubifs_dump_lpt_lebs(c);
|
||||||
dump_stack();
|
dump_stack();
|
||||||
|
@ -545,8 +545,8 @@ static int write_cnodes(struct ubifs_info *c)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
no_space:
|
no_space:
|
||||||
ubifs_err("LPT out of space mismatch at LEB %d:%d needing %d, done_ltab "
|
ubifs_err("LPT out of space mismatch at LEB %d:%d needing %d, done_ltab %d, done_lsave %d",
|
||||||
"%d, done_lsave %d", lnum, offs, len, done_ltab, done_lsave);
|
lnum, offs, len, done_ltab, done_lsave);
|
||||||
ubifs_dump_lpt_info(c);
|
ubifs_dump_lpt_info(c);
|
||||||
ubifs_dump_lpt_lebs(c);
|
ubifs_dump_lpt_lebs(c);
|
||||||
dump_stack();
|
dump_stack();
|
||||||
|
@ -1668,14 +1668,12 @@ static int dbg_check_ltab_lnum(struct ubifs_info *c, int lnum)
|
||||||
}
|
}
|
||||||
i = lnum - c->lpt_first;
|
i = lnum - c->lpt_first;
|
||||||
if (len != c->ltab[i].free) {
|
if (len != c->ltab[i].free) {
|
||||||
dbg_msg("invalid free space in LEB %d "
|
dbg_msg("invalid free space in LEB %d (free %d, expected %d)",
|
||||||
"(free %d, expected %d)",
|
|
||||||
lnum, len, c->ltab[i].free);
|
lnum, len, c->ltab[i].free);
|
||||||
err = -EINVAL;
|
err = -EINVAL;
|
||||||
}
|
}
|
||||||
if (dirty != c->ltab[i].dirty) {
|
if (dirty != c->ltab[i].dirty) {
|
||||||
dbg_msg("invalid dirty space in LEB %d "
|
dbg_msg("invalid dirty space in LEB %d (dirty %d, expected %d)",
|
||||||
"(dirty %d, expected %d)",
|
|
||||||
lnum, dirty, c->ltab[i].dirty);
|
lnum, dirty, c->ltab[i].dirty);
|
||||||
err = -EINVAL;
|
err = -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
|
@ -562,8 +562,8 @@ static int do_kill_orphans(struct ubifs_info *c, struct ubifs_scan_leb *sleb,
|
||||||
|
|
||||||
list_for_each_entry(snod, &sleb->nodes, list) {
|
list_for_each_entry(snod, &sleb->nodes, list) {
|
||||||
if (snod->type != UBIFS_ORPH_NODE) {
|
if (snod->type != UBIFS_ORPH_NODE) {
|
||||||
ubifs_err("invalid node type %d in orphan area at "
|
ubifs_err("invalid node type %d in orphan area at %d:%d",
|
||||||
"%d:%d", snod->type, sleb->lnum, snod->offs);
|
snod->type, sleb->lnum, snod->offs);
|
||||||
ubifs_dump_node(c, snod->node);
|
ubifs_dump_node(c, snod->node);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
@ -589,8 +589,7 @@ static int do_kill_orphans(struct ubifs_info *c, struct ubifs_scan_leb *sleb,
|
||||||
* number. That makes this orphan node, out of date.
|
* number. That makes this orphan node, out of date.
|
||||||
*/
|
*/
|
||||||
if (!first) {
|
if (!first) {
|
||||||
ubifs_err("out of order commit number %llu in "
|
ubifs_err("out of order commit number %llu in orphan node at %d:%d",
|
||||||
"orphan node at %d:%d",
|
|
||||||
cmt_no, sleb->lnum, snod->offs);
|
cmt_no, sleb->lnum, snod->offs);
|
||||||
ubifs_dump_node(c, snod->node);
|
ubifs_dump_node(c, snod->node);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
|
@ -609,7 +609,8 @@ static void drop_last_node(struct ubifs_scan_leb *sleb, int *offs)
|
||||||
snod = list_entry(sleb->nodes.prev, struct ubifs_scan_node,
|
snod = list_entry(sleb->nodes.prev, struct ubifs_scan_node,
|
||||||
list);
|
list);
|
||||||
|
|
||||||
dbg_rcvry("dropping last node at %d:%d", sleb->lnum, snod->offs);
|
dbg_rcvry("dropping last node at %d:%d",
|
||||||
|
sleb->lnum, snod->offs);
|
||||||
*offs = snod->offs;
|
*offs = snod->offs;
|
||||||
list_del(&snod->list);
|
list_del(&snod->list);
|
||||||
kfree(snod);
|
kfree(snod);
|
||||||
|
@ -702,8 +703,8 @@ struct ubifs_scan_leb *ubifs_recover_leb(struct ubifs_info *c, int lnum,
|
||||||
* See header comment for this file for more
|
* See header comment for this file for more
|
||||||
* explanations about the reasons we have this check.
|
* explanations about the reasons we have this check.
|
||||||
*/
|
*/
|
||||||
ubifs_err("corrupt empty space LEB %d:%d, corruption "
|
ubifs_err("corrupt empty space LEB %d:%d, corruption starts at %d",
|
||||||
"starts at %d", lnum, offs, corruption);
|
lnum, offs, corruption);
|
||||||
/* Make sure we dump interesting non-0xFF data */
|
/* Make sure we dump interesting non-0xFF data */
|
||||||
offs += corruption;
|
offs += corruption;
|
||||||
buf += corruption;
|
buf += corruption;
|
||||||
|
@ -899,8 +900,8 @@ struct ubifs_scan_leb *ubifs_recover_log_leb(struct ubifs_info *c, int lnum,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (snod->sqnum > cs_sqnum) {
|
if (snod->sqnum > cs_sqnum) {
|
||||||
ubifs_err("unrecoverable log corruption "
|
ubifs_err("unrecoverable log corruption in LEB %d",
|
||||||
"in LEB %d", lnum);
|
lnum);
|
||||||
ubifs_scan_destroy(sleb);
|
ubifs_scan_destroy(sleb);
|
||||||
return ERR_PTR(-EUCLEAN);
|
return ERR_PTR(-EUCLEAN);
|
||||||
}
|
}
|
||||||
|
|
|
@ -141,9 +141,9 @@ static int set_bud_lprops(struct ubifs_info *c, struct bud_entry *b)
|
||||||
* during the replay.
|
* during the replay.
|
||||||
*/
|
*/
|
||||||
if (dirty != 0)
|
if (dirty != 0)
|
||||||
dbg_msg("LEB %d lp: %d free %d dirty "
|
dbg_msg("LEB %d lp: %d free %d dirty replay: %d free %d dirty",
|
||||||
"replay: %d free %d dirty", b->bud->lnum,
|
b->bud->lnum, lp->free, lp->dirty, b->free,
|
||||||
lp->free, lp->dirty, b->free, b->dirty);
|
b->dirty);
|
||||||
}
|
}
|
||||||
lp = ubifs_change_lp(c, lp, b->free, dirty + b->dirty,
|
lp = ubifs_change_lp(c, lp, b->free, dirty + b->dirty,
|
||||||
lp->flags | LPROPS_TAKEN, 0);
|
lp->flags | LPROPS_TAKEN, 0);
|
||||||
|
@ -677,7 +677,8 @@ static int replay_bud(struct ubifs_info *c, struct bud_entry *b)
|
||||||
|
|
||||||
b->dirty = sleb->endpt - offs - used;
|
b->dirty = sleb->endpt - offs - used;
|
||||||
b->free = c->leb_size - sleb->endpt;
|
b->free = c->leb_size - sleb->endpt;
|
||||||
dbg_mnt("bud LEB %d replied: dirty %d, free %d", lnum, b->dirty, b->free);
|
dbg_mnt("bud LEB %d replied: dirty %d, free %d",
|
||||||
|
lnum, b->dirty, b->free);
|
||||||
|
|
||||||
out:
|
out:
|
||||||
ubifs_scan_destroy(sleb);
|
ubifs_scan_destroy(sleb);
|
||||||
|
@ -865,8 +866,7 @@ static int replay_log_leb(struct ubifs_info *c, int lnum, int offs, void *sbuf)
|
||||||
goto out_dump;
|
goto out_dump;
|
||||||
}
|
}
|
||||||
if (le64_to_cpu(node->cmt_no) != c->cmt_no) {
|
if (le64_to_cpu(node->cmt_no) != c->cmt_no) {
|
||||||
ubifs_err("first CS node at LEB %d:%d has wrong "
|
ubifs_err("first CS node at LEB %d:%d has wrong commit number %llu expected %llu",
|
||||||
"commit number %llu expected %llu",
|
|
||||||
lnum, offs,
|
lnum, offs,
|
||||||
(unsigned long long)le64_to_cpu(node->cmt_no),
|
(unsigned long long)le64_to_cpu(node->cmt_no),
|
||||||
c->cmt_no);
|
c->cmt_no);
|
||||||
|
@ -1058,8 +1058,8 @@ int ubifs_replay_journal(struct ubifs_info *c)
|
||||||
c->bi.uncommitted_idx *= c->max_idx_node_sz;
|
c->bi.uncommitted_idx *= c->max_idx_node_sz;
|
||||||
|
|
||||||
ubifs_assert(c->bud_bytes <= c->max_bud_bytes || c->need_recovery);
|
ubifs_assert(c->bud_bytes <= c->max_bud_bytes || c->need_recovery);
|
||||||
dbg_mnt("finished, log head LEB %d:%d, max_sqnum %llu, "
|
dbg_mnt("finished, log head LEB %d:%d, max_sqnum %llu, highest_inum %lu",
|
||||||
"highest_inum %lu", c->lhead_lnum, c->lhead_offs, c->max_sqnum,
|
c->lhead_lnum, c->lhead_offs, c->max_sqnum,
|
||||||
(unsigned long)c->highest_inum);
|
(unsigned long)c->highest_inum);
|
||||||
out:
|
out:
|
||||||
destroy_replay_list(c);
|
destroy_replay_list(c);
|
||||||
|
|
|
@ -391,9 +391,8 @@ static int validate_sb(struct ubifs_info *c, struct ubifs_sb_node *sup)
|
||||||
min_leb_cnt += c->lpt_lebs + c->orph_lebs + c->jhead_cnt + 6;
|
min_leb_cnt += c->lpt_lebs + c->orph_lebs + c->jhead_cnt + 6;
|
||||||
|
|
||||||
if (c->leb_cnt < min_leb_cnt || c->leb_cnt > c->vi.size) {
|
if (c->leb_cnt < min_leb_cnt || c->leb_cnt > c->vi.size) {
|
||||||
ubifs_err("bad LEB count: %d in superblock, %d on UBI volume, "
|
ubifs_err("bad LEB count: %d in superblock, %d on UBI volume, %d minimum required",
|
||||||
"%d minimum required", c->leb_cnt, c->vi.size,
|
c->leb_cnt, c->vi.size, min_leb_cnt);
|
||||||
min_leb_cnt);
|
|
||||||
goto failed;
|
goto failed;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -411,15 +410,14 @@ static int validate_sb(struct ubifs_info *c, struct ubifs_sb_node *sup)
|
||||||
|
|
||||||
max_bytes = (long long)c->leb_size * UBIFS_MIN_BUD_LEBS;
|
max_bytes = (long long)c->leb_size * UBIFS_MIN_BUD_LEBS;
|
||||||
if (c->max_bud_bytes < max_bytes) {
|
if (c->max_bud_bytes < max_bytes) {
|
||||||
ubifs_err("too small journal (%lld bytes), must be at least "
|
ubifs_err("too small journal (%lld bytes), must be at least %lld bytes",
|
||||||
"%lld bytes", c->max_bud_bytes, max_bytes);
|
c->max_bud_bytes, max_bytes);
|
||||||
goto failed;
|
goto failed;
|
||||||
}
|
}
|
||||||
|
|
||||||
max_bytes = (long long)c->leb_size * c->main_lebs;
|
max_bytes = (long long)c->leb_size * c->main_lebs;
|
||||||
if (c->max_bud_bytes > max_bytes) {
|
if (c->max_bud_bytes > max_bytes) {
|
||||||
ubifs_err("too large journal size (%lld bytes), only %lld bytes"
|
ubifs_err("too large journal size (%lld bytes), only %lld bytes available in the main area",
|
||||||
"available in the main area",
|
|
||||||
c->max_bud_bytes, max_bytes);
|
c->max_bud_bytes, max_bytes);
|
||||||
goto failed;
|
goto failed;
|
||||||
}
|
}
|
||||||
|
@ -549,10 +547,9 @@ int ubifs_read_superblock(struct ubifs_info *c)
|
||||||
ubifs_assert(!c->ro_media || c->ro_mount);
|
ubifs_assert(!c->ro_media || c->ro_mount);
|
||||||
if (!c->ro_mount ||
|
if (!c->ro_mount ||
|
||||||
c->ro_compat_version > UBIFS_RO_COMPAT_VERSION) {
|
c->ro_compat_version > UBIFS_RO_COMPAT_VERSION) {
|
||||||
ubifs_err("on-flash format version is w%d/r%d, but "
|
ubifs_err("on-flash format version is w%d/r%d, but software only supports up to version w%d/r%d",
|
||||||
"software only supports up to version "
|
c->fmt_version, c->ro_compat_version,
|
||||||
"w%d/r%d", c->fmt_version,
|
UBIFS_FORMAT_VERSION,
|
||||||
c->ro_compat_version, UBIFS_FORMAT_VERSION,
|
|
||||||
UBIFS_RO_COMPAT_VERSION);
|
UBIFS_RO_COMPAT_VERSION);
|
||||||
if (c->ro_compat_version <= UBIFS_RO_COMPAT_VERSION) {
|
if (c->ro_compat_version <= UBIFS_RO_COMPAT_VERSION) {
|
||||||
ubifs_msg("only R/O mounting is possible");
|
ubifs_msg("only R/O mounting is possible");
|
||||||
|
|
|
@ -85,7 +85,8 @@ int ubifs_scan_a_node(const struct ubifs_info *c, void *buf, int len, int lnum,
|
||||||
if (len < UBIFS_CH_SZ)
|
if (len < UBIFS_CH_SZ)
|
||||||
return SCANNED_GARBAGE;
|
return SCANNED_GARBAGE;
|
||||||
|
|
||||||
dbg_scan("scanning %s at LEB %d:%d", dbg_ntype(ch->node_type), lnum, offs);
|
dbg_scan("scanning %s at LEB %d:%d",
|
||||||
|
dbg_ntype(ch->node_type), lnum, offs);
|
||||||
|
|
||||||
if (ubifs_check_node(c, buf, lnum, offs, quiet, 1))
|
if (ubifs_check_node(c, buf, lnum, offs, quiet, 1))
|
||||||
return SCANNED_A_CORRUPT_NODE;
|
return SCANNED_A_CORRUPT_NODE;
|
||||||
|
@ -150,8 +151,8 @@ struct ubifs_scan_leb *ubifs_start_scan(const struct ubifs_info *c, int lnum,
|
||||||
|
|
||||||
err = ubifs_leb_read(c, lnum, sbuf + offs, offs, c->leb_size - offs, 0);
|
err = ubifs_leb_read(c, lnum, sbuf + offs, offs, c->leb_size - offs, 0);
|
||||||
if (err && err != -EBADMSG) {
|
if (err && err != -EBADMSG) {
|
||||||
ubifs_err("cannot read %d bytes from LEB %d:%d,"
|
ubifs_err("cannot read %d bytes from LEB %d:%d, error %d",
|
||||||
" error %d", c->leb_size - offs, lnum, offs, err);
|
c->leb_size - offs, lnum, offs, err);
|
||||||
kfree(sleb);
|
kfree(sleb);
|
||||||
return ERR_PTR(err);
|
return ERR_PTR(err);
|
||||||
}
|
}
|
||||||
|
|
|
@ -89,9 +89,8 @@ static int validate_inode(struct ubifs_info *c, const struct inode *inode)
|
||||||
return 5;
|
return 5;
|
||||||
|
|
||||||
if (!ubifs_compr_present(ui->compr_type)) {
|
if (!ubifs_compr_present(ui->compr_type)) {
|
||||||
ubifs_warn("inode %lu uses '%s' compression, but it was not "
|
ubifs_warn("inode %lu uses '%s' compression, but it was not compiled in",
|
||||||
"compiled in", inode->i_ino,
|
inode->i_ino, ubifs_compr_name(ui->compr_type));
|
||||||
ubifs_compr_name(ui->compr_type));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
err = dbg_check_dir(c, inode);
|
err = dbg_check_dir(c, inode);
|
||||||
|
@ -1061,8 +1060,8 @@ static int ubifs_parse_options(struct ubifs_info *c, char *options,
|
||||||
|
|
||||||
flag = parse_standard_option(p);
|
flag = parse_standard_option(p);
|
||||||
if (!flag) {
|
if (!flag) {
|
||||||
ubifs_err("unrecognized mount option \"%s\" "
|
ubifs_err("unrecognized mount option \"%s\" or missing value",
|
||||||
"or missing value", p);
|
p);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
sb->s_flags |= flag;
|
sb->s_flags |= flag;
|
||||||
|
@ -1124,8 +1123,8 @@ again:
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Just disable bulk-read */
|
/* Just disable bulk-read */
|
||||||
ubifs_warn("Cannot allocate %d bytes of memory for bulk-read, "
|
ubifs_warn("cannot allocate %d bytes of memory for bulk-read, disabling it",
|
||||||
"disabling it", c->max_bu_buf_len);
|
c->max_bu_buf_len);
|
||||||
c->mount_opts.bulk_read = 1;
|
c->mount_opts.bulk_read = 1;
|
||||||
c->bulk_read = 0;
|
c->bulk_read = 0;
|
||||||
return;
|
return;
|
||||||
|
@ -1416,11 +1415,11 @@ static int mount_ubifs(struct ubifs_info *c)
|
||||||
if (c->ro_mount)
|
if (c->ro_mount)
|
||||||
ubifs_msg("mounted read-only");
|
ubifs_msg("mounted read-only");
|
||||||
x = (long long)c->main_lebs * c->leb_size;
|
x = (long long)c->main_lebs * c->leb_size;
|
||||||
ubifs_msg("file system size: %lld bytes (%lld KiB, %lld MiB, %d "
|
ubifs_msg("file system size: %lld bytes (%lld KiB, %lld MiB, %d LEBs)",
|
||||||
"LEBs)", x, x >> 10, x >> 20, c->main_lebs);
|
x, x >> 10, x >> 20, c->main_lebs);
|
||||||
x = (long long)c->log_lebs * c->leb_size + c->max_bud_bytes;
|
x = (long long)c->log_lebs * c->leb_size + c->max_bud_bytes;
|
||||||
ubifs_msg("journal size: %lld bytes (%lld KiB, %lld MiB, %d "
|
ubifs_msg("journal size: %lld bytes (%lld KiB, %lld MiB, %d LEBs)",
|
||||||
"LEBs)", x, x >> 10, x >> 20, c->log_lebs + c->max_bud_cnt);
|
x, x >> 10, x >> 20, c->log_lebs + c->max_bud_cnt);
|
||||||
ubifs_msg("media format: w%d/r%d (latest is w%d/r%d)",
|
ubifs_msg("media format: w%d/r%d (latest is w%d/r%d)",
|
||||||
c->fmt_version, c->ro_compat_version,
|
c->fmt_version, c->ro_compat_version,
|
||||||
UBIFS_FORMAT_VERSION, UBIFS_RO_COMPAT_VERSION);
|
UBIFS_FORMAT_VERSION, UBIFS_RO_COMPAT_VERSION);
|
||||||
|
@ -1563,10 +1562,9 @@ static int ubifs_remount_rw(struct ubifs_info *c)
|
||||||
|
|
||||||
if (c->rw_incompat) {
|
if (c->rw_incompat) {
|
||||||
ubifs_err("the file-system is not R/W-compatible");
|
ubifs_err("the file-system is not R/W-compatible");
|
||||||
ubifs_msg("on-flash format version is w%d/r%d, but software "
|
ubifs_msg("on-flash format version is w%d/r%d, but software only supports up to version w%d/r%d",
|
||||||
"only supports up to version w%d/r%d", c->fmt_version,
|
c->fmt_version, c->ro_compat_version,
|
||||||
c->ro_compat_version, UBIFS_FORMAT_VERSION,
|
UBIFS_FORMAT_VERSION, UBIFS_RO_COMPAT_VERSION);
|
||||||
UBIFS_RO_COMPAT_VERSION);
|
|
||||||
return -EROFS;
|
return -EROFS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1827,8 +1825,8 @@ static void ubifs_put_super(struct super_block *sb)
|
||||||
* next mount, so we just print a message and
|
* next mount, so we just print a message and
|
||||||
* continue to unmount normally.
|
* continue to unmount normally.
|
||||||
*/
|
*/
|
||||||
ubifs_err("failed to write master node, "
|
ubifs_err("failed to write master node, error %d",
|
||||||
"error %d", err);
|
err);
|
||||||
} else {
|
} else {
|
||||||
for (i = 0; i < c->jhead_cnt; i++)
|
for (i = 0; i < c->jhead_cnt; i++)
|
||||||
/* Make sure write-buffer timers are canceled */
|
/* Make sure write-buffer timers are canceled */
|
||||||
|
@ -2247,8 +2245,7 @@ static int __init ubifs_init(void)
|
||||||
* UBIFS_BLOCK_SIZE. It is assumed that both are powers of 2.
|
* UBIFS_BLOCK_SIZE. It is assumed that both are powers of 2.
|
||||||
*/
|
*/
|
||||||
if (PAGE_CACHE_SIZE < UBIFS_BLOCK_SIZE) {
|
if (PAGE_CACHE_SIZE < UBIFS_BLOCK_SIZE) {
|
||||||
ubifs_err("VFS page cache size is %u bytes, but UBIFS requires"
|
ubifs_err("VFS page cache size is %u bytes, but UBIFS requires at least 4096 bytes",
|
||||||
" at least 4096 bytes",
|
|
||||||
(unsigned int)PAGE_CACHE_SIZE);
|
(unsigned int)PAGE_CACHE_SIZE);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue