diff options
author | Mark Brown <broonie@kernel.org> | 2014-11-19 10:48:20 +0000 |
---|---|---|
committer | Mark Brown <broonie@kernel.org> | 2014-11-19 10:48:20 +0000 |
commit | e975cec295ea71d5ad01fd3b6195670d3e31885e (patch) | |
tree | 0b74ba93cecd9d577d6835e77ad7020f5b22db87 /include/sound | |
parent | c534107fd229ca7d8ae707b3936365445de9ca89 (diff) | |
parent | 20feb881988cdf5f53304c355ae8ee3bf82e80ec (diff) |
Merge branch 'topic/regmap' of git://git.kernel.org/pub/scm/linux/kernel/git/broonie/sound into asoc-ac97
Diffstat (limited to 'include/sound')
-rw-r--r-- | include/sound/soc.h | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/include/sound/soc.h b/include/sound/soc.h index 9e513ae1174..80ca937a20d 100644 --- a/include/sound/soc.h +++ b/include/sound/soc.h @@ -1286,6 +1286,41 @@ void snd_soc_component_async_complete(struct snd_soc_component *component); int snd_soc_component_test_bits(struct snd_soc_component *component, unsigned int reg, unsigned int mask, unsigned int value); +void snd_soc_component_init_regmap(struct snd_soc_component *component, + struct regmap *regmap); +void snd_soc_component_exit_regmap(struct snd_soc_component *component); + +/** + * snd_soc_codec_init_regmap() - Initialize regmap instance for the CODEC + * @codec: The CODEC for which to initialize the regmap instance + * @regmap: The regmap instance that should be used by the CODEC + * + * This function allows deferred assignment of the regmap instance that is + * associated with the CODEC. Only use this if the regmap instance is not yet + * ready when the CODEC is registered. The function must also be called before + * the first IO attempt of the CODEC. + */ +static inline void snd_soc_codec_init_regmap(struct snd_soc_codec *codec, + struct regmap *regmap) +{ + snd_soc_component_init_regmap(&codec->component, regmap); +} + +/** + * snd_soc_codec_exit_regmap() - De-initialize regmap instance for the CODEC + * @codec: The CODEC for which to de-initialize the regmap instance + * + * Calls regmap_exit() on the regmap instance associated to the CODEC and + * removes the regmap instance from the CODEC. + * + * This function should only be used if snd_soc_codec_init_regmap() was used to + * initialize the regmap instance. + */ +static inline void snd_soc_codec_exit_regmap(struct snd_soc_codec *codec) +{ + snd_soc_component_exit_regmap(&codec->component); +} + /* device driver data */ static inline void snd_soc_card_set_drvdata(struct snd_soc_card *card, |