From: Pierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>
To: Srinivas Kandagatla <srinivas.kandagatla@linaro.org>,
vkoul@kernel.org, yung-chuan.liao@linux.intel.com
Cc: gregkh@linuxfoundation.org, sanyog.r.kale@intel.com,
alsa-devel@alsa-project.org, linux-kernel@vger.kernel.org
Subject: Re: [RFC PATCH 1/2] soundwire: add support for static port mapping
Date: Thu, 21 Jan 2021 12:00:43 -0600 [thread overview]
Message-ID: <3ee60ad9-9635-649e-ba67-d40a96b25256@linux.intel.com> (raw)
In-Reply-To: <c6278763-57d9-2631-7b43-829259a9ea1f@linaro.org>
On 1/21/21 9:41 AM, Srinivas Kandagatla wrote:
>
>
> On 21/01/2021 14:56, Pierre-Louis Bossart wrote:
>>
>>
>>> Port allocations are something like this:
>>>
>>> RX: (Simple)
>>> Port 1 -> HPH L/R
>>> Port 2 -> CLASS H Amp
>>> Port 3 -> COMP
>>> Port 4 -> DSD.
>>>
>>> TX: (This get bit more complicated)
>>> Port 1: PCM
>>> Port 2: ADC 1 & 2
>>> Port 3: ADC 3 & 4
>>> Port 4: DMIC-0, DMIC-1, DIMC-2 , DMIC-3 and MBHC
>>> Port 5: DMIC-4, DMIC-5, DMIC-6 and DMIC-7
>>>
>>> We handle the port allocation dynamically based on mixer and dapm
>>> widgets in my code! Also channel allocations are different for each
>>> function!
>>
>> Sorry, I am not following here. What is dynamic here and use-case
>> dependent? And is this a mapping on the master or the codec sides that
>> you want to modify?
>
> [SLAVE]-------[MASTER]
> NA-------------Port 1: PCM
> Port 1---------Port 2: ADC 1 & 2
> Port 2---------Port 3: ADC 3 & 4
> Port 3---------Port 4: DMIC-0, DMIC-1, DIMC-2 , DMIC-3 and MBHC
> Port 4---------Port 5: DMIC-4, DMIC-5, DMIC-6 and DMIC-7
>
>
> Mapping is still static however Number of ports selection and channel
> mask will be dynamic here.
>
>
> Example: for Headset MIC usecase we will be using Slv Port1, Slv Port3
> along with Mstr Port2 and Master Port4
>
> Similarly for usecases like Digital MIC or other Analog MICs.
Sorry, I must be thick here, but in my experience the choice of Digital
or analog mics is a hardware design level not a use-case one. Using ADC
1 & 2 at the same time as DMICs is very surprising to me. You'd have
different sensitivities/performance, not sure how you would combine the
results.
I also don't see how a headset mic can both use Analog and digital,
unless we have a different definition of what a 'headset' is.
>>>> Does this help and can you align on what Intel started with?
>>>
>>> Firstly, This is where the issue comes, if we go with the
>>> suggested(dai->id) solution, we would end up with a long list of
>>> dai-links with different combinations of both inputs/output
>>> connections and usecases. Again we have to deal with limited DSP
>>> resources too!
>>>
>>> Secondly, The check [1] in stream.c will not allow more than one
>>> master port config to be added to master runtime. Ex: RX Port 1, 2, 3
>>> is used for Headset Playback.
>>
>> I am confused here, we do have examples in existing codec drivers
>> where we use multiple ports for a single stream, e.g. for IV feedback
>> we use 2 ports.
>
> Is this on multi_link? which is why it might be working for you.
no, this is done at the codec driver level, which has no notion of
multi-link. we pass a port_config as a array of 2.
> Currently we have below check in sdw_stream_add_master().
>
> if (!bus->multi_link && stream->m_rt_count > 0) {
> dev_err(bus->dev, "Multilink not supported, link %d\n", bus->link_id);
> ret = -EINVAL;
> goto unlock;
> }
>
> If we have single master(like my case) and dai-links which have more
> then one port will be calling sdw_stream_add_master() for each port,
> so m_rt_count above check will fail for the second call!
if you use multiple ports in a given master for the same stream, you
should have the m_rt_count == 1. That's a feature, not a bug.
A port is not a stream... You cannot call sdw_stream_add_master() for
each port, that's not what the concept was. You allocate ONE master_rt
per master, and that master_rt deals with one or more ports - your choice.
A 'stream' is an abstract data transport which can be split across
multiple masters/sales and for each master/slave use multiple ports.
When calling sdw_stream_add_master/slave, you need to provide a
port_config/num_ports to state which ports will be used on that
master/slave when using the stream. That's how we e.g. deal with 4ch
streams that are handled by two ports on each side.
To up-level a bit, the notion of 'stream' is actually very very similar
to the notion of dailink. And in fact, the 'stream' is actually created
for Intel in the dailink .startup callback, so I am quite in the dark on
what you are trying to accomplish.
next prev parent reply other threads:[~2021-01-21 18:02 UTC|newest]
Thread overview: 19+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-01-20 18:01 [RFC PATCH 0/2] soundwire: add static port mapping support Srinivas Kandagatla
2021-01-20 18:01 ` [RFC PATCH 1/2] soundwire: add support for static port mapping Srinivas Kandagatla
2021-01-20 22:15 ` Pierre-Louis Bossart
2021-01-21 11:35 ` Srinivas Kandagatla
2021-01-21 14:56 ` Pierre-Louis Bossart
2021-01-21 15:41 ` Srinivas Kandagatla
2021-01-21 18:00 ` Pierre-Louis Bossart [this message]
2021-01-21 18:41 ` Srinivas Kandagatla
2021-01-21 21:30 ` Pierre-Louis Bossart
2021-01-22 7:05 ` Srinivas Kandagatla
2021-01-22 15:32 ` Pierre-Louis Bossart
2021-01-22 15:46 ` Srinivas Kandagatla
2021-01-22 16:42 ` Pierre-Louis Bossart
2021-01-25 16:23 ` Srinivas Kandagatla
2021-02-01 10:27 ` Vinod Koul
2021-02-19 10:35 ` Srinivas Kandagatla
2021-02-19 19:52 ` Pierre-Louis Bossart
2021-02-22 13:40 ` Srinivas Kandagatla
2021-01-20 18:01 ` [RFC PATCH 2/2] soundwire: qcom: " Srinivas Kandagatla
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=3ee60ad9-9635-649e-ba67-d40a96b25256@linux.intel.com \
--to=pierre-louis.bossart@linux.intel.com \
--cc=alsa-devel@alsa-project.org \
--cc=gregkh@linuxfoundation.org \
--cc=linux-kernel@vger.kernel.org \
--cc=sanyog.r.kale@intel.com \
--cc=srinivas.kandagatla@linaro.org \
--cc=vkoul@kernel.org \
--cc=yung-chuan.liao@linux.intel.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox