All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH 1/2] Revert "mwifiex: handle race during mwifiex_usb_disconnect"
@ 2018-06-01 10:41 Ganapathi Bhat
  2018-06-01 10:41 ` [PATCH 2/2] mwifiex: handle race during mwifiex_usb_disconnect Ganapathi Bhat
                   ` (2 more replies)
  0 siblings, 3 replies; 6+ messages in thread
From: Ganapathi Bhat @ 2018-06-01 10:41 UTC (permalink / raw)
  To: linux-wireless
  Cc: Brian Norris, Cathy Luo, Xinming Hu, Zhiyuan Yang, James Cao,
	Mangesh Malusare, Ganapathi Bhat

This reverts commit b817047ae70c0bd67b677b65d0d69d72cd6e9728.

We have a better fix for this issue, which will be sent on top
of this revert.

Signed-off-by: Ganapathi Bhat <gbhat@marvell.com>
---
 drivers/net/wireless/marvell/mwifiex/usb.c | 3 ---
 1 file changed, 3 deletions(-)

diff --git a/drivers/net/wireless/marvell/mwifiex/usb.c b/drivers/net/wireless/marvell/mwifiex/usb.c
index 6e3cf98..bc475b8 100644
--- a/drivers/net/wireless/marvell/mwifiex/usb.c
+++ b/drivers/net/wireless/marvell/mwifiex/usb.c
@@ -644,9 +644,6 @@ static void mwifiex_usb_disconnect(struct usb_interface *intf)
 					 MWIFIEX_FUNC_SHUTDOWN);
 	}
 
-	if (adapter->workqueue)
-		flush_workqueue(adapter->workqueue);
-
 	mwifiex_usb_free(card);
 
 	mwifiex_dbg(adapter, FATAL,
-- 
1.9.1

^ permalink raw reply related	[flat|nested] 6+ messages in thread

* [PATCH 2/2] mwifiex: handle race during mwifiex_usb_disconnect
  2018-06-01 10:41 [PATCH 1/2] Revert "mwifiex: handle race during mwifiex_usb_disconnect" Ganapathi Bhat
@ 2018-06-01 10:41 ` Ganapathi Bhat
  2018-06-01 16:33   ` Brian Norris
  2018-06-01 15:56 ` [PATCH 1/2] Revert "mwifiex: handle race during mwifiex_usb_disconnect" Kalle Valo
  2018-06-24 17:01 ` [1/2] " Kalle Valo
  2 siblings, 1 reply; 6+ messages in thread
From: Ganapathi Bhat @ 2018-06-01 10:41 UTC (permalink / raw)
  To: linux-wireless
  Cc: Brian Norris, Cathy Luo, Xinming Hu, Zhiyuan Yang, James Cao,
	Mangesh Malusare, Ganapathi Bhat

Race condition is observed during rmmod of mwifiex_usb:

1. The rmmod thread will call mwifiex_usb_disconnect(), download
   SHUTDOWN command and do wait_event_interruptible_timeout(),
   waiting for response.

2. The main thread will handle the response and will do a
   wake_up_interruptible(), unblocking rmmod thread.

3. On getting unblocked, rmmod thread  will make rx_cmd.urb = NULL in
   mwifiex_usb_free().

4. The main thread will try to resubmit rx_cmd.urb in
   mwifiex_usb_submit_rx_urb(), which is NULL.

To fix this, move mwifiex_usb_free() from mwifiex_usb_disconnect
to mwifiex_unregister_dev(). Function mwifiex_unregister_dev() is
called after flushing the command and RX work queues.

Signed-off-by: Brian Norris <briannorris@chromium.org>
Signed-off-by: Ganapathi Bhat <gbhat@marvell.com>
---
 drivers/net/wireless/marvell/mwifiex/usb.c | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)

diff --git a/drivers/net/wireless/marvell/mwifiex/usb.c b/drivers/net/wireless/marvell/mwifiex/usb.c
index bc475b8..88f4c89 100644
--- a/drivers/net/wireless/marvell/mwifiex/usb.c
+++ b/drivers/net/wireless/marvell/mwifiex/usb.c
@@ -644,8 +644,6 @@ static void mwifiex_usb_disconnect(struct usb_interface *intf)
 					 MWIFIEX_FUNC_SHUTDOWN);
 	}
 
-	mwifiex_usb_free(card);
-
 	mwifiex_dbg(adapter, FATAL,
 		    "%s: removing card\n", __func__);
 	mwifiex_remove_card(adapter);
@@ -1353,6 +1351,8 @@ static void mwifiex_unregister_dev(struct mwifiex_adapter *adapter)
 {
 	struct usb_card_rec *card = (struct usb_card_rec *)adapter->card;
 
+	mwifiex_usb_free(card);
+
 	mwifiex_usb_cleanup_tx_aggr(adapter);
 
 	card->adapter = NULL;
-- 
1.9.1

^ permalink raw reply related	[flat|nested] 6+ messages in thread

* Re: [PATCH 1/2] Revert "mwifiex: handle race during mwifiex_usb_disconnect"
  2018-06-01 10:41 [PATCH 1/2] Revert "mwifiex: handle race during mwifiex_usb_disconnect" Ganapathi Bhat
  2018-06-01 10:41 ` [PATCH 2/2] mwifiex: handle race during mwifiex_usb_disconnect Ganapathi Bhat
@ 2018-06-01 15:56 ` Kalle Valo
  2018-06-24 17:01 ` [1/2] " Kalle Valo
  2 siblings, 0 replies; 6+ messages in thread
From: Kalle Valo @ 2018-06-01 15:56 UTC (permalink / raw)
  To: Ganapathi Bhat
  Cc: linux-wireless, Brian Norris, Cathy Luo, Xinming Hu,
	Zhiyuan Yang, James Cao, Mangesh Malusare

Ganapathi Bhat <gbhat@marvell.com> writes:

> This reverts commit b817047ae70c0bd67b677b65d0d69d72cd6e9728.
>
> We have a better fix for this issue, which will be sent on top
> of this revert.
>
> Signed-off-by: Ganapathi Bhat <gbhat@marvell.com>

I'll queue both of these patches to 4.18.

-- 
Kalle Valo

^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: [PATCH 2/2] mwifiex: handle race during mwifiex_usb_disconnect
  2018-06-01 10:41 ` [PATCH 2/2] mwifiex: handle race during mwifiex_usb_disconnect Ganapathi Bhat
@ 2018-06-01 16:33   ` Brian Norris
  2018-06-18 14:41     ` Kalle Valo
  0 siblings, 1 reply; 6+ messages in thread
From: Brian Norris @ 2018-06-01 16:33 UTC (permalink / raw)
  To: Ganapathi Bhat
  Cc: linux-wireless, Cathy Luo, Xinming Hu, Zhiyuan Yang, James Cao,
	Mangesh Malusare

Hi Ganapathi,

On Fri, Jun 01, 2018 at 04:11:20PM +0530, Ganapathi Bhat wrote:
> Race condition is observed during rmmod of mwifiex_usb:
> 
> 1. The rmmod thread will call mwifiex_usb_disconnect(), download
>    SHUTDOWN command and do wait_event_interruptible_timeout(),
>    waiting for response.
> 
> 2. The main thread will handle the response and will do a
>    wake_up_interruptible(), unblocking rmmod thread.
> 
> 3. On getting unblocked, rmmod thread  will make rx_cmd.urb = NULL in
>    mwifiex_usb_free().
> 
> 4. The main thread will try to resubmit rx_cmd.urb in
>    mwifiex_usb_submit_rx_urb(), which is NULL.
> 
> To fix this, move mwifiex_usb_free() from mwifiex_usb_disconnect
> to mwifiex_unregister_dev(). Function mwifiex_unregister_dev() is
> called after flushing the command and RX work queues.
> 
> Signed-off-by: Brian Norris <briannorris@chromium.org>

^^ I'm not sure if that line is quite accurate. While I nearly spelled
out what the patch would look like, you wrote it.

Anyway, patch seems good to me, assuming it tests out OK for you:

Reviewed-by: Brian Norris <briannorris@chromium.org>

and if Kalle hasn't applied this yet, an alternative to Signed-off-by:

Suggested-by: Brian Norris <briannorris@chromium.org>

> Signed-off-by: Ganapathi Bhat <gbhat@marvell.com>
> ---
>  drivers/net/wireless/marvell/mwifiex/usb.c | 4 ++--
>  1 file changed, 2 insertions(+), 2 deletions(-)
> 
> diff --git a/drivers/net/wireless/marvell/mwifiex/usb.c b/drivers/net/wireless/marvell/mwifiex/usb.c
> index bc475b8..88f4c89 100644
> --- a/drivers/net/wireless/marvell/mwifiex/usb.c
> +++ b/drivers/net/wireless/marvell/mwifiex/usb.c
> @@ -644,8 +644,6 @@ static void mwifiex_usb_disconnect(struct usb_interface *intf)
>  					 MWIFIEX_FUNC_SHUTDOWN);
>  	}
>  
> -	mwifiex_usb_free(card);
> -
>  	mwifiex_dbg(adapter, FATAL,
>  		    "%s: removing card\n", __func__);
>  	mwifiex_remove_card(adapter);
> @@ -1353,6 +1351,8 @@ static void mwifiex_unregister_dev(struct mwifiex_adapter *adapter)
>  {
>  	struct usb_card_rec *card = (struct usb_card_rec *)adapter->card;
>  
> +	mwifiex_usb_free(card);
> +
>  	mwifiex_usb_cleanup_tx_aggr(adapter);
>  
>  	card->adapter = NULL;
> -- 
> 1.9.1
> 

^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: [PATCH 2/2] mwifiex: handle race during mwifiex_usb_disconnect
  2018-06-01 16:33   ` Brian Norris
@ 2018-06-18 14:41     ` Kalle Valo
  0 siblings, 0 replies; 6+ messages in thread
From: Kalle Valo @ 2018-06-18 14:41 UTC (permalink / raw)
  To: Brian Norris
  Cc: Ganapathi Bhat, linux-wireless, Cathy Luo, Xinming Hu,
	Zhiyuan Yang, James Cao, Mangesh Malusare

Brian Norris <briannorris@chromium.org> writes:

> Hi Ganapathi,
>
> On Fri, Jun 01, 2018 at 04:11:20PM +0530, Ganapathi Bhat wrote:
>> Race condition is observed during rmmod of mwifiex_usb:
>> 
>> 1. The rmmod thread will call mwifiex_usb_disconnect(), download
>>    SHUTDOWN command and do wait_event_interruptible_timeout(),
>>    waiting for response.
>> 
>> 2. The main thread will handle the response and will do a
>>    wake_up_interruptible(), unblocking rmmod thread.
>> 
>> 3. On getting unblocked, rmmod thread  will make rx_cmd.urb = NULL in
>>    mwifiex_usb_free().
>> 
>> 4. The main thread will try to resubmit rx_cmd.urb in
>>    mwifiex_usb_submit_rx_urb(), which is NULL.
>> 
>> To fix this, move mwifiex_usb_free() from mwifiex_usb_disconnect
>> to mwifiex_unregister_dev(). Function mwifiex_unregister_dev() is
>> called after flushing the command and RX work queues.
>> 
>> Signed-off-by: Brian Norris <briannorris@chromium.org>
>
> ^^ I'm not sure if that line is quite accurate. While I nearly spelled
> out what the patch would look like, you wrote it.
>
> Anyway, patch seems good to me, assuming it tests out OK for you:
>
> Reviewed-by: Brian Norris <briannorris@chromium.org>
>
> and if Kalle hasn't applied this yet, an alternative to Signed-off-by:
>
> Suggested-by: Brian Norris <briannorris@chromium.org>

Ok, I'll change that.

-- 
Kalle Valo

^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: [1/2] Revert "mwifiex: handle race during mwifiex_usb_disconnect"
  2018-06-01 10:41 [PATCH 1/2] Revert "mwifiex: handle race during mwifiex_usb_disconnect" Ganapathi Bhat
  2018-06-01 10:41 ` [PATCH 2/2] mwifiex: handle race during mwifiex_usb_disconnect Ganapathi Bhat
  2018-06-01 15:56 ` [PATCH 1/2] Revert "mwifiex: handle race during mwifiex_usb_disconnect" Kalle Valo
@ 2018-06-24 17:01 ` Kalle Valo
  2 siblings, 0 replies; 6+ messages in thread
From: Kalle Valo @ 2018-06-24 17:01 UTC (permalink / raw)
  To: Ganapathi Bhat
  Cc: linux-wireless, Brian Norris, Cathy Luo, Xinming Hu,
	Zhiyuan Yang, James Cao, Mangesh Malusare, Ganapathi Bhat

Ganapathi Bhat <gbhat@marvell.com> wrote:

> This reverts commit b817047ae70c0bd67b677b65d0d69d72cd6e9728.
> 
> We have a better fix for this issue, which will be sent on top
> of this revert.
> 
> Signed-off-by: Ganapathi Bhat <gbhat@marvell.com>

2 patches applied to wireless-drivers.git, thanks.

7e58e741c001 Revert "mwifiex: handle race during mwifiex_usb_disconnect"
f8c095f67962 mwifiex: handle race during mwifiex_usb_disconnect

-- 
https://patchwork.kernel.org/patch/10442949/

https://wireless.wiki.kernel.org/en/developers/documentation/submittingpatches

^ permalink raw reply	[flat|nested] 6+ messages in thread

end of thread, other threads:[~2018-06-24 17:01 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2018-06-01 10:41 [PATCH 1/2] Revert "mwifiex: handle race during mwifiex_usb_disconnect" Ganapathi Bhat
2018-06-01 10:41 ` [PATCH 2/2] mwifiex: handle race during mwifiex_usb_disconnect Ganapathi Bhat
2018-06-01 16:33   ` Brian Norris
2018-06-18 14:41     ` Kalle Valo
2018-06-01 15:56 ` [PATCH 1/2] Revert "mwifiex: handle race during mwifiex_usb_disconnect" Kalle Valo
2018-06-24 17:01 ` [1/2] " Kalle Valo

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.