ASoC: si476x: Remove custom register I/O implementation
The current si476x I/O implementation wraps the regmap for the core with functions that make the register map cache only when the device is powered down. This implementation appears to be incomplete since there is no code to synchronise the cache so writes done while the core is powered down will be ignored, the device will only be configured if it is powered. A better and more idiomatic approach would be to have the MFD manage the cache, making the device cache only when it powers things down. This also allows ASoC to use the standard regmap helpers for the device which helps remove the ASoC custom ones so do convert to do that. Signed-off-by: Mark Brown <broonie@linaro.org>
This commit is contained in:
		
					parent
					
						
							
								4a10c2ac2f
							
						
					
				
			
			
				commit
				
					
						d6173df35f
					
				
			
		
					 1 changed files with 1 additions and 45 deletions
				
			
		|  | @ -60,48 +60,6 @@ enum si476x_pcm_format { | |||
| 	SI476X_PCM_FORMAT_S24_LE	= 6, | ||||
| }; | ||||
| 
 | ||||
| static unsigned int si476x_codec_read(struct snd_soc_codec *codec, | ||||
| 				      unsigned int reg) | ||||
| { | ||||
| 	int err; | ||||
| 	unsigned int val; | ||||
| 	struct si476x_core *core = codec->control_data; | ||||
| 
 | ||||
| 	si476x_core_lock(core); | ||||
| 	if (!si476x_core_is_powered_up(core)) | ||||
| 		regcache_cache_only(core->regmap, true); | ||||
| 
 | ||||
| 	err = regmap_read(core->regmap, reg, &val); | ||||
| 
 | ||||
| 	if (!si476x_core_is_powered_up(core)) | ||||
| 		regcache_cache_only(core->regmap, false); | ||||
| 	si476x_core_unlock(core); | ||||
| 
 | ||||
| 	if (err < 0) | ||||
| 		return err; | ||||
| 
 | ||||
| 	return val; | ||||
| } | ||||
| 
 | ||||
| static int si476x_codec_write(struct snd_soc_codec *codec, | ||||
| 			      unsigned int reg, unsigned int val) | ||||
| { | ||||
| 	int err; | ||||
| 	struct si476x_core *core = codec->control_data; | ||||
| 
 | ||||
| 	si476x_core_lock(core); | ||||
| 	if (!si476x_core_is_powered_up(core)) | ||||
| 		regcache_cache_only(core->regmap, true); | ||||
| 
 | ||||
| 	err = regmap_write(core->regmap, reg, val); | ||||
| 
 | ||||
| 	if (!si476x_core_is_powered_up(core)) | ||||
| 		regcache_cache_only(core->regmap, false); | ||||
| 	si476x_core_unlock(core); | ||||
| 
 | ||||
| 	return err; | ||||
| } | ||||
| 
 | ||||
| static const struct snd_soc_dapm_widget si476x_dapm_widgets[] = { | ||||
| SND_SOC_DAPM_OUTPUT("LOUT"), | ||||
| SND_SOC_DAPM_OUTPUT("ROUT"), | ||||
|  | @ -239,7 +197,7 @@ static int si476x_codec_hw_params(struct snd_pcm_substream *substream, | |||
| 
 | ||||
| static int si476x_codec_probe(struct snd_soc_codec *codec) | ||||
| { | ||||
| 	codec->control_data = i2c_mfd_cell_to_core(codec->dev); | ||||
| 	codec->control_data = dev_get_regmap(codec->dev->parent, NULL); | ||||
| 	return 0; | ||||
| } | ||||
| 
 | ||||
|  | @ -268,8 +226,6 @@ static struct snd_soc_dai_driver si476x_dai = { | |||
| 
 | ||||
| static struct snd_soc_codec_driver soc_codec_dev_si476x = { | ||||
| 	.probe  = si476x_codec_probe, | ||||
| 	.read   = si476x_codec_read, | ||||
| 	.write  = si476x_codec_write, | ||||
| 	.dapm_widgets = si476x_dapm_widgets, | ||||
| 	.num_dapm_widgets = ARRAY_SIZE(si476x_dapm_widgets), | ||||
| 	.dapm_routes = si476x_dapm_routes, | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Mark Brown
				Mark Brown