]> www.infradead.org Git - users/jedix/linux-maple.git/commitdiff
usb: typec: ucsi: yoga-c630: remove extra AltModes for port 1
authorDmitry Baryshkov <dmitry.baryshkov@oss.qualcomm.com>
Sat, 21 Jun 2025 18:12:59 +0000 (21:12 +0300)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 24 Jun 2025 14:40:50 +0000 (15:40 +0100)
On Lenovo Yoga C630 the EC firmware is buggy and it cat return altmodes
for a device pushed into the port 0 (right) when the driver asks for
altmodes for port 1 (left). Since the left Type-C port doesn't support
DP anyway, ignore all UCSI_GET_ALTERNATE_MODES commands destined to the
port 1.

Signed-off-by: Dmitry Baryshkov <dmitry.baryshkov@oss.qualcomm.com>
Reviewed-by: Heikki Krogerus <heikki.krogerus@linux.intel.com>
Link: https://lore.kernel.org/r/20250621-c630-ucsi-v1-4-a86de5e11361@oss.qualcomm.com
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/usb/typec/ucsi/ucsi_yoga_c630.c

index 7cc1342d6e2f1d2c6f5b95caa48a711a280b91d3..2005f64ebfe43ca2bcada2231ff99c578fdce877 100644 (file)
@@ -71,6 +71,27 @@ static int yoga_c630_ucsi_async_control(struct ucsi *ucsi, u64 command)
        return yoga_c630_ec_ucsi_write(uec->ec, (u8*)&command);
 }
 
+static int yoga_c630_ucsi_sync_control(struct ucsi *ucsi,
+                                      u64 command,
+                                      u32 *cci,
+                                      void *data, size_t size)
+{
+       /*
+        * EC can return AltModes present on CON1 (port0, right) for CON2
+        * (port1, left) too. Ignore all requests going to CON2 (it doesn't
+        * support DP anyway).
+        */
+       if (UCSI_COMMAND(command) == UCSI_GET_ALTERNATE_MODES &&
+           UCSI_GET_ALTMODE_GET_CONNECTOR_NUMBER(command) == 2) {
+               dev_dbg(ucsi->dev, "ignoring altmodes for con2\n");
+               memset(data, 0, size);
+               *cci = UCSI_CCI_COMMAND_COMPLETE;
+               return 0;
+       }
+
+       return ucsi_sync_control_common(ucsi, command, cci, data, size);
+}
+
 static bool yoga_c630_ucsi_update_altmodes(struct ucsi *ucsi,
                                           u8 recipient,
                                           struct ucsi_altmode *orig,
@@ -98,7 +119,7 @@ static const struct ucsi_operations yoga_c630_ucsi_ops = {
        .read_cci = yoga_c630_ucsi_read_cci,
        .poll_cci = yoga_c630_ucsi_read_cci,
        .read_message_in = yoga_c630_ucsi_read_message_in,
-       .sync_control = ucsi_sync_control_common,
+       .sync_control = yoga_c630_ucsi_sync_control,
        .async_control = yoga_c630_ucsi_async_control,
        .update_altmodes = yoga_c630_ucsi_update_altmodes,
 };