mirror of
https://github.com/torvalds/linux.git
synced 2024-11-24 05:02:12 +00:00
usb: typec: Add parameter for the VDO to typec_altmode_enter()
Enter Mode Command may contain one VDO. Signed-off-by: Heikki Krogerus <heikki.krogerus@linux.intel.com> Link: https://lore.kernel.org/r/20191230142611.24921-3-heikki.krogerus@linux.intel.com Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
cf2f58fb88
commit
8face9aa57
@ -188,7 +188,7 @@ static void dp_altmode_work(struct work_struct *work)
|
||||
|
||||
switch (dp->state) {
|
||||
case DP_STATE_ENTER:
|
||||
ret = typec_altmode_enter(dp->alt);
|
||||
ret = typec_altmode_enter(dp->alt, NULL);
|
||||
if (ret)
|
||||
dev_err(&dp->alt->dev, "failed to enter mode\n");
|
||||
break;
|
||||
@ -306,7 +306,8 @@ err_unlock:
|
||||
|
||||
static int dp_altmode_activate(struct typec_altmode *alt, int activate)
|
||||
{
|
||||
return activate ? typec_altmode_enter(alt) : typec_altmode_exit(alt);
|
||||
return activate ? typec_altmode_enter(alt, NULL) :
|
||||
typec_altmode_exit(alt);
|
||||
}
|
||||
|
||||
static const struct typec_altmode_ops dp_altmode_ops = {
|
||||
|
@ -84,12 +84,14 @@ EXPORT_SYMBOL_GPL(typec_altmode_notify);
|
||||
/**
|
||||
* typec_altmode_enter - Enter Mode
|
||||
* @adev: The alternate mode
|
||||
* @vdo: VDO for the Enter Mode command
|
||||
*
|
||||
* The alternate mode drivers use this function to enter mode. The port drivers
|
||||
* use this to inform the alternate mode drivers that the partner has initiated
|
||||
* Enter Mode command.
|
||||
* Enter Mode command. If the alternate mode does not require VDO, @vdo must be
|
||||
* NULL.
|
||||
*/
|
||||
int typec_altmode_enter(struct typec_altmode *adev)
|
||||
int typec_altmode_enter(struct typec_altmode *adev, u32 *vdo)
|
||||
{
|
||||
struct altmode *partner = to_altmode(adev)->partner;
|
||||
struct typec_altmode *pdev = &partner->adev;
|
||||
@ -110,7 +112,7 @@ int typec_altmode_enter(struct typec_altmode *adev)
|
||||
return ret;
|
||||
|
||||
/* Enter Mode */
|
||||
return pdev->ops->enter(pdev);
|
||||
return pdev->ops->enter(pdev, vdo);
|
||||
}
|
||||
EXPORT_SYMBOL_GPL(typec_altmode_enter);
|
||||
|
||||
|
@ -1475,16 +1475,16 @@ static int tcpm_validate_caps(struct tcpm_port *port, const u32 *pdo,
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int tcpm_altmode_enter(struct typec_altmode *altmode)
|
||||
static int tcpm_altmode_enter(struct typec_altmode *altmode, u32 *vdo)
|
||||
{
|
||||
struct tcpm_port *port = typec_altmode_get_drvdata(altmode);
|
||||
u32 header;
|
||||
|
||||
mutex_lock(&port->lock);
|
||||
header = VDO(altmode->svid, 1, CMD_ENTER_MODE);
|
||||
header = VDO(altmode->svid, vdo ? 2 : 1, CMD_ENTER_MODE);
|
||||
header |= VDO_OPOS(altmode->mode);
|
||||
|
||||
tcpm_queue_vdm(port, header, NULL, 0);
|
||||
tcpm_queue_vdm(port, header, vdo, vdo ? 1 : 0);
|
||||
mod_delayed_work(port->wq, &port->vdm_state_machine, 0);
|
||||
mutex_unlock(&port->lock);
|
||||
|
||||
|
@ -45,7 +45,7 @@ struct ucsi_dp {
|
||||
* -EOPNOTSUPP.
|
||||
*/
|
||||
|
||||
static int ucsi_displayport_enter(struct typec_altmode *alt)
|
||||
static int ucsi_displayport_enter(struct typec_altmode *alt, u32 *vdo)
|
||||
{
|
||||
struct ucsi_dp *dp = typec_altmode_get_drvdata(alt);
|
||||
struct ucsi *ucsi = dp->con->ucsi;
|
||||
|
@ -55,7 +55,7 @@ static inline void *typec_altmode_get_drvdata(struct typec_altmode *altmode)
|
||||
* @activate: User callback for Enter/Exit Mode
|
||||
*/
|
||||
struct typec_altmode_ops {
|
||||
int (*enter)(struct typec_altmode *altmode);
|
||||
int (*enter)(struct typec_altmode *altmode, u32 *vdo);
|
||||
int (*exit)(struct typec_altmode *altmode);
|
||||
void (*attention)(struct typec_altmode *altmode, u32 vdo);
|
||||
int (*vdm)(struct typec_altmode *altmode, const u32 hdr,
|
||||
@ -65,7 +65,7 @@ struct typec_altmode_ops {
|
||||
int (*activate)(struct typec_altmode *altmode, int activate);
|
||||
};
|
||||
|
||||
int typec_altmode_enter(struct typec_altmode *altmode);
|
||||
int typec_altmode_enter(struct typec_altmode *altmode, u32 *vdo);
|
||||
int typec_altmode_exit(struct typec_altmode *altmode);
|
||||
void typec_altmode_attention(struct typec_altmode *altmode, u32 vdo);
|
||||
int typec_altmode_vdm(struct typec_altmode *altmode,
|
||||
|
Loading…
Reference in New Issue
Block a user