linux_swap.c 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. /*
  2. * volume_id - reads filesystem label and uuid
  3. *
  4. * Copyright (C) 2004 Kay Sievers <kay.sievers@vrfy.org>
  5. *
  6. * This library is free software; you can redistribute it and/or
  7. * modify it under the terms of the GNU Lesser General Public
  8. * License as published by the Free Software Foundation; either
  9. * version 2.1 of the License, or (at your option) any later version.
  10. *
  11. * This library is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  14. * Lesser General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU Lesser General Public
  17. * License along with this library; if not, write to the Free Software
  18. * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
  19. */
  20. //kbuild:lib-$(CONFIG_FEATURE_VOLUMEID_LINUXSWAP) += linux_swap.o
  21. //config:
  22. //config:config FEATURE_VOLUMEID_LINUXSWAP
  23. //config: bool "linux swap filesystem"
  24. //config: default y
  25. //config: depends on VOLUMEID
  26. //config: help
  27. //config: TODO
  28. //config:
  29. #include "volume_id_internal.h"
  30. struct swap_header_v1_2 {
  31. uint8_t bootbits[1024];
  32. uint32_t version;
  33. uint32_t last_page;
  34. uint32_t nr_badpages;
  35. uint8_t uuid[16];
  36. uint8_t volume_name[16];
  37. } PACKED;
  38. #define LARGEST_PAGESIZE 0x4000
  39. int FAST_FUNC volume_id_probe_linux_swap(struct volume_id *id /*,uint64_t off*/)
  40. {
  41. #define off ((uint64_t)0)
  42. struct swap_header_v1_2 *sw;
  43. const uint8_t *buf;
  44. unsigned page;
  45. dbg("probing at offset 0x%llx", (unsigned long long) off);
  46. /* the swap signature is at the end of the PAGE_SIZE */
  47. for (page = 0x1000; page <= LARGEST_PAGESIZE; page <<= 1) {
  48. buf = volume_id_get_buffer(id, off + page-10, 10);
  49. if (buf == NULL)
  50. return -1;
  51. if (memcmp(buf, "SWAP-SPACE", 10) == 0) {
  52. // id->type_version[0] = '1';
  53. // id->type_version[1] = '\0';
  54. goto found;
  55. }
  56. if (memcmp(buf, "SWAPSPACE2", 10) == 0
  57. || memcmp(buf, "S1SUSPEND", 9) == 0
  58. || memcmp(buf, "S2SUSPEND", 9) == 0
  59. || memcmp(buf, "ULSUSPEND", 9) == 0
  60. ) {
  61. sw = volume_id_get_buffer(id, off, sizeof(struct swap_header_v1_2));
  62. if (sw == NULL)
  63. return -1;
  64. // id->type_version[0] = '2';
  65. // id->type_version[1] = '\0';
  66. // volume_id_set_label_raw(id, sw->volume_name, 16);
  67. volume_id_set_label_string(id, sw->volume_name, 16);
  68. volume_id_set_uuid(id, sw->uuid, UUID_DCE);
  69. goto found;
  70. }
  71. }
  72. return -1;
  73. found:
  74. // volume_id_set_usage(id, VOLUME_ID_OTHER);
  75. IF_FEATURE_BLKID_TYPE(id->type = "swap";)
  76. return 0;
  77. }