Commit 3a288efb authored by Utkarsh Patel's avatar Utkarsh Patel Committed by Greg Kroah-Hartman

usb: typec: intel_pmc_mux: Use correct response message bits

When Intel PMC Mux agent driver receives the response message from PMC, it
checks for the same response bits for all the mux states.
Corrected it by checking correct response message bits, Bit 8 & 9 for the
SAFE Mode and Alternate Modes and Bit 16 & 17 for the Connect and
Disconnect Modes.
Reviewed-by: default avatarHeikki Krogerus <heikki.krogerus@linux.intel.com>
Signed-off-by: default avatarUtkarsh Patel <utkarsh.h.patel@intel.com>
Link: https://lore.kernel.org/r/20201203220813.16281-1-utkarsh.h.patel@intel.comSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent d6ff3247
...@@ -176,6 +176,7 @@ static int hsl_orientation(struct pmc_usb_port *port) ...@@ -176,6 +176,7 @@ static int hsl_orientation(struct pmc_usb_port *port)
static int pmc_usb_command(struct pmc_usb_port *port, u8 *msg, u32 len) static int pmc_usb_command(struct pmc_usb_port *port, u8 *msg, u32 len)
{ {
u8 response[4]; u8 response[4];
u8 status_res;
int ret; int ret;
/* /*
...@@ -189,9 +190,13 @@ static int pmc_usb_command(struct pmc_usb_port *port, u8 *msg, u32 len) ...@@ -189,9 +190,13 @@ static int pmc_usb_command(struct pmc_usb_port *port, u8 *msg, u32 len)
if (ret) if (ret)
return ret; return ret;
if (response[2] & PMC_USB_RESP_STATUS_FAILURE) { status_res = (msg[0] & 0xf) < PMC_USB_SAFE_MODE ?
if (response[2] & PMC_USB_RESP_STATUS_FATAL) response[2] : response[1];
if (status_res & PMC_USB_RESP_STATUS_FAILURE) {
if (status_res & PMC_USB_RESP_STATUS_FATAL)
return -EIO; return -EIO;
return -EBUSY; return -EBUSY;
} }
......
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