env_fat.c 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. /*
  2. * (c) Copyright 2011 by Tigris Elektronik GmbH
  3. *
  4. * Author:
  5. * Maximilian Schwerin <mvs@tigris.de>
  6. *
  7. * SPDX-License-Identifier: GPL-2.0+
  8. */
  9. #include <common.h>
  10. #include <command.h>
  11. #include <environment.h>
  12. #include <linux/stddef.h>
  13. #include <malloc.h>
  14. #include <search.h>
  15. #include <errno.h>
  16. #include <fat.h>
  17. #include <mmc.h>
  18. char *env_name_spec = "FAT";
  19. env_t *env_ptr;
  20. DECLARE_GLOBAL_DATA_PTR;
  21. int env_init(void)
  22. {
  23. /* use default */
  24. gd->env_addr = (ulong)&default_environment[0];
  25. gd->env_valid = 1;
  26. return 0;
  27. }
  28. #ifdef CONFIG_CMD_SAVEENV
  29. int saveenv(void)
  30. {
  31. env_t env_new;
  32. ssize_t len;
  33. char *res;
  34. block_dev_desc_t *dev_desc = NULL;
  35. int dev = FAT_ENV_DEVICE;
  36. int part = FAT_ENV_PART;
  37. int err;
  38. res = (char *)&env_new.data;
  39. len = hexport_r(&env_htab, '\0', 0, &res, ENV_SIZE, 0, NULL);
  40. if (len < 0) {
  41. error("Cannot export environment: errno = %d\n", errno);
  42. return 1;
  43. }
  44. #ifdef CONFIG_MMC
  45. if (strcmp(FAT_ENV_INTERFACE, "mmc") == 0) {
  46. struct mmc *mmc = find_mmc_device(dev);
  47. if (!mmc) {
  48. printf("no mmc device at slot %x\n", dev);
  49. return 1;
  50. }
  51. mmc->has_init = 0;
  52. mmc_init(mmc);
  53. }
  54. #endif /* CONFIG_MMC */
  55. dev_desc = get_dev(FAT_ENV_INTERFACE, dev);
  56. if (dev_desc == NULL) {
  57. printf("Failed to find %s%d\n",
  58. FAT_ENV_INTERFACE, dev);
  59. return 1;
  60. }
  61. err = fat_register_device(dev_desc, part);
  62. if (err) {
  63. printf("Failed to register %s%d:%d\n",
  64. FAT_ENV_INTERFACE, dev, part);
  65. return 1;
  66. }
  67. env_new.crc = crc32(0, env_new.data, ENV_SIZE);
  68. err = file_fat_write(FAT_ENV_FILE, (void *)&env_new, sizeof(env_t));
  69. if (err == -1) {
  70. printf("\n** Unable to write \"%s\" from %s%d:%d **\n",
  71. FAT_ENV_FILE, FAT_ENV_INTERFACE, dev, part);
  72. return 1;
  73. }
  74. puts("done\n");
  75. return 0;
  76. }
  77. #endif /* CONFIG_CMD_SAVEENV */
  78. void env_relocate_spec(void)
  79. {
  80. char buf[CONFIG_ENV_SIZE];
  81. block_dev_desc_t *dev_desc = NULL;
  82. int dev = FAT_ENV_DEVICE;
  83. int part = FAT_ENV_PART;
  84. int err;
  85. #ifdef CONFIG_MMC
  86. if (strcmp(FAT_ENV_INTERFACE, "mmc") == 0) {
  87. struct mmc *mmc = find_mmc_device(dev);
  88. if (!mmc) {
  89. printf("no mmc device at slot %x\n", dev);
  90. set_default_env(NULL);
  91. return;
  92. }
  93. mmc->has_init = 0;
  94. mmc_init(mmc);
  95. }
  96. #endif /* CONFIG_MMC */
  97. dev_desc = get_dev(FAT_ENV_INTERFACE, dev);
  98. if (dev_desc == NULL) {
  99. printf("Failed to find %s%d\n",
  100. FAT_ENV_INTERFACE, dev);
  101. set_default_env(NULL);
  102. return;
  103. }
  104. err = fat_register_device(dev_desc, part);
  105. if (err) {
  106. printf("Failed to register %s%d:%d\n",
  107. FAT_ENV_INTERFACE, dev, part);
  108. set_default_env(NULL);
  109. return;
  110. }
  111. err = file_fat_read(FAT_ENV_FILE, (uchar *)&buf, CONFIG_ENV_SIZE);
  112. if (err == -1) {
  113. printf("\n** Unable to read \"%s\" from %s%d:%d **\n",
  114. FAT_ENV_FILE, FAT_ENV_INTERFACE, dev, part);
  115. set_default_env(NULL);
  116. return;
  117. }
  118. env_import(buf, 1);
  119. }