On Tuesday 11 April 2017 03:43 AM, Adam Ford wrote: > The previous version of omap3_logic_defconfig supported either > Torpedo or SOM-LV. Now with the device tree, there are two > different defconfig files: > > omap3_logic_defconfig = torpedo > omap3_logic_somlv_defconfig = SOM-LV > > This patch also removes all the excessive code in trying to > determine the differences between these boards as well as removing > the some of the unnecessary NS16550 intiailization as the device > tree can do that now. This also adds DM_I2C and DM_MMC since > the overlying drivers have the built-in support already. The > corresponding include/config/omap3_logic.h also reduced in size > due to the new device tree support.
This could be a separate patch. Otherwise Reviewed-by: Lokesh Vutla <lokeshvu...@ti.com> Thanks and regards, Lokesh > > The device trees were sync'd with 4.9.y stable with two changes: > disable mmc2 and stdout-path = &uart1. Both of those two changes > will be submitted to the linux-omap list. > > Signed-off-by: Adam Ford <aford...@gmail.com> > > diff --git a/arch/arm/dts/Makefile b/arch/arm/dts/Makefile > index 7378c88..44c586d 100644 > --- a/arch/arm/dts/Makefile > +++ b/arch/arm/dts/Makefile > @@ -341,6 +341,10 @@ dtb-$(CONFIG_SOC_KEYSTONE) += keystone-k2hk-evm.dtb \ > keystone-k2e-evm.dtb \ > keystone-k2g-evm.dtb > > +dtb-$(CONFIG_TARGET_OMAP3_LOGIC) += \ > + logicpd-torpedo-37xx-devkit.dtb \ > + logicpd-som-lv-37xx-devkit.dts > + > dtb-$(CONFIG_TARGET_SAMA5D2_XPLAINED) += \ > at91-sama5d2_xplained.dtb > > diff --git a/arch/arm/dts/logicpd-som-lv-37xx-devkit.dts > b/arch/arm/dts/logicpd-som-lv-37xx-devkit.dts > new file mode 100644 > index 0000000..31ecfdc > --- /dev/null > +++ b/arch/arm/dts/logicpd-som-lv-37xx-devkit.dts > @@ -0,0 +1,271 @@ > +/* > + * 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. > + */ > + > +/dts-v1/; > + > +#include "omap36xx.dtsi" > +#include "logicpd-som-lv.dtsi" > +#include "omap-gpmc-smsc9221.dtsi" > + > +/ { > + model = "LogicPD Zoom DM3730 SOM-LV Development Kit"; > + compatible = "logicpd,dm3730-som-lv-devkit", "ti,omap3630", "ti,omap3"; > + > + chosen { > + stdout-path = &uart1; > + }; > + > + gpio_keys { > + compatible = "gpio-keys"; > + pinctrl-names = "default"; > + pinctrl-0 = <&gpio_key_pins>; > + > + sysboot2 { > + label = "gpio3"; > + gpios = <&gpio4 15 GPIO_ACTIVE_LOW>; /* gpio_111 / > uP_GPIO_3 */ > + linux,code = <BTN_0>; > + wakeup-source; > + }; > + }; > + > + sound { > + compatible = "ti,omap-twl4030"; > + ti,model = "omap3logic"; > + ti,mcbsp = <&mcbsp2>; > + }; > + > + leds { > + compatible = "gpio-leds"; > + pinctrl-names = "default"; > + pinctrl-0 = <&led_pins &led_pins_wkup>; > + > + led1 { > + label = "led1"; > + gpios = <&gpio5 5 GPIO_ACTIVE_LOW>; /* gpio133 */ > + linux,default-trigger = "cpu0"; > + }; > + > + led2 { > + label = "led2"; > + gpios = <&gpio1 11 GPIO_ACTIVE_LOW>; /* gpio11 */ > + linux,default-trigger = "none"; > + }; > + }; > +}; > + > +&vaux1 { > + regulator-min-microvolt = <3000000>; > + regulator-max-microvolt = <3000000>; > +}; > + > +&vaux4 { > + regulator-min-microvolt = <1800000>; > + regulator-max-microvolt = <1800000>; > +}; > + > +&mcbsp2 { > + status = "okay"; > +}; > + > +&charger { > + ti,bb-uvolt = <3200000>; > + ti,bb-uamp = <150>; > +}; > + > +&gpmc { > + ranges = <1 0 0x08000000 0x1000000>; /* CS1: 16MB for LAN9221 */ > + > + ethernet@gpmc { > + pinctrl-names = "default"; > + pinctrl-0 = <&lan9221_pins>; > + interrupt-parent = <&gpio5>; > + interrupts = <24 IRQ_TYPE_LEVEL_LOW>; /* gpio_152 */ > + reg = <1 0 0xff>; > + }; > +}; > + > +&vpll2 { > + regulator-always-on; > +}; > + > +&dss { > + status = "ok"; > + vdds_dsi-supply = <&vpll2>; > + vdda_video-supply = <&video_reg>; > + pinctrl-names = "default"; > + pinctrl-0 = <&dss_dpi_pins1>; > + port { > + dpi_out: endpoint { > + remote-endpoint = <&lcd_in>; > + data-lines = <16>; > + }; > + }; > +}; > + > +/ { > + aliases { > + display0 = &lcd0; > + }; > + > + video_reg: video_reg { > + compatible = "regulator-fixed"; > + regulator-name = "fixed-supply"; > + regulator-min-microvolt = <3300000>; > + regulator-max-microvolt = <3300000>; > + }; > + > + lcd0: display@0 { > + compatible = "panel-dpi"; > + label = "28"; > + status = "okay"; > + /* default-on; */ > + pinctrl-names = "default"; > + pinctrl-0 = <&lcd_enable_pin>; > + enable-gpios = <&gpio5 27 GPIO_ACTIVE_HIGH>; /* gpio155, lcd > INI */ > + port { > + lcd_in: endpoint { > + remote-endpoint = <&dpi_out>; > + }; > + }; > + > + panel-timing { > + clock-frequency = <9000000>; > + hactive = <480>; > + vactive = <272>; > + hfront-porch = <3>; > + hback-porch = <2>; > + hsync-len = <42>; > + vback-porch = <3>; > + vfront-porch = <2>; > + vsync-len = <11>; > + hsync-active = <1>; > + vsync-active = <1>; > + de-active = <1>; > + pixelclk-active = <0>; > + }; > + }; > + > + bl: backlight { > + compatible = "pwm-backlight"; > + pinctrl-names = "default"; > + pinctrl-0 = <&backlight_pins>; > + pwms = <&twl_pwm 0 5000000>; > + brightness-levels = <0 10 20 30 40 50 60 70 80 90 100>; > + default-brightness-level = <7>; > + enable-gpios = <&gpio1 8 GPIO_ACTIVE_HIGH>; /* gpio_8 */ > + }; > +}; > + > +&mmc1 { > + interrupts-extended = <&intc 83 &omap3_pmx_core 0x11a>; > + pinctrl-names = "default"; > + pinctrl-0 = <&mmc1_pins>; > + wp-gpios = <&gpio4 30 GPIO_ACTIVE_HIGH>; /* gpio_126 */ > + cd-gpios = <&gpio4 14 IRQ_TYPE_LEVEL_LOW>; /* gpio_110 */ > + vmmc-supply = <&vmmc1>; > + bus-width = <4>; > + cap-power-off-card; > +}; > + > +&mmc2 { > + status = "disabled"; > +}; > + > +&omap3_pmx_core { > + gpio_key_pins: pinmux_gpio_key_pins { > + pinctrl-single,pins = < > + OMAP3_CORE1_IOPAD(0x212e, PIN_INPUT_PULLUP | MUX_MODE4) > /* cam_xclkb.gpio_111 / uP_GPIO_3*/ > + >; > + }; > + > + led_pins: pinmux_led_pins { > + pinctrl-single,pins = < > + OMAP3_CORE1_IOPAD(0x215e, PIN_OUTPUT_PULLUP | > MUX_MODE4) /* sdmmc2_dat1.gpio_133 / uP_GPIO_0 */ > + >; > + }; > + > + lan9221_pins: pinmux_lan9221_pins { > + pinctrl-single,pins = < > + OMAP3_CORE1_IOPAD(0x2184, PIN_INPUT_PULLUP | MUX_MODE4) > /* mcbsp4_clkx.gpio_152 */ > + >; > + }; > + > + mmc1_pins: pinmux_mmc1_pins { > + pinctrl-single,pins = < > + OMAP3_CORE1_IOPAD(0x2144, PIN_OUTPUT | MUX_MODE0) > /* sdmmc1_clk.sdmmc1_clk */ > + OMAP3_CORE1_IOPAD(0x2146, PIN_INPUT | MUX_MODE0) > /* sdmmc1_cmd.sdmmc1_cmd */ > + OMAP3_CORE1_IOPAD(0x2148, PIN_INPUT | MUX_MODE0) > /* sdmmc1_dat0.sdmmc1_dat0 */ > + OMAP3_CORE1_IOPAD(0x214a, PIN_INPUT | MUX_MODE0) > /* sdmmc1_dat1.sdmmc1_dat1 */ > + OMAP3_CORE1_IOPAD(0x214c, PIN_INPUT | MUX_MODE0) > /* sdmmc1_dat2.sdmmc1_dat2 */ > + OMAP3_CORE1_IOPAD(0x214e, PIN_INPUT | MUX_MODE0) > /* sdmmc1_dat3.sdmmc1_dat3 */ > + OMAP3_CORE1_IOPAD(0x2132, PIN_INPUT_PULLUP | MUX_MODE4) > /* cam_strobe.gpio_126 */ > + OMAP3_CORE1_IOPAD(0x212c, PIN_INPUT_PULLUP | MUX_MODE4) > /* cam_d11.gpio_110 */ > + >; > + }; > + > + lcd_enable_pin: pinmux_lcd_enable_pin { > + pinctrl-single,pins = < > + OMAP3_CORE1_IOPAD(0x218a, PIN_OUTPUT | > PIN_OFF_OUTPUT_LOW | MUX_MODE4) /* mcbsp4_fs.gpio_155 */ > + >; > + }; > + > + dss_dpi_pins1: pinmux_dss_dpi_pins1 { > + pinctrl-single,pins = < > + OMAP3_CORE1_IOPAD(0x20d4, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_pclk.dss_pclk */ > + OMAP3_CORE1_IOPAD(0x20d6, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_hsync.dss_hsync */ > + OMAP3_CORE1_IOPAD(0x20d8, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_vsync.dss_vsync */ > + OMAP3_CORE1_IOPAD(0x20da, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_acbias.dss_acbias */ > + > + OMAP3_CORE1_IOPAD(0x20dc, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_data0.dss_data0 */ > + OMAP3_CORE1_IOPAD(0x20de, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_data1.dss_data1 */ > + OMAP3_CORE1_IOPAD(0x20e0, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_data2.dss_data2 */ > + OMAP3_CORE1_IOPAD(0x20e2, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_data3.dss_data3 */ > + OMAP3_CORE1_IOPAD(0x20e4, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_data4.dss_data4 */ > + OMAP3_CORE1_IOPAD(0x20e6, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_data5.dss_data5 */ > + OMAP3_CORE1_IOPAD(0x20e8, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_data6.dss_data6 */ > + OMAP3_CORE1_IOPAD(0x20ea, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_data7.dss_data7 */ > + OMAP3_CORE1_IOPAD(0x20ec, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_data8.dss_data8 */ > + OMAP3_CORE1_IOPAD(0x20ee, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_data9.dss_data9 */ > + OMAP3_CORE1_IOPAD(0x20f0, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_data10.dss_data10 */ > + OMAP3_CORE1_IOPAD(0x20f2, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_data11.dss_data11 */ > + OMAP3_CORE1_IOPAD(0x20f4, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_data12.dss_data12 */ > + OMAP3_CORE1_IOPAD(0x20f6, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_data13.dss_data13 */ > + OMAP3_CORE1_IOPAD(0x20f8, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_data14.dss_data14 */ > + OMAP3_CORE1_IOPAD(0x20fa, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_data15.dss_data15 */ > + >; > + }; > +}; > + > +&omap3_pmx_wkup { > + led_pins_wkup: pinmux_led_pins_wkup { > + pinctrl-single,pins = < > + OMAP3_WKUP_IOPAD(0x2a24, PIN_OUTPUT_PULLUP | MUX_MODE4) > /* jtag_emu0.gpio_11 / uP_GPIO_1 */ > + >; > + }; > + > + backlight_pins: pinmux_backlight_pins { > + pinctrl-single,pins = < > + OMAP3_WKUP_IOPAD(0x2a16, PIN_OUTPUT | > PIN_OFF_OUTPUT_LOW | MUX_MODE4) /* sys_boot6.gpio_8 */ > + >; > + }; > +}; > + > + > +&uart1 { > + interrupts-extended = <&intc 72 &omap3_pmx_core OMAP3_UART1_RX>; > +}; > + > +/* Wired to the tps65950 on the SOM, only the USB connector is on the devkit > */ > +&usb_otg_hs { > + pinctrl-names = "default"; > + pinctrl-0 = <&hsusb_otg_pins>; > + interface-type = <0>; > + usb-phy = <&usb2_phy>; > + phys = <&usb2_phy>; > + phy-names = "usb2-phy"; > + mode = <3>; > + power = <50>; > +}; > diff --git a/arch/arm/dts/logicpd-som-lv.dtsi > b/arch/arm/dts/logicpd-som-lv.dtsi > new file mode 100644 > index 0000000..46dae55 > --- /dev/null > +++ b/arch/arm/dts/logicpd-som-lv.dtsi > @@ -0,0 +1,271 @@ > +/* > + * 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 <dt-bindings/input/input.h> > + > +/ { > + cpus { > + cpu@0 { > + cpu0-supply = <&vcc>; > + }; > + }; > + > + memory@80000000 { > + device_type = "memory"; > + reg = <0x80000000 0>; > + }; > + > + wl12xx_vmmc: wl12xx_vmmc { > + compatible = "regulator-fixed"; > + regulator-name = "vwl1271"; > + regulator-min-microvolt = <1800000>; > + regulator-max-microvolt = <1800000>; > + gpio = <&gpio1 3 0>; /* gpio_3 */ > + startup-delay-us = <70000>; > + enable-active-high; > + vin-supply = <&vmmc2>; > + }; > + > + /* HS USB Host PHY on PORT 1 */ > + hsusb2_phy: hsusb2_phy { > + compatible = "usb-nop-xceiv"; > + reset-gpios = <&gpio1 4 GPIO_ACTIVE_LOW>; /* gpio_4 */ > + }; > +}; > + > +&gpmc { > + ranges = <0 0 0x00000000 0x1000000>; /* CS0: 16MB for NAND */ > + > + nand@0,0 { > + compatible = "ti,omap2-nand"; > + reg = <0 0 4>; /* CS0, offset 0, IO size 4 */ > + interrupt-parent = <&gpmc>; > + interrupts = <0 IRQ_TYPE_NONE>, /* fifoevent */ > + <1 IRQ_TYPE_NONE>; /* termcount */ > + linux,mtd-name = "micron,mt29f4g16abbda3w"; > + nand-bus-width = <16>; > + ti,nand-ecc-opt = "bch8"; > + rb-gpios = <&gpmc 0 GPIO_ACTIVE_HIGH>; /* gpmc_wait0 */ > + gpmc,sync-clk-ps = <0>; > + gpmc,cs-on-ns = <0>; > + gpmc,cs-rd-off-ns = <44>; > + gpmc,cs-wr-off-ns = <44>; > + gpmc,adv-on-ns = <6>; > + gpmc,adv-rd-off-ns = <34>; > + gpmc,adv-wr-off-ns = <44>; > + gpmc,we-off-ns = <40>; > + gpmc,oe-off-ns = <54>; > + gpmc,access-ns = <64>; > + gpmc,rd-cycle-ns = <82>; > + gpmc,wr-cycle-ns = <82>; > + gpmc,wr-access-ns = <40>; > + gpmc,wr-data-mux-bus-ns = <0>; > + gpmc,device-width = <2>; > + #address-cells = <1>; > + #size-cells = <1>; > + > + /* u-boot uses > mtdparts=omap2-nand.0:512k(x-loader),1920k(u-boot),128k(u-boot-env),4m(kernel),-(fs) > */ > + > + x-loader@0 { > + label = "x-loader"; > + reg = <0 0x80000>; > + }; > + > + bootloaders@80000 { > + label = "u-boot"; > + reg = <0x80000 0x1e0000>; > + }; > + > + bootloaders_env@260000 { > + label = "u-boot-env"; > + reg = <0x260000 0x20000>; > + }; > + > + kernel@280000 { > + label = "kernel"; > + reg = <0x280000 0x400000>; > + }; > + > + filesystem@680000 { > + label = "fs"; > + reg = <0x680000 0>; /* 0 = MTDPART_SIZ_FULL */ > + }; > + }; > +}; > + > +&i2c1 { > + clock-frequency = <400000>; > + > + twl: twl@48 { > + reg = <0x48>; > + interrupts = <7>; /* SYS_NIRQ cascaded to intc */ > + interrupt-parent = <&intc>; > + twl_audio: audio { > + compatible = "ti,twl4030-audio"; > + codec { > + }; > + }; > + }; > +}; > + > +&i2c2 { > + clock-frequency = <400000>; > +}; > + > +&i2c3 { > + clock-frequency = <400000>; > +}; > + > +&mmc3 { > + interrupts-extended = <&intc 94 &omap3_pmx_core2 0x46>; > + pinctrl-0 = <&mmc3_pins>; > + pinctrl-names = "default"; > + vmmc-supply = <&wl12xx_vmmc>; > + non-removable; > + bus-width = <4>; > + cap-power-off-card; > + #address-cells = <1>; > + #size-cells = <0>; > + wlcore: wlcore@2 { > + compatible = "ti,wl1273"; > + reg = <2>; > + interrupt-parent = <&gpio5>; > + interrupts = <24 IRQ_TYPE_LEVEL_HIGH>; /* gpio 152 */ > + ref-clock-frequency = <26000000>; > + }; > +}; > + > +&usbhshost { > + port2-mode = "ehci-phy"; > +}; > + > +&usbhsehci { > + phys = <0 &hsusb2_phy>; > +}; > + > + > +&omap3_pmx_core { > + pinctrl-names = "default"; > + pinctrl-0 = <&hsusb2_pins>; > + > + mmc3_pins: pinmux_mm3_pins { > + pinctrl-single,pins = < > + OMAP3_CORE1_IOPAD(0x2164, PIN_INPUT_PULLUP | MUX_MODE3) > /* sdmmc2_dat4.sdmmc3_dat0 */ > + OMAP3_CORE1_IOPAD(0x2166, PIN_INPUT_PULLUP | MUX_MODE3) > /* sdmmc2_dat5.sdmmc3_dat1 */ > + OMAP3_CORE1_IOPAD(0x2168, PIN_INPUT_PULLUP | MUX_MODE3) > /* sdmmc2_dat6.sdmmc3_dat2 */ > + OMAP3_CORE1_IOPAD(0x216a, PIN_INPUT_PULLUP | MUX_MODE3) > /* sdmmc2_dat6.sdmmc3_dat3 */ > + OMAP3_CORE1_IOPAD(0x2184, PIN_INPUT_PULLUP | MUX_MODE4) > /* mcbsp4_clkx.gpio_152 */ > + OMAP3_CORE1_IOPAD(0x2a0c, PIN_OUTPUT | MUX_MODE4) > /* sys_boot1.gpio_3 */ > + OMAP3_CORE1_IOPAD(0x21d0, PIN_INPUT_PULLUP | MUX_MODE3) > /* mcspi1_cs1.sdmmc3_cmd */ > + OMAP3_CORE1_IOPAD(0x21d2, PIN_INPUT_PULLUP | MUX_MODE3) > /* mcspi1_cs2.sdmmc_clk */ > + >; > + }; > + mcbsp2_pins: pinmux_mcbsp2_pins { > + pinctrl-single,pins = < > + OMAP3_CORE1_IOPAD(0x213c, PIN_INPUT | MUX_MODE0) > /* mcbsp2_fsx */ > + OMAP3_CORE1_IOPAD(0x213e, PIN_INPUT | MUX_MODE0) > /* mcbsp2_clkx */ > + OMAP3_CORE1_IOPAD(0x2140, PIN_INPUT | MUX_MODE0) > /* mcbsp2_dr */ > + OMAP3_CORE1_IOPAD(0x2142, PIN_OUTPUT | MUX_MODE0) > /* mcbsp2_dx */ > + >; > + }; > + uart2_pins: pinmux_uart2_pins { > + pinctrl-single,pins = < > + OMAP3_CORE1_IOPAD(0x2174, PIN_INPUT | MUX_MODE0) > /* uart2_cts.uart2_cts */ > + OMAP3_CORE1_IOPAD(0x2176, PIN_OUTPUT | MUX_MODE0) > /* uart2_rts .uart2_rts*/ > + OMAP3_CORE1_IOPAD(0x2178, PIN_OUTPUT | MUX_MODE0) > /* uart2_tx.uart2_tx */ > + OMAP3_CORE1_IOPAD(0x217a, PIN_INPUT | MUX_MODE0) > /* uart2_rx.uart2_rx */ > + OMAP3_CORE1_IOPAD(0x2198, PIN_OUTPUT | MUX_MODE4) > /* GPIO_162,BT_EN */ > + >; > + }; > + mcspi1_pins: pinmux_mcspi1_pins { > + pinctrl-single,pins = < > + OMAP3_CORE1_IOPAD(0x21c8, PIN_INPUT | MUX_MODE0) > /* mcspi1_clk.mcspi1_clk */ > + OMAP3_CORE1_IOPAD(0x21ca, PIN_OUTPUT | MUX_MODE0) > /* mcspi1_simo.mcspi1_simo */ > + OMAP3_CORE1_IOPAD(0x21cc, PIN_INPUT_PULLUP | MUX_MODE0) > /* mcspi1_somi.mcspi1_somi */ > + OMAP3_CORE1_IOPAD(0x21ce, PIN_OUTPUT | MUX_MODE0) > /* mcspi1_cs0.mcspi1_cs0 */ > + >; > + }; > + > + hsusb2_pins: pinmux_hsusb2_pins { > + pinctrl-single,pins = < > + OMAP3_CORE1_IOPAD(0x21d4, PIN_INPUT_PULLDOWN | > MUX_MODE3) /* mcspi1_cs3.hsusb2_data2 */ > + OMAP3_CORE1_IOPAD(0x21d6, PIN_INPUT_PULLDOWN | > MUX_MODE3) /* mcspi2_clk.hsusb2_data7 */ > + OMAP3_CORE1_IOPAD(0x21d8, PIN_INPUT_PULLDOWN | > MUX_MODE3) /* mcspi2_simo.hsusb2_data4 */ > + OMAP3_CORE1_IOPAD(0x21da, PIN_INPUT_PULLDOWN | > MUX_MODE3) /* mcspi2_somi.hsusb2_data5 */ > + OMAP3_CORE1_IOPAD(0x21dc, PIN_INPUT_PULLDOWN | > MUX_MODE3) /* mcspi2_cs0.hsusb2_data6 */ > + OMAP3_CORE1_IOPAD(0x21de, PIN_INPUT_PULLDOWN | > MUX_MODE3) /* mcspi2_cs1.hsusb2_data3 */ > + >; > + }; > + > + hsusb_otg_pins: pinmux_hsusb_otg_pins { > + pinctrl-single,pins = < > + OMAP3_CORE1_IOPAD(0x21a2, PIN_INPUT | MUX_MODE0) > /* hsusb0_clk.hsusb0_clk */ > + OMAP3_CORE1_IOPAD(0x21a4, PIN_OUTPUT | MUX_MODE0) > /* hsusb0_stp.hsusb0_stp */ > + OMAP3_CORE1_IOPAD(0x21a6, PIN_INPUT | MUX_MODE0) > /* hsusb0_dir.hsusb0_dir */ > + OMAP3_CORE1_IOPAD(0x21a8, PIN_INPUT | MUX_MODE0) > /* hsusb0_nxt.hsusb0_nxt */ > + OMAP3_CORE1_IOPAD(0x21aa, PIN_INPUT | MUX_MODE0) > /* hsusb0_data0.hsusb0_data0 */ > + OMAP3_CORE1_IOPAD(0x21ac, PIN_INPUT | MUX_MODE0) > /* hsusb0_data1.hsusb0_data1 */ > + OMAP3_CORE1_IOPAD(0x21ae, PIN_INPUT | MUX_MODE0) > /* hsusb0_data2.hsusb0_data2 */ > + OMAP3_CORE1_IOPAD(0x21b0, PIN_INPUT | MUX_MODE0) > /* hsusb0_data3.hsusb0_data3 */ > + OMAP3_CORE1_IOPAD(0x21b2, PIN_INPUT | MUX_MODE0) > /* hsusb0_data4.hsusb0_data4 */ > + OMAP3_CORE1_IOPAD(0x21b4, PIN_INPUT | MUX_MODE0) > /* hsusb0_data5.hsusb0_data5 */ > + OMAP3_CORE1_IOPAD(0x21b6, PIN_INPUT | MUX_MODE0) > /* hsusb0_data6.hsusb0_data6 */ > + OMAP3_CORE1_IOPAD(0x21b8, PIN_INPUT | MUX_MODE0) > /* hsusb0_data7.hsusb0_data7 */ > + >; > + }; > + > + > +}; > + > +&omap3_pmx_wkup { > + pinctrl-names = "default"; > + pinctrl-0 = <&hsusb2_reset_pin>; > + hsusb2_reset_pin: pinmux_hsusb1_reset_pin { > + pinctrl-single,pins = < > + OMAP3_WKUP_IOPAD(0x2a0e, PIN_OUTPUT | MUX_MODE4) > /* sys_boot2.gpio_4 */ > + >; > + }; > +}; > + > +&omap3_pmx_core2 { > + pinctrl-names = "default"; > + pinctrl-0 = <&hsusb2_2_pins>; > + hsusb2_2_pins: pinmux_hsusb2_2_pins { > + pinctrl-single,pins = < > + OMAP3630_CORE2_IOPAD(0x25f0, PIN_OUTPUT | MUX_MODE3) > /* etk_d10.hsusb2_clk */ > + OMAP3630_CORE2_IOPAD(0x25f2, PIN_OUTPUT | MUX_MODE3) > /* etk_d11.hsusb2_stp */ > + OMAP3630_CORE2_IOPAD(0x25f4, PIN_INPUT_PULLDOWN | > MUX_MODE3) /* etk_d12.hsusb2_dir */ > + OMAP3630_CORE2_IOPAD(0x25f6, PIN_INPUT_PULLDOWN | > MUX_MODE3) /* etk_d13.hsusb2_nxt */ > + OMAP3630_CORE2_IOPAD(0x25f8, PIN_INPUT_PULLDOWN | > MUX_MODE3) /* etk_d14.hsusb2_data0 */ > + OMAP3630_CORE2_IOPAD(0x25fa, PIN_INPUT_PULLDOWN | > MUX_MODE3) /* etk_d15.hsusb2_data1 */ > + >; > + }; > +}; > + > +&uart2 { > + interrupts-extended = <&intc 73 &omap3_pmx_core OMAP3_UART2_RX>; > + pinctrl-names = "default"; > + pinctrl-0 = <&uart2_pins>; > +}; > + > +&mcspi1 { > + pinctrl-names = "default"; > + pinctrl-0 = <&mcspi1_pins>; > +}; > + > +#include "twl4030.dtsi" > +#include "twl4030_omap3.dtsi" > + > +&twl { > + twl_power: power { > + compatible = "ti,twl4030-power-idle-osc-off", > "ti,twl4030-power-idle"; > + ti,use_poweroff; > + }; > +}; > + > +&twl_gpio { > + ti,use-leds; > +}; > diff --git a/arch/arm/dts/logicpd-torpedo-37xx-devkit.dts > b/arch/arm/dts/logicpd-torpedo-37xx-devkit.dts > new file mode 100644 > index 0000000..b6838ce > --- /dev/null > +++ b/arch/arm/dts/logicpd-torpedo-37xx-devkit.dts > @@ -0,0 +1,412 @@ > +/* > + * 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. > + */ > + > +/dts-v1/; > + > +#include "omap36xx.dtsi" > +#include "logicpd-torpedo-som.dtsi" > +#include "omap-gpmc-smsc9221.dtsi" > + > +/ { > + model = "LogicPD Zoom DM3730 Torpedo + Wireless Development Kit"; > + compatible = "logicpd,dm3730-torpedo-devkit", "ti,omap3630", "ti,omap3"; > + > + chosen { > + stdout-path = &uart1; > + }; > + > + gpio_keys { > + compatible = "gpio-keys"; > + pinctrl-names = "default"; > + pinctrl-0 = <&gpio_key_pins &gpio_key_pins_wkup>; > + > + sysboot2 { > + label = "sysboot2"; > + gpios = <&gpio1 2 GPIO_ACTIVE_LOW>; /* gpio2 */ > + linux,code = <BTN_0>; > + wakeup-source; > + }; > + > + sysboot5 { > + label = "sysboot5"; > + gpios = <&gpio1 7 GPIO_ACTIVE_LOW>; /* gpio7 */ > + linux,code = <BTN_1>; > + wakeup-source; > + }; > + > + gpio1 { > + label = "gpio1"; > + gpios = <&gpio6 21 GPIO_ACTIVE_LOW>; /* gpio181 */ > + linux,code = <BTN_2>; > + wakeup-source; > + }; > + > + gpio2 { > + label = "gpio2"; > + gpios = <&gpio6 18 GPIO_ACTIVE_LOW>; /* gpio178 */ > + linux,code = <BTN_3>; > + wakeup-source; > + }; > + }; > + > + sound { > + compatible = "ti,omap-twl4030"; > + ti,model = "omap3logic"; > + ti,mcbsp = <&mcbsp2>; > + }; > + > + leds { > + compatible = "gpio-leds"; > + pinctrl-names = "default"; > + pinctrl-0 = <&led_pins>; > + > + led1 { > + label = "led1"; > + gpios = <&gpio6 20 GPIO_ACTIVE_HIGH>; /* gpio180 */ > + linux,default-trigger = "cpu0"; > + }; > + > + led2 { > + label = "led2"; > + gpios = <&gpio6 19 GPIO_ACTIVE_HIGH>; /* gpio179 */ > + linux,default-trigger = "none"; > + }; > + }; > + > + pwm10: dmtimer-pwm { > + compatible = "ti,omap-dmtimer-pwm"; > + pinctrl-names = "default"; > + pinctrl-0 = <&pwm_pins>; > + ti,timers = <&timer10>; > + #pwm-cells = <3>; > + }; > + > +}; > + > +&vaux1 { > + regulator-min-microvolt = <3000000>; > + regulator-max-microvolt = <3000000>; > +}; > + > +&vaux4 { > + regulator-min-microvolt = <1800000>; > + regulator-max-microvolt = <1800000>; > +}; > + > +&mcbsp2 { > + status = "okay"; > +}; > + > +&charger { > + ti,bb-uvolt = <3200000>; > + ti,bb-uamp = <150>; > +}; > + > +&gpmc { > + ranges = <0 0 0x30000000 0x1000000 /* CS0: 16MB for NAND */ > + 1 0 0x2c000000 0x1000000>; /* CS1: 16MB for LAN9221 */ > + > + ethernet@gpmc { > + pinctrl-names = "default"; > + pinctrl-0 = <&lan9221_pins>; > + interrupt-parent = <&gpio5>; > + interrupts = <1 IRQ_TYPE_LEVEL_LOW>; /* gpio129 */ > + reg = <1 0 0xff>; > + }; > +}; > + > +&vpll2 { > + regulator-always-on; > +}; > + > +&dss { > + status = "ok"; > + vdds_dsi-supply = <&vpll2>; > + vdda_video-supply = <&video_reg>; > + pinctrl-names = "default"; > + pinctrl-0 = <&dss_dpi_pins1>; > + port { > + dpi_out: endpoint { > + remote-endpoint = <&lcd_in>; > + data-lines = <16>; > + }; > + }; > +}; > + > +/ { > + aliases { > + display0 = &lcd0; > + }; > + > + video_reg: video_reg { > + pinctrl-names = "default"; > + pinctrl-0 = <&panel_pwr_pins>; > + compatible = "regulator-fixed"; > + regulator-name = "fixed-supply"; > + regulator-min-microvolt = <3300000>; > + regulator-max-microvolt = <3300000>; > + gpio = <&gpio5 27 GPIO_ACTIVE_HIGH>; /* gpio155, lcd INI */ > + }; > + > + lcd0: display { > + compatible = "panel-dpi"; > + label = "15"; > + status = "okay"; > + /* default-on; */ > + pinctrl-names = "default"; > + > + port { > + lcd_in: endpoint { > + remote-endpoint = <&dpi_out>; > + }; > + }; > + > + panel-timing { > + clock-frequency = <9000000>; > + hactive = <480>; > + vactive = <272>; > + hfront-porch = <3>; > + hback-porch = <2>; > + hsync-len = <42>; > + vback-porch = <3>; > + vfront-porch = <4>; > + vsync-len = <11>; > + hsync-active = <0>; > + vsync-active = <0>; > + de-active = <1>; > + pixelclk-active = <1>; > + }; > + }; > + > + bl: backlight { > + compatible = "pwm-backlight"; > + pinctrl-names = "default"; > + pinctrl-0 = <&backlight_pins>; > + pwms = <&pwm10 0 5000000 0>; > + brightness-levels = <0 10 20 30 40 50 60 70 80 90 100>; > + default-brightness-level = <7>; > + enable-gpios = <&gpio5 26 GPIO_ACTIVE_HIGH>; /* gpio_154 */ > + }; > +}; > + > +&mmc1 { > + interrupts-extended = <&intc 83 &omap3_pmx_core 0x11a>; > + pinctrl-names = "default"; > + pinctrl-0 = <&mmc1_pins &mmc1_cd>; > + cd-gpios = <&gpio4 31 IRQ_TYPE_LEVEL_LOW>; /* gpio127 */ > + vmmc-supply = <&vmmc1>; > + bus-width = <4>; > + cap-power-off-card; > +}; > + > +&mmc2 { > + status = "disabled"; > +}; > + > +&omap3_pmx_core { > + gpio_key_pins: pinmux_gpio_key_pins { > + pinctrl-single,pins = < > + OMAP3_CORE1_IOPAD(0x21d6, PIN_INPUT_PULLUP | MUX_MODE4) > /* mcspi2_clk.gpio_178 */ > + OMAP3_CORE1_IOPAD(0x21dc, PIN_INPUT_PULLUP | MUX_MODE4) > /* mcspi2_cs0.gpio_181 */ > + >; > + }; > + > + pwm_pins: pinmux_pwm_pins { > + pinctrl-single,pins = < > + OMAP3_CORE1_IOPAD(0x20B8, PIN_OUTPUT | > PIN_OFF_OUTPUT_LOW | MUX_MODE3) /* gpmc_ncs5.gpt_10_pwm_evt */ > + >; > + }; > + > + led_pins: pinmux_led_pins { > + pinctrl-single,pins = < > + OMAP3_CORE1_IOPAD(0x21d8, PIN_OUTPUT | MUX_MODE4) > /* gpio_179 */ > + OMAP3_CORE1_IOPAD(0x21da, PIN_OUTPUT | MUX_MODE4) > /* gpio_180 */ > + >; > + }; > + > + mmc1_pins: pinmux_mmc1_pins { > + pinctrl-single,pins = < > + OMAP3_CORE1_IOPAD(0x2144, PIN_OUTPUT | MUX_MODE0) > /* sdmmc1_clk.sdmmc1_clk */ > + OMAP3_CORE1_IOPAD(0x2146, PIN_INPUT | MUX_MODE0) > /* sdmmc1_cmd.sdmmc1_cmd */ > + OMAP3_CORE1_IOPAD(0x2148, PIN_INPUT | MUX_MODE0) > /* sdmmc1_dat0.sdmmc1_dat0 */ > + OMAP3_CORE1_IOPAD(0x214a, PIN_INPUT | MUX_MODE0) > /* sdmmc1_dat1.sdmmc1_dat1 */ > + OMAP3_CORE1_IOPAD(0x214c, PIN_INPUT | MUX_MODE0) > /* sdmmc1_dat2.sdmmc1_dat2 */ > + OMAP3_CORE1_IOPAD(0x214e, PIN_INPUT | MUX_MODE0) > /* sdmmc1_dat3.sdmmc1_dat3 */ > + >; > + }; > + > + tsc2004_pins: pinmux_tsc2004_pins { > + pinctrl-single,pins = < > + OMAP3_CORE1_IOPAD(0x2186, PIN_INPUT | MUX_MODE4) > /* mcbsp4_dr.gpio_153 */ > + >; > + }; > + > + backlight_pins: pinmux_backlight_pins { > + pinctrl-single,pins = < > + OMAP3_CORE1_IOPAD(0x2188, PIN_OUTPUT | > PIN_OFF_OUTPUT_LOW | MUX_MODE4) /* mcbsp4_dx.gpio_154 */ > + >; > + }; > + > + isp_pins: pinmux_isp_pins { > + pinctrl-single,pins = < > + OMAP3_CORE1_IOPAD(0x210c, PIN_INPUT | MUX_MODE0) /* > cam_hs.cam_hs */ > + OMAP3_CORE1_IOPAD(0x210e, PIN_INPUT | MUX_MODE0) /* > cam_vs.cam_vs */ > + OMAP3_CORE1_IOPAD(0x2110, PIN_INPUT | MUX_MODE0) /* > cam_xclka.cam_xclka */ > + OMAP3_CORE1_IOPAD(0x2112, PIN_INPUT | MUX_MODE0) /* > cam_pclk.cam_pclk */ > + > + OMAP3_CORE1_IOPAD(0x2114, PIN_INPUT | MUX_MODE0) /* > cam_d0.cam_d0 */ > + OMAP3_CORE1_IOPAD(0x2116, PIN_INPUT | MUX_MODE0) /* > cam_d1.cam_d1 */ > + OMAP3_CORE1_IOPAD(0x2118, PIN_INPUT | MUX_MODE0) /* > cam_d2.cam_d2 */ > + OMAP3_CORE1_IOPAD(0x211c, PIN_INPUT | MUX_MODE0) /* > cam_d3.cam_d3 */ > + OMAP3_CORE1_IOPAD(0x211e, PIN_INPUT | MUX_MODE0) /* > cam_d4.cam_d4 */ > + OMAP3_CORE1_IOPAD(0x2120, PIN_INPUT | MUX_MODE0) /* > cam_d5.cam_d5 */ > + OMAP3_CORE1_IOPAD(0x2122, PIN_INPUT | MUX_MODE0) /* > cam_d6.cam_d6 */ > + OMAP3_CORE1_IOPAD(0x2124, PIN_INPUT | MUX_MODE0) /* > cam_d7.cam_d7 */ > + >; > + }; > + > + panel_pwr_pins: pinmux_panel_pwr_pins { > + pinctrl-single,pins = < > + OMAP3_CORE1_IOPAD(0x218a, PIN_OUTPUT | > PIN_OFF_OUTPUT_LOW | MUX_MODE4) /* mcbsp4_fs.gpio_155 */ > + >; > + }; > + > + dss_dpi_pins1: pinmux_dss_dpi_pins1 { > + pinctrl-single,pins = < > + OMAP3_CORE1_IOPAD(0x20d4, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_pclk.dss_pclk */ > + OMAP3_CORE1_IOPAD(0x20d6, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_hsync.dss_hsync */ > + OMAP3_CORE1_IOPAD(0x20d8, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_vsync.dss_vsync */ > + OMAP3_CORE1_IOPAD(0x20da, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_acbias.dss_acbias */ > + > + OMAP3_CORE1_IOPAD(0x20e8, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_data6.dss_data6 */ > + OMAP3_CORE1_IOPAD(0x20ea, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_data7.dss_data7 */ > + OMAP3_CORE1_IOPAD(0x20ec, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_data8.dss_data8 */ > + OMAP3_CORE1_IOPAD(0x20ee, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_data9.dss_data9 */ > + OMAP3_CORE1_IOPAD(0x20f0, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_data10.dss_data10 */ > + OMAP3_CORE1_IOPAD(0x20f2, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_data11.dss_data11 */ > + OMAP3_CORE1_IOPAD(0x20f4, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_data12.dss_data12 */ > + OMAP3_CORE1_IOPAD(0x20f6, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_data13.dss_data13 */ > + OMAP3_CORE1_IOPAD(0x20f8, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_data14.dss_data14 */ > + OMAP3_CORE1_IOPAD(0x20fa, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_data15.dss_data15 */ > + OMAP3_CORE1_IOPAD(0x20fc, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_data16.dss_data16 */ > + OMAP3_CORE1_IOPAD(0x20fe, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE0) /* dss_data17.dss_data17 */ > + > + OMAP3_CORE1_IOPAD(0x2100, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE3) /* dss_data18.dss_data0 */ > + OMAP3_CORE1_IOPAD(0x2102, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE3) /* dss_data19.dss_data1 */ > + OMAP3_CORE1_IOPAD(0x2104, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE3) /* dss_data20.dss_data2 */ > + OMAP3_CORE1_IOPAD(0x2106, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE3) /* dss_data21.dss_data3 */ > + OMAP3_CORE1_IOPAD(0x2108, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE3) /* dss_data22.dss_data4 */ > + OMAP3_CORE1_IOPAD(0x210a, PIN_OUTPUT_PULLDOWN | > PIN_OFF_OUTPUT_LOW | MUX_MODE3) /* dss_data23.dss_data5 */ > + >; > + }; > +}; > + > +&omap3_pmx_wkup { > + gpio_key_pins_wkup: pinmux_gpio_key_pins_wkup { > + pinctrl-single,pins = < > + OMAP3_WKUP_IOPAD(0x2a0a, PIN_INPUT_PULLUP | MUX_MODE4) > /* sys_boot0.gpio_2 */ > + OMAP3_WKUP_IOPAD(0x2a14, PIN_INPUT_PULLUP | MUX_MODE4) > /* sys_boot5.gpio_7 */ > + >; > + }; > + > + lan9221_pins: pinmux_lan9221_pins { > + pinctrl-single,pins = < > + OMAP3_WKUP_IOPAD(0x2a5a, PIN_INPUT | MUX_MODE4) > /* reserved.gpio_129 */ > + >; > + }; > + > + mmc1_cd: pinmux_mmc1_cd { > + pinctrl-single,pins = < > + OMAP3_WKUP_IOPAD(0x2a54, PIN_INPUT_PULLUP | MUX_MODE4) > /* reserved.gpio_127 */ > + >; > + }; > +}; > + > +&i2c2 { > + mt9p031@48 { > + compatible = "aptina,mt9p031"; > + reg = <0x48>; > + clocks = <&isp 0>; > + vaa-supply = <&vaux4>; > + vdd-supply = <&vaux4>; > + vdd_io-supply = <&vaux4>; > + port { > + mt9p031_out: endpoint { > + input-clock-frequency = <24000000>; > + pixel-clock-frequency = <72000000>; > + remote-endpoint = <&ccdc_ep>; > + }; > + }; > + }; > +}; > + > +&i2c3 { > + touchscreen: tsc2004@48 { > + compatible = "ti,tsc2004"; > + reg = <0x48>; > + vio-supply = <&vaux1>; > + pinctrl-names = "default"; > + pinctrl-0 = <&tsc2004_pins>; > + interrupts-extended = <&gpio5 25 IRQ_TYPE_EDGE_RISING>; /* gpio > 153 */ > + > + touchscreen-fuzz-x = <4>; > + touchscreen-fuzz-y = <7>; > + touchscreen-fuzz-pressure = <2>; > + touchscreen-size-x = <4096>; > + touchscreen-size-y = <4096>; > + touchscreen-max-pressure = <2048>; > + > + ti,x-plate-ohms = <280>; > + ti,esd-recovery-timeout-ms = <8000>; > + }; > +}; > + > +&mcspi1 { > + at25@0 { > + compatible = "atmel,at25"; > + reg = <0>; > + spi-max-frequency = <5000000>; > + spi-cpha; > + spi-cpol; > + > + pagesize = <64>; > + size = <32768>; > + address-width = <16>; > + }; > +}; > + > +&isp { > + pinctrl-names = "default"; > + pinctrl-0 = <&isp_pins>; > + ports { > + port@0 { > + reg = <0>; > + ccdc_ep: endpoint { > + remote-endpoint = <&mt9p031_out>; > + bus-width = <8>; > + hsync-active = <1>; > + vsync-active = <1>; > + pclk-sample = <0>; > + }; > + }; > + }; > +}; > + > +&uart1 { > + interrupts-extended = <&intc 72 &omap3_pmx_core OMAP3_UART1_RX>; > +}; > + > +/* Wired to the tps65950 on the SOM, only the USB connector is on the devkit > */ > +&usb_otg_hs { > + pinctrl-names = "default"; > + pinctrl-0 = <&hsusb_otg_pins>; > + interface-type = <0>; > + usb-phy = <&usb2_phy>; > + phys = <&usb2_phy>; > + phy-names = "usb2-phy"; > + mode = <3>; > + power = <50>; > +}; > diff --git a/arch/arm/dts/logicpd-torpedo-som.dtsi > b/arch/arm/dts/logicpd-torpedo-som.dtsi > new file mode 100644 > index 0000000..23c9228 > --- /dev/null > +++ b/arch/arm/dts/logicpd-torpedo-som.dtsi > @@ -0,0 +1,217 @@ > +/* > + * 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 <dt-bindings/input/input.h> > + > +/ { > + cpus { > + cpu@0 { > + cpu0-supply = <&vcc>; > + }; > + }; > + > + memory@80000000 { > + device_type = "memory"; > + reg = <0x80000000 0>; > + }; > + > + leds { > + compatible = "gpio-leds"; > + user0 { > + label = "user0"; > + gpios = <&twl_gpio 18 GPIO_ACTIVE_LOW>; /* LEDA */ > + linux,default-trigger = "none"; > + }; > + }; > + > + wl12xx_vmmc: wl12xx_vmmc { > + compatible = "regulator-fixed"; > + regulator-name = "vwl1271"; > + regulator-min-microvolt = <1800000>; > + regulator-max-microvolt = <1800000>; > + gpio = <&gpio5 29 0>; /* gpio157 */ > + startup-delay-us = <70000>; > + enable-active-high; > + vin-supply = <&vmmc2>; > + }; > +}; > + > +&gpmc { > + ranges = <0 0 0x30000000 0x1000000>; /* CS0: 16MB for NAND */ > + > + nand@0,0 { > + compatible = "ti,omap2-nand"; > + reg = <0 0 4>; /* CS0, offset 0, IO size 4 */ > + interrupt-parent = <&gpmc>; > + interrupts = <0 IRQ_TYPE_NONE>, /* fifoevent */ > + <1 IRQ_TYPE_NONE>; /* termcount */ > + linux,mtd-name = "micron,mt29f4g16abbda3w"; > + nand-bus-width = <16>; > + ti,nand-ecc-opt = "bch8"; > + rb-gpios = <&gpmc 0 GPIO_ACTIVE_HIGH>; /* gpmc_wait0 */ > + gpmc,sync-clk-ps = <0>; > + gpmc,cs-on-ns = <0>; > + gpmc,cs-rd-off-ns = <44>; > + gpmc,cs-wr-off-ns = <44>; > + gpmc,adv-on-ns = <6>; > + gpmc,adv-rd-off-ns = <34>; > + gpmc,adv-wr-off-ns = <44>; > + gpmc,we-off-ns = <40>; > + gpmc,oe-off-ns = <54>; > + gpmc,access-ns = <64>; > + gpmc,rd-cycle-ns = <82>; > + gpmc,wr-cycle-ns = <82>; > + gpmc,wr-access-ns = <40>; > + gpmc,wr-data-mux-bus-ns = <0>; > + gpmc,device-width = <2>; > + #address-cells = <1>; > + #size-cells = <1>; > + }; > +}; > + > +&i2c1 { > + clock-frequency = <400000>; > + > + twl: twl@48 { > + reg = <0x48>; > + interrupts = <7>; /* SYS_NIRQ cascaded to intc */ > + interrupt-parent = <&intc>; > + twl_audio: audio { > + compatible = "ti,twl4030-audio"; > + codec { > + }; > + }; > + }; > +}; > + > +&i2c2 { > + clock-frequency = <400000>; > +}; > + > +&i2c3 { > + clock-frequency = <400000>; > + at24@50 { > + compatible = "at24,24c02"; > + readonly; > + reg = <0x50>; > + }; > +}; > + > +/* > + * Only found on the wireless SOM. For the SOM without wireless, the pins for > + * MMC3 can be routed with jumpers to the second MMC slot on the devkit and > + * gpio157 is not connected. So this should be OK to keep common for now, > + * probably device tree overlays is the way to go with the various SOM and > + * jumpering combinations for the long run. > + */ > +&mmc3 { > + interrupts-extended = <&intc 94 &omap3_pmx_core2 0x46>; > + pinctrl-0 = <&mmc3_pins &mmc3_core2_pins>; > + pinctrl-names = "default"; > + vmmc-supply = <&wl12xx_vmmc>; > + non-removable; > + bus-width = <4>; > + cap-power-off-card; > + #address-cells = <1>; > + #size-cells = <0>; > + wlcore: wlcore@2 { > + compatible = "ti,wl1283"; > + reg = <2>; > + interrupt-parent = <&gpio5>; > + interrupts = <24 IRQ_TYPE_LEVEL_HIGH>; /* gpio 152 */ > + ref-clock-frequency = <26000000>; > + tcxo-clock-frequency = <26000000>; > + }; > +}; > + > +&omap3_pmx_core { > + mmc3_pins: pinmux_mm3_pins { > + pinctrl-single,pins = < > + OMAP3_CORE1_IOPAD(0x2164, PIN_INPUT_PULLUP | MUX_MODE3) > /* sdmmc2_dat4.sdmmc3_dat0 */ > + OMAP3_CORE1_IOPAD(0x2166, PIN_INPUT_PULLUP | MUX_MODE3) > /* sdmmc2_dat5.sdmmc3_dat1 */ > + OMAP3_CORE1_IOPAD(0x2168, PIN_INPUT_PULLUP | MUX_MODE3) > /* sdmmc2_dat6.sdmmc3_dat2 */ > + OMAP3_CORE1_IOPAD(0x216a, PIN_INPUT_PULLUP | MUX_MODE3) > /* sdmmc2_dat6.sdmmc3_dat3 */ > + OMAP3_CORE1_IOPAD(0x2184, PIN_INPUT_PULLUP | MUX_MODE4) > /* mcbsp4_clkx.gpio_152 */ > + OMAP3_CORE1_IOPAD(0x218e, PIN_OUTPUT | MUX_MODE4) > /* mcbsp1_fsr.gpio_157 */ > + >; > + }; > + mcbsp2_pins: pinmux_mcbsp2_pins { > + pinctrl-single,pins = < > + OMAP3_CORE1_IOPAD(0x213c, PIN_INPUT | MUX_MODE0) > /* mcbsp2_fsx */ > + OMAP3_CORE1_IOPAD(0x213e, PIN_INPUT | MUX_MODE0) > /* mcbsp2_clkx */ > + OMAP3_CORE1_IOPAD(0x2140, PIN_INPUT | MUX_MODE0) > /* mcbsp2_dr */ > + OMAP3_CORE1_IOPAD(0x2142, PIN_OUTPUT | MUX_MODE0) > /* mcbsp2_dx */ > + >; > + }; > + uart2_pins: pinmux_uart2_pins { > + pinctrl-single,pins = < > + OMAP3_CORE1_IOPAD(0x2174, PIN_INPUT | MUX_MODE0) > /* uart2_cts.uart2_cts */ > + OMAP3_CORE1_IOPAD(0x2176, PIN_OUTPUT | MUX_MODE0) > /* uart2_rts .uart2_rts*/ > + OMAP3_CORE1_IOPAD(0x2178, PIN_OUTPUT | MUX_MODE0) > /* uart2_tx.uart2_tx */ > + OMAP3_CORE1_IOPAD(0x217a, PIN_INPUT | MUX_MODE0) > /* uart2_rx.uart2_rx */ > + OMAP3_CORE1_IOPAD(0x2198, PIN_OUTPUT | MUX_MODE4) > /* GPIO_162,BT_EN */ > + >; > + }; > + mcspi1_pins: pinmux_mcspi1_pins { > + pinctrl-single,pins = < > + OMAP3_CORE1_IOPAD(0x21c8, PIN_INPUT | MUX_MODE0) > /* mcspi1_clk.mcspi1_clk */ > + OMAP3_CORE1_IOPAD(0x21ca, PIN_OUTPUT | MUX_MODE0) > /* mcspi1_simo.mcspi1_simo */ > + OMAP3_CORE1_IOPAD(0x21cc, PIN_INPUT_PULLUP | MUX_MODE0) > /* mcspi1_somi.mcspi1_somi */ > + OMAP3_CORE1_IOPAD(0x21ce, PIN_OUTPUT | MUX_MODE0) > /* mcspi1_cs0.mcspi1_cs0 */ > + >; > + }; > + hsusb_otg_pins: pinmux_hsusb_otg_pins { > + pinctrl-single,pins = < > + OMAP3_CORE1_IOPAD(0x21a2, PIN_INPUT | MUX_MODE0) > /* hsusb0_clk.hsusb0_clk */ > + OMAP3_CORE1_IOPAD(0x21a4, PIN_OUTPUT | MUX_MODE0) > /* hsusb0_stp.hsusb0_stp */ > + OMAP3_CORE1_IOPAD(0x21a6, PIN_INPUT | MUX_MODE0) > /* hsusb0_dir.hsusb0_dir */ > + OMAP3_CORE1_IOPAD(0x21a8, PIN_INPUT | MUX_MODE0) > /* hsusb0_nxt.hsusb0_nxt */ > + > + OMAP3_CORE1_IOPAD(0x21aa, PIN_INPUT | MUX_MODE0) > /* hsusb0_data0.hsusb0_data0 */ > + OMAP3_CORE1_IOPAD(0x21ac, PIN_INPUT | MUX_MODE0) > /* hsusb0_data1.hsusb0_data1 */ > + OMAP3_CORE1_IOPAD(0x21ae, PIN_INPUT | MUX_MODE0) > /* hsusb0_data2.hsusb0_data2 */ > + OMAP3_CORE1_IOPAD(0x21b0, PIN_INPUT | MUX_MODE0) > /* hsusb0_data3.hsusb0_data3 */ > + OMAP3_CORE1_IOPAD(0x21b2, PIN_INPUT | MUX_MODE0) > /* hsusb0_data4.hsusb0_data4 */ > + OMAP3_CORE1_IOPAD(0x21b4, PIN_INPUT | MUX_MODE0) > /* hsusb0_data5.hsusb0_data5 */ > + OMAP3_CORE1_IOPAD(0x21b6, PIN_INPUT | MUX_MODE0) > /* hsusb0_data6.hsusb0_data6 */ > + OMAP3_CORE1_IOPAD(0x21b8, PIN_INPUT | MUX_MODE0) > /* hsusb0_data7.hsusb0_data7 */ > + >; > + }; > +}; > + > +&uart2 { > + interrupts-extended = <&intc 73 &omap3_pmx_core OMAP3_UART2_RX>; > + pinctrl-names = "default"; > + pinctrl-0 = <&uart2_pins>; > +}; > + > +&mcspi1 { > + pinctrl-names = "default"; > + pinctrl-0 = <&mcspi1_pins>; > +}; > + > +&omap3_pmx_core2 { > + mmc3_core2_pins: pinmux_mmc3_core2_pins { > + pinctrl-single,pins = < > + OMAP3630_CORE2_IOPAD(0x25d8, PIN_INPUT_PULLUP | > MUX_MODE2) /* etk_clk.sdmmc3_clk */ > + OMAP3630_CORE2_IOPAD(0x25da, PIN_INPUT_PULLUP | > MUX_MODE2) /* etk_ctl.sdmmc3_cmd */ > + >; > + }; > +}; > + > +#include "twl4030.dtsi" > +#include "twl4030_omap3.dtsi" > + > +&twl { > + twl_power: power { > + compatible = "ti,twl4030-power-idle-osc-off", > "ti,twl4030-power-idle"; > + ti,use_poweroff; > + }; > +}; > + > +&twl_gpio { > + ti,use-leds; > +}; > diff --git a/arch/arm/mach-omap2/omap3/Kconfig > b/arch/arm/mach-omap2/omap3/Kconfig > index 933fcba..a9d7e29 100644 > --- a/arch/arm/mach-omap2/omap3/Kconfig > +++ b/arch/arm/mach-omap2/omap3/Kconfig > @@ -67,7 +67,6 @@ config TARGET_MCX > > config TARGET_OMAP3_LOGIC > bool "OMAP3 Logic" > - select BOARD_LATE_INIT > select DM > select DM_SERIAL > select DM_GPIO > diff --git a/board/logicpd/omap3som/omap3logic.c > b/board/logicpd/omap3som/omap3logic.c > index 4ad496e..495bc73 100644 > --- a/board/logicpd/omap3som/omap3logic.c > +++ b/board/logicpd/omap3som/omap3logic.c > @@ -40,53 +40,6 @@ DECLARE_GLOBAL_DATA_PTR; > #define GPIO_IO_PWRDNZ (1 << 6) > #define PBIASLITEVMODE1 (1 << 8) > > -/* > - * two dimensional array of strucures containining board name and Linux > - * machine IDs; row it selected based on CPU column is slected based > - * on hsusb0_data5 pin having a pulldown resistor > - */ > - > -static const struct ns16550_platdata omap3logic_serial = { > - .base = OMAP34XX_UART1, > - .reg_shift = 2, > - .clock = V_NS16550_CLK, > - .fcr = UART_FCR_DEFVAL, > -}; > - > -U_BOOT_DEVICE(omap3logic_uart) = { > - "ns16550_serial", > - &omap3logic_serial > -}; > - > -static struct board_id { > - char *name; > - int machine_id; > - char *fdtfile; > -} boards[2][2] = { > - { > - { > - .name = "OMAP35xx SOM LV", > - .machine_id = MACH_TYPE_OMAP3530_LV_SOM, > - .fdtfile = "logicpd-som-lv-35xx-devkit.dtb", > - }, > - { > - .name = "OMAP35xx Torpedo", > - .machine_id = MACH_TYPE_OMAP3_TORPEDO, > - .fdtfile = "logicpd-torpedo-35xx-devkit.dtb", > - }, > - }, > - { > - { > - .name = "DM37xx SOM LV", > - .fdtfile = "logicpd-som-lv-37xx-devkit.dtb", > - }, > - { > - .name = "DM37xx Torpedo", > - .fdtfile = "logicpd-torpedo-37xx-devkit.dtb", > - }, > - }, > -}; > - > #ifdef CONFIG_SPL_OS_BOOT > int spl_start_uboot(void) > { > @@ -159,11 +112,6 @@ int misc_init_r(void) > } > > /* > - * BOARD_ID_GPIO - GPIO of pin with optional pulldown resistor on SOM LV > - */ > -#define BOARD_ID_GPIO 189 /* hsusb0_data5 pin */ > - > -/* > * Routine: board_init > * Description: Early hardware init. > */ > @@ -177,60 +125,6 @@ int board_init(void) > return 0; > } > > -#ifdef CONFIG_BOARD_LATE_INIT > -int board_late_init(void) > -{ > - struct board_id *board; > - unsigned int val; > - > - /* > - * To identify between a SOM LV and Torpedo module, > - * a pulldown resistor is on hsusb0_data5 for the SOM LV module. > - * Drive the pin (and let it soak), then read it back. > - * If the pin is still high its a Torpedo. If low its a SOM LV > - */ > - > - /* Mux hsusb0_data5 as a GPIO */ > - MUX_VAL(CP(HSUSB0_DATA5), (IEN | PTD | DIS | M4)); > - > - if (gpio_request(BOARD_ID_GPIO, "husb0_data5.gpio_189") == 0) { > - > - /* > - * Drive BOARD_ID_GPIO - the pulldown resistor on the SOM LV > - * will drain the voltage. > - */ > - gpio_direction_output(BOARD_ID_GPIO, 0); > - gpio_set_value(BOARD_ID_GPIO, 1); > - > - /* Let it soak for a bit */ > - sdelay(0x100); > - > - /* > - * Read state of BOARD_ID_GPIO as an input and if its set. > - * If so the board is a Torpedo > - */ > - gpio_direction_input(BOARD_ID_GPIO); > - val = gpio_get_value(BOARD_ID_GPIO); > - gpio_free(BOARD_ID_GPIO); > - > - board = &boards[!!(get_cpu_family() == CPU_OMAP36XX)][!!val]; > - printf("Board: %s\n", board->name); > - > - /* Set the machine_id passed to Linux */ > - if (board->machine_id) > - gd->bd->bi_arch_number = board->machine_id; > - > - /* If the user has not set fdtimage, set the default */ > - if (!getenv("fdtimage")) > - setenv("fdtimage", board->fdtfile); > - } > - > - /* restore hsusb0_data5 pin as hsusb0_data5 */ > - MUX_VAL(CP(HSUSB0_DATA5), (IEN | PTD | DIS | M0)); > - return 0; > -} > -#endif > - > #if defined(CONFIG_GENERIC_MMC) > int board_mmc_init(bd_t *bis) > { > @@ -598,3 +492,18 @@ void set_muxconf_regs(void) > MUX_VAL(CP(D2D_MBUSFLAG), (IEN | PTD | DIS | M0)); /*d2d_mbusflag*/ > MUX_VAL(CP(D2D_SBUSFLAG), (IEN | PTD | DIS | M0)); /*d2d_sbusflag*/ > } > + > +/* This is only needed until SPL gets OF support */ > +#ifdef CONFIG_SPL_BUILD > +static const struct ns16550_platdata omap3logic_serial = { > + .base = OMAP34XX_UART1, > + .reg_shift = 2, > + .clock = V_NS16550_CLK, > + .fcr = UART_FCR_DEFVAL, > +}; > + > +U_BOOT_DEVICE(omap3logic_uart) = { > + "ns16550_serial", > + &omap3logic_serial > +}; > +#endif > diff --git a/configs/omap3_logic_defconfig b/configs/omap3_logic_defconfig > index 89bf38f..13c996d 100644 > --- a/configs/omap3_logic_defconfig > +++ b/configs/omap3_logic_defconfig > @@ -3,6 +3,7 @@ CONFIG_OMAP34XX=y > CONFIG_SYS_MALLOC_F_LEN=0x2000 > CONFIG_TARGET_OMAP3_LOGIC=y > CONFIG_SPL_STACK_R_ADDR=0x82000000 > +CONFIG_DEFAULT_DEVICE_TREE="logicpd-torpedo-37xx-devkit" > CONFIG_SYS_EXTRA_OPTIONS="NAND" > CONFIG_SYS_CONSOLE_INFO_QUIET=y > CONFIG_VERSION_VARIABLE=y > @@ -36,6 +37,11 @@ CONFIG_CMD_FS_GENERIC=y > CONFIG_CMD_UBI=y > CONFIG_ISO_PARTITION=y > CONFIG_EFI_PARTITION=y > +CONFIG_OF_CONTROL=y > +# CONFIG_BLK is not set > +CONFIG_DM_I2C=y > +CONFIG_DM_MMC=y > +# CONFIG_DM_MMC_OPS is not set > CONFIG_MMC_OMAP_HS=y > CONFIG_MMC_OMAP36XX_PINS=y > CONFIG_SYS_NS16550=y > @@ -46,4 +52,3 @@ CONFIG_USB_GADGET_DOWNLOAD=y > CONFIG_G_DNL_MANUFACTURER="TI" > CONFIG_G_DNL_VENDOR_NUM=0x0451 > CONFIG_G_DNL_PRODUCT_NUM=0xd022 > -CONFIG_OF_LIBFDT=y > diff --git a/configs/omap3_logic_somlv_defconfig > b/configs/omap3_logic_somlv_defconfig > new file mode 100644 > index 0000000..2b1eeba > --- /dev/null > +++ b/configs/omap3_logic_somlv_defconfig > @@ -0,0 +1,54 @@ > +CONFIG_ARM=y > +CONFIG_OMAP34XX=y > +CONFIG_SYS_MALLOC_F_LEN=0x2000 > +CONFIG_TARGET_OMAP3_LOGIC=y > +CONFIG_SPL_STACK_R_ADDR=0x82000000 > +CONFIG_DEFAULT_DEVICE_TREE="logicpd-som-lv-37xx-devkit" > +CONFIG_SYS_EXTRA_OPTIONS="NAND" > +CONFIG_SYS_CONSOLE_INFO_QUIET=y > +CONFIG_VERSION_VARIABLE=y > +CONFIG_SPL=y > +CONFIG_SPL_SYS_MALLOC_SIMPLE=y > +CONFIG_SPL_STACK_R=y > +CONFIG_SPL_MTD_SUPPORT=y > +CONFIG_SPL_OS_BOOT=y > +CONFIG_HUSH_PARSER=y > +CONFIG_SYS_PROMPT="OMAP Logic # " > +CONFIG_CMD_BOOTZ=y > +# CONFIG_CMD_IMI is not set > +# CONFIG_CMD_IMLS is not set > +CONFIG_CMD_ASKENV=y > +# CONFIG_CMD_FLASH is not set > +CONFIG_CMD_MMC=y > +CONFIG_CMD_PART=y > +CONFIG_CMD_SPI=y > +CONFIG_CMD_I2C=y > +# CONFIG_CMD_FPGA is not set > +CONFIG_CMD_GPIO=y > +CONFIG_CMD_DHCP=y > +CONFIG_CMD_MII=y > +CONFIG_CMD_PING=y > +CONFIG_CMD_CACHE=y > +CONFIG_CMD_EXT2=y > +CONFIG_CMD_EXT4=y > +CONFIG_CMD_EXT4_WRITE=y > +CONFIG_CMD_FAT=y > +CONFIG_CMD_FS_GENERIC=y > +CONFIG_CMD_UBI=y > +CONFIG_ISO_PARTITION=y > +CONFIG_EFI_PARTITION=y > +CONFIG_OF_CONTROL=y > +# CONFIG_BLK is not set > +CONFIG_DM_I2C=y > +CONFIG_DM_MMC=y > +# CONFIG_DM_MMC_OPS is not set > +CONFIG_MMC_OMAP_HS=y > +CONFIG_MMC_OMAP36XX_PINS=y > +CONFIG_SYS_NS16550=y > +CONFIG_USB=y > +CONFIG_USB_MUSB_GADGET=y > +CONFIG_USB_GADGET=y > +CONFIG_USB_GADGET_DOWNLOAD=y > +CONFIG_G_DNL_MANUFACTURER="TI" > +CONFIG_G_DNL_VENDOR_NUM=0x0451 > +CONFIG_G_DNL_PRODUCT_NUM=0xd022 > diff --git a/include/configs/omap3_logic.h b/include/configs/omap3_logic.h > index 706175c..dde52e7 100644 > --- a/include/configs/omap3_logic.h > +++ b/include/configs/omap3_logic.h > @@ -17,6 +17,20 @@ > > #include <configs/ti_omap3_common.h> > > +#ifdef CONFIG_SPL_BUILD > +/* > + * Disable MMC DM for SPL build and can be re-enabled after adding > + * DM support in SPL > + */ > +#undef CONFIG_DM_MMC > +#undef OMAP_HSMMC_USE_GPIO > + > +/* select serial console configuration for SPL */ > +#undef CONFIG_CONS_INDEX > +#define CONFIG_CONS_INDEX 1 > +#define CONFIG_SYS_NS16550_COM1 OMAP34XX_UART1 > +#endif > + > /* > * We are only ever GP parts and will utilize all of the "downloaded image" > * area in SRAM which starts at 0x40200000 and ends at 0x4020FFFF (64KB) in > @@ -34,16 +48,10 @@ > /* Hardware drivers */ > > /* GPIO banks */ > -#define CONFIG_OMAP3_GPIO_6 /* GPIO160..191 is in GPIO bank 6 */ > +#define CONFIG_OMAP3_GPIO_4 /* GPIO 96..128 is in GPIO bank 4 */ > > #define CONFIG_USB_OMAP3 > > -/* select serial console configuration */ > -#undef CONFIG_CONS_INDEX > -#define CONFIG_CONS_INDEX 1 > -#define CONFIG_SYS_NS16550_COM1 OMAP34XX_UART1 > -#define CONFIG_SERIAL1 1 /* UART1 on OMAP Logic > boards */ > - > /* commands to include */ > #define CONFIG_CMD_NAND > #define CONFIG_CMD_MTDPARTS > @@ -52,8 +60,6 @@ > /* I2C */ > #define CONFIG_SYS_I2C_OMAP34XX > #define CONFIG_SYS_I2C_EEPROM_ADDR 0x50 /* EEPROM AT24C64 */ > -#define EXPANSION_EEPROM_I2C_BUS 2 /* I2C Bus for AT24C64 */ > -#define CONFIG_OMAP3_LOGIC_USE_NEW_PRODUCT_ID > > /* USB */ > #define CONFIG_USB_MUSB_OMAP2PLUS > @@ -138,6 +144,7 @@ > "fi; " \ > "else run defaultboot; fi\0" \ > "defaultboot=run mmcramboot\0" \ > + "fdtimage=" CONFIG_DEFAULT_DEVICE_TREE ".dtb\0" \ > "consoledevice=ttyO0\0" \ > "setconsole=setenv console ${consoledevice},${baudrate}n8\0" \ > "dump_bootargs=echo 'Bootargs: '; echo $bootargs\0" \ > _______________________________________________ U-Boot mailing list U-Boot@lists.denx.de https://lists.denx.de/listinfo/u-boot