usb: typec: ucsi: Start using struct typec_operations
Supplying the operation callbacks as part of a struct typec_operations instead of as part of struct typec_capability during port registration. Signed-off-by: Heikki Krogerus <heikki.krogerus@linux.intel.com> Reviewed-by: Guenter Roeck <linux@roeck-us.net> Link: https://lore.kernel.org/r/20191104142435.29960-7-heikki.krogerus@linux.intel.com Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
Родитель
1007dda3be
Коммит
6df475f804
|
@ -17,9 +17,6 @@
|
|||
#include "ucsi.h"
|
||||
#include "trace.h"
|
||||
|
||||
#define to_ucsi_connector(_cap_) container_of(_cap_, struct ucsi_connector, \
|
||||
typec_cap)
|
||||
|
||||
/*
|
||||
* UCSI_TIMEOUT_MS - PPM communication timeout
|
||||
*
|
||||
|
@ -713,10 +710,9 @@ static int ucsi_role_cmd(struct ucsi_connector *con, struct ucsi_control *ctrl)
|
|||
return ret;
|
||||
}
|
||||
|
||||
static int
|
||||
ucsi_dr_swap(const struct typec_capability *cap, enum typec_data_role role)
|
||||
static int ucsi_dr_swap(struct typec_port *port, enum typec_data_role role)
|
||||
{
|
||||
struct ucsi_connector *con = to_ucsi_connector(cap);
|
||||
struct ucsi_connector *con = typec_get_drvdata(port);
|
||||
struct ucsi_control ctrl;
|
||||
int ret = 0;
|
||||
|
||||
|
@ -748,10 +744,9 @@ out_unlock:
|
|||
return ret < 0 ? ret : 0;
|
||||
}
|
||||
|
||||
static int
|
||||
ucsi_pr_swap(const struct typec_capability *cap, enum typec_role role)
|
||||
static int ucsi_pr_swap(struct typec_port *port, enum typec_role role)
|
||||
{
|
||||
struct ucsi_connector *con = to_ucsi_connector(cap);
|
||||
struct ucsi_connector *con = typec_get_drvdata(port);
|
||||
struct ucsi_control ctrl;
|
||||
int ret = 0;
|
||||
|
||||
|
@ -788,6 +783,11 @@ out_unlock:
|
|||
return ret;
|
||||
}
|
||||
|
||||
static const struct typec_operations ucsi_ops = {
|
||||
.dr_set = ucsi_dr_swap,
|
||||
.pr_set = ucsi_pr_swap
|
||||
};
|
||||
|
||||
static struct fwnode_handle *ucsi_find_fwnode(struct ucsi_connector *con)
|
||||
{
|
||||
struct fwnode_handle *fwnode;
|
||||
|
@ -843,8 +843,8 @@ static int ucsi_register_port(struct ucsi *ucsi, int index)
|
|||
*accessory = TYPEC_ACCESSORY_DEBUG;
|
||||
|
||||
cap->fwnode = ucsi_find_fwnode(con);
|
||||
cap->dr_set = ucsi_dr_swap;
|
||||
cap->pr_set = ucsi_pr_swap;
|
||||
cap->driver_data = con;
|
||||
cap->ops = &ucsi_ops;
|
||||
|
||||
/* Register the connector */
|
||||
con->port = typec_register_port(ucsi->dev, cap);
|
||||
|
|
Загрузка…
Ссылка в новой задаче