Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 16963513 authored by Linux Build Service Account's avatar Linux Build Service Account Committed by Gerrit - the friendly Code Review server
Browse files

Merge "asoc: wcd938x: Fix swr get logical addr fail during SSR" into audio-drivers.lnx.4.0

parents e96eb4e5 9a37b81c
Loading
Loading
Loading
Loading
+17 −8
Original line number Original line Diff line number Diff line
@@ -41,6 +41,8 @@
#define ADC_MODE_VAL_ULP1     0x09
#define ADC_MODE_VAL_ULP1     0x09
#define ADC_MODE_VAL_ULP2     0x0B
#define ADC_MODE_VAL_ULP2     0x0B


#define NUM_ATTEMPTS 5

enum {
enum {
	CODEC_TX = 0,
	CODEC_TX = 0,
	CODEC_RX,
	CODEC_RX,
@@ -1842,15 +1844,18 @@ static int wcd938x_get_logical_addr(struct swr_device *swr_dev)
{
{
	int ret = 0;
	int ret = 0;
	uint8_t devnum = 0;
	uint8_t devnum = 0;
	int num_retry = NUM_ATTEMPTS;


	do {
		ret = swr_get_logical_dev_num(swr_dev, swr_dev->addr, &devnum);
		ret = swr_get_logical_dev_num(swr_dev, swr_dev->addr, &devnum);
		if (ret) {
		if (ret) {
			dev_err(&swr_dev->dev,
			dev_err(&swr_dev->dev,
				"%s get devnum %d for dev addr %lx failed\n",
				"%s get devnum %d for dev addr %lx failed\n",
				__func__, devnum, swr_dev->addr);
				__func__, devnum, swr_dev->addr);
		swr_remove_device(swr_dev);
			/* retry after 1ms */
		return ret;
			usleep_range(1000, 1010);
		}
		}
	} while (ret && --num_retry);
	swr_dev->dev_num = devnum;
	swr_dev->dev_num = devnum;
	return 0;
	return 0;
}
}
@@ -1904,8 +1909,12 @@ static int wcd938x_event_notify(struct notifier_block *block,
		break;
		break;
	case BOLERO_WCD_EVT_SSR_UP:
	case BOLERO_WCD_EVT_SSR_UP:
		wcd938x_reset(wcd938x->dev);
		wcd938x_reset(wcd938x->dev);
		/* allow reset to take effect */
		usleep_range(10000, 10010);

		wcd938x_get_logical_addr(wcd938x->tx_swr_dev);
		wcd938x_get_logical_addr(wcd938x->tx_swr_dev);
		wcd938x_get_logical_addr(wcd938x->rx_swr_dev);
		wcd938x_get_logical_addr(wcd938x->rx_swr_dev);

		wcd938x_init_reg(component);
		wcd938x_init_reg(component);
		regcache_mark_dirty(wcd938x->regmap);
		regcache_mark_dirty(wcd938x->regmap);
		regcache_sync(wcd938x->regmap);
		regcache_sync(wcd938x->regmap);