[alsa-devel] [PATCHv2 - CA0132 HDA Codec 1/2] ALSA: Update Creative CA0132 codec to add DSP features.
Takashi Iwai
tiwai at suse.de
Tue Jul 31 17:15:40 CEST 2012
At Mon, 30 Jul 2012 15:49:00 -0700,
Ian Minett wrote:
>
> >> One thought we have is to handle the spin_lock_irqxxx() as a special
> >> case or quirk for the CA0132 codec. Using an approach similar to
> >> 'needs_damn_long_delay' in the CA0110 patch, we could define another
> >> flag e.g. 'needs_trigger_irqsave' in hda_codec.h struct hda_bus{}. In
> >> the CA0132 patch, we would set this flag, which would then be read in
> >> hda_intel.c,azx_pcm_trigger(). Either spin_lock_irqxxx() or the current
> >> spin_lock() would then be called depending on the flag condition.
> >> What is your opinion on an approach like this? Would this be acceptable?
>
> >No. The fact that you are calling the PCM functions is already
> >wrong. The irqsave() is just a side-effect by that, and we can forget
> >about it completely now.
>
> >The only question is where to implement the DSP loader stuff and how.
>
> Ok, we understand. Given that the codec cannot call into the controller's
> PCM interface to load the DSP image, is there an acceptable way you could
> recommend for us to add this functionality to the module, without breaking
> the architecture?
Well, as mentioned earlier, we need to push it up to the controller
layer, i.e. hda_intel.c. For example, add a new op for firmware DMA
transfer in hda_bus_ops.
Could you describe briefly the procedure for the DMA transfer of
CA0132? The code looks too complex to follow.
thanks,
Takashi
More information about the Alsa-devel
mailing list