Commit 113972d2 authored by Hector Martin's avatar Hector Martin Committed by Greg Kroah-Hartman

usb: typec: tipd: Fix initialization sequence for cd321x

The power state switch needs to happen first, as that
kickstarts the firmware into normal mode.

Fixes: c9c14be6 ("usb: typec: tipd: Switch CD321X power state to S0")
Reviewed-by: default avatarHeikki Krogerus <heikki.krogerus@linux.intel.com>
Reviewed-by: default avatarSven Peter <sven@svenpeter.dev>
Signed-off-by: default avatarHector Martin <marcan@marcan.st>
Link: https://lore.kernel.org/r/20211120030717.84287-3-marcan@marcan.stSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 7b9c90e3
...@@ -707,6 +707,7 @@ static int tps6598x_probe(struct i2c_client *client) ...@@ -707,6 +707,7 @@ static int tps6598x_probe(struct i2c_client *client)
u32 conf; u32 conf;
u32 vid; u32 vid;
int ret; int ret;
u64 mask1;
tps = devm_kzalloc(&client->dev, sizeof(*tps), GFP_KERNEL); tps = devm_kzalloc(&client->dev, sizeof(*tps), GFP_KERNEL);
if (!tps) if (!tps)
...@@ -730,11 +731,6 @@ static int tps6598x_probe(struct i2c_client *client) ...@@ -730,11 +731,6 @@ static int tps6598x_probe(struct i2c_client *client)
if (i2c_check_functionality(client->adapter, I2C_FUNC_I2C)) if (i2c_check_functionality(client->adapter, I2C_FUNC_I2C))
tps->i2c_protocol = true; tps->i2c_protocol = true;
/* Make sure the controller has application firmware running */
ret = tps6598x_check_mode(tps);
if (ret)
return ret;
if (np && of_device_is_compatible(np, "apple,cd321x")) { if (np && of_device_is_compatible(np, "apple,cd321x")) {
/* Switch CD321X chips to the correct system power state */ /* Switch CD321X chips to the correct system power state */
ret = cd321x_switch_power_state(tps, TPS_SYSTEM_POWER_STATE_S0); ret = cd321x_switch_power_state(tps, TPS_SYSTEM_POWER_STATE_S0);
...@@ -742,23 +738,26 @@ static int tps6598x_probe(struct i2c_client *client) ...@@ -742,23 +738,26 @@ static int tps6598x_probe(struct i2c_client *client)
return ret; return ret;
/* CD321X chips have all interrupts masked initially */ /* CD321X chips have all interrupts masked initially */
ret = tps6598x_write64(tps, TPS_REG_INT_MASK1, mask1 = APPLE_CD_REG_INT_POWER_STATUS_UPDATE |
APPLE_CD_REG_INT_POWER_STATUS_UPDATE |
APPLE_CD_REG_INT_DATA_STATUS_UPDATE | APPLE_CD_REG_INT_DATA_STATUS_UPDATE |
APPLE_CD_REG_INT_PLUG_EVENT); APPLE_CD_REG_INT_PLUG_EVENT;
if (ret)
return ret;
irq_handler = cd321x_interrupt; irq_handler = cd321x_interrupt;
} else { } else {
/* Enable power status, data status and plug event interrupts */ /* Enable power status, data status and plug event interrupts */
ret = tps6598x_write64(tps, TPS_REG_INT_MASK1, mask1 = TPS_REG_INT_POWER_STATUS_UPDATE |
TPS_REG_INT_POWER_STATUS_UPDATE |
TPS_REG_INT_DATA_STATUS_UPDATE | TPS_REG_INT_DATA_STATUS_UPDATE |
TPS_REG_INT_PLUG_EVENT); TPS_REG_INT_PLUG_EVENT;
}
/* Make sure the controller has application firmware running */
ret = tps6598x_check_mode(tps);
if (ret)
return ret;
ret = tps6598x_write64(tps, TPS_REG_INT_MASK1, mask1);
if (ret) if (ret)
return ret; return ret;
}
ret = tps6598x_read32(tps, TPS_REG_STATUS, &status); ret = tps6598x_read32(tps, TPS_REG_STATUS, &status);
if (ret < 0) if (ret < 0)
......
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