On Monday 19 September 2011 12:00:06 Mark Brown wrote:
On Thu, Sep 15, 2011 at 03:39:29PM +0300, Peter Ujfalusi wrote:
The default gains on outputs/inputs are set to 0dB. To be able to handle pop noise better, we need to lower the gains on controls, where it is possible.
It looks like what you really want to do here is implement support having PGAs able to cache the gain the user has set but hold the gain at zero while the PGA is disabled.
The twl6040 had support for this, but we did not lowered the initial gain after cold power on. This resulted a pop noise at the first time the audio paths had been used.
This would be generally useful, a lot of older parts liked to have the PGAs muted when powering them.
I have similar implementation (caching of the output gain values) in the twl4030 - there the reason was to decrease the power consumption. We need to have some sort of caching for the gain values, and linking the volume controls to DAPM in order to restore, or turn them off at the correct time. In twl4030 case I have custom PGA event handlers for outputs, and I manage the individual output amplifiers through them. Here in twl6040 we also have event handlers to do the ramp up/down on the gains. AFAIK some wm* codec have similar code.
I can take a look at these to find a generic way to handle them.
-- Péter