| // SPDX-License-Identifier: (GPL-2.0+ OR BSD-3-Clause) |
| /* |
| * Copyright (C) STMicroelectronics 2017 - All Rights Reserved |
| * Author: Ludovic Barre <ludovic.barre@st.com> for STMicroelectronics. |
| */ |
| /dts-v1/; |
| |
| #include "stm32mp157c-ed1.dts" |
| #include <dt-bindings/gpio/gpio.h> |
| #include <dt-bindings/input/input.h> |
| |
| / { |
| model = "STMicroelectronics STM32MP157C eval daughter on eval mother"; |
| compatible = "st,stm32mp157c-ev1", "st,stm32mp157c-ed1", "st,stm32mp157"; |
| |
| chosen { |
| stdout-path = "serial0:115200n8"; |
| }; |
| |
| aliases { |
| serial0 = &uart4; |
| ethernet0 = ðernet0; |
| }; |
| |
| clocks { |
| clk_ext_camera: clk-ext-camera { |
| #clock-cells = <0>; |
| compatible = "fixed-clock"; |
| clock-frequency = <24000000>; |
| }; |
| }; |
| |
| joystick { |
| compatible = "gpio-keys"; |
| #size-cells = <0>; |
| pinctrl-0 = <&joystick_pins>; |
| pinctrl-names = "default"; |
| button-0 { |
| label = "JoySel"; |
| linux,code = <KEY_ENTER>; |
| interrupt-parent = <&stmfx_pinctrl>; |
| interrupts = <0 IRQ_TYPE_EDGE_RISING>; |
| }; |
| button-1 { |
| label = "JoyDown"; |
| linux,code = <KEY_DOWN>; |
| interrupt-parent = <&stmfx_pinctrl>; |
| interrupts = <1 IRQ_TYPE_EDGE_RISING>; |
| }; |
| button-2 { |
| label = "JoyLeft"; |
| linux,code = <KEY_LEFT>; |
| interrupt-parent = <&stmfx_pinctrl>; |
| interrupts = <2 IRQ_TYPE_EDGE_RISING>; |
| }; |
| button-3 { |
| label = "JoyRight"; |
| linux,code = <KEY_RIGHT>; |
| interrupt-parent = <&stmfx_pinctrl>; |
| interrupts = <3 IRQ_TYPE_EDGE_RISING>; |
| }; |
| button-4 { |
| label = "JoyUp"; |
| linux,code = <KEY_UP>; |
| interrupt-parent = <&stmfx_pinctrl>; |
| interrupts = <4 IRQ_TYPE_EDGE_RISING>; |
| }; |
| }; |
| |
| panel_backlight: panel-backlight { |
| compatible = "gpio-backlight"; |
| gpios = <&gpiod 13 GPIO_ACTIVE_LOW>; |
| default-on; |
| status = "okay"; |
| }; |
| }; |
| |
| &cec { |
| pinctrl-names = "default"; |
| pinctrl-0 = <&cec_pins_a>; |
| status = "okay"; |
| }; |
| |
| &dcmi { |
| status = "okay"; |
| pinctrl-names = "default", "sleep"; |
| pinctrl-0 = <&dcmi_pins_a>; |
| pinctrl-1 = <&dcmi_sleep_pins_a>; |
| |
| port { |
| dcmi_0: endpoint { |
| remote-endpoint = <&ov5640_0>; |
| bus-width = <8>; |
| hsync-active = <0>; |
| vsync-active = <0>; |
| pclk-sample = <1>; |
| }; |
| }; |
| }; |
| |
| &dsi { |
| #address-cells = <1>; |
| #size-cells = <0>; |
| status = "okay"; |
| |
| ports { |
| #address-cells = <1>; |
| #size-cells = <0>; |
| |
| port@0 { |
| reg = <0>; |
| dsi_in: endpoint { |
| remote-endpoint = <<dc_ep0_out>; |
| }; |
| }; |
| |
| port@1 { |
| reg = <1>; |
| dsi_out: endpoint { |
| remote-endpoint = <&dsi_panel_in>; |
| }; |
| }; |
| }; |
| |
| panel-dsi@0 { |
| compatible = "raydium,rm68200"; |
| reg = <0>; |
| reset-gpios = <&gpiof 15 GPIO_ACTIVE_LOW>; |
| backlight = <&panel_backlight>; |
| power-supply = <&v3v3>; |
| status = "okay"; |
| |
| port { |
| dsi_panel_in: endpoint { |
| remote-endpoint = <&dsi_out>; |
| }; |
| }; |
| }; |
| }; |
| |
| ðernet0 { |
| status = "okay"; |
| pinctrl-0 = <ðernet0_rgmii_pins_a>; |
| pinctrl-1 = <ðernet0_rgmii_pins_sleep_a>; |
| pinctrl-names = "default", "sleep"; |
| phy-mode = "rgmii-id"; |
| max-speed = <1000>; |
| phy-handle = <&phy0>; |
| |
| mdio0 { |
| #address-cells = <1>; |
| #size-cells = <0>; |
| compatible = "snps,dwmac-mdio"; |
| phy0: ethernet-phy@0 { |
| reg = <0>; |
| }; |
| }; |
| }; |
| |
| &i2c2 { |
| pinctrl-names = "default"; |
| pinctrl-0 = <&i2c2_pins_a>; |
| i2c-scl-rising-time-ns = <185>; |
| i2c-scl-falling-time-ns = <20>; |
| status = "okay"; |
| |
| ov5640: camera@3c { |
| compatible = "ovti,ov5640"; |
| pinctrl-names = "default"; |
| pinctrl-0 = <&ov5640_pins>; |
| reg = <0x3c>; |
| clocks = <&clk_ext_camera>; |
| clock-names = "xclk"; |
| DOVDD-supply = <&v2v8>; |
| powerdown-gpios = <&stmfx_pinctrl 18 GPIO_ACTIVE_HIGH>; |
| reset-gpios = <&stmfx_pinctrl 19 GPIO_ACTIVE_LOW>; |
| rotation = <180>; |
| status = "okay"; |
| |
| port { |
| ov5640_0: endpoint { |
| remote-endpoint = <&dcmi_0>; |
| bus-width = <8>; |
| data-shift = <2>; /* lines 9:2 are used */ |
| hsync-active = <0>; |
| vsync-active = <0>; |
| pclk-sample = <1>; |
| }; |
| }; |
| }; |
| |
| stmfx: stmfx@42 { |
| compatible = "st,stmfx-0300"; |
| reg = <0x42>; |
| interrupts = <8 IRQ_TYPE_EDGE_RISING>; |
| interrupt-parent = <&gpioi>; |
| vdd-supply = <&v3v3>; |
| |
| stmfx_pinctrl: stmfx-pin-controller { |
| compatible = "st,stmfx-0300-pinctrl"; |
| gpio-controller; |
| #gpio-cells = <2>; |
| interrupt-controller; |
| #interrupt-cells = <2>; |
| gpio-ranges = <&stmfx_pinctrl 0 0 24>; |
| |
| joystick_pins: joystick { |
| pins = "gpio0", "gpio1", "gpio2", "gpio3", "gpio4"; |
| drive-push-pull; |
| bias-pull-down; |
| }; |
| |
| ov5640_pins: camera { |
| pins = "agpio2", "agpio3"; /* stmfx pins 18 & 19 */ |
| drive-push-pull; |
| output-low; |
| }; |
| }; |
| }; |
| }; |
| |
| &i2c5 { |
| pinctrl-names = "default"; |
| pinctrl-0 = <&i2c5_pins_a>; |
| i2c-scl-rising-time-ns = <185>; |
| i2c-scl-falling-time-ns = <20>; |
| status = "okay"; |
| }; |
| |
| <dc { |
| status = "okay"; |
| |
| port { |
| #address-cells = <1>; |
| #size-cells = <0>; |
| |
| ltdc_ep0_out: endpoint@0 { |
| reg = <0>; |
| remote-endpoint = <&dsi_in>; |
| }; |
| }; |
| }; |
| |
| &m_can1 { |
| pinctrl-names = "default", "sleep"; |
| pinctrl-0 = <&m_can1_pins_a>; |
| pinctrl-1 = <&m_can1_sleep_pins_a>; |
| status = "okay"; |
| }; |
| |
| &qspi { |
| pinctrl-names = "default", "sleep"; |
| pinctrl-0 = <&qspi_clk_pins_a &qspi_bk1_pins_a &qspi_bk2_pins_a>; |
| pinctrl-1 = <&qspi_clk_sleep_pins_a &qspi_bk1_sleep_pins_a &qspi_bk2_sleep_pins_a>; |
| reg = <0x58003000 0x1000>, <0x70000000 0x4000000>; |
| #address-cells = <1>; |
| #size-cells = <0>; |
| status = "okay"; |
| |
| flash0: mx66l51235l@0 { |
| compatible = "jedec,spi-nor"; |
| reg = <0>; |
| spi-rx-bus-width = <4>; |
| spi-max-frequency = <108000000>; |
| #address-cells = <1>; |
| #size-cells = <1>; |
| }; |
| |
| flash1: mx66l51235l@1 { |
| compatible = "jedec,spi-nor"; |
| reg = <1>; |
| spi-rx-bus-width = <4>; |
| spi-max-frequency = <108000000>; |
| #address-cells = <1>; |
| #size-cells = <1>; |
| }; |
| }; |
| |
| &spi1 { |
| pinctrl-names = "default"; |
| pinctrl-0 = <&spi1_pins_a>; |
| status = "disabled"; |
| }; |
| |
| &timers2 { |
| /* spare dmas for other usage (un-delete to enable pwm capture) */ |
| /delete-property/dmas; |
| /delete-property/dma-names; |
| status = "disabled"; |
| pwm { |
| pinctrl-0 = <&pwm2_pins_a>; |
| pinctrl-names = "default"; |
| status = "okay"; |
| }; |
| timer@1 { |
| status = "okay"; |
| }; |
| }; |
| |
| &timers8 { |
| /delete-property/dmas; |
| /delete-property/dma-names; |
| status = "disabled"; |
| pwm { |
| pinctrl-0 = <&pwm8_pins_a>; |
| pinctrl-names = "default"; |
| status = "okay"; |
| }; |
| timer@7 { |
| status = "okay"; |
| }; |
| }; |
| |
| &timers12 { |
| /delete-property/dmas; |
| /delete-property/dma-names; |
| status = "disabled"; |
| pwm { |
| pinctrl-0 = <&pwm12_pins_a>; |
| pinctrl-names = "default"; |
| status = "okay"; |
| }; |
| timer@11 { |
| status = "okay"; |
| }; |
| }; |
| |
| &usbh_ehci { |
| phys = <&usbphyc_port0>; |
| phy-names = "usb"; |
| status = "okay"; |
| }; |
| |
| &usbotg_hs { |
| dr_mode = "peripheral"; |
| phys = <&usbphyc_port1 0>; |
| phy-names = "usb2-phy"; |
| status = "okay"; |
| }; |
| |
| &usbphyc { |
| status = "okay"; |
| }; |