Message ID | 20200907135740.19941-3-heikki.krogerus@linux.intel.com |
---|---|
State | New |
Headers | show |
Series | Fixes for the Intel PMC mux driver | expand |
On Mon, Sep 07, 2020 at 04:57:40PM +0300, Heikki Krogerus wrote: > From: Utkarsh Patel <utkarsh.h.patel@intel.com> > > According to the PMC Type C Subsystem (TCSS) Mux programming guide rev > 0.7, bits 4 and 5 are reserved in Alternate modes. > SBU Orientation and HSL Orientation needs to be configured only during > initial cable detection in USB connect flow based on device property of > "sbu-orientation" and "hsl-orientation". > Configuring these reserved bits in the Alternate modes may result in delay > in display link training or some unexpected behaviour. > So do not configure them while issuing Alternate Mode requests. > > Fixes: ff4a30d5e243 ("usb: typec: mux: intel_pmc_mux: Support for static SBU/HSL orientation") > Signed-off-by: Utkarsh Patel <utkarsh.h.patel@intel.com> > Signed-off-by: Heikki Krogerus <heikki.krogerus@linux.intel.com> Shouldn't this also need a cc:stable? And why not cc: the linux-usb list on these patches? thanks, greg k-h
diff --git a/drivers/usb/typec/mux/intel_pmc_mux.c b/drivers/usb/typec/mux/intel_pmc_mux.c index 802d443b367c6..3bc08847fb7f0 100644 --- a/drivers/usb/typec/mux/intel_pmc_mux.c +++ b/drivers/usb/typec/mux/intel_pmc_mux.c @@ -61,8 +61,6 @@ enum { #define PMC_USB_ALTMODE_ORI_SHIFT 1 #define PMC_USB_ALTMODE_UFP_SHIFT 3 -#define PMC_USB_ALTMODE_ORI_AUX_SHIFT 4 -#define PMC_USB_ALTMODE_ORI_HSL_SHIFT 5 /* DP specific Mode Data bits */ #define PMC_USB_ALTMODE_DP_MODE_SHIFT 8 @@ -178,9 +176,6 @@ pmc_usb_mux_dp(struct pmc_usb_port *port, struct typec_mux_state *state) req.mode_data = (port->orientation - 1) << PMC_USB_ALTMODE_ORI_SHIFT; req.mode_data |= (port->role - 1) << PMC_USB_ALTMODE_UFP_SHIFT; - req.mode_data |= sbu_orientation(port) << PMC_USB_ALTMODE_ORI_AUX_SHIFT; - req.mode_data |= hsl_orientation(port) << PMC_USB_ALTMODE_ORI_HSL_SHIFT; - req.mode_data |= (state->mode - TYPEC_STATE_MODAL) << PMC_USB_ALTMODE_DP_MODE_SHIFT; @@ -208,9 +203,6 @@ pmc_usb_mux_tbt(struct pmc_usb_port *port, struct typec_mux_state *state) req.mode_data = (port->orientation - 1) << PMC_USB_ALTMODE_ORI_SHIFT; req.mode_data |= (port->role - 1) << PMC_USB_ALTMODE_UFP_SHIFT; - req.mode_data |= sbu_orientation(port) << PMC_USB_ALTMODE_ORI_AUX_SHIFT; - req.mode_data |= hsl_orientation(port) << PMC_USB_ALTMODE_ORI_HSL_SHIFT; - if (TBT_ADAPTER(data->device_mode) == TBT_ADAPTER_TBT3) req.mode_data |= PMC_USB_ALTMODE_TBT_TYPE;