From: rpeterso@sourceware.org <rpeterso@sourceware.org>
To: cluster-devel.redhat.com
Subject: [Cluster-devel] cluster/gfs2/fsck metawalk.c
Date: 20 Nov 2006 21:46:24 -0000 [thread overview]
Message-ID: <20061120214624.19041.qmail@sourceware.org> (raw)
CVSROOT: /cvs/cluster
Module name: cluster
Branch: RHEL50
Changes by: rpeterso at sourceware.org 2006-11-20 21:46:23
Modified files:
gfs2/fsck : metawalk.c
Log message:
Fix another case where lf_dirent_format was not rewritten to disk
after it was fixed.
Patches:
http://sourceware.org/cgi-bin/cvsweb.cgi/cluster/gfs2/fsck/metawalk.c.diff?cvsroot=cluster&only_with_tag=RHEL50&r1=1.3.4.1&r2=1.3.4.2
--- cluster/gfs2/fsck/metawalk.c 2006/11/20 21:30:40 1.3.4.1
+++ cluster/gfs2/fsck/metawalk.c 2006/11/20 21:46:23 1.3.4.2
@@ -166,6 +166,20 @@
lbh = bread(sbp, leaf_no);
gfs2_leaf_in(&leaf, lbh->b_data);
+ /*
+ * Early versions of GFS2 had an endianess bug in the kernel
+ * that set lf_dirent_format to cpu_to_be16(GFS2_FORMAT_DE).
+ * This was fixed to use cpu_to_be32(), but we should check
+ * for incorrect values and replace them with the correct value. */
+
+ if (leaf.lf_dirent_format == (GFS2_FORMAT_DE << 16)) {
+ log_debug("incorrect lf_dirent_format@leaf #%" PRIu64 "\n", leaf_no);
+ leaf.lf_dirent_format = GFS2_FORMAT_DE;
+ gfs2_leaf_out(&leaf, lbh->b_data);
+ log_debug("Fixing lf_dirent_format.\n");
+ *update = updated;
+ }
+
exp_count = (1 << (ip->i_di.di_depth - leaf.lf_depth));
log_debug("expected count %u - di_depth %u, leaf depth %u\n",
exp_count, ip->i_di.di_depth, leaf.lf_depth);
@@ -190,9 +204,8 @@
return 1;
if(update && (count != leaf.lf_entries)) {
- enum update_flags f;
+ enum update_flags f = not_updated;
- f = not_updated;
lbh = bread(sbp, leaf_no);
gfs2_leaf_in(&leaf, lbh->b_data);
@@ -214,7 +227,7 @@
* compare it against leaf->lf_entries */
break;
} else {
- brelse(lbh, not_updated);
+ brelse(lbh, *update);
if(!leaf.lf_next)
break;
leaf_no = leaf.lf_next;
next reply other threads:[~2006-11-20 21:46 UTC|newest]
Thread overview: 12+ messages / expand[flat|nested] mbox.gz Atom feed top
2006-11-20 21:46 rpeterso [this message]
-- strict thread matches above, loose matches on Subject: below --
2007-02-26 19:20 [Cluster-devel] cluster/gfs2/fsck metawalk.c rpeterso
2007-02-26 19:19 rpeterso
2007-01-23 19:54 rpeterso
2007-01-23 19:44 rpeterso
2006-11-20 21:30 rpeterso
2006-11-20 15:44 rohara
2006-11-20 15:35 rpeterso
2006-11-16 20:12 rohara
2006-11-16 19:56 rohara
2006-11-14 22:55 rpeterso
2006-11-14 22:51 rpeterso
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20061120214624.19041.qmail@sourceware.org \
--to=rpeterso@sourceware.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).