diff options
-rw-r--r-- | fs/udf/super.c | 59 |
1 files changed, 30 insertions, 29 deletions
diff --git a/fs/udf/super.c b/fs/udf/super.c index 52d2c32b6c7b..2048351c56c0 100644 --- a/fs/udf/super.c +++ b/fs/udf/super.c | |||
@@ -1447,44 +1447,45 @@ static int udf_load_partition(struct super_block *sb, kernel_lb_addr *fileset) | |||
1447 | sbi = UDF_SB(sb); | 1447 | sbi = UDF_SB(sb); |
1448 | 1448 | ||
1449 | for (i = 0; i < ARRAY_SIZE(sbi->s_anchor); i++) { | 1449 | for (i = 0; i < ARRAY_SIZE(sbi->s_anchor); i++) { |
1450 | if (sbi->s_anchor[i] && | 1450 | if (!sbi->s_anchor[i]) |
1451 | (bh = udf_read_tagged(sb, sbi->s_anchor[i], | 1451 | continue; |
1452 | sbi->s_anchor[i], &ident))) { | 1452 | bh = udf_read_tagged(sb, sbi->s_anchor[i], sbi->s_anchor[i], |
1453 | anchor = (struct anchorVolDescPtr *)bh->b_data; | 1453 | &ident); |
1454 | 1454 | if (!bh) | |
1455 | /* Locate the main sequence */ | 1455 | continue; |
1456 | main_s = le32_to_cpu( | 1456 | |
1457 | anchor->mainVolDescSeqExt.extLocation); | 1457 | anchor = (struct anchorVolDescPtr *)bh->b_data; |
1458 | main_e = le32_to_cpu( | 1458 | |
1459 | anchor->mainVolDescSeqExt.extLength); | 1459 | /* Locate the main sequence */ |
1460 | main_e = main_e >> sb->s_blocksize_bits; | 1460 | main_s = le32_to_cpu(anchor->mainVolDescSeqExt.extLocation); |
1461 | main_e += main_s; | 1461 | main_e = le32_to_cpu(anchor->mainVolDescSeqExt.extLength); |
1462 | 1462 | main_e = main_e >> sb->s_blocksize_bits; | |
1463 | /* Locate the reserve sequence */ | 1463 | main_e += main_s; |
1464 | reserve_s = le32_to_cpu( | 1464 | |
1465 | /* Locate the reserve sequence */ | ||
1466 | reserve_s = le32_to_cpu( | ||
1465 | anchor->reserveVolDescSeqExt.extLocation); | 1467 | anchor->reserveVolDescSeqExt.extLocation); |
1466 | reserve_e = le32_to_cpu( | 1468 | reserve_e = le32_to_cpu( |
1467 | anchor->reserveVolDescSeqExt.extLength); | 1469 | anchor->reserveVolDescSeqExt.extLength); |
1468 | reserve_e = reserve_e >> sb->s_blocksize_bits; | 1470 | reserve_e = reserve_e >> sb->s_blocksize_bits; |
1469 | reserve_e += reserve_s; | 1471 | reserve_e += reserve_s; |
1470 | 1472 | ||
1471 | brelse(bh); | 1473 | brelse(bh); |
1472 | 1474 | ||
1473 | /* Process the main & reserve sequences */ | 1475 | /* Process the main & reserve sequences */ |
1474 | /* responsible for finding the PartitionDesc(s) */ | 1476 | /* responsible for finding the PartitionDesc(s) */ |
1475 | if (!(udf_process_sequence(sb, main_s, main_e, | 1477 | if (!(udf_process_sequence(sb, main_s, main_e, |
1476 | fileset) && | 1478 | fileset) && |
1477 | udf_process_sequence(sb, reserve_s, reserve_e, | 1479 | udf_process_sequence(sb, reserve_s, reserve_e, |
1478 | fileset))) | 1480 | fileset))) |
1479 | break; | 1481 | break; |
1480 | } | ||
1481 | } | 1482 | } |
1482 | 1483 | ||
1483 | if (i == ARRAY_SIZE(sbi->s_anchor)) { | 1484 | if (i == ARRAY_SIZE(sbi->s_anchor)) { |
1484 | udf_debug("No Anchor block found\n"); | 1485 | udf_debug("No Anchor block found\n"); |
1485 | return 1; | 1486 | return 1; |
1486 | } else | 1487 | } |
1487 | udf_debug("Using anchor in block %d\n", sbi->s_anchor[i]); | 1488 | udf_debug("Using anchor in block %d\n", sbi->s_anchor[i]); |
1488 | 1489 | ||
1489 | for (i = 0; i < sbi->s_partitions; i++) { | 1490 | for (i = 0; i < sbi->s_partitions; i++) { |
1490 | kernel_lb_addr uninitialized_var(ino); | 1491 | kernel_lb_addr uninitialized_var(ino); |