squashfs.c 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. /*
  2. * volume_id - reads filesystem label and uuid
  3. *
  4. * Copyright (C) 2012 S-G Bergh <sgb@systemasis.org>
  5. *
  6. * Licensed under GPLv2, see file LICENSE in this source tree.
  7. */
  8. //kbuild:lib-$(CONFIG_FEATURE_VOLUMEID_SQUASHFS) += squashfs.o
  9. //config:config FEATURE_VOLUMEID_SQUASHFS
  10. //config: bool "SquashFS filesystem"
  11. //config: default y
  12. //config: depends on VOLUMEID && FEATURE_BLKID_TYPE
  13. //config: help
  14. //config: Squashfs is a compressed read-only filesystem for Linux. Squashfs is
  15. //config: intended for general read-only filesystem use and in constrained block
  16. //config: device/memory systems (e.g. embedded systems) where low overhead is
  17. //config: needed.
  18. #include "volume_id_internal.h"
  19. struct squashfs_superblock {
  20. uint32_t magic;
  21. /*
  22. uint32_t dummy[6];
  23. uint16_t major;
  24. uint16_t minor;
  25. */
  26. } PACKED;
  27. int FAST_FUNC volume_id_probe_squashfs(struct volume_id *id /*,uint64_t off*/)
  28. {
  29. #define off ((uint64_t)0)
  30. struct squashfs_superblock *sb;
  31. dbg("SquashFS: probing at offset 0x%llx", (unsigned long long) off);
  32. sb = volume_id_get_buffer(id, off, 0x200);
  33. if (!sb)
  34. return -1;
  35. // Old SquashFS (pre 4.0) can be both big and little endian, so test for both.
  36. // Likewise, it is commonly used in firwmare with some non-standard signatures.
  37. #define pack(a,b,c,d) ( (uint32_t)((a * 256 + b) * 256 + c) * 256 + d )
  38. #define SIG1 pack('s','q','s','h')
  39. #define SIG2 pack('h','s','q','s')
  40. #define SIG3 pack('s','h','s','q')
  41. #define SIG4 pack('q','s','h','s')
  42. if (sb->magic == SIG1
  43. || sb->magic == SIG2
  44. || sb->magic == SIG3
  45. || sb->magic == SIG4
  46. ) {
  47. IF_FEATURE_BLKID_TYPE(id->type = "squashfs";)
  48. return 0;
  49. }
  50. return -1;
  51. }