From: Alexandre Ferrieux <[email protected]>

The aw88261_dev_reg_update() function sets the Awinic registers in a
rather nonuniform way:
  - most registers get directly overwritten from the firmware blob
  - but a handful of them need more delicate logic to preserve
    some bits from their current value, according to a register-
    specific mask
For the latter, the logic is basically
       NEW = (OLD & MASK) | (VAL & ~MASK)
However, the ~MASK value is hand-computed, and in the specific case
of the SYSCTRL register, in a buggy way.
This patch restores the proper ~MASK value.

Fixes: 028a2ae25691 ("ASoC: codecs: Add aw88261 amplifier driver")
Signed-off-by: Alexandre Ferrieux <[email protected]>
---
 sound/soc/codecs/aw88261.c | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)

diff --git a/sound/soc/codecs/aw88261.c b/sound/soc/codecs/aw88261.c
index 29b3fc8a1ea4..43c03d3cb252 100644
--- a/sound/soc/codecs/aw88261.c
+++ b/sound/soc/codecs/aw88261.c
@@ -424,9 +424,10 @@ static int aw88261_dev_reg_update(struct aw88261 *aw88261,
                        if (ret)
                                break;
 
+                       /* keep all three bits from current hw status */
                        read_val &= (~AW88261_AMPPD_MASK) | 
(~AW88261_PWDN_MASK) |
                                                                
(~AW88261_HMUTE_MASK);
-                       reg_val &= (AW88261_AMPPD_MASK | AW88261_PWDN_MASK | 
AW88261_HMUTE_MASK);
+                       reg_val &= (AW88261_AMPPD_MASK & AW88261_PWDN_MASK & 
AW88261_HMUTE_MASK);
                        reg_val |= read_val;
 
                        /* enable uls hmute */

-- 
2.53.0


Reply via email to