Skip to content

Commit

Permalink
staging/rtl8821ae: Fix OOM handling in _rtl_init_deferred_work()
Browse files Browse the repository at this point in the history
alloc_workqueue() can fail, handle this case.

Signed-off-by: Richard Weinberger <[email protected]>
Signed-off-by: Greg Kroah-Hartman <[email protected]>
  • Loading branch information
richardweinberger authored and gregkh committed Apr 15, 2014
1 parent c9eaa44 commit 29d1e72
Showing 1 changed file with 8 additions and 2 deletions.
10 changes: 8 additions & 2 deletions drivers/staging/rtl8821ae/base.c
Original file line number Diff line number Diff line change
Expand Up @@ -388,7 +388,7 @@ static void _rtl_init_mac80211(struct ieee80211_hw *hw)

}

static void _rtl_init_deferred_work(struct ieee80211_hw *hw)
static int _rtl_init_deferred_work(struct ieee80211_hw *hw)
{
struct rtl_priv *rtlpriv = rtl_priv(hw);

Expand All @@ -410,6 +410,9 @@ static void _rtl_init_deferred_work(struct ieee80211_hw *hw)
rtlpriv->works.rtl_wq = create_workqueue(rtlpriv->cfg->name);
#endif
/*<delete in kernel end>*/
if (!rtlpriv->works.rtl_wq)
return -ENOMEM;

INIT_DELAYED_WORK(&rtlpriv->works.watchdog_wq,
(void *)rtl_watchdog_wq_callback);
INIT_DELAYED_WORK(&rtlpriv->works.ips_nic_off_wq,
Expand All @@ -421,6 +424,8 @@ static void _rtl_init_deferred_work(struct ieee80211_hw *hw)
INIT_DELAYED_WORK(&rtlpriv->works.fwevt_wq,
(void *)rtl_fwevt_wq_callback);

return 0;

}

void rtl_deinit_deferred_work(struct ieee80211_hw *hw)
Expand Down Expand Up @@ -519,7 +524,8 @@ int rtl_init_core(struct ieee80211_hw *hw)
INIT_LIST_HEAD(&rtlpriv->entry_list);

/* <6> init deferred work */
_rtl_init_deferred_work(hw);
if (_rtl_init_deferred_work(hw))
return 1;

/* <7> */
#ifdef VIF_TODO
Expand Down

0 comments on commit 29d1e72

Please sign in to comment.