mwifiex: Convert timers to use timer_setup()
In preparation for unconditionally passing the struct timer_list pointer to all timer callbacks, switch to using the new timer_setup() and from_timer() to pass the timer pointer explicitly. Cc: Kalle Valo <kvalo@codeaurora.org> Cc: Amitkumar Karwar <amitkarwar@gmail.com> Cc: Nishant Sarmukadam <nishants@marvell.com> Cc: Ganapathi Bhat <gbhat@marvell.com> Cc: Xinming Hu <huxm@marvell.com> Cc: Arvind Yadav <arvind.yadav.cs@gmail.com> Cc: Ingo Molnar <mingo@kernel.org> Cc: Johannes Berg <johannes.berg@intel.com> Cc: "David S. Miller" <davem@davemloft.net> Cc: Andrew Zaborowski <andrew.zaborowski@intel.com> Cc: libertas-dev@lists.infradead.org Cc: linux-wireless@vger.kernel.org Cc: netdev@vger.kernel.org Signed-off-by: Kees Cook <keescook@chromium.org> Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
This commit is contained in:
parent
dfefb9f8d0
commit
08c2eb8ec8
@ -312,10 +312,10 @@ mwifiex_11n_find_last_seq_num(struct reorder_tmr_cnxt *ctx)
|
|||||||
* them and then dumps the Rx reordering table.
|
* them and then dumps the Rx reordering table.
|
||||||
*/
|
*/
|
||||||
static void
|
static void
|
||||||
mwifiex_flush_data(unsigned long context)
|
mwifiex_flush_data(struct timer_list *t)
|
||||||
{
|
{
|
||||||
struct reorder_tmr_cnxt *ctx =
|
struct reorder_tmr_cnxt *ctx =
|
||||||
(struct reorder_tmr_cnxt *) context;
|
from_timer(ctx, t, timer);
|
||||||
int start_win, seq_num;
|
int start_win, seq_num;
|
||||||
|
|
||||||
ctx->timer_is_set = false;
|
ctx->timer_is_set = false;
|
||||||
@ -412,8 +412,7 @@ mwifiex_11n_create_rx_reorder_tbl(struct mwifiex_private *priv, u8 *ta,
|
|||||||
new_node->timer_context.priv = priv;
|
new_node->timer_context.priv = priv;
|
||||||
new_node->timer_context.timer_is_set = false;
|
new_node->timer_context.timer_is_set = false;
|
||||||
|
|
||||||
setup_timer(&new_node->timer_context.timer, mwifiex_flush_data,
|
timer_setup(&new_node->timer_context.timer, mwifiex_flush_data, 0);
|
||||||
(unsigned long)&new_node->timer_context);
|
|
||||||
|
|
||||||
for (i = 0; i < win_size; ++i)
|
for (i = 0; i < win_size; ++i)
|
||||||
new_node->rx_reorder_ptr[i] = NULL;
|
new_node->rx_reorder_ptr[i] = NULL;
|
||||||
|
@ -920,10 +920,9 @@ int mwifiex_process_cmdresp(struct mwifiex_adapter *adapter)
|
|||||||
* It will re-send the same command again.
|
* It will re-send the same command again.
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
mwifiex_cmd_timeout_func(unsigned long function_context)
|
mwifiex_cmd_timeout_func(struct timer_list *t)
|
||||||
{
|
{
|
||||||
struct mwifiex_adapter *adapter =
|
struct mwifiex_adapter *adapter = from_timer(adapter, t, cmd_timer);
|
||||||
(struct mwifiex_adapter *) function_context;
|
|
||||||
struct cmd_ctrl_node *cmd_node;
|
struct cmd_ctrl_node *cmd_node;
|
||||||
|
|
||||||
adapter->is_cmd_timedout = 1;
|
adapter->is_cmd_timedout = 1;
|
||||||
|
@ -52,9 +52,9 @@ static int mwifiex_add_bss_prio_tbl(struct mwifiex_private *priv)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void wakeup_timer_fn(unsigned long data)
|
static void wakeup_timer_fn(struct timer_list *t)
|
||||||
{
|
{
|
||||||
struct mwifiex_adapter *adapter = (struct mwifiex_adapter *)data;
|
struct mwifiex_adapter *adapter = from_timer(adapter, t, wakeup_timer);
|
||||||
|
|
||||||
mwifiex_dbg(adapter, ERROR, "Firmware wakeup failed\n");
|
mwifiex_dbg(adapter, ERROR, "Firmware wakeup failed\n");
|
||||||
adapter->hw_status = MWIFIEX_HW_STATUS_RESET;
|
adapter->hw_status = MWIFIEX_HW_STATUS_RESET;
|
||||||
@ -313,8 +313,7 @@ static void mwifiex_init_adapter(struct mwifiex_adapter *adapter)
|
|||||||
adapter->iface_limit.uap_intf = MWIFIEX_MAX_UAP_NUM;
|
adapter->iface_limit.uap_intf = MWIFIEX_MAX_UAP_NUM;
|
||||||
adapter->iface_limit.p2p_intf = MWIFIEX_MAX_P2P_NUM;
|
adapter->iface_limit.p2p_intf = MWIFIEX_MAX_P2P_NUM;
|
||||||
adapter->active_scan_triggered = false;
|
adapter->active_scan_triggered = false;
|
||||||
setup_timer(&adapter->wakeup_timer, wakeup_timer_fn,
|
timer_setup(&adapter->wakeup_timer, wakeup_timer_fn, 0);
|
||||||
(unsigned long)adapter);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -100,8 +100,7 @@ static int mwifiex_register(void *card, struct device *dev,
|
|||||||
}
|
}
|
||||||
mwifiex_init_lock_list(adapter);
|
mwifiex_init_lock_list(adapter);
|
||||||
|
|
||||||
setup_timer(&adapter->cmd_timer, mwifiex_cmd_timeout_func,
|
timer_setup(&adapter->cmd_timer, mwifiex_cmd_timeout_func, 0);
|
||||||
(unsigned long)adapter);
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
@ -1072,7 +1072,7 @@ int mwifiex_complete_cmd(struct mwifiex_adapter *adapter,
|
|||||||
int mwifiex_send_cmd(struct mwifiex_private *priv, u16 cmd_no,
|
int mwifiex_send_cmd(struct mwifiex_private *priv, u16 cmd_no,
|
||||||
u16 cmd_action, u32 cmd_oid, void *data_buf, bool sync);
|
u16 cmd_action, u32 cmd_oid, void *data_buf, bool sync);
|
||||||
|
|
||||||
void mwifiex_cmd_timeout_func(unsigned long function_context);
|
void mwifiex_cmd_timeout_func(struct timer_list *t);
|
||||||
|
|
||||||
int mwifiex_get_debug_info(struct mwifiex_private *,
|
int mwifiex_get_debug_info(struct mwifiex_private *,
|
||||||
struct mwifiex_debug_info *);
|
struct mwifiex_debug_info *);
|
||||||
@ -1617,7 +1617,7 @@ void mwifiex_auto_tdls_update_peer_status(struct mwifiex_private *priv,
|
|||||||
const u8 *mac, u8 link_status);
|
const u8 *mac, u8 link_status);
|
||||||
void mwifiex_auto_tdls_update_peer_signal(struct mwifiex_private *priv,
|
void mwifiex_auto_tdls_update_peer_signal(struct mwifiex_private *priv,
|
||||||
u8 *mac, s8 snr, s8 nflr);
|
u8 *mac, s8 snr, s8 nflr);
|
||||||
void mwifiex_check_auto_tdls(unsigned long context);
|
void mwifiex_check_auto_tdls(struct timer_list *t);
|
||||||
void mwifiex_add_auto_tdls_peer(struct mwifiex_private *priv, const u8 *mac);
|
void mwifiex_add_auto_tdls_peer(struct mwifiex_private *priv, const u8 *mac);
|
||||||
void mwifiex_setup_auto_tdls_timer(struct mwifiex_private *priv);
|
void mwifiex_setup_auto_tdls_timer(struct mwifiex_private *priv);
|
||||||
void mwifiex_clean_auto_tdls(struct mwifiex_private *priv);
|
void mwifiex_clean_auto_tdls(struct mwifiex_private *priv);
|
||||||
|
@ -1389,9 +1389,9 @@ void mwifiex_auto_tdls_update_peer_signal(struct mwifiex_private *priv,
|
|||||||
spin_unlock_irqrestore(&priv->auto_tdls_lock, flags);
|
spin_unlock_irqrestore(&priv->auto_tdls_lock, flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
void mwifiex_check_auto_tdls(unsigned long context)
|
void mwifiex_check_auto_tdls(struct timer_list *t)
|
||||||
{
|
{
|
||||||
struct mwifiex_private *priv = (struct mwifiex_private *)context;
|
struct mwifiex_private *priv = from_timer(priv, t, auto_tdls_timer);
|
||||||
struct mwifiex_auto_tdls_peer *tdls_peer;
|
struct mwifiex_auto_tdls_peer *tdls_peer;
|
||||||
unsigned long flags;
|
unsigned long flags;
|
||||||
u16 reason = WLAN_REASON_TDLS_TEARDOWN_UNSPECIFIED;
|
u16 reason = WLAN_REASON_TDLS_TEARDOWN_UNSPECIFIED;
|
||||||
@ -1456,8 +1456,7 @@ void mwifiex_check_auto_tdls(unsigned long context)
|
|||||||
|
|
||||||
void mwifiex_setup_auto_tdls_timer(struct mwifiex_private *priv)
|
void mwifiex_setup_auto_tdls_timer(struct mwifiex_private *priv)
|
||||||
{
|
{
|
||||||
setup_timer(&priv->auto_tdls_timer, mwifiex_check_auto_tdls,
|
timer_setup(&priv->auto_tdls_timer, mwifiex_check_auto_tdls, 0);
|
||||||
(unsigned long)priv);
|
|
||||||
priv->auto_tdls_timer_active = true;
|
priv->auto_tdls_timer_active = true;
|
||||||
mod_timer(&priv->auto_tdls_timer,
|
mod_timer(&priv->auto_tdls_timer,
|
||||||
jiffies + msecs_to_jiffies(MWIFIEX_TIMER_10S));
|
jiffies + msecs_to_jiffies(MWIFIEX_TIMER_10S));
|
||||||
|
@ -1096,12 +1096,12 @@ postcopy_cur_buf:
|
|||||||
return -EINPROGRESS;
|
return -EINPROGRESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void mwifiex_usb_tx_aggr_tmo(unsigned long context)
|
static void mwifiex_usb_tx_aggr_tmo(struct timer_list *t)
|
||||||
{
|
{
|
||||||
struct urb_context *urb_cnxt = NULL;
|
struct urb_context *urb_cnxt = NULL;
|
||||||
struct sk_buff *skb_send = NULL;
|
struct sk_buff *skb_send = NULL;
|
||||||
struct tx_aggr_tmr_cnxt *timer_context =
|
struct tx_aggr_tmr_cnxt *timer_context =
|
||||||
(struct tx_aggr_tmr_cnxt *)context;
|
from_timer(timer_context, t, hold_timer);
|
||||||
struct mwifiex_adapter *adapter = timer_context->adapter;
|
struct mwifiex_adapter *adapter = timer_context->adapter;
|
||||||
struct usb_tx_data_port *port = timer_context->port;
|
struct usb_tx_data_port *port = timer_context->port;
|
||||||
unsigned long flags;
|
unsigned long flags;
|
||||||
@ -1236,9 +1236,8 @@ static int mwifiex_usb_tx_init(struct mwifiex_adapter *adapter)
|
|||||||
port->tx_aggr.timer_cnxt.port = port;
|
port->tx_aggr.timer_cnxt.port = port;
|
||||||
port->tx_aggr.timer_cnxt.is_hold_timer_set = false;
|
port->tx_aggr.timer_cnxt.is_hold_timer_set = false;
|
||||||
port->tx_aggr.timer_cnxt.hold_tmo_msecs = 0;
|
port->tx_aggr.timer_cnxt.hold_tmo_msecs = 0;
|
||||||
setup_timer(&port->tx_aggr.timer_cnxt.hold_timer,
|
timer_setup(&port->tx_aggr.timer_cnxt.hold_timer,
|
||||||
mwifiex_usb_tx_aggr_tmo,
|
mwifiex_usb_tx_aggr_tmo, 0);
|
||||||
(unsigned long)&port->tx_aggr.timer_cnxt);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
Loading…
Reference in New Issue
Block a user