[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <0e007f7f-d9ff-4b2d-914d-ad62b9983bba@linaro.org>
Date: Wed, 30 Apr 2025 08:19:04 +0200
From: Krzysztof Kozlowski <krzysztof.kozlowski@...aro.org>
To: Konrad Dybcio <konrad.dybcio@....qualcomm.com>,
Bjorn Andersson <andersson@...nel.org>,
Konrad Dybcio <konradybcio@...nel.org>, Rob Herring <robh@...nel.org>,
Krzysztof Kozlowski <krzk+dt@...nel.org>, Conor Dooley <conor+dt@...nel.org>
Cc: linux-arm-msm@...r.kernel.org, devicetree@...r.kernel.org,
linux-kernel@...r.kernel.org
Subject: Re: [PATCH 2/2] arm64: dts: qcom: sm8750-mtp: Add sound (speakers,
headset codec, dmics)
On 29/04/2025 21:11, Konrad Dybcio wrote:
> On 4/28/25 4:41 PM, Krzysztof Kozlowski wrote:
>> On 25/04/2025 11:30, Konrad Dybcio wrote:
>>> On 4/24/25 11:40 AM, Krzysztof Kozlowski wrote:
>>>> Add device nodes for most of the sound support - WSA883x smart speakers,
>>>> WCD9395 audio codec (headset) and sound card - which allows sound
>>>> playback via speakers and recording via DMIC microphones. Changes bring
>>>> necessary foundation for headset playback/recording via USB, but that
>>>> part is not yet ready.
>>>>
>>>> Signed-off-by: Krzysztof Kozlowski <krzysztof.kozlowski@...aro.org>
>>>> ---
>>>
>>> [...]
>>>
>>>> + sound {
>>>> + compatible = "qcom,sm8750-sndcard", "qcom,sm8450-sndcard";
>>>> + model = "SM8750-MTP";
>>>> + audio-routing = "SpkrLeft IN", "WSA_SPK1 OUT",
>>>> + "SpkrRight IN", "WSA_SPK2 OUT",
>>>> + "IN1_HPHL", "HPHL_OUT",
>>>> + "IN2_HPHR", "HPHR_OUT",
>>>> + "AMIC2", "MIC BIAS2",
>>>> + "VA DMIC0", "MIC BIAS3", /* MIC4 on schematics */
>>>> + "VA DMIC1", "MIC BIAS3", /* MIC1 on schematics */
>>>
>>> Is this a mistake in what the codec driver exposes, or just a fumble
>>> in numbering $somewhere?
>>
>> Which mistake? MIC4? Schematics call name things differently. They
>> always were, so to make it clear for people without schematics I wrote
>> which MIC it actually is.
>
> I'm not sure how to parse your response
>
> are you saying that there are MIC[0..4] that are/may be connected
> to different codec ports, and that the MIC4/1 lines are plumbed to
> VA DMIC0/1 respectively?
Yes, as always. Nothing weird here.
>
> I think I got confused about the MIC BIAS3 going to both and none
What is both and none?
> matching the index, but perhaps that's just because it comes from
> the WCD (which is the third piece of hw involved beyond VA and the
> mic itself)
Again, what is the mistake you are pointing here?
>
>>
>>>
>>>> + "VA DMIC2", "MIC BIAS1",
>>>> + "VA DMIC3", "MIC BIAS1",
>>>> + "VA DMIC0", "VA MIC BIAS3",
>>>> + "VA DMIC1", "VA MIC BIAS3",
>>>> + "VA DMIC2", "VA MIC BIAS1",
>>>> + "VA DMIC3", "VA MIC BIAS1",
>>>> + "TX SWR_INPUT1", "ADC2_OUTPUT";
>>>> +
>>>> + wcd-playback-dai-link {
>>>> + link-name = "WCD Playback";
>>>> +
>>>> + cpu {
>>>> + sound-dai = <&q6apmbedai RX_CODEC_DMA_RX_0>;
>>>> + };
>>>> +
>>>> + codec {
>>>
>>> 'co'dec < 'cp'u
>>>
>>> [...]
>>
>> That was the convention so far, but we can start a new one, sure. Just
>> ask the same all other patch contributors, because each of them will be
>> copying old code, which means cpu->codec->platform
>
> I've been doing just that for the past couple weeks indeed
>
>>>> + /*
>>>> + * WCD9395 RX Port 1 (HPH_L/R) <=> SWR1 Port 1 (HPH_L/R)
>>>> + * WCD9395 RX Port 2 (CLSH) <=> SWR1 Port 2 (CLSH)
>>>> + * WCD9395 RX Port 3 (COMP_L/R) <=> SWR1 Port 3 (COMP_L/R)
>>>> + * WCD9395 RX Port 4 (LO) <=> SWR1 Port 4 (LO)
>>>> + * WCD9395 RX Port 5 (DSD_L/R) <=> SWR1 Port 5 (DSD_L/R)
>>>> + * WCD9395 RX Port 6 (HIFI_PCM_L/R) <=> SWR1 Port 9 (HIFI_PCM_L/R)
>>>> + */
>>>> + qcom,rx-port-mapping = <1 2 3 4 5 9>;
>>>
>>> Does this deserve some dt-bindings constants?
>>
>> No, because these are hardware details/constants. Drivers do not use them.
>
> I'd argue it makes sense here - it makes more sense to pass meaningfully
> named constants to the driver, rather than blobs with a comment
Sense of what? You want to make it a binding then answer what does it
bind, what part of ABI for driver is here a binding (answer none:
because driver does not use it)?
Best regards,
Krzysztof
Powered by blists - more mailing lists