[PATCH/RFC] Allow CONFIG_OF_FLAT_TREE to boot a non-arch/powerpc kernel
Grant Likely
grant.likely at secretlab.ca
Fri Oct 27 07:11:19 EST 2006
BTW, can someone please actually test this w/ a arch/powerpc kernel?
I've only got a lite5200b to play with, and it isn't ported yet. :)
g.
On 10/26/06, Grant Likely <grant.likely at secretlab.ca> wrote:
> This patch allows an arch/ppc kernel to be booted by just passing 1 or 2
> arguments to bootm. It removes the getenv("disable_of") test that used
> to be used for this purpose.
>
> Signed-off-by: Grant Likely <grant.likely at secretlab.ca>
> ---
> common/cmd_bootm.c | 52 ++++++++++++++++++++--------------------------------
> 1 files changed, 20 insertions(+), 32 deletions(-)
>
> diff --git a/common/cmd_bootm.c b/common/cmd_bootm.c
> index 3091a58..07a9f12 100644
> --- a/common/cmd_bootm.c
> +++ b/common/cmd_bootm.c
> @@ -833,10 +833,6 @@ #endif
> printf ("ERROR: flat device tree size does not agree with image\n");
> return;
> }
> -
> - } else if (getenv("disable_of") == NULL) {
> - printf ("ERROR: bootm needs flat device tree as third argument\n");
> - return;
> }
> #endif
> if (!data) {
> @@ -913,23 +909,11 @@ #endif /* CONFIG_HW_WATCHDOG || CONFIG_W
>
> SHOW_BOOT_PROGRESS (15);
>
> -#ifndef CONFIG_OF_FLAT_TREE
> -
> #if defined(CFG_INIT_RAM_LOCK) && !defined(CONFIG_E500)
> unlock_ram_in_cache();
> #endif
>
> - /*
> - * Linux Kernel Parameters:
> - * r3: ptr to board info data
> - * r4: initrd_start or 0 if no initrd
> - * r5: initrd_end - unused if r4 is 0
> - * r6: Start of command line string
> - * r7: End of command line string
> - */
> - (*kernel) (kbd, initrd_start, initrd_end, cmd_start, cmd_end);
> -
> -#else /* CONFIG_OF_FLAT_TREE */
> +#ifdef CONFIG_OF_FLAT_TREE
> /* move of_flat_tree if needed */
> if (of_data) {
> ulong of_start, of_len;
> @@ -949,29 +933,33 @@ #else /* CONFIG_OF_FLAT_TREE */
> memmove ((void *)of_start, (void *)of_data, of_len);
> }
>
> - ft_setup(of_flat_tree, kbd, initrd_start, initrd_end);
> - /* ft_dump_blob(of_flat_tree); */
> -
> -#if defined(CFG_INIT_RAM_LOCK) && !defined(CONFIG_E500)
> - unlock_ram_in_cache();
> + /*
> + * Linux Kernel Parameters (passing board info data):
> + * r3: ptr to board info data
> + * r4: initrd_start or 0 if no initrd
> + * r5: initrd_end - unused if r4 is 0
> + * r6: Start of command line string
> + * r7: End of command line string
> + */
> +#ifdef CONFIG_OF_FLAT_TREE
> + if (!of_flat_tree) /* no device tree; boot old style */
> #endif
> + (*kernel) (kbd, initrd_start, initrd_end, cmd_start, cmd_end);
> + /* does not return */
> +
> /*
> - * Linux Kernel Parameters:
> + * Linux Kernel Parameters (passing device tree):
> * r3: ptr to OF flat tree, followed by the board info data
> * r4: physical pointer to the kernel itself
> * r5: NULL
> * r6: NULL
> * r7: NULL
> */
> - if (getenv("disable_of") != NULL)
> - (*kernel) ((bd_t *)of_flat_tree, initrd_start, initrd_end,
> - cmd_start, cmd_end);
> - else {
> - ft_setup(of_flat_tree, kbd, initrd_start, initrd_end);
> - /* ft_dump_blob(of_flat_tree); */
> - (*kernel) ((bd_t *)of_flat_tree, (ulong)kernel, 0, 0, 0);
> - }
> -#endif /* CONFIG_OF_FLAT_TREE */
> + ft_setup(of_flat_tree, kbd, initrd_start, initrd_end);
> + /* ft_dump_blob(of_flat_tree); */
> +
> + (*kernel) ((bd_t *)of_flat_tree, (ulong)kernel, 0, 0, 0);
> +#endif
> }
> #endif /* CONFIG_PPC */
>
> --
> 1.4.3.rc2.g0503
>
>
--
Grant Likely, B.Sc. P.Eng.
Secret Lab Technologies Ltd.
grant.likely at secretlab.ca
(403) 399-0195
More information about the Linuxppc-dev
mailing list