[PATCH 4/4] ASoC: enable wm8753 in aspenite
Haojian Zhuang
haojian.zhuang at gmail.com
Fri Apr 2 00:40:30 EDT 2010
On Fri, Apr 2, 2010 at 2:21 AM, Mark Brown
<broonie at opensource.wolfsonmicro.com> wrote:
> On Wed, Mar 31, 2010 at 08:48:58AM -0400, Haojian Zhuang wrote:
>
>> +/* Seek the index of MCLK configuration table */
>> +static int pxa168_seek_mclk_conf(int rate, int format, int channel)
>> +{
>> + int i;
>> +
>> + for (i = 0; i < ARRAY_SIZE(mclk_conf); i++) {
>> + if ((mclk_conf[i].rate == rate)
>> + && (mclk_conf[i].format == format)
>> + && (mclk_conf[i].channel == channel))
>> + return i;
>> + }
>> + return -EINVAL;
>> +}
>
>> +/* Get the MCLK frequency */
>> +static int pxa168_get_mclk(int i)
>> +{
>> + if ((i < 0) || (i >= ARRAY_SIZE(mclk_conf)))
>> + return -EINVAL;
>> + return mclk_conf[i].mclk;
>> +}
>
> This stuff probably shouldn't be in the machine driver since pretty much
> all machine drivers are going to want exactly the same code - it should
> be in the library code. Probably best to have them take hw_params
> rather than require the machine driver to decode the format, rate and
> channel since that'll save a bit of per driver boiler plate if they
> don't otherwise need that information.
>
> As I said last time ideally machine drivers shouldn't have to see this
> at all, of course.
>
This functions is used to get the sysclk. It's the parameter that is
used in hw_params() of machine driver since we need set codec and cpu
sysclock. But hw_params() of machine driver is invoked before
hw_params() of cpu_dai.
That's the main reason. If hw_params() of cpu_dai is invoked before
machine driver. This issue won't exist.
More information about the linux-arm-kernel
mailing list