diff options
| author | Artem Bityutskiy <Artem.Bityutskiy@nokia.com> | 2011-05-26 08:36:52 +0300 | 
|---|---|---|
| committer | Artem Bityutskiy <Artem.Bityutskiy@nokia.com> | 2011-06-01 12:29:06 +0300 | 
| commit | efcfde54ca68091b164f9aec544c7233a9760aff (patch) | |
| tree | f94cd590448a23c2ba7c6566dcbeb72eb3f3dd1d /fs/ubifs | |
| parent | 1a0b06997ceca96db9259e537eb935f9fe59a3de (diff) | |
UBIFS: amend ubifs_recover_leb interface
Instead of passing "grouped" parameter to 'ubifs_recover_leb()' which tells
whether the nodes are grouped in the LEB to recover, pass the journal head
number and let 'ubifs_recover_leb()' look at the journal head's 'grouped' flag.
This patch is a preparation to a further fix where we'll need to know the
journal head number for other purposes.
Signed-off-by: Artem Bityutskiy <Artem.Bityutskiy@nokia.com>
Diffstat (limited to 'fs/ubifs')
| -rw-r--r-- | fs/ubifs/orphan.c | 2 | ||||
| -rw-r--r-- | fs/ubifs/recovery.c | 10 | ||||
| -rw-r--r-- | fs/ubifs/replay.c | 3 | ||||
| -rw-r--r-- | fs/ubifs/ubifs.h | 2 | 
4 files changed, 9 insertions, 8 deletions
| diff --git a/fs/ubifs/orphan.c b/fs/ubifs/orphan.c index bd644bf587a..a5422fffbd6 100644 --- a/fs/ubifs/orphan.c +++ b/fs/ubifs/orphan.c @@ -674,7 +674,7 @@ static int kill_orphans(struct ubifs_info *c)  		if (IS_ERR(sleb)) {  			if (PTR_ERR(sleb) == -EUCLEAN)  				sleb = ubifs_recover_leb(c, lnum, 0, -							 c->sbuf, 0); +							 c->sbuf, -1);  			if (IS_ERR(sleb)) {  				err = PTR_ERR(sleb);  				break; diff --git a/fs/ubifs/recovery.c b/fs/ubifs/recovery.c index 95e24183b71..6adb5328a01 100644 --- a/fs/ubifs/recovery.c +++ b/fs/ubifs/recovery.c @@ -604,7 +604,8 @@ static int drop_last_node(struct ubifs_scan_leb *sleb, int *offs, int grouped)   * @lnum: LEB number   * @offs: offset   * @sbuf: LEB-sized buffer to use - * @grouped: nodes may be grouped for recovery + * @jhead: journal head number this LEB belongs to (%-1 if the LEB does not + *         belong to any journal head)   *   * This function does a scan of a LEB, but caters for errors that might have   * been caused by the unclean unmount from which we are attempting to recover. @@ -612,13 +613,14 @@ static int drop_last_node(struct ubifs_scan_leb *sleb, int *offs, int grouped)   * found, and a negative error code in case of failure.   */  struct ubifs_scan_leb *ubifs_recover_leb(struct ubifs_info *c, int lnum, -					 int offs, void *sbuf, int grouped) +					 int offs, void *sbuf, int jhead)  {  	int ret = 0, err, len = c->leb_size - offs, start = offs, min_io_unit; +	int grouped = jhead == -1 ? 0 : c->jheads[jhead].grouped;  	struct ubifs_scan_leb *sleb;  	void *buf = sbuf + offs; -	dbg_rcvry("%d:%d", lnum, offs); +	dbg_rcvry("%d:%d, jhead %d, grouped %d", lnum, offs, jhead, grouped);  	sleb = ubifs_start_scan(c, lnum, offs, sbuf);  	if (IS_ERR(sleb)) @@ -881,7 +883,7 @@ struct ubifs_scan_leb *ubifs_recover_log_leb(struct ubifs_info *c, int lnum,  		}  		ubifs_scan_destroy(sleb);  	} -	return ubifs_recover_leb(c, lnum, offs, sbuf, 0); +	return ubifs_recover_leb(c, lnum, offs, sbuf, -1);  }  /** diff --git a/fs/ubifs/replay.c b/fs/ubifs/replay.c index 6617280d167..5e97161ce4d 100644 --- a/fs/ubifs/replay.c +++ b/fs/ubifs/replay.c @@ -557,8 +557,7 @@ static int replay_bud(struct ubifs_info *c, struct bud_entry *b)  		 * these LEBs could possibly be written to at the power cut  		 * time.  		 */ -		sleb = ubifs_recover_leb(c, lnum, offs, c->sbuf, -					 b->bud->jhead != GCHD); +		sleb = ubifs_recover_leb(c, lnum, offs, c->sbuf, b->bud->jhead);  	else  		sleb = ubifs_scan(c, lnum, offs, c->sbuf, 0);  	if (IS_ERR(sleb)) diff --git a/fs/ubifs/ubifs.h b/fs/ubifs/ubifs.h index adeca14c0e9..f79983d6f86 100644 --- a/fs/ubifs/ubifs.h +++ b/fs/ubifs/ubifs.h @@ -1744,7 +1744,7 @@ struct inode *ubifs_iget(struct super_block *sb, unsigned long inum);  int ubifs_recover_master_node(struct ubifs_info *c);  int ubifs_write_rcvrd_mst_node(struct ubifs_info *c);  struct ubifs_scan_leb *ubifs_recover_leb(struct ubifs_info *c, int lnum, -					 int offs, void *sbuf, int grouped); +					 int offs, void *sbuf, int jhead);  struct ubifs_scan_leb *ubifs_recover_log_leb(struct ubifs_info *c, int lnum,  					     int offs, void *sbuf);  int ubifs_recover_inl_heads(const struct ubifs_info *c, void *sbuf); | 
