[<prev] [next>] [day] [month] [year] [list]
Message-ID: <47BD3C96.40501@openvz.org>
Date: Thu, 21 Feb 2008 11:55:50 +0300
From: Pavel Emelyanov <xemul@...nvz.org>
To: Jan Kara <jack@...e.cz>
CC: Linux Kernel Mailing List <linux-kernel@...r.kernel.org>,
Yuri Per <Yuri.Per@...onis.com>,
Max Lyadvinsky <Max.Lyadvinsky@...onis.com>,
Vladimir Simonov <Vladimir.Simonov@...onis.com>,
Andrew Neporada <Andrew.Neporada@...onis.com>,
Kirill Korotaev <dev@...nvz.org>
Subject: [PATCH] UDF: fix anchor point detection
According to ECMA 167 rev. 3 (see 3/8.4.2.1), Anchor Volume
Descriptor Pointer should be recorded at two or more anchor
points located at sectors 256, N, N - 256, where N - is a
largest logical sector number at volume space.
So we should always try to detect N on UDF volume before
trying to find Anchor Volume Descriptor (i.e. calling to
udf_find_anchor()).
That said, all this patch does is updates the s_last_block
even if the udf_vrs() returns positive value.
Originally written and tested by Yuri Per, ported on latest
mainline by me.
Signed-off-by: Yuri Per <Yuri.Per@...onis.com>
Signed-off-by: Pavel Emelyanov <xemul@...nvz.org>
Cc: Max Lyadvinsky <Max.Lyadvinsky@...onis.com>
Cc: Vladimir Simonov <Vladimir.Simonov@...onis.com>
Cc: Andrew Neporada <Andrew.Neporada@...onis.com>
Cc: Kirill Korotaev <dev@...nvz.org>
---
diff --git a/fs/udf/super.c b/fs/udf/super.c
index f3ac4ab..abd5e30 100644
--- a/fs/udf/super.c
+++ b/fs/udf/super.c
@@ -1486,16 +1486,17 @@ static int udf_check_valid(struct super_block *sb, int novrs, int silent)
/* Check that it is NSR02 compliant */
/* Process any "CD-ROM Volume Descriptor Set" (ECMA 167 2/8.3.1) */
else {
+ struct udf_sb_info *sbi = UDF_SB(sb);
+
block = udf_vrs(sb, silent);
- if (block == -1) {
- struct udf_sb_info *sbi = UDF_SB(sb);
+ if (block == -1)
udf_debug("Failed to read byte 32768. Assuming open "
"disc. Skipping validity check\n");
- if (!sbi->s_last_block)
- sbi->s_last_block = udf_get_last_block(sb);
- return 0;
- } else
- return !block;
+
+ if (block && !sbi->s_last_block)
+ sbi->s_last_block = udf_get_last_block(sb);
+
+ return !block;
}
}
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists