[PATCH/RFC] Allow CONFIG_OF_FLAT_TREE to boot a non-arch/powerpc kernel
Grant Likely
grant.likely at secretlab.ca
Fri Oct 27 12:37:54 EST 2006
BBTW, considering that this is a u-boot patch; sorry for posting this
here linuxppc-dev instead of u-boot-users.
g.
On 10/26/06, Grant Likely <grant.likely at secretlab.ca> wrote:
> 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
>
--
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