From: Brian McFarland <bmcfarl...@rldrake.com> The current head revision of mkenvimage (e72be8947e129f5ab274c0a9f235d2cc0014b2ea) will prevent you from creating an env image from a text file that is larger than the env length specified by the '-s' option. That doesn't make sense given that the tool now allows comments and blank lines. This patch removes that limitation and allows longer text files to be used.
Signed-off-by: Brian McFarland <bmcfarl...@rldrake.com> Signed-off-by: Joe Hershberger <joe.hershber...@ni.com> --- Converted to a proper patch for the mailing list to be able to process. tools/mkenvimage.c | 34 +++++++++++++++++++++++++++------- 1 file changed, 27 insertions(+), 7 deletions(-) diff --git a/tools/mkenvimage.c b/tools/mkenvimage.c index 6971b91..f1f602a 100644 --- a/tools/mkenvimage.c +++ b/tools/mkenvimage.c @@ -214,14 +214,13 @@ int main(int argc, char **argv) } ret = close(txt_fd); } - /* The +1 is for the additionnal ending \0. See below. */ - if (filesize + 1 > envsize) { - fprintf(stderr, "The input file is larger than the environment partition size\n"); - return EXIT_FAILURE; - } - /* Replace newlines separating variables with \0 */ - for (fp = 0, ep = 0 ; fp < filesize ; fp++) { + /* + * Parse one byte at a time until reaching the end of the file OR until + * the environment fills up. Check ep against envsize - 1 to allow for + * an extra trailing '\0'. + */ + for (fp = 0, ep = 0 ; fp < filesize && ep < envsize - 1; fp++) { if (filebuf[fp] == '\n') { if (fp == 0 || filebuf[fp-1] == '\n') { /* @@ -250,6 +249,27 @@ int main(int argc, char **argv) } } /* + * If there are more bytes in the file still, it means the env filled up + * before parsing the whole file. Eat comments & whitespace here to see + * if there was anything meaningful left in the file, and if so, throw + * an error and exit. + */ + for (; fp < filesize; fp++) { + if (filebuf[fp] == '\n') { + if (fp == 0 || filebuf[fp-1] == '\n') { + /* Ignore blank lines */ + continue; + } + } else if ((fp == 0 || filebuf[fp-1] == '\n') && + filebuf[fp] == '#') { + while (++fp < filesize && filebuf[fp] != '\n') + continue; + } else { + fprintf(stderr, "The environment file is too large for the target environment storage\n"); + return EXIT_FAILURE; + } + } + /* * Make sure there is a final '\0' * And do it again on the next byte to mark the end of the environment. */ -- 1.7.11.5 _______________________________________________ U-Boot mailing list U-Boot@lists.denx.de http://lists.denx.de/mailman/listinfo/u-boot