Commit 63b5e505 authored by Nam Cao's avatar Nam Cao Committed by Greg Kroah-Hartman

staging: rtl8712: check for alloc fail in _r8712_init_recv_priv()

The function _r8712_init_recv_priv() and also r8712_init_recv_priv()
just returns silently if they fail to allocate memory. Change their
return type to int and add necessary checks and handling if they return
-ENOMEM
Tested-by: default avatarPhilipp Hortmann <philipp.g.hortmann@gmail.com>
Signed-off-by: default avatarNam Cao <namcaov@gmail.com>
Link: https://lore.kernel.org/r/506ac35a667e511db568b06b86834fd0ceeba453.1666688642.git.namcaov@gmail.comSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent c5a7eecd
...@@ -309,7 +309,9 @@ int r8712_init_drv_sw(struct _adapter *padapter) ...@@ -309,7 +309,9 @@ int r8712_init_drv_sw(struct _adapter *padapter)
if (ret) if (ret)
return ret; return ret;
_r8712_init_xmit_priv(&padapter->xmitpriv, padapter); _r8712_init_xmit_priv(&padapter->xmitpriv, padapter);
_r8712_init_recv_priv(&padapter->recvpriv, padapter); ret = _r8712_init_recv_priv(&padapter->recvpriv, padapter);
if (ret)
return ret;
memset((unsigned char *)&padapter->securitypriv, 0, memset((unsigned char *)&padapter->securitypriv, 0,
sizeof(struct security_priv)); sizeof(struct security_priv));
timer_setup(&padapter->securitypriv.tkip_timer, timer_setup(&padapter->securitypriv.tkip_timer,
......
...@@ -18,15 +18,15 @@ ...@@ -18,15 +18,15 @@
#include "drv_types.h" #include "drv_types.h"
#include <linux/skbuff.h> #include <linux/skbuff.h>
void _r8712_init_recv_priv(struct recv_priv *precvpriv, int _r8712_init_recv_priv(struct recv_priv *precvpriv,
struct _adapter *padapter); struct _adapter *padapter);
void _r8712_free_recv_priv(struct recv_priv *precvpriv); void _r8712_free_recv_priv(struct recv_priv *precvpriv);
void r8712_recv_entry(union recv_frame *precv_frame); void r8712_recv_entry(union recv_frame *precv_frame);
void r8712_recv_indicatepkt(struct _adapter *adapter, void r8712_recv_indicatepkt(struct _adapter *adapter,
union recv_frame *precv_frame); union recv_frame *precv_frame);
void r8712_handle_tkip_mic_err(struct _adapter *padapter, u8 bgroup); void r8712_handle_tkip_mic_err(struct _adapter *padapter, u8 bgroup);
void r8712_init_recv_priv(struct recv_priv *precvpriv, int r8712_init_recv_priv(struct recv_priv *precvpriv,
struct _adapter *padapter); struct _adapter *padapter);
void r8712_free_recv_priv(struct recv_priv *precvpriv); void r8712_free_recv_priv(struct recv_priv *precvpriv);
void r8712_os_recv_resource_alloc(struct _adapter *padapter, void r8712_os_recv_resource_alloc(struct _adapter *padapter,
union recv_frame *precvframe); union recv_frame *precvframe);
......
...@@ -30,8 +30,8 @@ ...@@ -30,8 +30,8 @@
static void recv_tasklet(struct tasklet_struct *t); static void recv_tasklet(struct tasklet_struct *t);
void r8712_init_recv_priv(struct recv_priv *precvpriv, int r8712_init_recv_priv(struct recv_priv *precvpriv,
struct _adapter *padapter) struct _adapter *padapter)
{ {
int i; int i;
struct recv_buf *precvbuf; struct recv_buf *precvbuf;
...@@ -44,7 +44,7 @@ void r8712_init_recv_priv(struct recv_priv *precvpriv, ...@@ -44,7 +44,7 @@ void r8712_init_recv_priv(struct recv_priv *precvpriv,
precvpriv->pallocated_recv_buf = precvpriv->pallocated_recv_buf =
kzalloc(NR_RECVBUFF * sizeof(struct recv_buf) + 4, GFP_ATOMIC); kzalloc(NR_RECVBUFF * sizeof(struct recv_buf) + 4, GFP_ATOMIC);
if (!precvpriv->pallocated_recv_buf) if (!precvpriv->pallocated_recv_buf)
return; return -ENOMEM;
precvpriv->precv_buf = precvpriv->pallocated_recv_buf + 4 - precvpriv->precv_buf = precvpriv->pallocated_recv_buf + 4 -
((addr_t)(precvpriv->pallocated_recv_buf) & 3); ((addr_t)(precvpriv->pallocated_recv_buf) & 3);
precvbuf = (struct recv_buf *)precvpriv->precv_buf; precvbuf = (struct recv_buf *)precvpriv->precv_buf;
...@@ -75,6 +75,7 @@ void r8712_init_recv_priv(struct recv_priv *precvpriv, ...@@ -75,6 +75,7 @@ void r8712_init_recv_priv(struct recv_priv *precvpriv,
} }
pskb = NULL; pskb = NULL;
} }
return 0;
} }
void r8712_free_recv_priv(struct recv_priv *precvpriv) void r8712_free_recv_priv(struct recv_priv *precvpriv)
......
...@@ -42,9 +42,10 @@ void _r8712_init_sta_recv_priv(struct sta_recv_priv *psta_recvpriv) ...@@ -42,9 +42,10 @@ void _r8712_init_sta_recv_priv(struct sta_recv_priv *psta_recvpriv)
_init_queue(&psta_recvpriv->defrag_q); _init_queue(&psta_recvpriv->defrag_q);
} }
void _r8712_init_recv_priv(struct recv_priv *precvpriv, int _r8712_init_recv_priv(struct recv_priv *precvpriv,
struct _adapter *padapter) struct _adapter *padapter)
{ {
int ret;
sint i; sint i;
union recv_frame *precvframe; union recv_frame *precvframe;
...@@ -58,7 +59,7 @@ void _r8712_init_recv_priv(struct recv_priv *precvpriv, ...@@ -58,7 +59,7 @@ void _r8712_init_recv_priv(struct recv_priv *precvpriv,
sizeof(union recv_frame) + RXFRAME_ALIGN_SZ, sizeof(union recv_frame) + RXFRAME_ALIGN_SZ,
GFP_ATOMIC); GFP_ATOMIC);
if (!precvpriv->pallocated_frame_buf) if (!precvpriv->pallocated_frame_buf)
return; return -ENOMEM;
precvpriv->precv_frame_buf = precvpriv->pallocated_frame_buf + precvpriv->precv_frame_buf = precvpriv->pallocated_frame_buf +
RXFRAME_ALIGN_SZ - RXFRAME_ALIGN_SZ -
((addr_t)(precvpriv->pallocated_frame_buf) & ((addr_t)(precvpriv->pallocated_frame_buf) &
...@@ -73,7 +74,11 @@ void _r8712_init_recv_priv(struct recv_priv *precvpriv, ...@@ -73,7 +74,11 @@ void _r8712_init_recv_priv(struct recv_priv *precvpriv,
precvframe++; precvframe++;
} }
precvpriv->rx_pending_cnt = 1; precvpriv->rx_pending_cnt = 1;
r8712_init_recv_priv(precvpriv, padapter); ret = r8712_init_recv_priv(precvpriv, padapter);
if (ret)
kfree(precvpriv->pallocated_frame_buf);
return ret;
} }
void _r8712_free_recv_priv(struct recv_priv *precvpriv) void _r8712_free_recv_priv(struct recv_priv *precvpriv)
......
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