Commit 7ac50510 authored by Kyle Tso's avatar Kyle Tso Committed by Greg Kroah-Hartman

usb: typec: tcpm: Introduce snk_vdo_v1 for SVDM version 1.0

The ID Header VDO and Product VDOs defined in USB PD Spec rev 2.0 and
rev 3.1 are quite different. Add an additional array snk_vdo_v1 and
send it as the response to the port partner if it only supports SVDM
version 1.0.
Acked-by: default avatarHeikki Krogerus <heikki.krogerus@linux.intel.com>
Signed-off-by: default avatarKyle Tso <kyletso@google.com>
Link: https://lore.kernel.org/r/20210601123151.3441914-4-kyletso@google.comSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 55b54c26
...@@ -401,6 +401,8 @@ struct tcpm_port { ...@@ -401,6 +401,8 @@ struct tcpm_port {
unsigned int nr_src_pdo; unsigned int nr_src_pdo;
u32 snk_pdo[PDO_MAX_OBJECTS]; u32 snk_pdo[PDO_MAX_OBJECTS];
unsigned int nr_snk_pdo; unsigned int nr_snk_pdo;
u32 snk_vdo_v1[VDO_MAX_OBJECTS];
unsigned int nr_snk_vdo_v1;
u32 snk_vdo[VDO_MAX_OBJECTS]; u32 snk_vdo[VDO_MAX_OBJECTS];
unsigned int nr_snk_vdo; unsigned int nr_snk_vdo;
...@@ -1561,18 +1563,16 @@ static int tcpm_pd_svdm(struct tcpm_port *port, struct typec_altmode *adev, ...@@ -1561,18 +1563,16 @@ static int tcpm_pd_svdm(struct tcpm_port *port, struct typec_altmode *adev,
*/ */
if ((port->data_role == TYPEC_DEVICE || svdm_version >= SVDM_VER_2_0) && if ((port->data_role == TYPEC_DEVICE || svdm_version >= SVDM_VER_2_0) &&
port->nr_snk_vdo) { port->nr_snk_vdo) {
/* if (svdm_version < SVDM_VER_2_0) {
* Product Type DFP and Connector Type are not defined in SVDM for (i = 0; i < port->nr_snk_vdo_v1; i++)
* version 1.0 and shall be set to zero. response[i + 1] = port->snk_vdo_v1[i];
*/ rlen = port->nr_snk_vdo_v1 + 1;
if (svdm_version < SVDM_VER_2_0)
response[1] = port->snk_vdo[0] & ~IDH_DFP_MASK } else {
& ~IDH_CONN_MASK; for (i = 0; i < port->nr_snk_vdo; i++)
else response[i + 1] = port->snk_vdo[i];
response[1] = port->snk_vdo[0]; rlen = port->nr_snk_vdo + 1;
for (i = 1; i < port->nr_snk_vdo; i++) }
response[i + 1] = port->snk_vdo[i];
rlen = port->nr_snk_vdo + 1;
} }
break; break;
case CMD_DISCOVER_SVID: case CMD_DISCOVER_SVID:
...@@ -5953,6 +5953,22 @@ static int tcpm_fw_get_caps(struct tcpm_port *port, ...@@ -5953,6 +5953,22 @@ static int tcpm_fw_get_caps(struct tcpm_port *port,
return ret; return ret;
} }
/* If sink-vdos is found, sink-vdos-v1 is expected for backward compatibility. */
if (port->nr_snk_vdo) {
ret = fwnode_property_count_u32(fwnode, "sink-vdos-v1");
if (ret < 0)
return ret;
else if (ret == 0)
return -ENODATA;
port->nr_snk_vdo_v1 = min(ret, VDO_MAX_OBJECTS);
ret = fwnode_property_read_u32_array(fwnode, "sink-vdos-v1",
port->snk_vdo_v1,
port->nr_snk_vdo_v1);
if (ret < 0)
return ret;
}
return 0; return 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