All of lore.kernel.org
 help / color / mirror / Atom feed
From: Daniel Mack <zonque@gmail.com>
To: Mark Brown <broonie@kernel.org>
Cc: ALSA development <alsa-devel@alsa-project.org>,
	Liam Girdwood <lgirdwood@gmail.com>
Subject: Re: Connecting two Codecs to the same CPU DAI
Date: Wed, 17 Jul 2013 11:16:22 +0200	[thread overview]
Message-ID: <51E660E6.4010902@gmail.com> (raw)
In-Reply-To: <20130716174703.GW22506@sirena.org.uk>

On 16.07.2013 19:47, Mark Brown wrote:
> On Tue, Jul 16, 2013 at 07:07:33PM +0200, Daniel Mack wrote:
>> On 16.07.2013 18:57, Mark Brown wrote:
> 
>>>>> No, no feature here.  Off the top of my head I'd suggest soc-pcm plus a
>>>>> virtual DAI for the second link.
> 
>>>> That would still require userspace to open and configure both
>>>> subdevices, right?
> 
>>> Shouldn't.
> 
>> How so? As each link exposes its own PCM subdevice, how would codec of
>> link #1 get a hw_params call if an application just opens PCM subdevice
>> #0 for playback? This is the case I want to address.
> 
> Half the point of soc-pcm is to decouple the streams seen by the
> application layer from the DAIs that the driver sees so I'd expect us to
> be able to map a single application layer/memory stream onto multiple
> CODEC DAIs.  One front end connected to two back ends.

You're talking about DPCM, right? Unfortunately, there is no active user
of this in mainline, and no documentation either. I'll try and find out
how this is supposed to work first ...

Maybe Liam has some explanation ready?

>> By naive approach atm would be to just add .codec_names,
>> .codec_dai_names and .codec_of_node to snd_soc_dai_link, and make their
>> use mutually exclusive to the existing ones. That way, we don't need to
>> touch any existing user.
> 
> May as well bite the bullet and do the refactoring, it should be
> automatable.  There's also the fun of handling what happens when you
> want to stream from one CODEC to another but I think that's second
> stage...

Looking deeper into this, I'm not sure whether each of those codec
instances inside one snd_soc_dai_link should have it own runtime, of if
they should rather share one. The latter isn't straight-forward, as
current users simply access the codec from their callbacks as
rtd->codec_dai. However, open-coding routines to access the correct
codec from these callbacks is not nice at all either. Hmm.

Let's see if DPCM can help here.


Daniel

  reply	other threads:[~2013-07-17  9:16 UTC|newest]

Thread overview: 8+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2013-07-16 14:31 Connecting two Codecs to the same CPU DAI Daniel Mack
2013-07-16 16:20 ` Mark Brown
2013-07-16 16:33   ` Daniel Mack
2013-07-16 16:57     ` Mark Brown
2013-07-16 17:07       ` Daniel Mack
2013-07-16 17:47         ` Mark Brown
2013-07-17  9:16           ` Daniel Mack [this message]
2013-07-17  9:31             ` Mark Brown

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=51E660E6.4010902@gmail.com \
    --to=zonque@gmail.com \
    --cc=alsa-devel@alsa-project.org \
    --cc=broonie@kernel.org \
    --cc=lgirdwood@gmail.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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.