1# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) 2%YAML 1.2 3--- 4$id: http://devicetree.org/schemas/sound/st,stm32-sai.yaml# 5$schema: http://devicetree.org/meta-schemas/core.yaml# 6 7title: STMicroelectronics STM32 Serial Audio Interface (SAI) 8 9maintainers: 10 - Olivier Moysan <olivier.moysan@st.com> 11 12description: 13 The SAI interface (Serial Audio Interface) offers a wide set of audio 14 protocols as I2S standards, LSB or MSB-justified, PCM/DSP, TDM, and AC'97. 15 The SAI contains two independent audio sub-blocks. Each sub-block has 16 its own clock generator and I/O lines controller. 17 18properties: 19 compatible: 20 enum: 21 - st,stm32f4-sai 22 - st,stm32h7-sai 23 24 reg: 25 items: 26 - description: Base address and size of SAI common register set. 27 - description: Base address and size of SAI identification register set. 28 minItems: 1 29 maxItems: 2 30 31 ranges: 32 maxItems: 1 33 34 interrupts: 35 maxItems: 1 36 37 resets: 38 maxItems: 1 39 40 "#address-cells": 41 const: 1 42 43 "#size-cells": 44 const: 1 45 46 clocks: 47 maxItems: 3 48 49 clock-names: 50 maxItems: 3 51 52required: 53 - compatible 54 - reg 55 - ranges 56 - "#address-cells" 57 - "#size-cells" 58 - clocks 59 - clock-names 60 61patternProperties: 62 "^audio-controller@[0-9a-f]+$": 63 type: object 64 description: 65 Two subnodes corresponding to SAI sub-block instances A et B 66 can be defined. Subnode can be omitted for unsused sub-block. 67 68 properties: 69 compatible: 70 description: Compatible for SAI sub-block A or B. 71 pattern: "st,stm32-sai-sub-[ab]" 72 73 "#sound-dai-cells": 74 const: 0 75 76 reg: 77 maxItems: 1 78 79 clocks: 80 items: 81 - description: sai_ck clock feeding the internal clock generator. 82 - description: MCLK clock from a SAI set as master clock provider. 83 minItems: 1 84 maxItems: 2 85 86 clock-names: 87 items: 88 - const: sai_ck 89 - const: MCLK 90 minItems: 1 91 maxItems: 2 92 93 dmas: 94 maxItems: 1 95 96 dma-names: 97 description: | 98 rx: SAI sub-block is configured as a capture DAI. 99 tx: SAI sub-block is configured as a playback DAI. 100 enum: [ rx, tx ] 101 102 st,sync: 103 description: 104 Configure the SAI sub-block as slave of another SAI sub-block. 105 By default SAI sub-block is in asynchronous mode. 106 Must contain the phandle and index of the SAI sub-block providing 107 the synchronization. 108 allOf: 109 - $ref: /schemas/types.yaml#/definitions/phandle-array 110 - maxItems: 1 111 112 st,iec60958: 113 description: 114 If set, support S/PDIF IEC6958 protocol for playback. 115 IEC60958 protocol is not available for capture. 116 By default, custom protocol is assumed, meaning that protocol is 117 configured according to protocol defined in related DAI link node, 118 such as i2s, left justified, right justified, dsp and pdm protocols. 119 allOf: 120 - $ref: /schemas/types.yaml#/definitions/flag 121 122 "#clock-cells": 123 description: Configure the SAI device as master clock provider. 124 const: 0 125 126 required: 127 - compatible 128 - "#sound-dai-cells" 129 - reg 130 - clocks 131 - clock-names 132 - dmas 133 - dma-names 134 135allOf: 136 - if: 137 properties: 138 compatible: 139 contains: 140 const: st,stm32f4-sai 141 142 - then: 143 properties: 144 clocks: 145 items: 146 - description: x8k, SAI parent clock for sampling rates multiple of 8kHz. 147 - description: x11k, SAI parent clock for sampling rates multiple of 11.025kHz. 148 149 clock-names: 150 items: 151 - const: x8k 152 - const: x11k 153 154 - else: 155 properties: 156 clocks: 157 items: 158 - description: pclk feeds the peripheral bus interface. 159 - description: x8k, SAI parent clock for sampling rates multiple of 8kHz. 160 - description: x11k, SAI parent clock for sampling rates multiple of 11.025kHz. 161 162 clock-names: 163 items: 164 - const: pclk 165 - const: x8k 166 - const: x11k 167 168additionalProperties: false 169 170examples: 171 - | 172 #include <dt-bindings/interrupt-controller/arm-gic.h> 173 #include <dt-bindings/clock/stm32mp1-clks.h> 174 #include <dt-bindings/reset/stm32mp1-resets.h> 175 sai2: sai@4400b000 { 176 compatible = "st,stm32h7-sai"; 177 #address-cells = <1>; 178 #size-cells = <1>; 179 ranges = <0 0x4400b000 0x400>; 180 reg = <0x4400b000 0x4>, <0x4400b3f0 0x10>; 181 clocks = <&rcc SAI2>, <&rcc PLL3_Q>, <&rcc PLL3_R>; 182 clock-names = "pclk", "x8k", "x11k"; 183 pinctrl-names = "default", "sleep"; 184 pinctrl-0 = <&sai2a_pins_a>, <&sai2b_pins_b>; 185 pinctrl-1 = <&sai2a_sleep_pins_a>, <&sai2b_sleep_pins_b>; 186 status = "okay"; 187 188 sai2a: audio-controller@4400b004 { 189 #sound-dai-cells = <0>; 190 compatible = "st,stm32-sai-sub-a"; 191 reg = <0x4 0x1c>; 192 dmas = <&dmamux1 89 0x400 0x01>; 193 dma-names = "tx"; 194 clocks = <&rcc SAI2_K>; 195 clock-names = "sai_ck"; 196 status = "okay"; 197 }; 198 }; 199 200... 201