From mboxrd@z Thu Jan 1 00:00:00 1970 Return-path: Received: from metis.ext.pengutronix.de ([2001:6f8:1178:4:290:27ff:fe1d:cc33]) by bombadil.infradead.org with esmtps (Exim 4.69 #1 (Red Hat Linux)) id 1Nv92Y-0003M2-Ag for barebox@lists.infradead.org; Fri, 26 Mar 2010 12:53:32 +0000 From: Luotao Fu Date: Fri, 26 Mar 2010 13:52:27 +0100 Message-Id: <1269607949-5336-4-git-send-email-l.fu@pengutronix.de> In-Reply-To: <1269607949-5336-1-git-send-email-l.fu@pengutronix.de> References: <1269607949-5336-1-git-send-email-l.fu@pengutronix.de> List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , MIME-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Sender: barebox-bounces@lists.infradead.org Errors-To: barebox-bounces+u.kleine-koenig=pengutronix.de@lists.infradead.org Subject: [PATCH 3/5] add multi environment support To: sha@pengutronix.de Cc: barebox@lists.infradead.org, Luotao Fu We can deal with multiple environments now in our barebox. With this option enabled barebox will scan all environment partions on start up and load the environment from the first loadable environment partition it finds. Also it will check the content of all environment parttions and autmotically synchronize content of any outdated partition. Signed-off-by: Luotao Fu --- common/Kconfig | 11 ++++++ common/startup.c | 90 ++++++++++++++++++++++++++++++++++++++++++++++++----- 2 files changed, 92 insertions(+), 9 deletions(-) diff --git a/common/Kconfig b/common/Kconfig index 4c4a627..ffb0257 100644 --- a/common/Kconfig +++ b/common/Kconfig @@ -40,6 +40,17 @@ config LOCALVERSION_AUTO which is done within the script "scripts/setlocalversion".) +config MULTI_ENV_HANDLING + select ENV_HANDLING + bool "Enable handling multiple environment partitions" + help + We can have multiple environments in our barebox. With this option + enabled barebox will scan all environment partions on start up and + load the environment from the first loadable environment partition + it finds. Also it will check if the content of all environment + parttions are synchronized and autmotically synchronize content of + the outdated partition. + config BOARDINFO string diff --git a/common/startup.c b/common/startup.c index 6dca270..af929f8 100644 --- a/common/startup.c +++ b/common/startup.c @@ -110,6 +110,87 @@ static int mount_root(void) } fs_initcall(mount_root); +#ifdef CONFIG_ENV_HANDLING +#ifdef CONFIG_MULTI_ENV_HANDLING +static int init_envfs_load(void) +{ + char *dirname = "/env"; + char file[9 + 5]; /* '/dev/env.....' */ + int i = 0, j = 0, no_more_parts = 0; + int crc = 0, crc_ref = 0; + int rc; + struct stat file_info; + + while (1) { + sprintf(file, "/dev/env%d", i); + + if (stat(file, &file_info) != 0) { + no_more_parts = 1; + break; + } + + /* first loadable environment is considered to be + * reference */ + if (envfs_load(file, dirname, &crc_ref) == 0) + break; + + i++; + } + + /* no loadable environment partition found */ + if (no_more_parts == 1) { +#ifdef CONFIG_DEFAULT_ENVIRONMENT + printf("no valid environment found. " + "Using default environment\n"); + envfs_load("/dev/defaultenv", "/env", &crc_ref); +#endif + goto out; + } + + /* Now try to restore, if any, the previous failed partitions */ + for (j = 0; j < i; j++) { + sprintf(file, "/dev/env%d", j); + if (envfs_save(file, dirname)) + printf("failed to sync environment on %s\n", file); + } + + /* proceed to scan further env partitions */ + while (1) { + i++; + sprintf(file, "/dev/env%d", i); + + if (stat(file, &file_info) != 0) + break; + + /* sync partition if loading failed or crc mismatch with + * the reference*/ + rc = envfs_load(file, NULL, &crc); + if (rc != 0 || crc != crc_ref) { + if (envfs_save(file, dirname)) + printf("failed to sync environment on %s\n", + file); + } + } +out: + return 0; +} +#else /* MULTI_ENV_HANDLING */ +static int init_envfs_load(void) +{ + if (envfs_load("/dev/env0", "/env")) { +#ifdef CONFIG_DEFAULT_ENVIRONMENT + printf("no valid environment found. " + "Using default environment\n"); + envfs_load("/dev/defaultenv", "/env", NULL); +#endif + } + + return 0; +} +#endif /* MULTI_ENV_HANDLING */ +late_initcall(init_envfs_load); +#endif /* CONFIG_ENV_HANDLING */ + void start_barebox (void) { initcall_t *initcall; @@ -137,15 +218,6 @@ void start_barebox (void) display_meminfo(); -#ifdef CONFIG_ENV_HANDLING - if (envfs_load("/dev/env0", "/env")) { -#ifdef CONFIG_DEFAULT_ENVIRONMENT - printf("no valid environment found on /dev/env0. " - "Using default environment\n"); - envfs_load("/dev/defaultenv", "/env"); -#endif - } -#endif printf("running /env/bin/init...\n"); if (!stat("/env/bin/init", &s)) { -- 1.7.0 _______________________________________________ barebox mailing list barebox@lists.infradead.org http://lists.infradead.org/mailman/listinfo/barebox