platform/chrome: cros_ec_typec: Register PD CTRL cmd v2
authorPrashant Malani <pmalani@chromium.org>
Thu, 28 May 2020 11:36:05 +0000 (04:36 -0700)
committerEnric Balletbo i Serra <enric.balletbo@collabora.com>
Fri, 19 Jun 2020 17:16:18 +0000 (19:16 +0200)
Recognize EC_CMD_USB_PD_CONTROL command version 2. This is necessary in
order to process Type C mux information (like DP alt mode pin
configuration), which is needed by the Type C Connector class API to
configure the Type C muxes correctly

While we are here, rename the struct member storing this version number
from cmd_ver to pd_ctrl_ver, which more accurately reflects what is
being stored.

Also, slightly change the logic for calling
cros_typec_set_port_params_*(). Now, v0 is called when pd_ctrl_ver is 0,
and v1 is called otherwise.

Signed-off-by: Prashant Malani <pmalani@chromium.org>
Reviewed-by: Heikki Krogerus <heikki.krogerus@linux.intel.com>
Signed-off-by: Enric Balletbo i Serra <enric.balletbo@collabora.com>
drivers/platform/chrome/cros_ec_typec.c

index 6e79f917314bf96e11a531a9e6a934c21ed724d9..d69a88464cef0cef587fd9df0a6c3646371f672c 100644 (file)
@@ -37,7 +37,7 @@ struct cros_typec_data {
        struct device *dev;
        struct cros_ec_device *ec;
        int num_ports;
-       unsigned int cmd_ver;
+       unsigned int pd_ctrl_ver;
        /* Array of ports, indexed by port number. */
        struct cros_typec_port *ports[EC_USB_PD_MAX_PORTS];
        struct notifier_block nb;
@@ -340,7 +340,7 @@ static int cros_typec_port_update(struct cros_typec_data *typec, int port_num)
        req.mux = USB_PD_CTRL_MUX_NO_CHANGE;
        req.swap = USB_PD_CTRL_SWAP_NONE;
 
-       ret = cros_typec_ec_command(typec, typec->cmd_ver,
+       ret = cros_typec_ec_command(typec, typec->pd_ctrl_ver,
                                    EC_CMD_USB_PD_CONTROL, &req, sizeof(req),
                                    &resp, sizeof(resp));
        if (ret < 0)
@@ -351,7 +351,7 @@ static int cros_typec_port_update(struct cros_typec_data *typec, int port_num)
        dev_dbg(typec->dev, "Polarity %d: 0x%hhx\n", port_num, resp.polarity);
        dev_dbg(typec->dev, "State %d: %s\n", port_num, resp.state);
 
-       if (typec->cmd_ver == 1)
+       if (typec->pd_ctrl_ver != 0)
                cros_typec_set_port_params_v1(typec, port_num, &resp);
        else
                cros_typec_set_port_params_v0(typec, port_num,
@@ -374,13 +374,15 @@ static int cros_typec_get_cmd_version(struct cros_typec_data *typec)
        if (ret < 0)
                return ret;
 
-       if (resp.version_mask & EC_VER_MASK(1))
-               typec->cmd_ver = 1;
+       if (resp.version_mask & EC_VER_MASK(2))
+               typec->pd_ctrl_ver = 2;
+       else if (resp.version_mask & EC_VER_MASK(1))
+               typec->pd_ctrl_ver = 1;
        else
-               typec->cmd_ver = 0;
+               typec->pd_ctrl_ver = 0;
 
        dev_dbg(typec->dev, "PD Control has version mask 0x%hhx\n",
-               typec->cmd_ver);
+               typec->pd_ctrl_ver);
 
        return 0;
 }