Hi
I'd like to clarify a bit. Also more details below. My system is IP phone, that has a DSP device (proprietary of Audiocodes). Currently, I did things in user space. I read a buffer from ALSA (capture), and write it to the DSP. I read a buffer from the DSP, and write it to the ALSA. The problem is that when I establish a call, there are many things happening, so probably my user space threads don't run on time, so I get under runs and over runs, from which I couldn't recover.
I wanted to move to kernel to assure CPU for the ALSA I/O. I want a very simple thing. I don't mind even changing the my USB ALSA driver to call my DSP_TX whenever it has a capture buffer ready, and to be able to do something like snd_pcm_writei (or mmap_writei) from my DSP driver. I just don't know where to hack to it...
I still don't understand if I need ALSA driver (in which there is no DAI), or an ASOC driver. BTW, I don't need any "mixer" capabilities.
Thanks, Eli.
My system is IP phone. -----Original Message----- From: Liam Girdwood [mailto:liam.r.girdwood@linux.intel.com] Sent: Thursday, November 27, 2014 15:12 To: Eli Britstein Cc: alsa-devel@alsa-project.org; Mark Brown Subject: Re: [alsa-devel] ALSA/ASOC new device and routing
Reflowed the message.
On Thu, 2014-11-27 at 09:21 +0000, Eli Britstein wrote:
Hi
I'm a newbie to ALSA. I'm targeting to use ALSA or ASoC solution in order to route capture/playback streams of a USB headset (that uses ALSA) to/from my own DSP device. I saw DPCM which is a part of ASoC manages dynamically connections between FE and BE streams. In my product, I just need them to be connected. No need for the "dynamically" part.
Ok, so you have standard static routing from source to sink. ? or does your DSP allow routing from PCM 0 to HW port 0 .. N ? [EliB] my DSP doesn't have any relationship with ALSA, so I guess the answer for that is no.
Best to also describe your HW in more detail so that people on the list can provide better answers. [EliB] see above.
My questions:
- Can someone please recommend a step by step guide, or an example
how to make my DSP "look like" a BE? Do I need to write an ALSA driver for it or a ASOC driver?
If the routing is static then there is no need to create FE and BE DAI links for your DSP. Just create standard PCM and DAI link. Otherwise have a look at existing DPCM based drivers like Intel Haswell/Broadwell and OMAP4. [EliB] the routing I want is static.
- After I have it as a BE, how can I connect the streams? I want the
transfers to be done in kernel level, without need for application interventions for each buffer.
The connection depends on your DSP routing topology. Again look at the existing examples. I think you are also asking about DMA here ? if so, the kernel takes care of DMA configuration, however your application will probably still have to perform IO on your audio buffers.
- I'm using kernel 2.6.10 (quite old, I know). I don't want to port
my entire kernel to a new one. As my requirement is not very complex, I don't think I'd encounter too many issues. However, if someone can point the important parts I need to back port, I'd appreciate it. Alternatively, if someone sees a showstopper in this approach, I'd be grateful to be aware of it.
2.6.10 is really ancient and there have been many improvements since. I would strongly recommend upgrading to the latest release.
[EliB] I understand, but I cannot. Such upgrade is quite massive. As I think my requirements are quite simple, I think I can live without it.
Liam
Thanks, Best regards,
Eli
________________________________
This email and any files transmitted with it are confidential material. They are intended solely for the use of the designated individual or entity to whom they are addressed. If the reader of this message is not the intended recipient, you are hereby notified that any dissemination, use, distribution or copying of this communication is strictly prohibited and may be unlawful.
If you have received this email in error please immediately notify the sender and delete or destroy any copy of this message