ASoC: rt5514-spi: only enable wakeup when fully initialized
authorBrian Norris <briannorris@chromium.org>
Sat, 16 Dec 2017 04:07:23 +0000 (20:07 -0800)
committerMark Brown <broonie@kernel.org>
Tue, 19 Dec 2017 11:08:03 +0000 (11:08 +0000)
commit20220945b1a8e77c789dd4bb9aa1471b6e8695cc
tree7a05788bd86e923bdf26a28dfa2ffe812769ca86
parent346cccf88319344c9f513bd85df6ae2258e8a8ea
ASoC: rt5514-spi: only enable wakeup when fully initialized

If an rt5514-spi device is probed but the platform hasn't linked it in,
we might never fully request the SPI IRQ, nor configure the rt5514 DSP,
but we still might try to enable the SPI IRQ (enable_irq_wake()). This
is bad, and among other things, can cause the interrupt to trigger every
time we try to suspend the system (e.g., because the interrupt trigger
setting was never set properly).

Instead of setting our wakeup capabilities in the SPI driver probe
routine, let's wait until we've actually requested the IRQ.

Fixes issues seen on the "kevin" Chromebook (Samsung Chromebook Plus).

Fixes: 58f1c07d23cd ("ASoC: rt5514: Voice wakeup support.")
Signed-off-by: Brian Norris <briannorris@chromium.org>
Signed-off-by: Mark Brown <broonie@kernel.org>
sound/soc/codecs/rt5514-spi.c