blob: d4f4901ac4b1fbfccd0ad8958582e86dbacc8e53 [file] [log] [blame]
Joe Hershberger2b744332013-04-08 10:32:51 +00001/*
2 * (c) Copyright 2012 by National Instruments,
3 * Joe Hershberger <joe.hershberger@ni.com>
4 *
Wolfgang Denk3765b3e2013-10-07 13:07:26 +02005 * SPDX-License-Identifier: GPL-2.0+
Joe Hershberger2b744332013-04-08 10:32:51 +00006 */
7
8#include <common.h>
9
10#include <command.h>
11#include <environment.h>
12#include <errno.h>
13#include <malloc.h>
Simon Glasscf92e052015-09-02 17:24:58 -060014#include <memalign.h>
Joe Hershberger2b744332013-04-08 10:32:51 +000015#include <search.h>
16#include <ubi_uboot.h>
17#undef crc32
18
Joe Hershberger2b744332013-04-08 10:32:51 +000019DECLARE_GLOBAL_DATA_PTR;
20
Joe Hershberger2b744332013-04-08 10:32:51 +000021#ifdef CONFIG_CMD_SAVEENV
Joe Hershberger785881f2013-04-08 10:32:52 +000022#ifdef CONFIG_SYS_REDUNDAND_ENVIRONMENT
Simon Glasse5bce242017-08-03 12:22:01 -060023static int env_ubi_save(void)
Joe Hershberger785881f2013-04-08 10:32:52 +000024{
25 ALLOC_CACHE_ALIGN_BUFFER(env_t, env_new, 1);
Marek Vasut7ce15262014-03-05 19:59:50 +010026 int ret;
Joe Hershberger785881f2013-04-08 10:32:52 +000027
Marek Vasut7ce15262014-03-05 19:59:50 +010028 ret = env_export(env_new);
29 if (ret)
30 return ret;
Joe Hershberger785881f2013-04-08 10:32:52 +000031
32 if (ubi_part(CONFIG_ENV_UBI_PART, NULL)) {
33 printf("\n** Cannot find mtd partition \"%s\"\n",
34 CONFIG_ENV_UBI_PART);
35 return 1;
36 }
37
Simon Glass203e94f2017-08-03 12:21:56 -060038 if (gd->env_valid == ENV_VALID) {
Joe Hershberger785881f2013-04-08 10:32:52 +000039 puts("Writing to redundant UBI... ");
40 if (ubi_volume_write(CONFIG_ENV_UBI_VOLUME_REDUND,
41 (void *)env_new, CONFIG_ENV_SIZE)) {
42 printf("\n** Unable to write env to %s:%s **\n",
43 CONFIG_ENV_UBI_PART,
44 CONFIG_ENV_UBI_VOLUME_REDUND);
45 return 1;
46 }
47 } else {
48 puts("Writing to UBI... ");
49 if (ubi_volume_write(CONFIG_ENV_UBI_VOLUME,
50 (void *)env_new, CONFIG_ENV_SIZE)) {
51 printf("\n** Unable to write env to %s:%s **\n",
52 CONFIG_ENV_UBI_PART,
53 CONFIG_ENV_UBI_VOLUME);
54 return 1;
55 }
56 }
57
58 puts("done\n");
59
Simon Glass203e94f2017-08-03 12:21:56 -060060 gd->env_valid = gd->env_valid == ENV_REDUND ? ENV_VALID : ENV_REDUND;
Joe Hershberger785881f2013-04-08 10:32:52 +000061
62 return 0;
63}
64#else /* ! CONFIG_SYS_REDUNDAND_ENVIRONMENT */
Simon Glasse5bce242017-08-03 12:22:01 -060065static int env_ubi_save(void)
Joe Hershberger2b744332013-04-08 10:32:51 +000066{
67 ALLOC_CACHE_ALIGN_BUFFER(env_t, env_new, 1);
Marek Vasut7ce15262014-03-05 19:59:50 +010068 int ret;
Joe Hershberger2b744332013-04-08 10:32:51 +000069
Marek Vasut7ce15262014-03-05 19:59:50 +010070 ret = env_export(env_new);
71 if (ret)
72 return ret;
Joe Hershberger2b744332013-04-08 10:32:51 +000073
74 if (ubi_part(CONFIG_ENV_UBI_PART, NULL)) {
75 printf("\n** Cannot find mtd partition \"%s\"\n",
76 CONFIG_ENV_UBI_PART);
77 return 1;
78 }
79
Joe Hershberger2b744332013-04-08 10:32:51 +000080 if (ubi_volume_write(CONFIG_ENV_UBI_VOLUME, (void *)env_new,
81 CONFIG_ENV_SIZE)) {
82 printf("\n** Unable to write env to %s:%s **\n",
83 CONFIG_ENV_UBI_PART, CONFIG_ENV_UBI_VOLUME);
84 return 1;
85 }
86
87 puts("done\n");
88 return 0;
89}
Joe Hershberger785881f2013-04-08 10:32:52 +000090#endif /* CONFIG_SYS_REDUNDAND_ENVIRONMENT */
Joe Hershberger2b744332013-04-08 10:32:51 +000091#endif /* CONFIG_CMD_SAVEENV */
92
Joe Hershberger785881f2013-04-08 10:32:52 +000093#ifdef CONFIG_SYS_REDUNDAND_ENVIRONMENT
Simon Glassc5951992017-08-03 12:22:17 -060094static int env_ubi_load(void)
Joe Hershberger785881f2013-04-08 10:32:52 +000095{
96 ALLOC_CACHE_ALIGN_BUFFER(char, env1_buf, CONFIG_ENV_SIZE);
97 ALLOC_CACHE_ALIGN_BUFFER(char, env2_buf, CONFIG_ENV_SIZE);
Simon Goldschmidt31f044b2018-01-31 14:47:11 +010098 int read1_fail, read2_fail;
Fiach Antaw9d364af2017-01-25 18:53:12 +100099 env_t *tmp_env1, *tmp_env2;
Joe Hershberger785881f2013-04-08 10:32:52 +0000100
Marcin Niestrojc1f51e02016-05-24 14:59:55 +0200101 /*
102 * In case we have restarted u-boot there is a chance that buffer
103 * contains old environment (from the previous boot).
104 * If UBI volume is zero size, ubi_volume_read() doesn't modify the
105 * buffer.
106 * We need to clear buffer manually here, so the invalid CRC will
107 * cause setting default environment as expected.
108 */
109 memset(env1_buf, 0x0, CONFIG_ENV_SIZE);
110 memset(env2_buf, 0x0, CONFIG_ENV_SIZE);
111
Joe Hershberger785881f2013-04-08 10:32:52 +0000112 tmp_env1 = (env_t *)env1_buf;
113 tmp_env2 = (env_t *)env2_buf;
114
115 if (ubi_part(CONFIG_ENV_UBI_PART, NULL)) {
116 printf("\n** Cannot find mtd partition \"%s\"\n",
117 CONFIG_ENV_UBI_PART);
118 set_default_env(NULL);
Simon Glassc5951992017-08-03 12:22:17 -0600119 return -EIO;
Joe Hershberger785881f2013-04-08 10:32:52 +0000120 }
121
Simon Goldschmidt31f044b2018-01-31 14:47:11 +0100122 read1_fail = ubi_volume_read(CONFIG_ENV_UBI_VOLUME, (void *)tmp_env1,
123 CONFIG_ENV_SIZE);
124 if (read1_fail)
Joe Hershberger785881f2013-04-08 10:32:52 +0000125 printf("\n** Unable to read env from %s:%s **\n",
126 CONFIG_ENV_UBI_PART, CONFIG_ENV_UBI_VOLUME);
Joe Hershberger785881f2013-04-08 10:32:52 +0000127
Simon Goldschmidt31f044b2018-01-31 14:47:11 +0100128 read2_fail = ubi_volume_read(CONFIG_ENV_UBI_VOLUME_REDUND,
129 (void *)tmp_env2, CONFIG_ENV_SIZE);
130 if (read2_fail)
Joe Hershberger785881f2013-04-08 10:32:52 +0000131 printf("\n** Unable to read redundant env from %s:%s **\n",
132 CONFIG_ENV_UBI_PART, CONFIG_ENV_UBI_VOLUME_REDUND);
Joe Hershberger785881f2013-04-08 10:32:52 +0000133
Simon Goldschmidt31f044b2018-01-31 14:47:11 +0100134 return env_import_redund((char *)tmp_env1, read1_fail, (char *)tmp_env2,
135 read2_fail);
Joe Hershberger785881f2013-04-08 10:32:52 +0000136}
137#else /* ! CONFIG_SYS_REDUNDAND_ENVIRONMENT */
Simon Glassc5951992017-08-03 12:22:17 -0600138static int env_ubi_load(void)
Joe Hershberger2b744332013-04-08 10:32:51 +0000139{
140 ALLOC_CACHE_ALIGN_BUFFER(char, buf, CONFIG_ENV_SIZE);
141
Marcin Niestrojc1f51e02016-05-24 14:59:55 +0200142 /*
143 * In case we have restarted u-boot there is a chance that buffer
144 * contains old environment (from the previous boot).
145 * If UBI volume is zero size, ubi_volume_read() doesn't modify the
146 * buffer.
147 * We need to clear buffer manually here, so the invalid CRC will
148 * cause setting default environment as expected.
149 */
150 memset(buf, 0x0, CONFIG_ENV_SIZE);
151
Joe Hershberger2b744332013-04-08 10:32:51 +0000152 if (ubi_part(CONFIG_ENV_UBI_PART, NULL)) {
153 printf("\n** Cannot find mtd partition \"%s\"\n",
154 CONFIG_ENV_UBI_PART);
155 set_default_env(NULL);
Simon Glassc5951992017-08-03 12:22:17 -0600156 return -EIO;
Joe Hershberger2b744332013-04-08 10:32:51 +0000157 }
158
Kevin Smitha7c06cd2015-10-23 17:51:47 +0000159 if (ubi_volume_read(CONFIG_ENV_UBI_VOLUME, buf, CONFIG_ENV_SIZE)) {
Joe Hershberger2b744332013-04-08 10:32:51 +0000160 printf("\n** Unable to read env from %s:%s **\n",
161 CONFIG_ENV_UBI_PART, CONFIG_ENV_UBI_VOLUME);
162 set_default_env(NULL);
Simon Glassc5951992017-08-03 12:22:17 -0600163 return -EIO;
Joe Hershberger2b744332013-04-08 10:32:51 +0000164 }
165
Simon Goldschmidt2166ebf2018-01-31 14:47:12 +0100166 return env_import(buf, 1);
Joe Hershberger2b744332013-04-08 10:32:51 +0000167}
Joe Hershberger785881f2013-04-08 10:32:52 +0000168#endif /* CONFIG_SYS_REDUNDAND_ENVIRONMENT */
Simon Glass4415f1d2017-08-03 12:21:58 -0600169
170U_BOOT_ENV_LOCATION(ubi) = {
171 .location = ENVL_UBI,
Simon Glasse5bce242017-08-03 12:22:01 -0600172 .load = env_ubi_load,
173 .save = env_save_ptr(env_ubi_save),
Simon Glass4415f1d2017-08-03 12:21:58 -0600174};