18c2ecf20Sopenharmony_ci# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) 28c2ecf20Sopenharmony_ci%YAML 1.2 38c2ecf20Sopenharmony_ci--- 48c2ecf20Sopenharmony_ci$id: http://devicetree.org/schemas/sound/ti,j721e-cpb-audio.yaml# 58c2ecf20Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml# 68c2ecf20Sopenharmony_ci 78c2ecf20Sopenharmony_cititle: Texas Instruments J721e Common Processor Board Audio Support 88c2ecf20Sopenharmony_ci 98c2ecf20Sopenharmony_cimaintainers: 108c2ecf20Sopenharmony_ci - Peter Ujfalusi <peter.ujfalusi@ti.com> 118c2ecf20Sopenharmony_ci 128c2ecf20Sopenharmony_cidescription: | 138c2ecf20Sopenharmony_ci The audio support on the board is using pcm3168a codec connected to McASP10 148c2ecf20Sopenharmony_ci serializers in parallel setup. 158c2ecf20Sopenharmony_ci The pcm3168a SCKI clock is sourced from j721e AUDIO_REFCLK2 pin. 168c2ecf20Sopenharmony_ci In order to support 48KHz and 44.1KHz family of sampling rates the parent 178c2ecf20Sopenharmony_ci clock for AUDIO_REFCLK2 needs to be changed between PLL4 (for 48KHz) and 188c2ecf20Sopenharmony_ci PLL15 (for 44.1KHz). The same PLLs are used for McASP10's AUXCLK clock via 198c2ecf20Sopenharmony_ci different HSDIVIDER. 208c2ecf20Sopenharmony_ci 218c2ecf20Sopenharmony_ci Clocking setup for j721e: 228c2ecf20Sopenharmony_ci 48KHz family: 238c2ecf20Sopenharmony_ci PLL4 ---> PLL4_HSDIV0 ---> MCASP10_AUXCLK ---> McASP10.auxclk 248c2ecf20Sopenharmony_ci |-> PLL4_HSDIV2 ---> AUDIO_REFCLK2 ---> pcm3168a.SCKI 258c2ecf20Sopenharmony_ci 268c2ecf20Sopenharmony_ci 44.1KHz family: 278c2ecf20Sopenharmony_ci PLL15 ---> PLL15_HSDIV0 ---> MCASP10_AUXCLK ---> McASP10.auxclk 288c2ecf20Sopenharmony_ci |-> PLL15_HSDIV2 ---> AUDIO_REFCLK2 ---> pcm3168a.SCKI 298c2ecf20Sopenharmony_ci 308c2ecf20Sopenharmony_ci Clocking setup for j7200: 318c2ecf20Sopenharmony_ci 48KHz family: 328c2ecf20Sopenharmony_ci PLL4 ---> PLL4_HSDIV0 ---> MCASP0_AUXCLK ---> McASP0.auxclk 338c2ecf20Sopenharmony_ci |-> PLL4_HSDIV2 ---> AUDIO_REFCLK2 ---> pcm3168a.SCKI 348c2ecf20Sopenharmony_ci 358c2ecf20Sopenharmony_ciproperties: 368c2ecf20Sopenharmony_ci compatible: 378c2ecf20Sopenharmony_ci enum: 388c2ecf20Sopenharmony_ci - ti,j721e-cpb-audio 398c2ecf20Sopenharmony_ci - ti,j7200-cpb-audio 408c2ecf20Sopenharmony_ci 418c2ecf20Sopenharmony_ci model: 428c2ecf20Sopenharmony_ci $ref: /schemas/types.yaml#/definitions/string 438c2ecf20Sopenharmony_ci description: User specified audio sound card name 448c2ecf20Sopenharmony_ci 458c2ecf20Sopenharmony_ci ti,cpb-mcasp: 468c2ecf20Sopenharmony_ci description: phandle to McASP used on CPB 478c2ecf20Sopenharmony_ci $ref: /schemas/types.yaml#/definitions/phandle 488c2ecf20Sopenharmony_ci 498c2ecf20Sopenharmony_ci ti,cpb-codec: 508c2ecf20Sopenharmony_ci description: phandle to the pcm3168a codec used on the CPB 518c2ecf20Sopenharmony_ci $ref: /schemas/types.yaml#/definitions/phandle 528c2ecf20Sopenharmony_ci 538c2ecf20Sopenharmony_ci clocks: 548c2ecf20Sopenharmony_ci minItems: 4 558c2ecf20Sopenharmony_ci maxItems: 6 568c2ecf20Sopenharmony_ci 578c2ecf20Sopenharmony_ci clock-names: 588c2ecf20Sopenharmony_ci minItems: 4 598c2ecf20Sopenharmony_ci maxItems: 6 608c2ecf20Sopenharmony_ci 618c2ecf20Sopenharmony_cirequired: 628c2ecf20Sopenharmony_ci - compatible 638c2ecf20Sopenharmony_ci - model 648c2ecf20Sopenharmony_ci - ti,cpb-mcasp 658c2ecf20Sopenharmony_ci - ti,cpb-codec 668c2ecf20Sopenharmony_ci - clocks 678c2ecf20Sopenharmony_ci - clock-names 688c2ecf20Sopenharmony_ci 698c2ecf20Sopenharmony_ciadditionalProperties: false 708c2ecf20Sopenharmony_ci 718c2ecf20Sopenharmony_ciallOf: 728c2ecf20Sopenharmony_ci - if: 738c2ecf20Sopenharmony_ci properties: 748c2ecf20Sopenharmony_ci compatible: 758c2ecf20Sopenharmony_ci contains: 768c2ecf20Sopenharmony_ci const: ti,j721e-cpb-audio 778c2ecf20Sopenharmony_ci 788c2ecf20Sopenharmony_ci then: 798c2ecf20Sopenharmony_ci properties: 808c2ecf20Sopenharmony_ci clocks: 818c2ecf20Sopenharmony_ci minItems: 6 828c2ecf20Sopenharmony_ci items: 838c2ecf20Sopenharmony_ci - description: AUXCLK clock for McASP used by CPB audio 848c2ecf20Sopenharmony_ci - description: Parent for CPB_McASP auxclk (for 48KHz) 858c2ecf20Sopenharmony_ci - description: Parent for CPB_McASP auxclk (for 44.1KHz) 868c2ecf20Sopenharmony_ci - description: SCKI clock for the pcm3168a codec on CPB 878c2ecf20Sopenharmony_ci - description: Parent for CPB_SCKI clock (for 48KHz) 888c2ecf20Sopenharmony_ci - description: Parent for CPB_SCKI clock (for 44.1KHz) 898c2ecf20Sopenharmony_ci 908c2ecf20Sopenharmony_ci clock-names: 918c2ecf20Sopenharmony_ci items: 928c2ecf20Sopenharmony_ci - const: cpb-mcasp-auxclk 938c2ecf20Sopenharmony_ci - const: cpb-mcasp-auxclk-48000 948c2ecf20Sopenharmony_ci - const: cpb-mcasp-auxclk-44100 958c2ecf20Sopenharmony_ci - const: cpb-codec-scki 968c2ecf20Sopenharmony_ci - const: cpb-codec-scki-48000 978c2ecf20Sopenharmony_ci - const: cpb-codec-scki-44100 988c2ecf20Sopenharmony_ci 998c2ecf20Sopenharmony_ci - if: 1008c2ecf20Sopenharmony_ci properties: 1018c2ecf20Sopenharmony_ci compatible: 1028c2ecf20Sopenharmony_ci contains: 1038c2ecf20Sopenharmony_ci const: ti,j7200-cpb-audio 1048c2ecf20Sopenharmony_ci 1058c2ecf20Sopenharmony_ci then: 1068c2ecf20Sopenharmony_ci properties: 1078c2ecf20Sopenharmony_ci clocks: 1088c2ecf20Sopenharmony_ci maxItems: 4 1098c2ecf20Sopenharmony_ci items: 1108c2ecf20Sopenharmony_ci - description: AUXCLK clock for McASP used by CPB audio 1118c2ecf20Sopenharmony_ci - description: Parent for CPB_McASP auxclk (for 48KHz) 1128c2ecf20Sopenharmony_ci - description: SCKI clock for the pcm3168a codec on CPB 1138c2ecf20Sopenharmony_ci - description: Parent for CPB_SCKI clock (for 48KHz) 1148c2ecf20Sopenharmony_ci 1158c2ecf20Sopenharmony_ci clock-names: 1168c2ecf20Sopenharmony_ci items: 1178c2ecf20Sopenharmony_ci - const: cpb-mcasp-auxclk 1188c2ecf20Sopenharmony_ci - const: cpb-mcasp-auxclk-48000 1198c2ecf20Sopenharmony_ci - const: cpb-codec-scki 1208c2ecf20Sopenharmony_ci - const: cpb-codec-scki-48000 1218c2ecf20Sopenharmony_ci 1228c2ecf20Sopenharmony_ciexamples: 1238c2ecf20Sopenharmony_ci - |+ 1248c2ecf20Sopenharmony_ci sound { 1258c2ecf20Sopenharmony_ci compatible = "ti,j721e-cpb-audio"; 1268c2ecf20Sopenharmony_ci model = "j721e-cpb"; 1278c2ecf20Sopenharmony_ci 1288c2ecf20Sopenharmony_ci status = "okay"; 1298c2ecf20Sopenharmony_ci 1308c2ecf20Sopenharmony_ci ti,cpb-mcasp = <&mcasp10>; 1318c2ecf20Sopenharmony_ci ti,cpb-codec = <&pcm3168a_1>; 1328c2ecf20Sopenharmony_ci 1338c2ecf20Sopenharmony_ci clocks = <&k3_clks 184 1>, 1348c2ecf20Sopenharmony_ci <&k3_clks 184 2>, <&k3_clks 184 4>, 1358c2ecf20Sopenharmony_ci <&k3_clks 157 371>, 1368c2ecf20Sopenharmony_ci <&k3_clks 157 400>, <&k3_clks 157 401>; 1378c2ecf20Sopenharmony_ci clock-names = "cpb-mcasp-auxclk", 1388c2ecf20Sopenharmony_ci "cpb-mcasp-auxclk-48000", "cpb-mcasp-auxclk-44100", 1398c2ecf20Sopenharmony_ci "cpb-codec-scki", 1408c2ecf20Sopenharmony_ci "cpb-codec-scki-48000", "cpb-codec-scki-44100"; 1418c2ecf20Sopenharmony_ci }; 142