staging: r8188eu: merge _rtw_enqueue_cmd into its caller

Message ID 20230211165045.414424-1-martin@kaiser.cx
State New
Headers
Series staging: r8188eu: merge _rtw_enqueue_cmd into its caller |

Commit Message

Martin Kaiser Feb. 11, 2023, 4:50 p.m. UTC
  The _rtw_enqueue_cmd function is called only by rtw_enqueue_cmd.

When _rtw_enqueue_cmd is called, the caller has already checked that the
obj parameter is not NULL. _rtw_enqueue_cmd returns _SUCCESS in any case.

We can merge the two functions and simplify the error handling.

Signed-off-by: Martin Kaiser <martin@kaiser.cx>
---
 drivers/staging/r8188eu/core/rtw_cmd.c | 47 +++++---------------------
 1 file changed, 9 insertions(+), 38 deletions(-)
  

Comments

Philipp Hortmann Feb. 13, 2023, 7:23 p.m. UTC | #1
On 2/11/23 17:50, Martin Kaiser wrote:
> The _rtw_enqueue_cmd function is called only by rtw_enqueue_cmd.
> 
> When _rtw_enqueue_cmd is called, the caller has already checked that the
> obj parameter is not NULL. _rtw_enqueue_cmd returns _SUCCESS in any case.
> 
> We can merge the two functions and simplify the error handling.
> 
> Signed-off-by: Martin Kaiser <martin@kaiser.cx>
> ---
>   drivers/staging/r8188eu/core/rtw_cmd.c | 47 +++++---------------------
>   1 file changed, 9 insertions(+), 38 deletions(-)
> 
> diff --git a/drivers/staging/r8188eu/core/rtw_cmd.c b/drivers/staging/r8188eu/core/rtw_cmd.c
> index d57360a68fb3..ca9e3d4ee7f4 100644
> --- a/drivers/staging/r8188eu/core/rtw_cmd.c
> +++ b/drivers/staging/r8188eu/core/rtw_cmd.c
> @@ -28,32 +28,6 @@ void rtw_free_evt_priv(struct	evt_priv *pevtpriv)
>   	}
>   }
>   
> -/* Calling Context:
> - *
> - * rtw_enqueue_cmd can only be called between kernel thread,
> - * since only spin_lock is used.
> - *
> - * ISR/Call-Back functions can't call this sub-function.
> - */
> -
> -static int _rtw_enqueue_cmd(struct __queue *queue, struct cmd_obj *obj)
> -{
> -	unsigned long flags;
> -
> -	if (!obj)
> -		goto exit;
> -
> -	spin_lock_irqsave(&queue->lock, flags);
> -
> -	list_add_tail(&obj->list, &queue->queue);
> -
> -	spin_unlock_irqrestore(&queue->lock, flags);
> -
> -exit:
> -
> -	return _SUCCESS;
> -}
> -
>   int rtw_init_cmd_priv(struct cmd_priv *pcmdpriv)
>   {
>   	init_completion(&pcmdpriv->enqueue_cmd);
> @@ -125,28 +99,25 @@ static int rtw_cmd_filter(struct cmd_priv *pcmdpriv, struct cmd_obj *cmd_obj)
>   
>   u32 rtw_enqueue_cmd(struct cmd_priv *pcmdpriv, struct cmd_obj *cmd_obj)
>   {
> -	int res = _FAIL;
> +	unsigned long flags;
>   	struct adapter *padapter = pcmdpriv->padapter;
>   
>   	if (!cmd_obj)
> -		goto exit;
> +		return _FAIL;
>   
>   	cmd_obj->padapter = padapter;
>   
> -	res = rtw_cmd_filter(pcmdpriv, cmd_obj);
> -	if (res == _FAIL) {
> +	if (rtw_cmd_filter(pcmdpriv, cmd_obj) == _FAIL) {
>   		rtw_free_cmd_obj(cmd_obj);
> -		goto exit;
> +		return _FAIL;
>   	}
>   
> -	res = _rtw_enqueue_cmd(&pcmdpriv->cmd_queue, cmd_obj);
> -
> -	if (res == _SUCCESS)
> -		complete(&pcmdpriv->enqueue_cmd);
> +	spin_lock_irqsave(&pcmdpriv->cmd_queue.lock, flags);
> +	list_add_tail(&cmd_obj->list, &pcmdpriv->cmd_queue.queue);
> +	spin_unlock_irqrestore(&pcmdpriv->cmd_queue.lock, flags);
>   
> -exit:
> -
> -	return res;
> +	complete(&pcmdpriv->enqueue_cmd);
> +	return _SUCCESS;
>   }
>   
>   struct	cmd_obj	*rtw_dequeue_cmd(struct cmd_priv *pcmdpriv)

Tested-by: Philipp Hortmann <philipp.g.hortmann@gmail.com> # Edimax N150
  

Patch

diff --git a/drivers/staging/r8188eu/core/rtw_cmd.c b/drivers/staging/r8188eu/core/rtw_cmd.c
index d57360a68fb3..ca9e3d4ee7f4 100644
--- a/drivers/staging/r8188eu/core/rtw_cmd.c
+++ b/drivers/staging/r8188eu/core/rtw_cmd.c
@@ -28,32 +28,6 @@  void rtw_free_evt_priv(struct	evt_priv *pevtpriv)
 	}
 }
 
-/* Calling Context:
- *
- * rtw_enqueue_cmd can only be called between kernel thread,
- * since only spin_lock is used.
- *
- * ISR/Call-Back functions can't call this sub-function.
- */
-
-static int _rtw_enqueue_cmd(struct __queue *queue, struct cmd_obj *obj)
-{
-	unsigned long flags;
-
-	if (!obj)
-		goto exit;
-
-	spin_lock_irqsave(&queue->lock, flags);
-
-	list_add_tail(&obj->list, &queue->queue);
-
-	spin_unlock_irqrestore(&queue->lock, flags);
-
-exit:
-
-	return _SUCCESS;
-}
-
 int rtw_init_cmd_priv(struct cmd_priv *pcmdpriv)
 {
 	init_completion(&pcmdpriv->enqueue_cmd);
@@ -125,28 +99,25 @@  static int rtw_cmd_filter(struct cmd_priv *pcmdpriv, struct cmd_obj *cmd_obj)
 
 u32 rtw_enqueue_cmd(struct cmd_priv *pcmdpriv, struct cmd_obj *cmd_obj)
 {
-	int res = _FAIL;
+	unsigned long flags;
 	struct adapter *padapter = pcmdpriv->padapter;
 
 	if (!cmd_obj)
-		goto exit;
+		return _FAIL;
 
 	cmd_obj->padapter = padapter;
 
-	res = rtw_cmd_filter(pcmdpriv, cmd_obj);
-	if (res == _FAIL) {
+	if (rtw_cmd_filter(pcmdpriv, cmd_obj) == _FAIL) {
 		rtw_free_cmd_obj(cmd_obj);
-		goto exit;
+		return _FAIL;
 	}
 
-	res = _rtw_enqueue_cmd(&pcmdpriv->cmd_queue, cmd_obj);
-
-	if (res == _SUCCESS)
-		complete(&pcmdpriv->enqueue_cmd);
+	spin_lock_irqsave(&pcmdpriv->cmd_queue.lock, flags);
+	list_add_tail(&cmd_obj->list, &pcmdpriv->cmd_queue.queue);
+	spin_unlock_irqrestore(&pcmdpriv->cmd_queue.lock, flags);
 
-exit:
-
-	return res;
+	complete(&pcmdpriv->enqueue_cmd);
+	return _SUCCESS;
 }
 
 struct	cmd_obj	*rtw_dequeue_cmd(struct cmd_priv *pcmdpriv)