sysv68.c 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. /*
  2. * fs/partitions/sysv68.c
  3. *
  4. * Copyright (C) 2007 Philippe De Muyter <phdm@macqel.be>
  5. */
  6. #include "check.h"
  7. #include "sysv68.h"
  8. /*
  9. * Volume ID structure: on first 256-bytes sector of disk
  10. */
  11. struct volumeid {
  12. u8 vid_unused[248];
  13. u8 vid_mac[8]; /* ASCII string "MOTOROLA" */
  14. };
  15. /*
  16. * config block: second 256-bytes sector on disk
  17. */
  18. struct dkconfig {
  19. u8 ios_unused0[128];
  20. __be32 ios_slcblk; /* Slice table block number */
  21. __be16 ios_slccnt; /* Number of entries in slice table */
  22. u8 ios_unused1[122];
  23. };
  24. /*
  25. * combined volumeid and dkconfig block
  26. */
  27. struct dkblk0 {
  28. struct volumeid dk_vid;
  29. struct dkconfig dk_ios;
  30. };
  31. /*
  32. * Slice Table Structure
  33. */
  34. struct slice {
  35. __be32 nblocks; /* slice size (in blocks) */
  36. __be32 blkoff; /* block offset of slice */
  37. };
  38. int sysv68_partition(struct parsed_partitions *state, struct block_device *bdev)
  39. {
  40. int i, slices;
  41. int slot = 1;
  42. Sector sect;
  43. unsigned char *data;
  44. struct dkblk0 *b;
  45. struct slice *slice;
  46. data = read_dev_sector(bdev, 0, &sect);
  47. if (!data)
  48. return -1;
  49. b = (struct dkblk0 *)data;
  50. if (memcmp(b->dk_vid.vid_mac, "MOTOROLA", sizeof(b->dk_vid.vid_mac))) {
  51. put_dev_sector(sect);
  52. return 0;
  53. }
  54. slices = be16_to_cpu(b->dk_ios.ios_slccnt);
  55. i = be32_to_cpu(b->dk_ios.ios_slcblk);
  56. put_dev_sector(sect);
  57. data = read_dev_sector(bdev, i, &sect);
  58. if (!data)
  59. return -1;
  60. slices -= 1; /* last slice is the whole disk */
  61. printk("sysV68: %s(s%u)", state->name, slices);
  62. slice = (struct slice *)data;
  63. for (i = 0; i < slices; i++, slice++) {
  64. if (slot == state->limit)
  65. break;
  66. if (be32_to_cpu(slice->nblocks)) {
  67. put_partition(state, slot,
  68. be32_to_cpu(slice->blkoff),
  69. be32_to_cpu(slice->nblocks));
  70. printk("(s%u)", i);
  71. }
  72. slot++;
  73. }
  74. printk("\n");
  75. put_dev_sector(sect);
  76. return 1;
  77. }