[alsa-devel] [PATCH] ASoC: wm_hubs: Fix DC Servo readback
wm_hubs is a common driver code shared by WM8958, WM1811, WM8944 and WM8993 all these codecs have the DC Servo Values either in register 57h or 59h. Current code was reading register 58h for WM8958 and WM8994 revisions 2 and 3 but looking at the data sheet the DC Servo Values are stored in register 57h for these codecs. This patch fixes it by reading the correct register for DC Servo
Signed-off-by: Nikesh Oswal nikesh@opensource.wolfsonmicro.com --- sound/soc/codecs/wm_hubs.c | 3 --- 1 file changed, 3 deletions(-)
diff --git a/sound/soc/codecs/wm_hubs.c b/sound/soc/codecs/wm_hubs.c index 916817f..95c5d71 100644 --- a/sound/soc/codecs/wm_hubs.c +++ b/sound/soc/codecs/wm_hubs.c @@ -210,9 +210,6 @@ static int wm_hubs_read_dc_servo(struct snd_soc_codec *codec, case 2: dcs_reg = WM8994_DC_SERVO_4E; break; - case 1: - dcs_reg = WM8994_DC_SERVO_READBACK; - break; default: dcs_reg = WM8993_DC_SERVO_3; break;
On Wed, Aug 13, 2014 at 11:47:20AM +0100, Nikesh Oswal wrote:
wm_hubs is a common driver code shared by WM8958, WM1811, WM8944 and WM8993 all these codecs have the DC Servo Values either in register 57h or 59h. Current code was reading register 58h for WM8958 and WM8994 revisions 2 and 3 but looking at the data sheet the DC Servo Values are stored in register 57h for these codecs. This patch fixes it by reading the correct register for DC Servo
Signed-off-by: Nikesh Oswal nikesh@opensource.wolfsonmicro.com
sound/soc/codecs/wm_hubs.c | 3 --- 1 file changed, 3 deletions(-)
diff --git a/sound/soc/codecs/wm_hubs.c b/sound/soc/codecs/wm_hubs.c index 916817f..95c5d71 100644 --- a/sound/soc/codecs/wm_hubs.c +++ b/sound/soc/codecs/wm_hubs.c @@ -210,9 +210,6 @@ static int wm_hubs_read_dc_servo(struct snd_soc_codec *codec, case 2: dcs_reg = WM8994_DC_SERVO_4E; break;
- case 1:
dcs_reg = WM8994_DC_SERVO_READBACK;
default: dcs_reg = WM8993_DC_SERVO_3; break;break;
--
This doesn't look right, firstly if it is the same register for all versions then surely we should change the code that sets dcs_readback_mode rather than setting that to different values but treating them the same. Although obviously if nothing still uses this case we could remove it as well.
Also I think the situation is more complex for example on version 4.4 of the datasheet for wm8994 the WR_VAL fields appear to be in register 59h. Which is not consistent with this.
Thanks, Charles
On Wed, Aug 13, 2014 at 12:08:44PM +0100, Charles Keepax wrote:
On Wed, Aug 13, 2014 at 11:47:20AM +0100, Nikesh Oswal wrote:
case 2: dcs_reg = WM8994_DC_SERVO_4E; break;
- case 1:
dcs_reg = WM8994_DC_SERVO_READBACK;
default: dcs_reg = WM8993_DC_SERVO_3; break;break;
This doesn't look right, firstly if it is the same register for all versions then surely we should change the code that sets dcs_readback_mode rather than setting that to different values but treating them the same. Although obviously if nothing still uses this case we could remove it as well.
Also I think the situation is more complex for example on version 4.4 of the datasheet for wm8994 the WR_VAL fields appear to be in register 59h. Which is not consistent with this.
There was a change in the DC servo between revisions of the WM8994 (at revision E from the look of the code). This isn't documented in the datasheets as they only document current silicon.
On Wed, Aug 13, 2014 at 12:38:41PM +0100, Mark Brown wrote:
On Wed, Aug 13, 2014 at 12:08:44PM +0100, Charles Keepax wrote:
On Wed, Aug 13, 2014 at 11:47:20AM +0100, Nikesh Oswal wrote:
case 2: dcs_reg = WM8994_DC_SERVO_4E; break;
- case 1:
dcs_reg = WM8994_DC_SERVO_READBACK;
default: dcs_reg = WM8993_DC_SERVO_3; break;break;
This doesn't look right, firstly if it is the same register for all versions then surely we should change the code that sets dcs_readback_mode rather than setting that to different values but treating them the same. Although obviously if nothing still uses this case we could remove it as well.
Also I think the situation is more complex for example on version 4.4 of the datasheet for wm8994 the WR_VAL fields appear to be in register 59h. Which is not consistent with this.
There was a change in the DC servo between revisions of the WM8994 (at revision E from the look of the code). This isn't documented in the datasheets as they only document current silicon.
Indeed, but this patch sets all revs of wm8994 to use register 57h. The lastest version of the datasheet has this register at 59h although some of the older versions of the datasheet (which likely match some older revs of the chip although no way to tell which one just from the datasheet) have it at 57h.
I think basically we need to get some clarity from hardware here on which revs use which address and update this patch to match, but either way it looks likely that this patch doesn't address the whole picture.
Thanks, Charles
On Wed, Aug 13, 2014 at 01:16:37PM +0100, Charles Keepax wrote:
On Wed, Aug 13, 2014 at 12:38:41PM +0100, Mark Brown wrote:
On Wed, Aug 13, 2014 at 12:08:44PM +0100, Charles Keepax wrote:
On Wed, Aug 13, 2014 at 11:47:20AM +0100, Nikesh Oswal wrote:
case 2: dcs_reg = WM8994_DC_SERVO_4E; break;
- case 1:
dcs_reg = WM8994_DC_SERVO_READBACK;
default: dcs_reg = WM8993_DC_SERVO_3; break;break;
This doesn't look right, firstly if it is the same register for all versions then surely we should change the code that sets dcs_readback_mode rather than setting that to different values but treating them the same. Although obviously if nothing still uses this case we could remove it as well.
Also I think the situation is more complex for example on version 4.4 of the datasheet for wm8994 the WR_VAL fields appear to be in register 59h. Which is not consistent with this.
There was a change in the DC servo between revisions of the WM8994 (at revision E from the look of the code). This isn't documented in the datasheets as they only document current silicon.
Indeed, but this patch sets all revs of wm8994 to use register 57h. The lastest version of the datasheet has this register at 59h although some of the older versions of the datasheet (which likely match some older revs of the chip although no way to tell which one just from the datasheet) have it at 57h.
I think basically we need to get some clarity from hardware here on which revs use which address and update this patch to match, but either way it looks likely that this patch doesn't address the whole picture.
Sorry no ignore me I am talking non-sense here. It still treats the newer revs correctly, I suspect this might be a nice change though:
--- a/sound/soc/codecs/wm_hubs.c +++ b/sound/soc/codecs/wm_hubs.c @@ -209,7 +209,7 @@ static int wm_hubs_read_dc_servo(struct snd_soc_codec *codec, dcs_reg = WM8994_DC_SERVO_4E; break; case 1: - dcs_reg = WM8994_DC_SERVO_READBACK; + dcs_reg = WM8994_DC_SERVO_4; break;
Thanks, Charles
On Wed, Aug 13, 2014 at 01:16:37PM +0100, Charles Keepax wrote:
On Wed, Aug 13, 2014 at 12:38:41PM +0100, Mark Brown wrote:
On Wed, Aug 13, 2014 at 12:08:44PM +0100, Charles Keepax wrote:
Also I think the situation is more complex for example on version 4.4 of the datasheet for wm8994 the WR_VAL fields appear to be in register 59h. Which is not consistent with this.
There was a change in the DC servo between revisions of the WM8994 (at revision E from the look of the code). This isn't documented in the datasheets as they only document current silicon.
Indeed, but this patch sets all revs of wm8994 to use register 57h. The lastest version of the datasheet has this register at 59h although some of the older versions of the datasheet (which likely match some older revs of the chip although no way to tell which one just from the datasheet) have it at 57h.
Yes, I'm agreeing with you - I'm pointing out what Nikesh has missed (you can see this from the changelogs as well). The patch will break anything using older devices.
I think basically we need to get some clarity from hardware here on which revs use which address and update this patch to match, but either way it looks likely that this patch doesn't address the whole picture.
This code got rather a lot of attention...
participants (3)
-
Charles Keepax
-
Mark Brown
-
Nikesh Oswal