Blame view

fs/gfs2/recovery.c 13 KB
b3b94faa5   David Teigland   [GFS2] The core o...
1
2
  /*
   * Copyright (C) Sistina Software, Inc.  1997-2003 All rights reserved.
3a8a9a103   Steven Whitehouse   [GFS2] Update cop...
3
   * Copyright (C) 2004-2006 Red Hat, Inc.  All rights reserved.
b3b94faa5   David Teigland   [GFS2] The core o...
4
5
6
   *
   * This copyrighted material is made available to anyone wishing to use,
   * modify, copy, or redistribute it subject to the terms and conditions
e9fc2aa09   Steven Whitehouse   [GFS2] Update cop...
7
   * of the GNU General Public License version 2.
b3b94faa5   David Teigland   [GFS2] The core o...
8
   */
b3b94faa5   David Teigland   [GFS2] The core o...
9
10
11
12
  #include <linux/slab.h>
  #include <linux/spinlock.h>
  #include <linux/completion.h>
  #include <linux/buffer_head.h>
5c676f6d3   Steven Whitehouse   [GFS2] Macros rem...
13
  #include <linux/gfs2_ondisk.h>
71b86f562   Steven Whitehouse   [GFS2] Further up...
14
  #include <linux/crc32.h>
7d308590a   Fabio Massimo Di Nitto   [GFS2] Export lm_...
15
  #include <linux/lm_interface.h>
b3b94faa5   David Teigland   [GFS2] The core o...
16
17
  
  #include "gfs2.h"
5c676f6d3   Steven Whitehouse   [GFS2] Macros rem...
18
  #include "incore.h"
b3b94faa5   David Teigland   [GFS2] The core o...
19
20
21
22
23
24
25
26
  #include "bmap.h"
  #include "glock.h"
  #include "glops.h"
  #include "lm.h"
  #include "lops.h"
  #include "meta_io.h"
  #include "recovery.h"
  #include "super.h"
5c676f6d3   Steven Whitehouse   [GFS2] Macros rem...
27
  #include "util.h"
71b86f562   Steven Whitehouse   [GFS2] Further up...
28
  #include "dir.h"
b3b94faa5   David Teigland   [GFS2] The core o...
29
30
31
32
  
  int gfs2_replay_read_block(struct gfs2_jdesc *jd, unsigned int blk,
  			   struct buffer_head **bh)
  {
feaa7bba0   Steven Whitehouse   [GFS2] Fix unlink...
33
  	struct gfs2_inode *ip = GFS2_I(jd->jd_inode);
5c676f6d3   Steven Whitehouse   [GFS2] Macros rem...
34
  	struct gfs2_glock *gl = ip->i_gl;
b3b94faa5   David Teigland   [GFS2] The core o...
35
  	int new = 0;
cd915493f   Steven Whitehouse   [GFS2] Change all...
36
37
  	u64 dblock;
  	u32 extlen;
b3b94faa5   David Teigland   [GFS2] The core o...
38
  	int error;
feaa7bba0   Steven Whitehouse   [GFS2] Fix unlink...
39
  	error = gfs2_extent_map(&ip->i_inode, blk, &new, &dblock, &extlen);
b3b94faa5   David Teigland   [GFS2] The core o...
40
41
42
  	if (error)
  		return error;
  	if (!dblock) {
5c676f6d3   Steven Whitehouse   [GFS2] Macros rem...
43
  		gfs2_consist_inode(ip);
b3b94faa5   David Teigland   [GFS2] The core o...
44
45
  		return -EIO;
  	}
7276b3b0c   Steven Whitehouse   [GFS2] Tidy up me...
46
  	*bh = gfs2_meta_ra(gl, dblock, extlen);
b3b94faa5   David Teigland   [GFS2] The core o...
47
48
49
  
  	return error;
  }
cd915493f   Steven Whitehouse   [GFS2] Change all...
50
  int gfs2_revoke_add(struct gfs2_sbd *sdp, u64 blkno, unsigned int where)
b3b94faa5   David Teigland   [GFS2] The core o...
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
  {
  	struct list_head *head = &sdp->sd_revoke_list;
  	struct gfs2_revoke_replay *rr;
  	int found = 0;
  
  	list_for_each_entry(rr, head, rr_list) {
  		if (rr->rr_blkno == blkno) {
  			found = 1;
  			break;
  		}
  	}
  
  	if (found) {
  		rr->rr_where = where;
  		return 0;
  	}
  
  	rr = kmalloc(sizeof(struct gfs2_revoke_replay), GFP_KERNEL);
  	if (!rr)
  		return -ENOMEM;
  
  	rr->rr_blkno = blkno;
  	rr->rr_where = where;
  	list_add(&rr->rr_list, head);
  
  	return 1;
  }
cd915493f   Steven Whitehouse   [GFS2] Change all...
78
  int gfs2_revoke_check(struct gfs2_sbd *sdp, u64 blkno, unsigned int where)
b3b94faa5   David Teigland   [GFS2] The core o...
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
  {
  	struct gfs2_revoke_replay *rr;
  	int wrap, a, b, revoke;
  	int found = 0;
  
  	list_for_each_entry(rr, &sdp->sd_revoke_list, rr_list) {
  		if (rr->rr_blkno == blkno) {
  			found = 1;
  			break;
  		}
  	}
  
  	if (!found)
  		return 0;
  
  	wrap = (rr->rr_where < sdp->sd_replay_tail);
  	a = (sdp->sd_replay_tail < where);
  	b = (where < rr->rr_where);
  	revoke = (wrap) ? (a || b) : (a && b);
  
  	return revoke;
  }
  
  void gfs2_revoke_clean(struct gfs2_sbd *sdp)
  {
  	struct list_head *head = &sdp->sd_revoke_list;
  	struct gfs2_revoke_replay *rr;
  
  	while (!list_empty(head)) {
  		rr = list_entry(head->next, struct gfs2_revoke_replay, rr_list);
  		list_del(&rr->rr_list);
  		kfree(rr);
  	}
  }
bb8d8a6f5   Steven Whitehouse   [GFS2] Fix sign p...
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
  static int gfs2_log_header_in(struct gfs2_log_header_host *lh, const void *buf)
  {
  	const struct gfs2_log_header *str = buf;
  
  	if (str->lh_header.mh_magic != cpu_to_be32(GFS2_MAGIC) ||
  	    str->lh_header.mh_type != cpu_to_be32(GFS2_METATYPE_LH))
  		return 1;
  
  	lh->lh_sequence = be64_to_cpu(str->lh_sequence);
  	lh->lh_flags = be32_to_cpu(str->lh_flags);
  	lh->lh_tail = be32_to_cpu(str->lh_tail);
  	lh->lh_blkno = be32_to_cpu(str->lh_blkno);
  	lh->lh_hash = be32_to_cpu(str->lh_hash);
  	return 0;
  }
b3b94faa5   David Teigland   [GFS2] The core o...
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
  /**
   * get_log_header - read the log header for a given segment
   * @jd: the journal
   * @blk: the block to look at
   * @lh: the log header to return
   *
   * Read the log header for a given segement in a given journal.  Do a few
   * sanity checks on it.
   *
   * Returns: 0 on success,
   *          1 if the header was invalid or incomplete,
   *          errno on error
   */
  
  static int get_log_header(struct gfs2_jdesc *jd, unsigned int blk,
551676226   Al Viro   [GFS2] split and ...
143
  			  struct gfs2_log_header_host *head)
b3b94faa5   David Teigland   [GFS2] The core o...
144
145
  {
  	struct buffer_head *bh;
551676226   Al Viro   [GFS2] split and ...
146
  	struct gfs2_log_header_host lh;
887bc5d00   Steven Whitehouse   [GFS2] Fix indent...
147
  	const u32 nothing = 0;
cd915493f   Steven Whitehouse   [GFS2] Change all...
148
  	u32 hash;
b3b94faa5   David Teigland   [GFS2] The core o...
149
150
151
152
153
  	int error;
  
  	error = gfs2_replay_read_block(jd, blk, &bh);
  	if (error)
  		return error;
2a2c98247   Steven Whitehouse   [GFS2] Fix crc32 ...
154
155
156
157
  	hash = crc32_le((u32)~0, bh->b_data, sizeof(struct gfs2_log_header) -
  					     sizeof(u32));
  	hash = crc32_le(hash, (unsigned char const *)&nothing, sizeof(nothing));
  	hash ^= (u32)~0;
bb8d8a6f5   Steven Whitehouse   [GFS2] Fix sign p...
158
  	error = gfs2_log_header_in(&lh, bh->b_data);
b3b94faa5   David Teigland   [GFS2] The core o...
159
  	brelse(bh);
bb8d8a6f5   Steven Whitehouse   [GFS2] Fix sign p...
160
  	if (error || lh.lh_blkno != blk || lh.lh_hash != hash)
b3b94faa5   David Teigland   [GFS2] The core o...
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
  		return 1;
  
  	*head = lh;
  
  	return 0;
  }
  
  /**
   * find_good_lh - find a good log header
   * @jd: the journal
   * @blk: the segment to start searching from
   * @lh: the log header to fill in
   * @forward: if true search forward in the log, else search backward
   *
   * Call get_log_header() to get a log header for a segment, but if the
   * segment is bad, either scan forward or backward until we find a good one.
   *
   * Returns: errno
   */
  
  static int find_good_lh(struct gfs2_jdesc *jd, unsigned int *blk,
551676226   Al Viro   [GFS2] split and ...
182
  			struct gfs2_log_header_host *head)
b3b94faa5   David Teigland   [GFS2] The core o...
183
184
185
186
187
188
189
190
191
192
193
194
195
  {
  	unsigned int orig_blk = *blk;
  	int error;
  
  	for (;;) {
  		error = get_log_header(jd, *blk, head);
  		if (error <= 0)
  			return error;
  
  		if (++*blk == jd->jd_blocks)
  			*blk = 0;
  
  		if (*blk == orig_blk) {
feaa7bba0   Steven Whitehouse   [GFS2] Fix unlink...
196
  			gfs2_consist_inode(GFS2_I(jd->jd_inode));
b3b94faa5   David Teigland   [GFS2] The core o...
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
  			return -EIO;
  		}
  	}
  }
  
  /**
   * jhead_scan - make sure we've found the head of the log
   * @jd: the journal
   * @head: this is filled in with the log descriptor of the head
   *
   * At this point, seg and lh should be either the head of the log or just
   * before.  Scan forward until we find the head.
   *
   * Returns: errno
   */
551676226   Al Viro   [GFS2] split and ...
212
  static int jhead_scan(struct gfs2_jdesc *jd, struct gfs2_log_header_host *head)
b3b94faa5   David Teigland   [GFS2] The core o...
213
214
  {
  	unsigned int blk = head->lh_blkno;
551676226   Al Viro   [GFS2] split and ...
215
  	struct gfs2_log_header_host lh;
b3b94faa5   David Teigland   [GFS2] The core o...
216
217
218
219
220
221
222
223
224
225
226
227
228
  	int error;
  
  	for (;;) {
  		if (++blk == jd->jd_blocks)
  			blk = 0;
  
  		error = get_log_header(jd, blk, &lh);
  		if (error < 0)
  			return error;
  		if (error == 1)
  			continue;
  
  		if (lh.lh_sequence == head->lh_sequence) {
feaa7bba0   Steven Whitehouse   [GFS2] Fix unlink...
229
  			gfs2_consist_inode(GFS2_I(jd->jd_inode));
b3b94faa5   David Teigland   [GFS2] The core o...
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
  			return -EIO;
  		}
  		if (lh.lh_sequence < head->lh_sequence)
  			break;
  
  		*head = lh;
  	}
  
  	return 0;
  }
  
  /**
   * gfs2_find_jhead - find the head of a log
   * @jd: the journal
   * @head: the log descriptor for the head of the log is returned here
   *
   * Do a binary search of a journal and find the valid log entry with the
   * highest sequence number.  (i.e. the log head)
   *
   * Returns: errno
   */
551676226   Al Viro   [GFS2] split and ...
251
  int gfs2_find_jhead(struct gfs2_jdesc *jd, struct gfs2_log_header_host *head)
b3b94faa5   David Teigland   [GFS2] The core o...
252
  {
551676226   Al Viro   [GFS2] split and ...
253
  	struct gfs2_log_header_host lh_1, lh_m;
cd915493f   Steven Whitehouse   [GFS2] Change all...
254
  	u32 blk_1, blk_2, blk_m;
b3b94faa5   David Teigland   [GFS2] The core o...
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
  	int error;
  
  	blk_1 = 0;
  	blk_2 = jd->jd_blocks - 1;
  
  	for (;;) {
  		blk_m = (blk_1 + blk_2) / 2;
  
  		error = find_good_lh(jd, &blk_1, &lh_1);
  		if (error)
  			return error;
  
  		error = find_good_lh(jd, &blk_m, &lh_m);
  		if (error)
  			return error;
  
  		if (blk_1 == blk_m || blk_m == blk_2)
  			break;
  
  		if (lh_1.lh_sequence <= lh_m.lh_sequence)
  			blk_1 = blk_m;
  		else
  			blk_2 = blk_m;
  	}
  
  	error = jhead_scan(jd, &lh_1);
  	if (error)
  		return error;
  
  	*head = lh_1;
  
  	return error;
  }
  
  /**
   * foreach_descriptor - go through the active part of the log
   * @jd: the journal
   * @start: the first log header in the active region
   * @end: the last log header (don't process the contents of this entry))
   *
   * Call a given function once for every log descriptor in the active
   * portion of the log.
   *
   * Returns: errno
   */
  
  static int foreach_descriptor(struct gfs2_jdesc *jd, unsigned int start,
  			      unsigned int end, int pass)
  {
feaa7bba0   Steven Whitehouse   [GFS2] Fix unlink...
304
  	struct gfs2_sbd *sdp = GFS2_SB(jd->jd_inode);
b3b94faa5   David Teigland   [GFS2] The core o...
305
306
307
308
309
310
  	struct buffer_head *bh;
  	struct gfs2_log_descriptor *ld;
  	int error = 0;
  	u32 length;
  	__be64 *ptr;
  	unsigned int offset = sizeof(struct gfs2_log_descriptor);
a67cdbd45   Steven Whitehouse   [GFS2] Style chan...
311
312
  	offset += sizeof(__be64) - 1;
  	offset &= ~(sizeof(__be64) - 1);
b3b94faa5   David Teigland   [GFS2] The core o...
313
314
315
316
317
318
319
320
321
322
323
  
  	while (start != end) {
  		error = gfs2_replay_read_block(jd, start, &bh);
  		if (error)
  			return error;
  		if (gfs2_meta_check(sdp, bh)) {
  			brelse(bh);
  			return -EIO;
  		}
  		ld = (struct gfs2_log_descriptor *)bh->b_data;
  		length = be32_to_cpu(ld->ld_length);
e3167ded1   Steven Whitehouse   [GFS] Fix bug in ...
324
  		if (be32_to_cpu(ld->ld_header.mh_type) == GFS2_METATYPE_LH) {
551676226   Al Viro   [GFS2] split and ...
325
  			struct gfs2_log_header_host lh;
b3b94faa5   David Teigland   [GFS2] The core o...
326
327
328
  			error = get_log_header(jd, start, &lh);
  			if (!error) {
  				gfs2_replay_incr_blk(sdp, &start);
887218778   Russell Cattelan   [GFS2] Fix a coup...
329
  				brelse(bh);
b3b94faa5   David Teigland   [GFS2] The core o...
330
331
332
  				continue;
  			}
  			if (error == 1) {
feaa7bba0   Steven Whitehouse   [GFS2] Fix unlink...
333
  				gfs2_consist_inode(GFS2_I(jd->jd_inode));
b3b94faa5   David Teigland   [GFS2] The core o...
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
  				error = -EIO;
  			}
  			brelse(bh);
  			return error;
  		} else if (gfs2_metatype_check(sdp, bh, GFS2_METATYPE_LD)) {
  			brelse(bh);
  			return -EIO;
  		}
  		ptr = (__be64 *)(bh->b_data + offset);
  		error = lops_scan_elements(jd, start, ld, ptr, pass);
  		if (error) {
  			brelse(bh);
  			return error;
  		}
  
  		while (length--)
  			gfs2_replay_incr_blk(sdp, &start);
  
  		brelse(bh);
  	}
  
  	return 0;
  }
  
  /**
   * clean_journal - mark a dirty journal as being clean
   * @sdp: the filesystem
   * @jd: the journal
   * @gl: the journal's glock
   * @head: the head journal to start from
   *
   * Returns: errno
   */
551676226   Al Viro   [GFS2] split and ...
367
  static int clean_journal(struct gfs2_jdesc *jd, struct gfs2_log_header_host *head)
b3b94faa5   David Teigland   [GFS2] The core o...
368
  {
feaa7bba0   Steven Whitehouse   [GFS2] Fix unlink...
369
370
  	struct gfs2_inode *ip = GFS2_I(jd->jd_inode);
  	struct gfs2_sbd *sdp = GFS2_SB(jd->jd_inode);
b3b94faa5   David Teigland   [GFS2] The core o...
371
  	unsigned int lblock;
b3b94faa5   David Teigland   [GFS2] The core o...
372
  	struct gfs2_log_header *lh;
cd915493f   Steven Whitehouse   [GFS2] Change all...
373
  	u32 hash;
b3b94faa5   David Teigland   [GFS2] The core o...
374
375
  	struct buffer_head *bh;
  	int error;
23591256d   Steven Whitehouse   [GFS2] Fix bmap t...
376
  	struct buffer_head bh_map = { .b_state = 0, .b_blocknr = 0 };
fd88de569   Steven Whitehouse   [GFS2] Readpages ...
377

b3b94faa5   David Teigland   [GFS2] The core o...
378
379
  	lblock = head->lh_blkno;
  	gfs2_replay_incr_blk(sdp, &lblock);
23591256d   Steven Whitehouse   [GFS2] Fix bmap t...
380
381
  	bh_map.b_size = 1 << ip->i_inode.i_blkbits;
  	error = gfs2_block_map(&ip->i_inode, lblock, 0, &bh_map);
b3b94faa5   David Teigland   [GFS2] The core o...
382
383
  	if (error)
  		return error;
7a6bbacbb   Steven Whitehouse   [GFS2] Map multip...
384
  	if (!bh_map.b_blocknr) {
b3b94faa5   David Teigland   [GFS2] The core o...
385
386
387
  		gfs2_consist_inode(ip);
  		return -EIO;
  	}
7a6bbacbb   Steven Whitehouse   [GFS2] Map multip...
388
  	bh = sb_getblk(sdp->sd_vfs, bh_map.b_blocknr);
b3b94faa5   David Teigland   [GFS2] The core o...
389
390
391
392
393
394
395
396
397
  	lock_buffer(bh);
  	memset(bh->b_data, 0, bh->b_size);
  	set_buffer_uptodate(bh);
  	clear_buffer_dirty(bh);
  	unlock_buffer(bh);
  
  	lh = (struct gfs2_log_header *)bh->b_data;
  	memset(lh, 0, sizeof(struct gfs2_log_header));
  	lh->lh_header.mh_magic = cpu_to_be32(GFS2_MAGIC);
887218778   Russell Cattelan   [GFS2] Fix a coup...
398
  	lh->lh_header.mh_type = cpu_to_be32(GFS2_METATYPE_LH);
e3167ded1   Steven Whitehouse   [GFS] Fix bug in ...
399
  	lh->lh_header.mh_format = cpu_to_be32(GFS2_FORMAT_LH);
b3b94faa5   David Teigland   [GFS2] The core o...
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
  	lh->lh_sequence = cpu_to_be64(head->lh_sequence + 1);
  	lh->lh_flags = cpu_to_be32(GFS2_LOG_HEAD_UNMOUNT);
  	lh->lh_blkno = cpu_to_be32(lblock);
  	hash = gfs2_disk_hash((const char *)lh, sizeof(struct gfs2_log_header));
  	lh->lh_hash = cpu_to_be32(hash);
  
  	set_buffer_dirty(bh);
  	if (sync_dirty_buffer(bh))
  		gfs2_io_error_bh(sdp, bh);
  	brelse(bh);
  
  	return error;
  }
  
  /**
   * gfs2_recover_journal - recovery a given journal
   * @jd: the struct gfs2_jdesc describing the journal
b3b94faa5   David Teigland   [GFS2] The core o...
417
418
419
420
421
422
   *
   * Acquire the journal's lock, check to see if the journal is clean, and
   * do recovery if necessary.
   *
   * Returns: errno
   */
c63e31c2c   David Teigland   [GFS2] journal re...
423
  int gfs2_recover_journal(struct gfs2_jdesc *jd)
b3b94faa5   David Teigland   [GFS2] The core o...
424
  {
feaa7bba0   Steven Whitehouse   [GFS2] Fix unlink...
425
426
  	struct gfs2_inode *ip = GFS2_I(jd->jd_inode);
  	struct gfs2_sbd *sdp = GFS2_SB(jd->jd_inode);
551676226   Al Viro   [GFS2] split and ...
427
  	struct gfs2_log_header_host head;
b3b94faa5   David Teigland   [GFS2] The core o...
428
429
430
431
432
  	struct gfs2_holder j_gh, ji_gh, t_gh;
  	unsigned long t;
  	int ro = 0;
  	unsigned int pass;
  	int error;
5965b1f47   Steven Whitehouse   [GFS2] Don't do r...
433
434
435
436
  	if (jd->jd_jid != sdp->sd_lockstruct.ls_jid) {
  		fs_info(sdp, "jid=%u: Trying to acquire journal lock...
  ",
  			jd->jd_jid);
b3b94faa5   David Teigland   [GFS2] The core o...
437

5965b1f47   Steven Whitehouse   [GFS2] Don't do r...
438
  		/* Aquire the journal lock so we can do recovery */
b3b94faa5   David Teigland   [GFS2] The core o...
439

5965b1f47   Steven Whitehouse   [GFS2] Don't do r...
440
441
442
443
444
445
446
  		error = gfs2_glock_nq_num(sdp, jd->jd_jid, &gfs2_journal_glops,
  					  LM_ST_EXCLUSIVE,
  					  LM_FLAG_NOEXP | LM_FLAG_TRY | GL_NOCACHE,
  					  &j_gh);
  		switch (error) {
  		case 0:
  			break;
907b9bceb   Steven Whitehouse   [GFS2/DLM] Fix tr...
447

5965b1f47   Steven Whitehouse   [GFS2] Don't do r...
448
449
450
451
  		case GLR_TRYFAILED:
  			fs_info(sdp, "jid=%u: Busy
  ", jd->jd_jid);
  			error = 0;
907b9bceb   Steven Whitehouse   [GFS2/DLM] Fix tr...
452

5965b1f47   Steven Whitehouse   [GFS2] Don't do r...
453
454
455
  		default:
  			goto fail;
  		};
b3b94faa5   David Teigland   [GFS2] The core o...
456

5965b1f47   Steven Whitehouse   [GFS2] Don't do r...
457
458
459
460
461
462
463
464
  		error = gfs2_glock_nq_init(ip->i_gl, LM_ST_SHARED,
  					   LM_FLAG_NOEXP, &ji_gh);
  		if (error)
  			goto fail_gunlock_j;
  	} else {
  		fs_info(sdp, "jid=%u, already locked for use
  ", jd->jd_jid);
  	}
b3b94faa5   David Teigland   [GFS2] The core o...
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
  
  	fs_info(sdp, "jid=%u: Looking at journal...
  ", jd->jd_jid);
  
  	error = gfs2_jdesc_check(jd);
  	if (error)
  		goto fail_gunlock_ji;
  
  	error = gfs2_find_jhead(jd, &head);
  	if (error)
  		goto fail_gunlock_ji;
  
  	if (!(head.lh_flags & GFS2_LOG_HEAD_UNMOUNT)) {
  		fs_info(sdp, "jid=%u: Acquiring the transaction lock...
  ",
  			jd->jd_jid);
  
  		t = jiffies;
  
  		/* Acquire a shared hold on the transaction lock */
59a1cc6bd   Steven Whitehouse   [GFS2] Fix lock o...
485
  		error = gfs2_glock_nq_init(sdp->sd_trans_gl, LM_ST_SHARED,
5965b1f47   Steven Whitehouse   [GFS2] Don't do r...
486
  					   LM_FLAG_NOEXP | LM_FLAG_PRIORITY |
59a1cc6bd   Steven Whitehouse   [GFS2] Fix lock o...
487
  					   GL_NOCANCEL | GL_NOCACHE, &t_gh);
b3b94faa5   David Teigland   [GFS2] The core o...
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
  		if (error)
  			goto fail_gunlock_ji;
  
  		if (test_bit(SDF_JOURNAL_CHECKED, &sdp->sd_flags)) {
  			if (!test_bit(SDF_JOURNAL_LIVE, &sdp->sd_flags))
  				ro = 1;
  		} else {
  			if (sdp->sd_vfs->s_flags & MS_RDONLY)
  				ro = 1;
  		}
  
  		if (ro) {
  			fs_warn(sdp, "jid=%u: Can't replay: read-only FS
  ",
  				jd->jd_jid);
  			error = -EROFS;
  			goto fail_gunlock_tr;
  		}
  
  		fs_info(sdp, "jid=%u: Replaying journal...
  ", jd->jd_jid);
  
  		for (pass = 0; pass < 2; pass++) {
  			lops_before_scan(jd, &head, pass);
  			error = foreach_descriptor(jd, head.lh_tail,
  						   head.lh_blkno, pass);
  			lops_after_scan(jd, error, pass);
  			if (error)
  				goto fail_gunlock_tr;
  		}
  
  		error = clean_journal(jd, &head);
  		if (error)
  			goto fail_gunlock_tr;
  
  		gfs2_glock_dq_uninit(&t_gh);
5c676f6d3   Steven Whitehouse   [GFS2] Macros rem...
524
  		t = DIV_ROUND_UP(jiffies - t, HZ);
b3b94faa5   David Teigland   [GFS2] The core o...
525
526
527
528
  		fs_info(sdp, "jid=%u: Journal replayed in %lus
  ",
  			jd->jd_jid, t);
  	}
5965b1f47   Steven Whitehouse   [GFS2] Don't do r...
529
530
  	if (jd->jd_jid != sdp->sd_lockstruct.ls_jid)
  		gfs2_glock_dq_uninit(&ji_gh);
b3b94faa5   David Teigland   [GFS2] The core o...
531
532
  
  	gfs2_lm_recovery_done(sdp, jd->jd_jid, LM_RD_SUCCESS);
5965b1f47   Steven Whitehouse   [GFS2] Don't do r...
533
534
  	if (jd->jd_jid != sdp->sd_lockstruct.ls_jid)
  		gfs2_glock_dq_uninit(&j_gh);
b3b94faa5   David Teigland   [GFS2] The core o...
535
536
537
  
  	fs_info(sdp, "jid=%u: Done
  ", jd->jd_jid);
b3b94faa5   David Teigland   [GFS2] The core o...
538
  	return 0;
5965b1f47   Steven Whitehouse   [GFS2] Don't do r...
539
  fail_gunlock_tr:
b3b94faa5   David Teigland   [GFS2] The core o...
540
  	gfs2_glock_dq_uninit(&t_gh);
5965b1f47   Steven Whitehouse   [GFS2] Don't do r...
541
542
543
544
545
546
  fail_gunlock_ji:
  	if (jd->jd_jid != sdp->sd_lockstruct.ls_jid) {
  		gfs2_glock_dq_uninit(&ji_gh);
  fail_gunlock_j:
  		gfs2_glock_dq_uninit(&j_gh);
  	}
b3b94faa5   David Teigland   [GFS2] The core o...
547
548
549
  
  	fs_info(sdp, "jid=%u: %s
  ", jd->jd_jid, (error) ? "Failed" : "Done");
5965b1f47   Steven Whitehouse   [GFS2] Don't do r...
550
  fail:
b3b94faa5   David Teigland   [GFS2] The core o...
551
  	gfs2_lm_recovery_done(sdp, jd->jd_jid, LM_RD_GAVEUP);
b3b94faa5   David Teigland   [GFS2] The core o...
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
  	return error;
  }
  
  /**
   * gfs2_check_journals - Recover any dirty journals
   * @sdp: the filesystem
   *
   */
  
  void gfs2_check_journals(struct gfs2_sbd *sdp)
  {
  	struct gfs2_jdesc *jd;
  
  	for (;;) {
  		jd = gfs2_jdesc_find_dirty(sdp);
  		if (!jd)
  			break;
  
  		if (jd != sdp->sd_jdesc)
c63e31c2c   David Teigland   [GFS2] journal re...
571
  			gfs2_recover_journal(jd);
b3b94faa5   David Teigland   [GFS2] The core o...
572
573
  	}
  }