162306a36Sopenharmony_ci// SPDX-License-Identifier: BSD-3-Clause 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * sc7280 device tree source for boards using Max98360 and wcd9385 codec 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * Copyright (c) 2022, The Linux Foundation. All rights reserved. 662306a36Sopenharmony_ci */ 762306a36Sopenharmony_ci 862306a36Sopenharmony_ci/ { 962306a36Sopenharmony_ci /* BOARD-SPECIFIC TOP LEVEL NODES */ 1062306a36Sopenharmony_ci sound: sound { 1162306a36Sopenharmony_ci compatible = "google,sc7280-herobrine"; 1262306a36Sopenharmony_ci model = "sc7280-wcd938x-max98360a-1mic"; 1362306a36Sopenharmony_ci 1462306a36Sopenharmony_ci audio-routing = 1562306a36Sopenharmony_ci "IN1_HPHL", "HPHL_OUT", 1662306a36Sopenharmony_ci "IN2_HPHR", "HPHR_OUT", 1762306a36Sopenharmony_ci "AMIC1", "MIC BIAS1", 1862306a36Sopenharmony_ci "AMIC2", "MIC BIAS2", 1962306a36Sopenharmony_ci "VA DMIC0", "MIC BIAS1", 2062306a36Sopenharmony_ci "VA DMIC1", "MIC BIAS1", 2162306a36Sopenharmony_ci "VA DMIC2", "MIC BIAS3", 2262306a36Sopenharmony_ci "VA DMIC3", "MIC BIAS3", 2362306a36Sopenharmony_ci "TX SWR_ADC0", "ADC1_OUTPUT", 2462306a36Sopenharmony_ci "TX SWR_ADC1", "ADC2_OUTPUT", 2562306a36Sopenharmony_ci "TX SWR_ADC2", "ADC3_OUTPUT", 2662306a36Sopenharmony_ci "TX SWR_DMIC0", "DMIC1_OUTPUT", 2762306a36Sopenharmony_ci "TX SWR_DMIC1", "DMIC2_OUTPUT", 2862306a36Sopenharmony_ci "TX SWR_DMIC2", "DMIC3_OUTPUT", 2962306a36Sopenharmony_ci "TX SWR_DMIC3", "DMIC4_OUTPUT", 3062306a36Sopenharmony_ci "TX SWR_DMIC4", "DMIC5_OUTPUT", 3162306a36Sopenharmony_ci "TX SWR_DMIC5", "DMIC6_OUTPUT", 3262306a36Sopenharmony_ci "TX SWR_DMIC6", "DMIC7_OUTPUT", 3362306a36Sopenharmony_ci "TX SWR_DMIC7", "DMIC8_OUTPUT"; 3462306a36Sopenharmony_ci 3562306a36Sopenharmony_ci #address-cells = <1>; 3662306a36Sopenharmony_ci #size-cells = <0>; 3762306a36Sopenharmony_ci 3862306a36Sopenharmony_ci dai-link@0 { 3962306a36Sopenharmony_ci link-name = "MAX98360A"; 4062306a36Sopenharmony_ci reg = <0>; 4162306a36Sopenharmony_ci 4262306a36Sopenharmony_ci cpu { 4362306a36Sopenharmony_ci sound-dai = <&lpass_cpu MI2S_SECONDARY>; 4462306a36Sopenharmony_ci }; 4562306a36Sopenharmony_ci 4662306a36Sopenharmony_ci codec { 4762306a36Sopenharmony_ci sound-dai = <&max98360a>; 4862306a36Sopenharmony_ci }; 4962306a36Sopenharmony_ci }; 5062306a36Sopenharmony_ci 5162306a36Sopenharmony_ci dai-link@1 { 5262306a36Sopenharmony_ci link-name = "DisplayPort"; 5362306a36Sopenharmony_ci reg = <1>; 5462306a36Sopenharmony_ci 5562306a36Sopenharmony_ci cpu { 5662306a36Sopenharmony_ci sound-dai = <&lpass_cpu LPASS_DP_RX>; 5762306a36Sopenharmony_ci }; 5862306a36Sopenharmony_ci 5962306a36Sopenharmony_ci codec { 6062306a36Sopenharmony_ci sound-dai = <&mdss_dp>; 6162306a36Sopenharmony_ci }; 6262306a36Sopenharmony_ci }; 6362306a36Sopenharmony_ci 6462306a36Sopenharmony_ci dai-link@2 { 6562306a36Sopenharmony_ci link-name = "WCD9385 Playback"; 6662306a36Sopenharmony_ci reg = <2>; 6762306a36Sopenharmony_ci 6862306a36Sopenharmony_ci cpu { 6962306a36Sopenharmony_ci sound-dai = <&lpass_cpu LPASS_CDC_DMA_RX0>; 7062306a36Sopenharmony_ci }; 7162306a36Sopenharmony_ci 7262306a36Sopenharmony_ci codec { 7362306a36Sopenharmony_ci sound-dai = <&wcd9385 0>, <&swr0 0>, <&lpass_rx_macro 0>; 7462306a36Sopenharmony_ci }; 7562306a36Sopenharmony_ci }; 7662306a36Sopenharmony_ci 7762306a36Sopenharmony_ci dai-link@3 { 7862306a36Sopenharmony_ci link-name = "WCD9385 Capture"; 7962306a36Sopenharmony_ci reg = <3>; 8062306a36Sopenharmony_ci 8162306a36Sopenharmony_ci cpu { 8262306a36Sopenharmony_ci sound-dai = <&lpass_cpu LPASS_CDC_DMA_TX3>; 8362306a36Sopenharmony_ci }; 8462306a36Sopenharmony_ci 8562306a36Sopenharmony_ci codec { 8662306a36Sopenharmony_ci sound-dai = <&wcd9385 1>, <&swr1 0>, <&lpass_tx_macro 0>; 8762306a36Sopenharmony_ci }; 8862306a36Sopenharmony_ci }; 8962306a36Sopenharmony_ci 9062306a36Sopenharmony_ci dai-link@4 { 9162306a36Sopenharmony_ci link-name = "DMIC"; 9262306a36Sopenharmony_ci reg = <4>; 9362306a36Sopenharmony_ci 9462306a36Sopenharmony_ci cpu { 9562306a36Sopenharmony_ci sound-dai = <&lpass_cpu LPASS_CDC_DMA_VA_TX0>; 9662306a36Sopenharmony_ci }; 9762306a36Sopenharmony_ci 9862306a36Sopenharmony_ci codec { 9962306a36Sopenharmony_ci sound-dai = <&lpass_va_macro 0>; 10062306a36Sopenharmony_ci }; 10162306a36Sopenharmony_ci }; 10262306a36Sopenharmony_ci }; 10362306a36Sopenharmony_ci}; 10462306a36Sopenharmony_ci 10562306a36Sopenharmony_ci/* ADDITIONS TO NODES DEFINED IN PARENT DEVICE TREE FILES */ 10662306a36Sopenharmony_ci 10762306a36Sopenharmony_ci&lpass_cpu { 10862306a36Sopenharmony_ci status = "okay"; 10962306a36Sopenharmony_ci 11062306a36Sopenharmony_ci pinctrl-names = "default"; 11162306a36Sopenharmony_ci pinctrl-0 = <&mi2s1_data0>, <&mi2s1_sclk>, <&mi2s1_ws>; 11262306a36Sopenharmony_ci 11362306a36Sopenharmony_ci dai-link@1 { 11462306a36Sopenharmony_ci reg = <MI2S_SECONDARY>; 11562306a36Sopenharmony_ci qcom,playback-sd-lines = <0>; 11662306a36Sopenharmony_ci }; 11762306a36Sopenharmony_ci 11862306a36Sopenharmony_ci dai-link@5 { 11962306a36Sopenharmony_ci reg = <LPASS_DP_RX>; 12062306a36Sopenharmony_ci }; 12162306a36Sopenharmony_ci 12262306a36Sopenharmony_ci dai-link@6 { 12362306a36Sopenharmony_ci reg = <LPASS_CDC_DMA_RX0>; 12462306a36Sopenharmony_ci }; 12562306a36Sopenharmony_ci 12662306a36Sopenharmony_ci dai-link@19 { 12762306a36Sopenharmony_ci reg = <LPASS_CDC_DMA_TX3>; 12862306a36Sopenharmony_ci }; 12962306a36Sopenharmony_ci 13062306a36Sopenharmony_ci dai-link@25 { 13162306a36Sopenharmony_ci reg = <LPASS_CDC_DMA_VA_TX0>; 13262306a36Sopenharmony_ci }; 13362306a36Sopenharmony_ci}; 13462306a36Sopenharmony_ci 13562306a36Sopenharmony_ci&lpass_rx_macro { 13662306a36Sopenharmony_ci status = "okay"; 13762306a36Sopenharmony_ci}; 13862306a36Sopenharmony_ci 13962306a36Sopenharmony_ci&lpass_tx_macro { 14062306a36Sopenharmony_ci status = "okay"; 14162306a36Sopenharmony_ci}; 14262306a36Sopenharmony_ci 14362306a36Sopenharmony_ci&lpass_va_macro { 14462306a36Sopenharmony_ci status = "okay"; 14562306a36Sopenharmony_ci}; 14662306a36Sopenharmony_ci 14762306a36Sopenharmony_ci&swr0 { 14862306a36Sopenharmony_ci status = "okay"; 14962306a36Sopenharmony_ci}; 15062306a36Sopenharmony_ci 15162306a36Sopenharmony_ci&swr1 { 15262306a36Sopenharmony_ci status = "okay"; 15362306a36Sopenharmony_ci}; 15462306a36Sopenharmony_ci 15562306a36Sopenharmony_ci&wcd9385 { 15662306a36Sopenharmony_ci status = "okay"; 15762306a36Sopenharmony_ci}; 15862306a36Sopenharmony_ci 15962306a36Sopenharmony_ci/* PINCTRL */ 16062306a36Sopenharmony_ci 16162306a36Sopenharmony_ci&lpass_dmic01_clk { 16262306a36Sopenharmony_ci drive-strength = <8>; 16362306a36Sopenharmony_ci bias-disable; 16462306a36Sopenharmony_ci}; 16562306a36Sopenharmony_ci 16662306a36Sopenharmony_ci&lpass_dmic01_data { 16762306a36Sopenharmony_ci bias-pull-down; 16862306a36Sopenharmony_ci}; 16962306a36Sopenharmony_ci 17062306a36Sopenharmony_ci&lpass_dmic23_clk { 17162306a36Sopenharmony_ci drive-strength = <8>; 17262306a36Sopenharmony_ci bias-disable; 17362306a36Sopenharmony_ci}; 17462306a36Sopenharmony_ci 17562306a36Sopenharmony_ci&lpass_dmic23_data { 17662306a36Sopenharmony_ci bias-pull-down; 17762306a36Sopenharmony_ci}; 17862306a36Sopenharmony_ci 17962306a36Sopenharmony_ci&lpass_rx_swr_clk { 18062306a36Sopenharmony_ci drive-strength = <2>; 18162306a36Sopenharmony_ci slew-rate = <1>; 18262306a36Sopenharmony_ci bias-disable; 18362306a36Sopenharmony_ci}; 18462306a36Sopenharmony_ci 18562306a36Sopenharmony_ci&lpass_rx_swr_data { 18662306a36Sopenharmony_ci drive-strength = <2>; 18762306a36Sopenharmony_ci slew-rate = <1>; 18862306a36Sopenharmony_ci bias-bus-hold; 18962306a36Sopenharmony_ci}; 19062306a36Sopenharmony_ci 19162306a36Sopenharmony_ci&lpass_tx_swr_clk { 19262306a36Sopenharmony_ci drive-strength = <2>; 19362306a36Sopenharmony_ci slew-rate = <1>; 19462306a36Sopenharmony_ci bias-disable; 19562306a36Sopenharmony_ci}; 19662306a36Sopenharmony_ci 19762306a36Sopenharmony_ci&lpass_tx_swr_data { 19862306a36Sopenharmony_ci drive-strength = <2>; 19962306a36Sopenharmony_ci slew-rate = <1>; 20062306a36Sopenharmony_ci bias-bus-hold; 20162306a36Sopenharmony_ci}; 20262306a36Sopenharmony_ci 20362306a36Sopenharmony_ci&mi2s1_data0 { 20462306a36Sopenharmony_ci drive-strength = <6>; 20562306a36Sopenharmony_ci bias-disable; 20662306a36Sopenharmony_ci}; 20762306a36Sopenharmony_ci 20862306a36Sopenharmony_ci&mi2s1_sclk { 20962306a36Sopenharmony_ci drive-strength = <6>; 21062306a36Sopenharmony_ci bias-disable; 21162306a36Sopenharmony_ci}; 21262306a36Sopenharmony_ci 21362306a36Sopenharmony_ci&mi2s1_ws { 21462306a36Sopenharmony_ci drive-strength = <6>; 21562306a36Sopenharmony_ci}; 216