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

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.st


Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 7b9c90e3
Loading
Loading
Loading
Loading
+16 −17
Original line number Diff line number Diff line
@@ -707,6 +707,7 @@ static int tps6598x_probe(struct i2c_client *client)
	u32 conf;
	u32 vid;
	int ret;
	u64 mask1;

	tps = devm_kzalloc(&client->dev, sizeof(*tps), GFP_KERNEL);
	if (!tps)
@@ -730,11 +731,6 @@ static int tps6598x_probe(struct i2c_client *client)
	if (i2c_check_functionality(client->adapter, I2C_FUNC_I2C))
		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")) {
		/* Switch CD321X chips to the correct system power state */
		ret = cd321x_switch_power_state(tps, TPS_SYSTEM_POWER_STATE_S0);
@@ -742,23 +738,26 @@ static int tps6598x_probe(struct i2c_client *client)
			return ret;

		/* CD321X chips have all interrupts masked initially */
		ret = tps6598x_write64(tps, TPS_REG_INT_MASK1,
					APPLE_CD_REG_INT_POWER_STATUS_UPDATE |
		mask1 = APPLE_CD_REG_INT_POWER_STATUS_UPDATE |
			APPLE_CD_REG_INT_DATA_STATUS_UPDATE |
					APPLE_CD_REG_INT_PLUG_EVENT);
		if (ret)
			return ret;
			APPLE_CD_REG_INT_PLUG_EVENT;

		irq_handler = cd321x_interrupt;
	} else {
		/* Enable power status, data status and plug event interrupts */
		ret = tps6598x_write64(tps, TPS_REG_INT_MASK1,
				       TPS_REG_INT_POWER_STATUS_UPDATE |
		mask1 = TPS_REG_INT_POWER_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)
		return ret;
	}

	ret = tps6598x_read32(tps, TPS_REG_STATUS, &status);
	if (ret < 0)