Commit 928adf0e authored by Stefan Binding's avatar Stefan Binding Committed by Takashi Iwai

ALSA: hda/cs8409: Use timeout rather than retries for I2C transaction waits

Signed-off-by: default avatarStefan Binding <sbinding@opensource.cirrus.com>
Signed-off-by: default avatarVitaly Rodionov <vitalyr@opensource.cirrus.com>
Link: https://lore.kernel.org/r/20210811185654.6837-25-vitalyr@opensource.cirrus.comSigned-off-by: default avatarTakashi Iwai <tiwai@suse.de>
parent fed0aaca
...@@ -140,24 +140,14 @@ static void cs8409_enable_i2c_clock(struct hda_codec *codec) ...@@ -140,24 +140,14 @@ static void cs8409_enable_i2c_clock(struct hda_codec *codec)
* @codec: the codec instance * @codec: the codec instance
* *
* Wait for I2C transaction to complete. * Wait for I2C transaction to complete.
* Return -1 if transaction wait times out. * Return -ETIMEDOUT if transaction wait times out.
*/ */
static int cs8409_i2c_wait_complete(struct hda_codec *codec) static int cs8409_i2c_wait_complete(struct hda_codec *codec)
{ {
int repeat = 5;
unsigned int retval; unsigned int retval;
do { return read_poll_timeout(cs8409_vendor_coef_get, retval, retval & 0x18,
retval = cs8409_vendor_coef_get(codec, CS8409_I2C_STS); CS42L42_I2C_SLEEP_US, CS42L42_I2C_TIMEOUT_US, false, codec, CS8409_I2C_STS);
if ((retval & 0x18) != 0x18) {
usleep_range(2000, 4000);
--repeat;
} else
return 0;
} while (repeat);
return -1;
} }
/** /**
......
...@@ -231,6 +231,8 @@ enum cs8409_coefficient_index_registers { ...@@ -231,6 +231,8 @@ enum cs8409_coefficient_index_registers {
#define CS42L42_HSTYPE_MASK (0x03) #define CS42L42_HSTYPE_MASK (0x03)
#define CS42L42_JACK_INSERTED (0x0C) #define CS42L42_JACK_INSERTED (0x0C)
#define CS42L42_JACK_REMOVED (0x00) #define CS42L42_JACK_REMOVED (0x00)
#define CS42L42_I2C_TIMEOUT_US (20000)
#define CS42L42_I2C_SLEEP_US (2000)
/* Dell BULLSEYE / WARLOCK / CYBORG Specific Definitions */ /* Dell BULLSEYE / WARLOCK / CYBORG Specific Definitions */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment