[PATCH 1/3] ARM: PRIMA2: use DT_MACHINE_START and convert to generic board
Arnd Bergmann
arnd at arndb.de
Tue Aug 21 03:53:12 EDT 2012
On Tuesday 21 August 2012, Barry Song wrote:
> 2012/8/21 Arnd Bergmann <arnd at arndb.de>:
> > On Monday 20 August 2012, Barry Song wrote:
> >
> > I would prefer not to have a board-* file in there, because it's not
> > specific to a board. If you want to get rid of the prima2 name in it,
> > you can call it common.c.
>
> that is fine to me. i rename to board-generic.c just because omap and
> some others did like that.
> and i'll add marco and polo DT_MACHINE_START to this file too.
Ok. For the older platforms that have a lot of non-DT board files, it makes
sense to have a separate board-generic.c file.
> >> diff --git a/arch/arm/mach-prima2/prima2.c b/arch/arm/mach-prima2/board-generic.c
> >> similarity index 81%
> >> rename from arch/arm/mach-prima2/prima2.c
> >> rename to arch/arm/mach-prima2/board-generic.c
> >> index e9a17ae..f06b887 100644
> >> --- a/arch/arm/mach-prima2/prima2.c
> >> +++ b/arch/arm/mach-prima2/board-generic.c
> >> @@ -30,12 +30,13 @@ void __init sirfsoc_init_late(void)
> >> sirfsoc_pm_init();
> >> }
> >>
> >> -static const char *prima2cb_dt_match[] __initdata = {
> >> - "sirf,prima2-cb",
> >> +#ifdef CONFIG_ARCH_PRIMA2
> >> +static const char *prima2_dt_match[] __initdata = {
> >> + "sirf,prima2",
> >> NULL
> >> };
> >>
> >> -MACHINE_START(PRIMA2_EVB, "prima2cb")
> >> +DT_MACHINE_START(PRIMA2_DT, "Generic PRIMA2 (Flattened Device Tree)")
> >> /* Maintainer: Barry Song <baohua.song at csr.com> */
> >> .atag_offset = 0x100,
> >> .map_io = sirfsoc_map_lluart,
> >> @@ -44,6 +45,7 @@ MACHINE_START(PRIMA2_EVB, "prima2cb")
> >> .dma_zone_size = SZ_256M,
> >> .init_machine = sirfsoc_mach_init,
> >> .init_late = sirfsoc_init_late,
> >> - .dt_compat = prima2cb_dt_match,
> >> + .dt_compat = prima2_dt_match,
> >> .restart = sirfsoc_restart,
> >> MACHINE_END
> >> +#endif
> >
> > I suppose this never really worked before then?
>
> i am not sure what you mean, but this does work and i tested and found
> prima2 can boot normally.
I mean the old version, not the new one. If you use MACHINE_START,
you cannot access the device tree data from the boot loader, which
means that none of the device drivers find their devices.
I also just noticed that you ahve both the .atag_offset and the .dt_compat
field set here, which is a bit strange as the dt_compat field was previously
unused. Now, the .atag_offset field is unused, so you should remove that.
Arnd
More information about the linux-arm-kernel
mailing list