super.c 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. /*
  2. * super.c
  3. *
  4. * Copyright (C) 2001-2002 Will Dyson <will_dyson@pobox.com>
  5. *
  6. * Licensed under the GNU GPL. See the file COPYING for details.
  7. *
  8. */
  9. #include <linux/fs.h>
  10. #include <asm/page.h> /* for PAGE_SIZE */
  11. #include "befs.h"
  12. #include "super.h"
  13. /**
  14. * load_befs_sb -- Read from disk and properly byteswap all the fields
  15. * of the befs superblock
  16. *
  17. *
  18. *
  19. *
  20. */
  21. int
  22. befs_load_sb(struct super_block *sb, befs_super_block * disk_sb)
  23. {
  24. befs_sb_info *befs_sb = BEFS_SB(sb);
  25. /* Check the byte order of the filesystem */
  26. if (disk_sb->fs_byte_order == BEFS_BYTEORDER_NATIVE_LE)
  27. befs_sb->byte_order = BEFS_BYTESEX_LE;
  28. else if (disk_sb->fs_byte_order == BEFS_BYTEORDER_NATIVE_BE)
  29. befs_sb->byte_order = BEFS_BYTESEX_BE;
  30. befs_sb->magic1 = fs32_to_cpu(sb, disk_sb->magic1);
  31. befs_sb->magic2 = fs32_to_cpu(sb, disk_sb->magic2);
  32. befs_sb->magic3 = fs32_to_cpu(sb, disk_sb->magic3);
  33. befs_sb->block_size = fs32_to_cpu(sb, disk_sb->block_size);
  34. befs_sb->block_shift = fs32_to_cpu(sb, disk_sb->block_shift);
  35. befs_sb->num_blocks = fs64_to_cpu(sb, disk_sb->num_blocks);
  36. befs_sb->used_blocks = fs64_to_cpu(sb, disk_sb->used_blocks);
  37. befs_sb->inode_size = fs32_to_cpu(sb, disk_sb->inode_size);
  38. befs_sb->blocks_per_ag = fs32_to_cpu(sb, disk_sb->blocks_per_ag);
  39. befs_sb->ag_shift = fs32_to_cpu(sb, disk_sb->ag_shift);
  40. befs_sb->num_ags = fs32_to_cpu(sb, disk_sb->num_ags);
  41. befs_sb->log_blocks = fsrun_to_cpu(sb, disk_sb->log_blocks);
  42. befs_sb->log_start = fs64_to_cpu(sb, disk_sb->log_start);
  43. befs_sb->log_end = fs64_to_cpu(sb, disk_sb->log_end);
  44. befs_sb->root_dir = fsrun_to_cpu(sb, disk_sb->root_dir);
  45. befs_sb->indices = fsrun_to_cpu(sb, disk_sb->indices);
  46. befs_sb->nls = NULL;
  47. return BEFS_OK;
  48. }
  49. int
  50. befs_check_sb(struct super_block *sb)
  51. {
  52. befs_sb_info *befs_sb = BEFS_SB(sb);
  53. /* Check magic headers of super block */
  54. if ((befs_sb->magic1 != BEFS_SUPER_MAGIC1)
  55. || (befs_sb->magic2 != BEFS_SUPER_MAGIC2)
  56. || (befs_sb->magic3 != BEFS_SUPER_MAGIC3)) {
  57. befs_error(sb, "invalid magic header");
  58. return BEFS_ERR;
  59. }
  60. /*
  61. * Check blocksize of BEFS.
  62. *
  63. * Blocksize of BEFS is 1024, 2048, 4096 or 8192.
  64. */
  65. if ((befs_sb->block_size != 1024)
  66. && (befs_sb->block_size != 2048)
  67. && (befs_sb->block_size != 4096)
  68. && (befs_sb->block_size != 8192)) {
  69. befs_error(sb, "invalid blocksize: %u", befs_sb->block_size);
  70. return BEFS_ERR;
  71. }
  72. if (befs_sb->block_size > PAGE_SIZE) {
  73. befs_error(sb, "blocksize(%u) cannot be larger"
  74. "than system pagesize(%lu)", befs_sb->block_size,
  75. PAGE_SIZE);
  76. return BEFS_ERR;
  77. }
  78. /*
  79. * block_shift and block_size encode the same information
  80. * in different ways as a consistency check.
  81. */
  82. if ((1 << befs_sb->block_shift) != befs_sb->block_size) {
  83. befs_error(sb, "block_shift disagrees with block_size. "
  84. "Corruption likely.");
  85. return BEFS_ERR;
  86. }
  87. if (befs_sb->log_start != befs_sb->log_end) {
  88. befs_error(sb, "Filesystem not clean! There are blocks in the "
  89. "journal. You must boot into BeOS and mount this volume "
  90. "to make it clean.");
  91. return BEFS_ERR;
  92. }
  93. return BEFS_OK;
  94. }