ASoC: rt5645: store eq kcontrol byte in __be

The eq parameters binary is stored in __be. However, it is unsigned short
in rt5645_eq_param_s{} which will cause incorrect type assignment. So add
struct rt5645_eq_param_s_be16{} to store the eq binary and convert it to
unsigned short in rt5645->eq_param.

Cc: Oder Chiou <oder_chiou@realtek.com>
Signed-off-by: Bard liao <yung-chuan.liao@linux.intel.com>
Signed-off-by: Pierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>
Signed-off-by: Mark Brown <broonie@kernel.org>
This commit is contained in:
Bard liao 2019-01-04 20:02:48 -06:00 committed by Mark Brown
parent b468f379e1
commit 60b52ed627
No known key found for this signature in database
GPG Key ID: 24D68B725D5487D0

View File

@ -401,6 +401,11 @@ struct rt5645_eq_param_s {
unsigned short val; unsigned short val;
}; };
struct rt5645_eq_param_s_be16 {
__be16 reg;
__be16 val;
};
static const char *const rt5645_supply_names[] = { static const char *const rt5645_supply_names[] = {
"avdd", "avdd",
"cpvdd", "cpvdd",
@ -672,8 +677,8 @@ static int rt5645_hweq_get(struct snd_kcontrol *kcontrol,
{ {
struct snd_soc_component *component = snd_kcontrol_chip(kcontrol); struct snd_soc_component *component = snd_kcontrol_chip(kcontrol);
struct rt5645_priv *rt5645 = snd_soc_component_get_drvdata(component); struct rt5645_priv *rt5645 = snd_soc_component_get_drvdata(component);
struct rt5645_eq_param_s *eq_param = struct rt5645_eq_param_s_be16 *eq_param =
(struct rt5645_eq_param_s *)ucontrol->value.bytes.data; (struct rt5645_eq_param_s_be16 *)ucontrol->value.bytes.data;
int i; int i;
for (i = 0; i < RT5645_HWEQ_NUM; i++) { for (i = 0; i < RT5645_HWEQ_NUM; i++) {
@ -698,36 +703,33 @@ static int rt5645_hweq_put(struct snd_kcontrol *kcontrol,
{ {
struct snd_soc_component *component = snd_kcontrol_chip(kcontrol); struct snd_soc_component *component = snd_kcontrol_chip(kcontrol);
struct rt5645_priv *rt5645 = snd_soc_component_get_drvdata(component); struct rt5645_priv *rt5645 = snd_soc_component_get_drvdata(component);
struct rt5645_eq_param_s *eq_param = struct rt5645_eq_param_s_be16 *eq_param =
(struct rt5645_eq_param_s *)ucontrol->value.bytes.data; (struct rt5645_eq_param_s_be16 *)ucontrol->value.bytes.data;
int i; int i;
for (i = 0; i < RT5645_HWEQ_NUM; i++) { for (i = 0; i < RT5645_HWEQ_NUM; i++) {
eq_param[i].reg = be16_to_cpu(eq_param[i].reg); rt5645->eq_param[i].reg = be16_to_cpu(eq_param[i].reg);
eq_param[i].val = be16_to_cpu(eq_param[i].val); rt5645->eq_param[i].val = be16_to_cpu(eq_param[i].val);
} }
/* The final setting of the table should be RT5645_EQ_CTRL2 */ /* The final setting of the table should be RT5645_EQ_CTRL2 */
for (i = RT5645_HWEQ_NUM - 1; i >= 0; i--) { for (i = RT5645_HWEQ_NUM - 1; i >= 0; i--) {
if (eq_param[i].reg == 0) if (rt5645->eq_param[i].reg == 0)
continue; continue;
else if (eq_param[i].reg != RT5645_EQ_CTRL2) else if (rt5645->eq_param[i].reg != RT5645_EQ_CTRL2)
return 0; return 0;
else else
break; break;
} }
for (i = 0; i < RT5645_HWEQ_NUM; i++) { for (i = 0; i < RT5645_HWEQ_NUM; i++) {
if (!rt5645_validate_hweq(eq_param[i].reg) && if (!rt5645_validate_hweq(rt5645->eq_param[i].reg) &&
eq_param[i].reg != 0) rt5645->eq_param[i].reg != 0)
return 0; return 0;
else if (eq_param[i].reg == 0) else if (rt5645->eq_param[i].reg == 0)
break; break;
} }
memcpy(rt5645->eq_param, eq_param,
RT5645_HWEQ_NUM * sizeof(struct rt5645_eq_param_s));
return 0; return 0;
} }