panther_pib_file.c 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. /*====================================================================*
  2. *
  3. * Copyright (c) 2013 Qualcomm Atheros, Inc.
  4. *
  5. * All rights reserved.
  6. *
  7. *====================================================================*/
  8. /*====================================================================*
  9. *
  10. * signed panther_pib_file (struct _file_ const * file);
  11. *
  12. * pib.h
  13. *
  14. * open a panther/lynx PIB file and validate it by
  15. * checking file size, checksum and selected internal parameters;
  16. * return a file descriptor on success; terminate the program on
  17. * error;
  18. *
  19. * Contributor(s):
  20. * Charles Maier <cmaier@qca.qualcomm.com>
  21. *
  22. *--------------------------------------------------------------------*/
  23. #ifndef PANTHER_PIB_FILE_SOURCE
  24. #define PANTHER_PIB_FILE_SOURCE
  25. #include <stdio.h>
  26. #include <stdint.h>
  27. #include <unistd.h>
  28. #include <memory.h>
  29. #include <errno.h>
  30. #include "../tools/memory.h"
  31. #include "../tools/files.h"
  32. #include "../tools/error.h"
  33. #include "../nvm/nvm.h"
  34. #include "../pib/pib.h"
  35. signed panther_pib_file (struct _file_ const * file)
  36. {
  37. struct panther_nvm_header header;
  38. uint32_t origin = ~ 0;
  39. uint32_t offset = 0;
  40. unsigned module = 0;
  41. if (lseek (file->file, 0, SEEK_SET))
  42. {
  43. error (1, errno, FILE_CANTHOME, file->name);
  44. }
  45. do
  46. {
  47. if (read (file->file, & header, sizeof (header)) != sizeof (header))
  48. {
  49. error (1, errno, NVM_HDR_CANTREAD, file->name, module);
  50. }
  51. if (LE16TOH (header.MajorVersion) != 1)
  52. {
  53. error (1, errno, NVM_HDR_VERSION, file->name, module);
  54. }
  55. if (LE16TOH (header.MinorVersion) != 1)
  56. {
  57. error (1, errno, NVM_HDR_VERSION, file->name, module);
  58. }
  59. if (checksum32 (& header, sizeof (header), 0))
  60. {
  61. error (1, errno, NVM_HDR_CHECKSUM, file->name, module);
  62. }
  63. if (LE32TOH (header.PrevHeader) != origin)
  64. {
  65. error (1, errno, NVM_HDR_LINK, file->name, module);
  66. }
  67. if (LE32TOH (header.ImageType) == NVM_IMAGE_PIB)
  68. {
  69. if (fdchecksum32 (file->file, LE32TOH (header.ImageLength), header.ImageChecksum))
  70. {
  71. error (1, errno, NVM_IMG_CHECKSUM, file->name, module);
  72. }
  73. return (0);
  74. }
  75. if (fdchecksum32 (file->file, LE32TOH (header.ImageLength), header.ImageChecksum))
  76. {
  77. error (1, errno, NVM_IMG_CHECKSUM, file->name, module);
  78. }
  79. origin = offset;
  80. offset = LE32TOH (header.NextHeader);
  81. module++;
  82. }
  83. while (~ header.NextHeader);
  84. return (- 1);
  85. }
  86. #endif