Message ID | 20161129235902.11882-2-Jes.Sorensen@redhat.com (mailing list archive) |
---|---|
State | Accepted |
Commit | c59f13bbead475096bdfebc7ef59c12e180858de |
Delegated to: | Kalle Valo |
Headers | show |
Jes Sorensen <Jes.Sorensen@redhat.com> wrote: > From: Jes Sorensen <Jes.Sorensen@redhat.com> > > The H2C MEDIA_STATUS_RPT command for some reason causes 8192eu and > 8723bu devices not being able to reconnect. > > Reported-by: Barry Day <briselec@gmail.com> > Signed-off-by: Jes Sorensen <Jes.Sorensen@redhat.com> Like discussed I'll add: Cc: <stable@vger.kernel.org> #4.8+
Jes Sorensen <Jes.Sorensen@redhat.com> wrote: > From: Jes Sorensen <Jes.Sorensen@redhat.com> > > The H2C MEDIA_STATUS_RPT command for some reason causes 8192eu and > 8723bu devices not being able to reconnect. > > Reported-by: Barry Day <briselec@gmail.com> > Cc: <stable@vger.kernel.org> #4.8+ > Signed-off-by: Jes Sorensen <Jes.Sorensen@redhat.com> Patch applied to wireless-drivers-next.git, thanks. c59f13bbead4 rtl8xxxu: Work around issue with 8192eu and 8723bu devices not reconnecting
diff --git a/drivers/net/wireless/realtek/rtl8xxxu/rtl8xxxu_core.c b/drivers/net/wireless/realtek/rtl8xxxu/rtl8xxxu_core.c index a9137ab..3a86675 100644 --- a/drivers/net/wireless/realtek/rtl8xxxu/rtl8xxxu_core.c +++ b/drivers/net/wireless/realtek/rtl8xxxu/rtl8xxxu_core.c @@ -4372,6 +4372,13 @@ void rtl8xxxu_gen1_report_connect(struct rtl8xxxu_priv *priv, void rtl8xxxu_gen2_report_connect(struct rtl8xxxu_priv *priv, u8 macid, bool connect) { +#ifdef RTL8XXXU_GEN2_REPORT_CONNECT + /* + * Barry Day reports this causes issues with 8192eu and 8723bu + * devices reconnecting. The reason for this is unclear, but + * until it is better understood, leave the code in place but + * disabled, so it is not lost. + */ struct h2c_cmd h2c; memset(&h2c, 0, sizeof(struct h2c_cmd)); @@ -4383,6 +4390,7 @@ void rtl8xxxu_gen2_report_connect(struct rtl8xxxu_priv *priv, h2c.media_status_rpt.parm &= ~BIT(0); rtl8xxxu_gen2_h2c_cmd(priv, &h2c, sizeof(h2c.media_status_rpt)); +#endif } void rtl8xxxu_gen1_init_aggregation(struct rtl8xxxu_priv *priv)