Am Fri,  8 Nov 2024 20:04:35 +0000
schrieb Mithil Bavishi <bavishimit...@gmail.com>:

> Create common device tree for Samsung Espresso series devices
> 
> Let's create a common tree for all the variants first. Later we can
> device specific trees based on their screen sizes.
> 
> Signed-off-by: Mithil Bavishi <bavishimit...@gmail.com>
> ---
>  .../omap/omap4-samsung-espresso-common.dtsi   | 680 ++++++++++++++++++
>  1 file changed, 680 insertions(+)
>  create mode 100644 
> arch/arm/boot/dts/ti/omap/omap4-samsung-espresso-common.dtsi
> 
> diff --git a/arch/arm/boot/dts/ti/omap/omap4-samsung-espresso-common.dtsi 
> b/arch/arm/boot/dts/ti/omap/omap4-samsung-espresso-common.dtsi
> new file mode 100644
> index 000000000..62ff3f36c
> --- /dev/null
> +++ b/arch/arm/boot/dts/ti/omap/omap4-samsung-espresso-common.dtsi
> @@ -0,0 +1,680 @@
> +// SPDX-License-Identifier: (GPL-2.0 OR MIT)
> +/dts-v1/;
> +#include "dt-bindings/gpio/gpio.h"
> +#include <dt-bindings/interrupt-controller/irq.h>
> +#include <dt-bindings/input/input.h>
> +#include "omap443x.dtsi"
> +
> +/ {
> +     memory@80000000 {
> +             device_type = "memory";
> +             reg = <0x80000000 0x40000000>; /* 1 GB */
> +     };
> +
> +     reserved-memory {
> +             #address-cells = <1>;
> +             #size-cells = <1>;
> +             ranges;
> +
> +             ramoops_region@A0000000 {

s/_/-/ in node names please.
> +                     no-map;
> +                     reg = <0xA0000000 0x200000>;

If used for ramoops, then there should be a compatible = "ramoops"
see Documentation/devicetree/bindings/reserved-memory/ramoops.yaml
> +             };
> +
> +             continuous_splash: framebuffer@bef00000{
> +                     reg = <0xbef00000 (1024 * 600 * 4)>;
> +                     no-map;
> +             };
> +     };
> +
> +     chosen { 
> +             #address-cells = <1>;
> +             #size-cells = <1>;
> +             ranges;

hmm, no bus here, so no need for address/size-cells, rather specify
stdout-path, etc.

> +     };
> +
> +     i2c-gpio-5 {
> +             compatible = "i2c-gpio";
> +             sda-gpios = <&gpio4 2 (GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN)>;
> +             scl-gpios = <&gpio4 3 (GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN)>;
> +             i2c-gpio,delay-us = <10>;
> +             #address-cells = <1>;
> +             #size-cells = <0>;
hmm, no pinmux here? 
> +     };
> +
> +     i2c-gpio-6 {
> +             compatible = "i2c-gpio";
> +             sda-gpios = <&gpio3 2 (GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN)>;
> +             scl-gpios = <&gpio3 1 (GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN)>;
> +             i2c-gpio,delay-us = <10>;
> +             #address-cells = <1>;
> +             #size-cells = <0>;

same here
> +     };
> +
> +     i2c-gpio-7 {
> +             compatible = "i2c-gpio";
> +             sda-gpios = <&gpio2 30 (GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN)>;
> +             scl-gpios = <&gpio2 29 (GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN)>;
> +             i2c-gpio,delay-us = <3>;
> +             #address-cells = <1>;
> +             #size-cells = <0>;
> +
same here

> +             fuel-gauge@36 {
> +                     compatible = "maxim,max17042";
> +                     reg = <0x36>;
> +                     pinctrl-0 = <&fuel_alert_irq>;
> +                     pinctrl-names = "default";
> +                     interrupt-parent = <&gpio2>;
> +                     interrupts = <12 IRQ_TYPE_LEVEL_LOW>;
> +                     maxim,rsns-microohm = <10000>;
> +                     maxim,over-heat-temp = <500>;
> +                     maxim,dead-volt = <2500>;
> +                     maxim,over-volt = <4300>;
> +             };
> +     };
> +
> +     reg_espresso_wlan: regulator-espresso-wlan {
> +             pinctrl-names = "default";
> +             pinctrl-0 = <&wlanen_gpio>;
> +             compatible = "regulator-fixed";
> +             regulator-name = "espresso_wlan";
> +             regulator-max-microvolt = <2000000>;
> +             regulator-min-microvolt = <2000000>;
> +             gpio = <&gpio4 8 GPIO_ACTIVE_HIGH>; /* GPIO_104 */
> +             startup-delay-us = <70000>;
> +             regulator-always-on;
> +             enable-active-high;
> +     };
> +
> +     wlan_pwrseq: wlan-pwrseq {
> +             compatible = "mmc-pwrseq-simple";
> +             clocks = <&twl 0>;
> +             clock-names = "ext_clock";
> +     };
> +
> +     reg_espresso_internal: regulator-espresso-internal {
> +             compatible = "regulator-fixed";
> +             regulator-name = "eMMC_LDO";
> +             regulator-max-microvolt = <1800000>;
> +             regulator-min-microvolt = <1800000>;
> +             gpios = <&gpio2 21 GPIO_ACTIVE_HIGH>; /* GPIO_63 */
> +             startup-delay-us = <100000>;
> +             regulator-boot-on;
> +             regulator-always-on;
> +             enable-active-high;
> +     };
> +
> +     reg_espresso_external: regulator-espresso-external {
> +             compatible = "regulator-fixed";
> +             regulator-name = "vmmc1";
> +             regulator-max-microvolt = <2800000>;
> +             regulator-min-microvolt = <2800000>;
> +             gpios = <&gpio2 2 GPIO_ACTIVE_HIGH>; /* GPIO_34 */
> +             regulator-always-on;

hmm, we cannot turn sd card power off?

> +             enable-active-high;
> +     };
> +
> +     reg_touch_ldo_en: regulator-touch-ldo-en  {
> +             compatible = "regulator-fixed";
> +             regulator-name = "touch_ldo_en";
> +             regulator-max-microvolt = <2800000>;
> +             regulator-min-microvolt = <2800000>;
> +             gpios = <&gpio2 22 GPIO_ACTIVE_HIGH>; /* GPIO_54 */
> +             regulator-always-on;
> +             enable-active-high;
> +     };
> +
> +     gpio-keys {
> +             compatible = "gpio-keys";
> +             pinctrl-names = "default";
> +             pinctrl-0 = <&gpio_keys>;
> +
> +             power {

button or key-power

> +                     label = "power";
> +
> +                     gpios = <&gpio1 3 GPIO_ACTIVE_HIGH>; /* GPIO_wk3 */
> +                     linux,code = <KEY_POWER>;
> +                     wakeup-source;
> +             };
> +
> +             button-volup {
> +                     linux,code = <KEY_VOLUMEUP>;
> +                     label = "volume_up"; /* GPIO_wk30 */
> +                     gpios = <&gpio1 30 GPIO_ACTIVE_LOW>;
> +             };
> +
> +             button-voldown {
> +                     linux,code = <KEY_VOLUMEDOWN>;
> +                     label = "volume_down"; /* GPIO_wk8 */
> +                     gpios = <&gpio1 8 GPIO_ACTIVE_LOW>;
> +             };
> +     };
> +
> +     reg_lcd: regulator-lcd  {
> +             compatible = "regulator-fixed";
> +             regulator-name = "lcd_en";
> +             gpios = <&gpio5 7 GPIO_ACTIVE_HIGH>; /* GPIO_135 */
> +             regulator-max-microvolt = <3300000>;
> +             regulator-min-microvolt = <3300000>;
> +             enable-active-high;
> +             regulator-boot-on;
> +     };
> +
> +     pwm10: pwm-10 {
> +             pinctrl-names = "default";
> +             pinctrl-0 = <&pwm10_default>;
> +             compatible = "ti,omap-dmtimer-pwm";
> +             #pwm-cells = <3>;
> +             ti,timers = <&timer10>;
> +             ti,clock-source = <0x00>;
> +     };
> +
> +     lvds-encoder {
> +             compatible = "doestek,dtc34lm85am", "lvds-encoder";
> +             powerdown-gpios = <&gpio5 8 GPIO_ACTIVE_LOW>; /* GPIO_136 */
> +             power-supply = <&reg_lcd>;
> +             ports {
> +                     #address-cells = <1>;
> +                     #size-cells = <0>;
> +
> +                     port@0 {
> +                             reg = <0>;
> +                             bridge_in: endpoint {
> +                                     remote-endpoint = <&dpi_out>;
> +                             };
> +                     };
> +
> +                     port@1 {
> +                             reg = <1>;
> +                             bridge_out: endpoint {
> +                                     remote-endpoint = <&panel_in>;
> +                             };
> +                     };
> +             };
> +     };
> +
> +     vibrator {
> +             compatible = "gpio-vibrator";
> +             enable-gpios = <&gpio2 6 GPIO_ACTIVE_HIGH>; /* GPIO_38 */
> +             pinctrl-names = "default";
> +             pinctrl-0 = <&vibrator_default>;
> +     };
> +
> +     gp2a_shunt: current-sense-shunt {
> +             compatible = "current-sense-shunt";
> +             io-channels = <&gpadc 4>;
> +             shunt-resistor-micro-ohms = <24000000>; /* 24 ohms */
> +             #io-channel-cells = <0>;
> +     };
> +
> +     led-ir {
> +             compatible = "gpio-ir-tx";
> +             gpios = <&gpio2 27 GPIO_ACTIVE_HIGH>; /* GPIO_59 */
pinmux?

> +     };
> +};
> +
> +&omap4_pmx_wkup {

order node names alphabetically

> +     twl6030_wkup_pins: pinmux-twl6030-wkup-pins {
> +             pinctrl-single,pins = <
> +                     OMAP4_IOPAD(0x54, PIN_OUTPUT | MUX_MODE3)
> +                     /* fref_clk0_out.sys_drm_msecure */
> +             >;
> +     };
> +
This can come from twl6030_omap4.dtsi

> +     gpio_keys: gpio-keys-pins {
> +             pinctrl-single,pins = <
> +                     OMAP4_IOPAD(0x046, WAKEUP_EN | PIN_INPUT | MUX_MODE3)
> +                     /* sim_cd.gpio_wk3 - EXT_WAKEUP */
> +                     OMAP4_IOPAD(0x056, WAKEUP_EN | PIN_INPUT | MUX_MODE3)
> +                     /* fref_clk3_req.gpio_wk30 - VOL_UP */
> +                     OMAP4_IOPAD(0x05C, WAKEUP_EN | PIN_INPUT | MUX_MODE3)
> +                     /* fref_clk4_out.gpio_wk8 - VOL_DN */
> +             >;
> +     };
> +
> +     prox_irq: prox-irq-pins {
> +             pinctrl-single,pins = <
> +                     OMAP4_IOPAD(0x042, WAKEUP_EN | PIN_INPUT_PULLUP | 
> MUX_MODE3)
> +                     /* sim_clk.gpio_wk1 - PS_VOUT */
> +             >;
> +     };
> +};
> +
> +&omap4_pmx_core {

order node names alphabetically

> +     pwm10_default: pinmux-pwm10-pins {
> +             pinctrl-single,pins = <
> +                     OMAP4_IOPAD(0X0D6, PIN_OUTPUT | PIN_OFF_OUTPUT_LOW | 
> MUX_MODE1)
> +                     /* usbb1_ulpitll_dat6.dmtimer10_pwm_evt - 
> LED_BACKLIGHT_PWM */
> +             >;
> +     };
> +
> +     backlight_pins: pinmux-backlight-pins {
> +             pinctrl-single,pins = <
> +                     OMAP4_IOPAD(0X0D8, PIN_OUTPUT | PIN_OFF_OUTPUT_LOW | 
> MUX_MODE3)
> +                     /* usbb1_ulpitll_dat7.gpio_95 - LED_BACKLIGHT_RESET */
> +             >;
> +     };
> +
> +     lvds_pins: pinmux-lvds-pins {
> +             pinctrl-single,pins = <
> +                     OMAP4_IOPAD(0X136, PIN_OUTPUT | MUX_MODE3)
> +                     /* mcspi1_simo.gpio_136 - LVDS_nSHDN */
> +             >;
> +     };
> +
> +     i2c1_pins: pinmux-i2c1-pins {
> +             pinctrl-single,pins = <
> +                     OMAP4_IOPAD(0x122, PIN_INPUT_PULLUP | MUX_MODE0)        
> /* i2c1_scl */
> +                     OMAP4_IOPAD(0x124, PIN_INPUT_PULLUP | MUX_MODE0)        
> /* i2c1_sda */
> +             >;
> +     };
> +
> +     i2c2_pins: pinmux-i2c2-pins {
> +             pinctrl-single,pins = <
> +                     OMAP4_IOPAD(0x126, PIN_INPUT_PULLUP | MUX_MODE0)        
> /* i2c2_scl */
> +                     OMAP4_IOPAD(0x128, PIN_INPUT_PULLUP | MUX_MODE0)        
> /* i2c2_sda */
> +             >;
> +     };
> +
> +     i2c3_pins: pinmux-i2c3-pins {
> +             pinctrl-single,pins = <
> +                     OMAP4_IOPAD(0x12a, PIN_INPUT_PULLUP | MUX_MODE0)        
> /* i2c3_scl */
> +                     OMAP4_IOPAD(0x12c, PIN_INPUT_PULLUP | MUX_MODE0)        
> /* i2c3_sda */
> +             >;
> +     };
> +
> +     i2c4_pins: pinmux-i2c4-pins {
> +             pinctrl-single,pins = <
> +                     OMAP4_IOPAD(0x12e, PIN_INPUT_PULLUP | MUX_MODE0)        
> /* i2c4_scl */
> +                     OMAP4_IOPAD(0x130, PIN_INPUT_PULLUP | MUX_MODE0)        
> /* i2c4_sda */
> +             >;
> +     };
> +
> +     mmc2_pins: pinmux-mmc2-pins {
> +             pinctrl-single,pins = <
> +                     OMAP4_IOPAD(0x040, PIN_INPUT_PULLUP | MUX_MODE1)        
> /* sdmmc2_dat0 */
> +                     OMAP4_IOPAD(0x042, PIN_INPUT_PULLUP | MUX_MODE1)        
> /* sdmmc2_dat1 */
> +                     OMAP4_IOPAD(0x044, PIN_INPUT_PULLUP | MUX_MODE1)        
> /* sdmmc2_dat2 */
> +                     OMAP4_IOPAD(0x046, PIN_INPUT_PULLUP | MUX_MODE1)        
> /* sdmmc2_dat3 */
> +                     OMAP4_IOPAD(0x048, PIN_INPUT_PULLUP | MUX_MODE1)        
> /* sdmmc2_dat4 */
> +                     OMAP4_IOPAD(0x04a, PIN_INPUT_PULLUP | MUX_MODE1)        
> /* sdmmc2_dat5 */
> +                     OMAP4_IOPAD(0x04c, PIN_INPUT_PULLUP | MUX_MODE1)        
> /* sdmmc2_dat6 */
> +                     OMAP4_IOPAD(0x04e, PIN_INPUT_PULLUP | MUX_MODE1)        
> /* sdmmc2_dat7 */
> +                     OMAP4_IOPAD(0x082, PIN_INPUT_PULLUP | MUX_MODE1)        
> /* sdmmc2_clk */
> +                     OMAP4_IOPAD(0x084, PIN_INPUT_PULLUP | MUX_MODE1)        
> /* sdmmc2_cmd */
> +             >;
> +     };
> +
> +     mmc1_pins: pinmux-mmc1-pins {
> +             pinctrl-single,pins = <
> +                     OMAP4_IOPAD(0x0e2, PIN_INPUT_PULLDOWN | MUX_MODE0)      
> /* sdmmc1_clk */
> +                     OMAP4_IOPAD(0x0e4, PIN_INPUT_PULLUP | MUX_MODE0)        
> /* sdmcc1_cmd */
> +                     OMAP4_IOPAD(0x0e6, PIN_INPUT_PULLUP | MUX_MODE0)        
> /* sdmcc1_dat0 */
> +                     OMAP4_IOPAD(0x0e8, PIN_INPUT_PULLUP | MUX_MODE0)        
> /* sdmmc1_dat1 */
> +                     OMAP4_IOPAD(0x0ea, PIN_INPUT_PULLUP | MUX_MODE0)        
> /* sdmmc1_dat2 */
> +                     OMAP4_IOPAD(0x0ec, PIN_INPUT_PULLUP | MUX_MODE0)        
> /* sdmmc1_dat3 */
> +             >;
> +     };
> +
> +     mmc5_pins: pinmux-mmc5-pins {
> +             pinctrl-single,pins = <
> +                     OMAP4_IOPAD(0x148, PIN_INPUT_PULLDOWN | MUX_MODE0)
> +                     /* sdmmc5_clk.sdmmc5_clk */
> +                     OMAP4_IOPAD(0x14a, PIN_INPUT_PULLUP | MUX_MODE0)
> +                     /* sdmmc5_cmd.sdmmc5_cmd */
> +                     OMAP4_IOPAD(0x14c, PIN_INPUT_PULLUP | MUX_MODE0)
> +                     /* sdmmc5_dat0.sdmmc5_dat0 */
> +                     OMAP4_IOPAD(0x14e, PIN_INPUT_PULLUP | MUX_MODE0)
> +                     /* sdmmc5_dat1.sdmmc5_dat1 */
> +                     OMAP4_IOPAD(0x150, PIN_INPUT_PULLUP | MUX_MODE0)
> +                     /* sdmmc5_dat2.sdmmc5_dat2 */
> +                     OMAP4_IOPAD(0x152, PIN_INPUT_PULLUP | MUX_MODE0)
> +                     /* sdmmc5_dat3.sdmmc5_dat3 */
> +             >;
> +     };
> +
> +     dss_dpi_pins: pinmux-dss-dpi-pins {
> +             pinctrl-single,pins = <
> +                     OMAP4_IOPAD(0x162, PIN_OFF_OUTPUT_LOW | MUX_MODE5)      
> /* dispc2_data23 */
> +                     OMAP4_IOPAD(0x164, PIN_OFF_OUTPUT_LOW | MUX_MODE5)      
> /* dispc2_data22 */
> +                     OMAP4_IOPAD(0x166, PIN_OFF_OUTPUT_LOW | MUX_MODE5)      
> /* dispc2_data21 */
> +                     OMAP4_IOPAD(0x168, PIN_OFF_OUTPUT_LOW | MUX_MODE5)      
> /* dispc2_data20 */
> +                     OMAP4_IOPAD(0x16a, PIN_OFF_OUTPUT_LOW | MUX_MODE5)      
> /* dispc2_data19 */
> +                     OMAP4_IOPAD(0x16c, PIN_OFF_OUTPUT_LOW | MUX_MODE5)      
> /* dispc2_data18 */
> +                     OMAP4_IOPAD(0x16e, PIN_OFF_OUTPUT_LOW | MUX_MODE5)      
> /* dispc2_data15 */
> +                     OMAP4_IOPAD(0x170, PIN_OFF_OUTPUT_LOW | MUX_MODE5)      
> /* dispc2_data14 */
> +                     OMAP4_IOPAD(0x172, PIN_OFF_OUTPUT_LOW | MUX_MODE5)      
> /* dispc2_data13 */
> +                     OMAP4_IOPAD(0x174, PIN_OFF_OUTPUT_LOW | MUX_MODE5)      
> /* dispc2_data12 */
> +                     OMAP4_IOPAD(0x176, PIN_OFF_OUTPUT_LOW | MUX_MODE5)      
> /* dispc2_data11 */
> +
> +                     OMAP4_IOPAD(0x1b4, PIN_OFF_OUTPUT_LOW | MUX_MODE5)      
> /* dispc2_data10 */
> +                     OMAP4_IOPAD(0x1b6, PIN_OFF_OUTPUT_LOW | MUX_MODE5)      
> /* dispc2_data9 */
> +                     OMAP4_IOPAD(0x1b8, PIN_OFF_OUTPUT_LOW | MUX_MODE5)      
> /* dispc2_data16 */
> +                     OMAP4_IOPAD(0x1ba, PIN_OFF_OUTPUT_LOW | MUX_MODE5)      
> /* dispc2_data17 */
> +                     OMAP4_IOPAD(0x1bc, PIN_OFF_OUTPUT_LOW | MUX_MODE5)      
> /* dispc2_hsync */
> +                     OMAP4_IOPAD(0x1be, PIN_OFF_OUTPUT_LOW | MUX_MODE5)      
> /* dispc2_pclk */
> +                     OMAP4_IOPAD(0x1c0, PIN_OFF_OUTPUT_LOW | MUX_MODE5)      
> /* dispc2_vsync */
> +                     OMAP4_IOPAD(0x1c2, PIN_OFF_OUTPUT_LOW | MUX_MODE5)      
> /* dispc2_de */
> +                     OMAP4_IOPAD(0x1c4, PIN_OFF_OUTPUT_LOW | MUX_MODE5)      
> /* dispc2_data8 */
> +                     OMAP4_IOPAD(0x1c6, PIN_OFF_OUTPUT_LOW | MUX_MODE5)      
> /* dispc2_data7 */
> +                     OMAP4_IOPAD(0x1c8, PIN_OFF_OUTPUT_LOW | MUX_MODE5)      
> /* dispc2_data6 */
> +                     OMAP4_IOPAD(0x1ca, PIN_OFF_OUTPUT_LOW | MUX_MODE5)      
> /* dispc2_data5 */
> +                     OMAP4_IOPAD(0x1cc, PIN_OFF_OUTPUT_LOW | MUX_MODE5)      
> /* dispc2_data4 */
> +                     OMAP4_IOPAD(0x1ce, PIN_OFF_OUTPUT_LOW | MUX_MODE5)      
> /* dispc2_data3 */
> +
> +                     OMAP4_IOPAD(0x1d0, PIN_OFF_OUTPUT_LOW | MUX_MODE5)      
> /* dispc2_data2 */
> +                     OMAP4_IOPAD(0x1d2, PIN_OFF_OUTPUT_LOW | MUX_MODE5)      
> /* dispc2_data1 */
> +                     OMAP4_IOPAD(0x1d4, PIN_OFF_OUTPUT_LOW | MUX_MODE5)      
> /* dispc2_data0 */
> +             >;
> +     };
> +
> +     wlanen_gpio: pinmux-wlanen-pins {
> +             pinctrl-single,pins = <
> +                     OMAP4_IOPAD(0x096, PIN_OUTPUT | MUX_MODE3)      /* 
> gpmc_ncs7.gpio_104 */
> +             >;
> +     };
> +
> +     twl6030_pins: pinmux-twl6030-pins {
> +             pinctrl-single,pins = <
> +                     OMAP4_IOPAD(0x19e, WAKEUP_EN | PIN_INPUT_PULLUP | 
> MUX_MODE0)
> +                     /* sys_nirq1.sys_nirq1 */
> +             >;
> +     };

you can simply include twl6030_omap4.dtsi describing recommended
connection between omap4 SoCs and twl603X pmics.

> +
> +     fuel_alert_irq: pinmux-fuel-alert-pins {
> +             pinctrl-single,pins = <
> +                     OMAP4_IOPAD(0x068, WAKEUP_EN | PIN_INPUT_PULLUP | 
> MUX_MODE3)
> +                     /* gpmc_a20.gpio_44 */
> +             >;
> +     };
> +
> +     uart3_pins: pinmux-uart3-pins {
> +             pinctrl-single,pins = <
> +                     OMAP4_IOPAD(0x144, PIN_INPUT | MUX_MODE0)       /* 
> uart3_rx_irrx */
> +                     OMAP4_IOPAD(0x146, PIN_OUTPUT | MUX_MODE0)      /* 
> uart3_tx_irtx */
> +             >;
> +     };
> +
> +     uart2_pins: pinmux-uart2-pins {
> +             pinctrl-single,pins = <
> +                     OMAP4_IOPAD(0x118, PIN_INPUT_PULLUP | MUX_MODE0)
> +                     /* uart2_cts.uart2_cts */
> +                     OMAP4_IOPAD(0x11a, PIN_INPUT_PULLUP | MUX_MODE0)
> +                     /* uart2_rts.uart2_rts */
> +                     OMAP4_IOPAD(0x11c, PIN_INPUT_PULLUP | MUX_MODE0)
> +                     /* uart2_rx.uart2_rx */
> +                     OMAP4_IOPAD(0x11e, PIN_INPUT_PULLUP | MUX_MODE0)
> +                     /* uart2_tx.uart2_tx */
> +             >;
> +     };
> +
> +     wlan_host_wake: pinmux-wlan-host-wake-pins {
> +             pinctrl-single,pins = <
> +                     OMAP4_IOPAD(0x0bc, WAKEUP_EN | PIN_INPUT | MUX_MODE3)
> +                     /* cam_shutter.gpio_81 - WLAN_HOST_WAKE */

It might be an idea to use a dedicated wakeup irq instead of
explicitely specifying WAKEUP_EN like you did for the uart.
That counts for other occurances of WAKEUP_EN as well.
> +             >;
> +     };
> +
> +     bluetooth_pins: pinmux-bluetooth-pins {
> +             pinctrl-single,pins = <
> +                     OMAP4_IOPAD(0x094, PIN_OUTPUT | MUX_MODE3)
> +                     /* gpmc_ncs6.gpio_103 - BT_EN */
> +                     OMAP4_IOPAD(0x0be, PIN_OUTPUT | MUX_MODE3)
> +                     /* cam_strobe.gpio_82 - BT_nRST */
> +                     OMAP4_IOPAD(0x0c0, WAKEUP_EN | PIN_INPUT | MUX_MODE3)
> +                     /* cam_globalreset.gpio_83 - BT_HOST_WAKE */
> +                     OMAP4_IOPAD(0x0d4, PIN_OUTPUT | MUX_MODE3)
> +                     /* usbb1_ulpitll_dat5.gpio_93 - BT_WAKE */
> +             >;
> +     };
> +
> +     touch_pins: pinmux-touch-pins {
> +             pinctrl-single,pins = <
> +                     OMAP4_IOPAD(0x06c, PIN_INPUT | MUX_MODE3)
> +                     /* gpmc_a22.gpio_46 - TSP_INT */
> +             >;
> +     };
> +
> +     vibrator_default: pinmux-vibrator-pins {
> +             pinctrl-single,pins = <
> +                     OMAP4_IOPAD(0x05c, PIN_INPUT_PULLDOWN | MUX_MODE3)
> +                     /* gpmc_ad14.gpio_38 - MOTOR_EN */
> +             >;
> +     };
> +
> +     gp2a_irq: pinmux-gp2a-irq-pins {
> +             pinctrl-single,pins = <
> +                     OMAP4_IOPAD(0x052, WAKEUP_EN | PIN_INPUT | MUX_MODE3)
> +                     /* gpmc_ad9.gpio_33 - ALS_INT_18 */
> +             >;
> +     };
> +};
> +
> +&uart3 {
> +     pinctrl-names = "default";
> +     pinctrl-0 = <&uart3_pins>;
> +
> +     interrupts-extended = <&wakeupgen GIC_SPI 74 IRQ_TYPE_LEVEL_HIGH
> +                            &omap4_pmx_core OMAP4_UART3_RX>;
> +};
> +
> +&i2c1 {
> +     pinctrl-names = "default";
> +     pinctrl-0 = <&i2c1_pins>;
> +
> +     clock-frequency = <400000>;
> +
> +     twl: twl@48 {

generic node names:
pmic@48
yes, there are a lot of bad examples in the tree people (including me!)
keep copying from, but lets not create new bad examples.

> +             reg = <0x48>;
> +             #clock-cells = <1>;
> +
> +             pinctrl-names = "default";
> +             pinctrl-0 = <
> +                     &twl6030_pins
> +                     &twl6030_wkup_pins
> +             >;
> +
> +             /* SPI = 0, IRQ# = 7, 4 = active high level-sensitive */
> +             interrupts = <GIC_SPI 7 IRQ_TYPE_LEVEL_HIGH>; /* IRQ_SYS_1N 
> cascaded to gic */
> +             interrupt-parent = <&gic>;
> +             system-power-controller;
> +     };
> +};
> +
> +#include "twl6032.dtsi"
> +
> +&ldo1 {
> +     regulator-min-microvolt = <2800000>;
> +     regulator-max-microvolt = <2800000>;
> +     regulator-always-on;
> +     regulator-state-mem {
> +             regulator-off-in-suspend;
> +     };
> +};
> +
> +&ldo3 {
> +     regulator-min-microvolt = <3300000>;
> +     regulator-max-microvolt = <3300000>;
> +     regulator-always-on;
> +     regulator-state-mem {
> +             regulator-off-in-suspend;
> +     };
> +};
> +
> +&ldo4 {
> +     regulator-min-microvolt = <2800000>;
> +     regulator-max-microvolt = <2800000>;
> +     regulator-always-on;
> +};
> +
> +&ldo5 {
> +     regulator-min-microvolt = <1800000>;
> +     regulator-max-microvolt = <1800000>;
> +     regulator-always-on;
> +};
> +
> +&ldo6 {
> +     regulator-min-microvolt = <1800000>;
> +     regulator-max-microvolt = <1800000>;
> +     regulator-always-on;
> +     regulator-state-mem {
> +             regulator-off-in-suspend;
> +     };
> +};
> +
> +&smps4 {
> +     regulator-min-microvolt = <1800000>;
> +     regulator-max-microvolt = <1800000>;
> +     regulator-always-on;
> +};
> +
> +&ldousb {
> +     regulator-min-microvolt = <3300000>;
> +     regulator-max-microvolt = <3300000>;
> +     regulator-always-on;
> +};
> +
> +&i2c2 {
> +     pinctrl-names = "default";
> +     pinctrl-0 = <&i2c2_pins>;
> +};
> +
> +&i2c3 {
> +     pinctrl-names = "default";
> +     pinctrl-0 = <&i2c3_pins>;
> +};
> +
> +&i2c4 {
> +     pinctrl-names = "default";
> +     pinctrl-0 = <&i2c4_pins>;
> +
> +     accelerometer@18 {
> +             compatible = "bosch,bma254";
> +             reg = <0x18>;
> +             vdd-supply = <&ldo4>;
> +             vddio-supply = <&ldo5>;
> +             interrupt-parent = <&gpio4>;
> +             interrupts = <25 (IRQ_TYPE_LEVEL_HIGH | IRQ_TYPE_EDGE_RISING)>,
> +                     <26 (IRQ_TYPE_LEVEL_HIGH | IRQ_TYPE_EDGE_RISING)>;

this looks odd, binding says IRQ_TYPE_EDGE_RISING. Why do you think you
need both? After something is rising, it is high, so both seem not to
make sense.

> +             mount-matrix =  "-1",  "0",  "0",
> +                             "0",  "1",  "0",
> +                             "0",  "0", "1";

hmm, checking twice, since I mixed up something earlier. This just
inverts x values, so we are mirroring across y-z plane, that does not
look like a rotation matrix, so it does not describe how it is mounted.
Eg. the n900 has two -1 in there, that is a turn by 180 degree.

Your mount-matrix would be achieved, by cutting the chip into ultra
thin slices, sorting them upside down and glueing that together. I
doubt somebody does that.

Regards,
Andreas

Reply via email to