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