1// SPDX-License-Identifier: GPL-2.0-only 2/* 3 * Copyright (C) 2014 STMicroelectronics (R&D) Limited. 4 * Author: Giuseppe Cavallaro <peppe.cavallaro@st.com> 5 */ 6#include <dt-bindings/clock/stih407-clks.h> 7#include <dt-bindings/gpio/gpio.h> 8#include <dt-bindings/media/c8sectpfe.h> 9/ { 10 leds { 11 compatible = "gpio-leds"; 12 red { 13 label = "Front Panel LED"; 14 gpios = <&pio4 1 GPIO_ACTIVE_HIGH>; 15 linux,default-trigger = "heartbeat"; 16 }; 17 green { 18 gpios = <&pio1 3 GPIO_ACTIVE_HIGH>; 19 default-state = "off"; 20 }; 21 }; 22 23 sound: sound { 24 compatible = "simple-audio-card"; 25 simple-audio-card,name = "STI-B2120"; 26 status = "okay"; 27 #address-cells = <1>; 28 #size-cells = <0>; 29 30 simple-audio-card,dai-link@0 { 31 reg = <0>; 32 /* HDMI */ 33 format = "i2s"; 34 mclk-fs = <128>; 35 cpu { 36 sound-dai = <&sti_uni_player0>; 37 }; 38 39 codec { 40 sound-dai = <&sti_hdmi>; 41 }; 42 }; 43 44 simple-audio-card,dai-link@1 { 45 reg = <1>; 46 /* DAC */ 47 format = "i2s"; 48 mclk-fs = <256>; 49 frame-inversion; 50 cpu { 51 sound-dai = <&sti_uni_player2>; 52 }; 53 54 codec { 55 sound-dai = <&sti_sasg_codec 1>; 56 }; 57 }; 58 59 simple-audio-card,dai-link@2 { 60 reg = <2>; 61 /* SPDIF */ 62 format = "left_j"; 63 mclk-fs = <128>; 64 cpu { 65 sound-dai = <&sti_uni_player3>; 66 }; 67 68 codec { 69 sound-dai = <&sti_sasg_codec 0>; 70 }; 71 }; 72 }; 73 74 soc { 75 sbc_serial0: serial@9530000 { 76 status = "okay"; 77 }; 78 79 pwm0: pwm@9810000 { 80 status = "okay"; 81 }; 82 83 pwm1: pwm@9510000 { 84 status = "okay"; 85 }; 86 87 ssc2: i2c@9842000 { 88 status = "okay"; 89 clock-frequency = <100000>; 90 st,i2c-min-scl-pulse-width-us = <0>; 91 st,i2c-min-sda-pulse-width-us = <5>; 92 }; 93 94 ssc3: i2c@9843000 { 95 status = "okay"; 96 clock-frequency = <100000>; 97 st,i2c-min-scl-pulse-width-us = <0>; 98 st,i2c-min-sda-pulse-width-us = <5>; 99 }; 100 101 i2c@9844000 { 102 status = "okay"; 103 }; 104 105 i2c@9845000 { 106 status = "okay"; 107 }; 108 109 i2c@9540000 { 110 status = "okay"; 111 }; 112 113 mmc0: sdhci@9060000 { 114 non-removable; 115 status = "okay"; 116 }; 117 118 mmc1: sdhci@9080000 { 119 status = "okay"; 120 }; 121 122 /* SSC11 to HDMI */ 123 hdmiddc: i2c@9541000 { 124 status = "okay"; 125 /* HDMI V1.3a supports Standard mode only */ 126 clock-frequency = <100000>; 127 st,i2c-min-scl-pulse-width-us = <0>; 128 st,i2c-min-sda-pulse-width-us = <5>; 129 }; 130 131 miphy28lp_phy: miphy28lp@0 { 132 133 phy_port0: port@9b22000 { 134 st,osc-rdy; 135 }; 136 137 phy_port1: port@9b2a000 { 138 st,osc-force-ext; 139 }; 140 }; 141 142 st_dwc3: dwc3@8f94000 { 143 status = "okay"; 144 }; 145 146 ethernet0: dwmac@9630000 { 147 st,tx-retime-src = "clkgen"; 148 status = "okay"; 149 phy-mode = "rgmii"; 150 fixed-link = <0 1 1000 0 0>; 151 }; 152 153 demux@8a20000 { 154 compatible = "st,stih407-c8sectpfe"; 155 status = "okay"; 156 reg = <0x08a20000 0x10000>, 157 <0x08a00000 0x4000>; 158 reg-names = "c8sectpfe", "c8sectpfe-ram"; 159 interrupts = <GIC_SPI 34 IRQ_TYPE_LEVEL_HIGH>, 160 <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>; 161 interrupt-names = "c8sectpfe-error-irq", 162 "c8sectpfe-idle-irq"; 163 pinctrl-0 = <&pinctrl_tsin0_serial>; 164 pinctrl-1 = <&pinctrl_tsin0_parallel>; 165 pinctrl-2 = <&pinctrl_tsin3_serial>; 166 pinctrl-3 = <&pinctrl_tsin4_serial_alt3>; 167 pinctrl-4 = <&pinctrl_tsin5_serial_alt1>; 168 pinctrl-names = "tsin0-serial", 169 "tsin0-parallel", 170 "tsin3-serial", 171 "tsin4-serial", 172 "tsin5-serial"; 173 clocks = <&clk_s_c0_flexgen CLK_PROC_STFE>; 174 clock-names = "c8sectpfe"; 175 176 /* tsin0 is TSA on NIMA */ 177 tsin0: port { 178 tsin-num = <0>; 179 serial-not-parallel; 180 i2c-bus = <&ssc2>; 181 reset-gpios = <&pio15 4 GPIO_ACTIVE_HIGH>; 182 dvb-card = <STV0367_TDA18212_NIMA_1>; 183 }; 184 }; 185 186 sti_uni_player0: sti-uni-player@8d80000 { 187 status = "okay"; 188 }; 189 190 sti_uni_player2: sti-uni-player@8d82000 { 191 status = "okay"; 192 }; 193 194 sti_uni_player3: sti-uni-player@8d85000 { 195 status = "okay"; 196 }; 197 198 syscfg_core: core-syscfg@92b0000 { 199 sti_sasg_codec: sti-sasg-codec { 200 status = "okay"; 201 pinctrl-names = "default"; 202 pinctrl-0 = <&pinctrl_spdif_out>; 203 }; 204 }; 205 }; 206}; 207