diff options
Diffstat (limited to 'sound/soc/codecs/wsa881x.c')
| -rw-r--r-- | sound/soc/codecs/wsa881x.c | 16 | 
1 files changed, 10 insertions, 6 deletions
| diff --git a/sound/soc/codecs/wsa881x.c b/sound/soc/codecs/wsa881x.c index f3a56f3ce487..6c8b1db649b8 100644 --- a/sound/soc/codecs/wsa881x.c +++ b/sound/soc/codecs/wsa881x.c @@ -749,11 +749,9 @@ static int wsa881x_put_pa_gain(struct snd_kcontrol *kc,  	unsigned int mask = (1 << fls(max)) - 1;  	int val, ret, min_gain, max_gain; -	ret = pm_runtime_get_sync(comp->dev); -	if (ret < 0 && ret != -EACCES) { -		pm_runtime_put_noidle(comp->dev); +	ret = pm_runtime_resume_and_get(comp->dev); +	if (ret < 0 && ret != -EACCES)  		return ret; -	}  	max_gain = (max - ucontrol->value.integer.value[0]) & mask;  	/* @@ -1175,11 +1173,17 @@ static int __maybe_unused wsa881x_runtime_resume(struct device *dev)  	struct sdw_slave *slave = dev_to_sdw_dev(dev);  	struct regmap *regmap = dev_get_regmap(dev, NULL);  	struct wsa881x_priv *wsa881x = dev_get_drvdata(dev); +	unsigned long time;  	gpiod_direction_output(wsa881x->sd_n, 1); -	wait_for_completion_timeout(&slave->initialization_complete, -				    msecs_to_jiffies(WSA881X_PROBE_TIMEOUT)); +	time = wait_for_completion_timeout(&slave->initialization_complete, +					   msecs_to_jiffies(WSA881X_PROBE_TIMEOUT)); +	if (!time) { +		dev_err(dev, "Initialization not complete, timed out\n"); +		gpiod_direction_output(wsa881x->sd_n, 0); +		return -ETIMEDOUT; +	}  	regcache_cache_only(regmap, false);  	regcache_sync(regmap); | 
