spl_fat.c 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * (C) Copyright 2014
  4. * Texas Instruments, <www.ti.com>
  5. *
  6. * Dan Murphy <dmurphy@ti.com>
  7. *
  8. * FAT Image Functions copied from spl_mmc.c
  9. */
  10. #include <common.h>
  11. #include <env.h>
  12. #include <log.h>
  13. #include <spl.h>
  14. #include <asm/u-boot.h>
  15. #include <fat.h>
  16. #include <errno.h>
  17. #include <image.h>
  18. #include <linux/libfdt.h>
  19. static int fat_registered;
  20. static int spl_register_fat_device(struct blk_desc *block_dev, int partition)
  21. {
  22. int err = 0;
  23. if (fat_registered)
  24. return err;
  25. err = fat_register_device(block_dev, partition);
  26. if (err) {
  27. #ifdef CONFIG_SPL_LIBCOMMON_SUPPORT
  28. printf("%s: fat register err - %d\n", __func__, err);
  29. #endif
  30. return err;
  31. }
  32. fat_registered = 1;
  33. return err;
  34. }
  35. static ulong spl_fit_read(struct spl_load_info *load, ulong file_offset,
  36. ulong size, void *buf)
  37. {
  38. loff_t actread;
  39. int ret;
  40. char *filename = (char *)load->filename;
  41. ret = fat_read_file(filename, buf, file_offset, size, &actread);
  42. if (ret)
  43. return ret;
  44. return actread;
  45. }
  46. int spl_load_image_fat(struct spl_image_info *spl_image,
  47. struct spl_boot_device *bootdev,
  48. struct blk_desc *block_dev, int partition,
  49. const char *filename)
  50. {
  51. int err;
  52. struct legacy_img_hdr *header;
  53. err = spl_register_fat_device(block_dev, partition);
  54. if (err)
  55. goto end;
  56. header = spl_get_load_buffer(-sizeof(*header), sizeof(*header));
  57. err = file_fat_read(filename, header, sizeof(struct legacy_img_hdr));
  58. if (err <= 0)
  59. goto end;
  60. if (IS_ENABLED(CONFIG_SPL_LOAD_FIT_FULL) &&
  61. image_get_magic(header) == FDT_MAGIC) {
  62. err = file_fat_read(filename, (void *)CONFIG_SYS_LOAD_ADDR, 0);
  63. if (err <= 0)
  64. goto end;
  65. err = spl_parse_image_header(spl_image, bootdev,
  66. (struct legacy_img_hdr *)CONFIG_SYS_LOAD_ADDR);
  67. if (err == -EAGAIN)
  68. return err;
  69. if (err == 0)
  70. err = 1;
  71. } else if (IS_ENABLED(CONFIG_SPL_LOAD_FIT) &&
  72. image_get_magic(header) == FDT_MAGIC) {
  73. struct spl_load_info load;
  74. debug("Found FIT\n");
  75. load.read = spl_fit_read;
  76. load.bl_len = 1;
  77. load.filename = (void *)filename;
  78. load.priv = NULL;
  79. return spl_load_simple_fit(spl_image, &load, 0, header);
  80. } else {
  81. err = spl_parse_image_header(spl_image, bootdev, header);
  82. if (err)
  83. goto end;
  84. err = file_fat_read(filename,
  85. (u8 *)(uintptr_t)spl_image->load_addr, 0);
  86. }
  87. end:
  88. #ifdef CONFIG_SPL_LIBCOMMON_SUPPORT
  89. if (err <= 0)
  90. printf("%s: error reading image %s, err - %d\n",
  91. __func__, filename, err);
  92. #endif
  93. return (err <= 0);
  94. }
  95. #if CONFIG_IS_ENABLED(OS_BOOT)
  96. int spl_load_image_fat_os(struct spl_image_info *spl_image,
  97. struct spl_boot_device *bootdev,
  98. struct blk_desc *block_dev, int partition)
  99. {
  100. int err;
  101. __maybe_unused char *file;
  102. err = spl_register_fat_device(block_dev, partition);
  103. if (err)
  104. return err;
  105. #if defined(CONFIG_SPL_ENV_SUPPORT) && defined(CONFIG_SPL_OS_BOOT)
  106. file = env_get("falcon_args_file");
  107. if (file) {
  108. err = file_fat_read(file, (void *)CONFIG_SYS_SPL_ARGS_ADDR, 0);
  109. if (err <= 0) {
  110. printf("spl: error reading image %s, err - %d, falling back to default\n",
  111. file, err);
  112. goto defaults;
  113. }
  114. file = env_get("falcon_image_file");
  115. if (file) {
  116. err = spl_load_image_fat(spl_image, bootdev, block_dev,
  117. partition, file);
  118. if (err != 0) {
  119. puts("spl: falling back to default\n");
  120. goto defaults;
  121. }
  122. return 0;
  123. } else
  124. puts("spl: falcon_image_file not set in environment, falling back to default\n");
  125. } else
  126. puts("spl: falcon_args_file not set in environment, falling back to default\n");
  127. defaults:
  128. #endif
  129. err = file_fat_read(CONFIG_SPL_FS_LOAD_ARGS_NAME,
  130. (void *)CONFIG_SYS_SPL_ARGS_ADDR, 0);
  131. if (err <= 0) {
  132. #ifdef CONFIG_SPL_LIBCOMMON_SUPPORT
  133. printf("%s: error reading image %s, err - %d\n",
  134. __func__, CONFIG_SPL_FS_LOAD_ARGS_NAME, err);
  135. #endif
  136. return -1;
  137. }
  138. return spl_load_image_fat(spl_image, bootdev, block_dev, partition,
  139. CONFIG_SPL_FS_LOAD_KERNEL_NAME);
  140. }
  141. #else
  142. int spl_load_image_fat_os(struct spl_image_info *spl_image,
  143. struct spl_boot_device *bootdev,
  144. struct blk_desc *block_dev, int partition)
  145. {
  146. return -ENOSYS;
  147. }
  148. #endif