[alsa-devel] HD-Audio: How to reduce driver initializaton time if multiple codecs present on the bus?
Takashi Iwai
tiwai at suse.de
Fri Nov 29 08:49:56 CET 2013
At Fri, 29 Nov 2013 15:31:59 +0800,
David Henningsson wrote:
>
> 2013-11-29 14:40, Takashi Iwai skrev:
> > At Fri, 29 Nov 2013 14:30:48 +0800,
> > David Henningsson wrote:
> >> 2013-11-28 22:57, Lin, Mengdong skrev:
> >>> Hi Takashi,
> >>>
> >>> We're trying to reduce the HD-A driver initialization time when more than one codecs are connected to the bus, but are blocked.
> >>> Would you please share some advices on this?
> >>>
> >>> Usually, there is one HD-A controller connecting to two codecs: one on-board codec and one integrated display codec.
> >>> During initialization, the codecs are created and configured in a serial way.
> >>>
> >>> Creating a codec may cost 6~20ms, and then building controls make cost about 15~30ms.
> >> Sorry for interrupting, but I just wonder - I assume you have a maximum
> >> of 4 CPUs. Can't the other 3 CPUs be used to load other non-audio
> >> hardware in parallel instead? It sounds you're going to run into lock
> >> contention instead if you try to modify the same card from two threads
> >> simultaneously.
> > IIRC, PCI device probes are done sequentially because asynchronous
> > probe caused too many troubles. And if it's a module, it's anyway
> > more strictly serialized.
>
> Okay. It just seems to me that from a bird's eye view that parallelizing
> module loading and pci probing would give us much bigger benefits than
> trying to parallellize internally in the snd-hda-intel driver.
Yeah, for a long run, this would be far benefit. But be warned,
several attempts in the past failed due to weird hardwares :)
> Btw, using a deferred azx_probe_continue (like we do if there's a
> firmware file), would one get more parallelization with other drivers?
> If so we could consider making that the default.
This sounds like a good idea as we have already that code. The patch
would be just a few-liners.
Takashi
More information about the Alsa-devel
mailing list