Message ID | 20201106184104.939284-3-pmalani@chromium.org (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
Series | platform/chrome: cros_ec_typec: Add cable | expand |
On Fri, Nov 06, 2020 at 10:41:01AM -0800, Prashant Malani wrote: > Factor out the PD identity parsing code into a separate function. This > way it can be re-used for Cable PD identity parsing in future patches. > > No functional changes are introduced by this patch. > > Signed-off-by: Prashant Malani <pmalani@chromium.org> Reviewed-by: Heikki Krogerus <heikki.krogerus@linux.intel.com> > --- > > Changes in v2: > - No changes. > > drivers/platform/chrome/cros_ec_typec.c | 35 ++++++++++++++++--------- > 1 file changed, 23 insertions(+), 12 deletions(-) > > diff --git a/drivers/platform/chrome/cros_ec_typec.c b/drivers/platform/chrome/cros_ec_typec.c > index 801c3d2c1fbd..f6d3c37c2c27 100644 > --- a/drivers/platform/chrome/cros_ec_typec.c > +++ b/drivers/platform/chrome/cros_ec_typec.c > @@ -657,6 +657,28 @@ static int cros_typec_register_altmodes(struct cros_typec_data *typec, int port_ > return ret; > } > > +/* > + * Parse the PD identity data from the EC PD discovery responses and copy that to the supplied > + * PD identity struct. > + */ > +static void cros_typec_parse_pd_identity(struct usb_pd_identity *id, > + struct ec_response_typec_discovery *disc) > +{ > + int i; > + > + /* First, update the PD identity VDOs for the partner. */ > + if (disc->identity_count > 0) > + id->id_header = disc->discovery_vdo[0]; > + if (disc->identity_count > 1) > + id->cert_stat = disc->discovery_vdo[1]; > + if (disc->identity_count > 2) > + id->product = disc->discovery_vdo[2]; > + > + /* Copy the remaining identity VDOs till a maximum of 6. */ > + for (i = 3; i < disc->identity_count && i < VDO_MAX_OBJECTS; i++) > + id->vdo[i - 3] = disc->discovery_vdo[i]; > +} > + > static int cros_typec_handle_sop_disc(struct cros_typec_data *typec, int port_num) > { > struct cros_typec_port *port = typec->ports[port_num]; > @@ -666,7 +688,6 @@ static int cros_typec_handle_sop_disc(struct cros_typec_data *typec, int port_nu > .partner_type = TYPEC_PARTNER_SOP, > }; > int ret = 0; > - int i; > > if (!port->partner) { > dev_err(typec->dev, > @@ -684,17 +705,7 @@ static int cros_typec_handle_sop_disc(struct cros_typec_data *typec, int port_nu > goto disc_exit; > } > > - /* First, update the PD identity VDOs for the partner. */ > - if (sop_disc->identity_count > 0) > - port->p_identity.id_header = sop_disc->discovery_vdo[0]; > - if (sop_disc->identity_count > 1) > - port->p_identity.cert_stat = sop_disc->discovery_vdo[1]; > - if (sop_disc->identity_count > 2) > - port->p_identity.product = sop_disc->discovery_vdo[2]; > - > - /* Copy the remaining identity VDOs till a maximum of 6. */ > - for (i = 3; i < sop_disc->identity_count && i < VDO_MAX_OBJECTS; i++) > - port->p_identity.vdo[i - 3] = sop_disc->discovery_vdo[i]; > + cros_typec_parse_pd_identity(&port->p_identity, sop_disc); > > ret = typec_partner_set_identity(port->partner); > if (ret < 0) { > -- thanks,
diff --git a/drivers/platform/chrome/cros_ec_typec.c b/drivers/platform/chrome/cros_ec_typec.c index 801c3d2c1fbd..f6d3c37c2c27 100644 --- a/drivers/platform/chrome/cros_ec_typec.c +++ b/drivers/platform/chrome/cros_ec_typec.c @@ -657,6 +657,28 @@ static int cros_typec_register_altmodes(struct cros_typec_data *typec, int port_ return ret; } +/* + * Parse the PD identity data from the EC PD discovery responses and copy that to the supplied + * PD identity struct. + */ +static void cros_typec_parse_pd_identity(struct usb_pd_identity *id, + struct ec_response_typec_discovery *disc) +{ + int i; + + /* First, update the PD identity VDOs for the partner. */ + if (disc->identity_count > 0) + id->id_header = disc->discovery_vdo[0]; + if (disc->identity_count > 1) + id->cert_stat = disc->discovery_vdo[1]; + if (disc->identity_count > 2) + id->product = disc->discovery_vdo[2]; + + /* Copy the remaining identity VDOs till a maximum of 6. */ + for (i = 3; i < disc->identity_count && i < VDO_MAX_OBJECTS; i++) + id->vdo[i - 3] = disc->discovery_vdo[i]; +} + static int cros_typec_handle_sop_disc(struct cros_typec_data *typec, int port_num) { struct cros_typec_port *port = typec->ports[port_num]; @@ -666,7 +688,6 @@ static int cros_typec_handle_sop_disc(struct cros_typec_data *typec, int port_nu .partner_type = TYPEC_PARTNER_SOP, }; int ret = 0; - int i; if (!port->partner) { dev_err(typec->dev, @@ -684,17 +705,7 @@ static int cros_typec_handle_sop_disc(struct cros_typec_data *typec, int port_nu goto disc_exit; } - /* First, update the PD identity VDOs for the partner. */ - if (sop_disc->identity_count > 0) - port->p_identity.id_header = sop_disc->discovery_vdo[0]; - if (sop_disc->identity_count > 1) - port->p_identity.cert_stat = sop_disc->discovery_vdo[1]; - if (sop_disc->identity_count > 2) - port->p_identity.product = sop_disc->discovery_vdo[2]; - - /* Copy the remaining identity VDOs till a maximum of 6. */ - for (i = 3; i < sop_disc->identity_count && i < VDO_MAX_OBJECTS; i++) - port->p_identity.vdo[i - 3] = sop_disc->discovery_vdo[i]; + cros_typec_parse_pd_identity(&port->p_identity, sop_disc); ret = typec_partner_set_identity(port->partner); if (ret < 0) {
Factor out the PD identity parsing code into a separate function. This way it can be re-used for Cable PD identity parsing in future patches. No functional changes are introduced by this patch. Signed-off-by: Prashant Malani <pmalani@chromium.org> --- Changes in v2: - No changes. drivers/platform/chrome/cros_ec_typec.c | 35 ++++++++++++++++--------- 1 file changed, 23 insertions(+), 12 deletions(-)