[PATCH 07/11] OMAP2+: board-generic: Add DT support to generic board
Cousson, Benoit
b-cousson at ti.com
Mon Sep 26 19:00:39 EST 2011
On 9/26/2011 8:32 AM, Nayak, Rajendra wrote:
> Hi Benoit,
>
> On Saturday 24 September 2011 01:53 AM, Benoit Cousson wrote:
>> Re-cycle the original board-generic file to support Device Tree
>> for every OMAP2+ variants.
>> Note: Since it is a completely new content in the existing file
>> I removed the original copyright.
>>
>> The current approach is an intermediate step before having only
>> one machine descriptor that will use some generic DT aware
>> functions.
>
> What config does this work with currently? If I use omap2plus_defconfig
> should I explicitly disable everything other than say CONFIG_ARCH_OMAP4
> if I want it working on OMAP4?
Nope, in theory, omap2plus_defconfig should work as usual:-)
If uboot does not provide and dtb, then the legacy board file will be
used. If a dtb is present then only the board-generic can match with the
DT mechanism.
Regards,
Benoit
>
> regards,
> Rajendra
>
>>
>> Signed-off-by: Benoit Cousson<b-cousson at ti.com>
>> Cc: Tony Lindgren<tony at atomide.com>
>> ---
>> arch/arm/mach-omap2/Kconfig | 8 ++-
>> arch/arm/mach-omap2/board-generic.c | 129 ++++++++++++++++++++++------------
>> 2 files changed, 89 insertions(+), 48 deletions(-)
>>
>> diff --git a/arch/arm/mach-omap2/Kconfig b/arch/arm/mach-omap2/Kconfig
>> index 7edf802..5934a27 100644
>> --- a/arch/arm/mach-omap2/Kconfig
>> +++ b/arch/arm/mach-omap2/Kconfig
>> @@ -106,9 +106,13 @@ comment "OMAP Board Type"
>> depends on ARCH_OMAP2PLUS
>>
>> config MACH_OMAP_GENERIC
>> - bool "Generic OMAP board"
>> - depends on ARCH_OMAP2
>> + bool "Generic OMAP2+ board"
>> + depends on ARCH_OMAP2PLUS
>> + select USE_OF
>> default y
>> + help
>> + Support for generic TI OMAP2+ boards using Flattened Device Tree.
>> + More information at Documentation/devicetree
>>
>> config MACH_OMAP2_TUSB6010
>> bool
>> diff --git a/arch/arm/mach-omap2/board-generic.c b/arch/arm/mach-omap2/board-generic.c
>> index e8d45d3..dcbd64c 100644
>> --- a/arch/arm/mach-omap2/board-generic.c
>> +++ b/arch/arm/mach-omap2/board-generic.c
>> @@ -1,76 +1,113 @@
>> /*
>> - * linux/arch/arm/mach-omap2/board-generic.c
>> + * Copyright (C) 2011 Texas Instruments Incorporated - http://www.ti.com/
>> *
>> - * Copyright (C) 2005 Nokia Corporation
>> - * Author: Paul Mundt<paul.mundt at nokia.com>
>> - *
>> - * Modified from mach-omap/omap1/board-generic.c
>> - *
>> - * Code for generic OMAP2 board. Should work on many OMAP2 systems where
>> - * the bootloader passes the board-specific data to the kernel.
>> - * Do not put any board specific code to this file; create a new machine
>> - * type if you need custom low-level initializations.
>> + * Support for generic OMAP2+ device tree boards.
>> *
>> * This program is free software; you can redistribute it and/or modify
>> * it under the terms of the GNU General Public License version 2 as
>> * published by the Free Software Foundation.
>> */
>>
>> -#include<linux/kernel.h>
>> -#include<linux/init.h>
>> -#include<linux/device.h>
>> +#include<linux/io.h>
>> +#include<linux/of_platform.h>
>> +#include<linux/irqdomain.h>
>>
>> #include<mach/hardware.h>
>> -#include<asm/mach-types.h>
>> #include<asm/mach/arch.h>
>> -#include<asm/mach/map.h>
>>
>> -#include<mach/gpio.h>
>> -#include<plat/usb.h>
>> #include<plat/board.h>
>> #include<plat/common.h>
>> +#include<mach/omap4-common.h>
>>
>> -static struct omap_board_config_kernel generic_config[] = {
>> +
>> +static struct of_device_id omap_dt_match_table[] __initdata = {
>> + { .compatible = "simple-bus", },
>> + { .compatible = "ti,omap-infra", },
>> + { }
>> };
>>
>> -static void __init omap_generic_init_early(void)
>> -{
>> - omap2_init_common_infrastructure();
>> -}
>> +static struct of_device_id intc_match[] __initdata = {
>> + { .compatible = "ti,omap3-intc", },
>> + { .compatible = "arm,cortex-a9-gic", },
>> + { }
>> +};
>>
>> static void __init omap_generic_init(void)
>> {
>> + struct device_node *node = of_find_matching_node(NULL, intc_match);
>> + if (node)
>> + irq_domain_add_simple(node, 0);
>> +
>> omap_serial_init();
>> omap_sdrc_init(NULL, NULL);
>> - omap_board_config = generic_config;
>> - omap_board_config_size = ARRAY_SIZE(generic_config);
>> -}
>>
>> -static void __init omap_generic_map_io(void)
>> -{
>> - if (cpu_is_omap242x()) {
>> - omap2_set_globals_242x();
>> - omap242x_map_common_io();
>> - } else if (cpu_is_omap243x()) {
>> - omap2_set_globals_243x();
>> - omap243x_map_common_io();
>> - } else if (cpu_is_omap34xx()) {
>> - omap2_set_globals_3xxx();
>> - omap34xx_map_common_io();
>> - } else if (cpu_is_omap44xx()) {
>> - omap2_set_globals_443x();
>> - omap44xx_map_common_io();
>> - }
>> + of_platform_populate(NULL, omap_dt_match_table, NULL, NULL);
>> }
>>
>> -/* XXX This machine entry name should be updated */
>> -MACHINE_START(OMAP_GENERIC, "Generic OMAP24xx")
>> - /* Maintainer: Paul Mundt<paul.mundt at nokia.com> */
>> - .atag_offset = 0x100,
>> +#if defined(CONFIG_SOC_OMAP2420)
>> +static const char *omap242x_boards_compat[] __initdata = {
>> + "ti,omap2420",
>> + NULL,
>> +};
>> +
>> +DT_MACHINE_START(OMAP242X_DT, "Generic OMAP2420 (Flattened Device Tree)")
>> .reserve = omap_reserve,
>> - .map_io = omap_generic_map_io,
>> - .init_early = omap_generic_init_early,
>> + .map_io = omap242x_map_io,
>> + .init_early = omap2420_init_early,
>> .init_irq = omap2_init_irq,
>> .init_machine = omap_generic_init,
>> .timer =&omap2_timer,
>> + .dt_compat = omap242x_boards_compat,
>> +MACHINE_END
>> +#endif
>> +
>> +#if defined(CONFIG_SOC_OMAP2430)
>> +static const char *omap243x_boards_compat[] __initdata = {
>> + "ti,omap2430",
>> + NULL,
>> +};
>> +
>> +DT_MACHINE_START(OMAP243X_DT, "Generic OMAP2430 (Flattened Device Tree)")
>> + .reserve = omap_reserve,
>> + .map_io = omap243x_map_io,
>> + .init_early = omap2430_init_early,
>> + .init_irq = omap2_init_irq,
>> + .init_machine = omap_generic_init,
>> + .timer =&omap2_timer,
>> + .dt_compat = omap243x_boards_compat,
>> +MACHINE_END
>> +#endif
>> +
>> +#if defined(CONFIG_ARCH_OMAP3)
>> +static const char *omap3_boards_compat[] __initdata = {
>> + "ti,omap3",
>> + NULL,
>> +};
>> +
>> +DT_MACHINE_START(OMAP3_DT, "Generic OMAP3 (Flattened Device Tree)")
>> + .reserve = omap_reserve,
>> + .map_io = omap3_map_io,
>> + .init_early = omap3430_init_early,
>> + .init_irq = omap3_init_irq,
>> + .init_machine = omap_generic_init,
>> + .timer =&omap3_timer,
>> + .dt_compat = omap3_boards_compat,
>> +MACHINE_END
>> +#endif
>> +
>> +#if defined(CONFIG_ARCH_OMAP4)
>> +static const char *omap4_boards_compat[] __initdata = {
>> + "ti,omap4",
>> + NULL,
>> +};
>> +
>> +DT_MACHINE_START(OMAP4_DT, "Generic OMAP4 (Flattened Device Tree)")
>> + .reserve = omap_reserve,
>> + .map_io = omap4_map_io,
>> + .init_early = omap4430_init_early,
>> + .init_irq = gic_init_irq,
>> + .init_machine = omap_generic_init,
>> + .timer =&omap4_timer,
>> + .dt_compat = omap4_boards_compat,
>> MACHINE_END
>> +#endif
>
More information about the devicetree-discuss
mailing list