net/mac80211/mesh_plink: 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. This requires adding a pointer back to the sta_info since container_of() can't resolve the sta_info. Cc: Johannes Berg <johannes@sipsolutions.net> Cc: "David S. Miller" <davem@davemloft.net> Cc: linux-wireless@vger.kernel.org Cc: netdev@vger.kernel.org Cc: Thomas Gleixner <tglx@linutronix.de> Signed-off-by: Kees Cook <keescook@chromium.org> Signed-off-by: Johannes Berg <johannes.berg@intel.com>
This commit is contained in:
parent
753d179ad0
commit
4c02d62fa3
|
@ -275,6 +275,7 @@ void mesh_neighbour_update(struct ieee80211_sub_if_data *sdata,
|
|||
u8 *hw_addr, struct ieee802_11_elems *ie);
|
||||
bool mesh_peer_accepts_plinks(struct ieee802_11_elems *ie);
|
||||
u32 mesh_accept_plinks_update(struct ieee80211_sub_if_data *sdata);
|
||||
void mesh_plink_timer(struct timer_list *t);
|
||||
void mesh_plink_broken(struct sta_info *sta);
|
||||
u32 mesh_plink_deactivate(struct sta_info *sta);
|
||||
u32 mesh_plink_open(struct sta_info *sta);
|
||||
|
|
|
@ -603,8 +603,9 @@ void mesh_neighbour_update(struct ieee80211_sub_if_data *sdata,
|
|||
ieee80211_mbss_info_change_notify(sdata, changed);
|
||||
}
|
||||
|
||||
static void mesh_plink_timer(unsigned long data)
|
||||
void mesh_plink_timer(struct timer_list *t)
|
||||
{
|
||||
struct mesh_sta *mesh = from_timer(mesh, t, plink_timer);
|
||||
struct sta_info *sta;
|
||||
u16 reason = 0;
|
||||
struct ieee80211_sub_if_data *sdata;
|
||||
|
@ -616,7 +617,7 @@ static void mesh_plink_timer(unsigned long data)
|
|||
* del_timer_sync() this timer after having made sure
|
||||
* it cannot be readded (by deleting the plink.)
|
||||
*/
|
||||
sta = (struct sta_info *) data;
|
||||
sta = mesh->plink_sta;
|
||||
|
||||
if (sta->sdata->local->quiescing)
|
||||
return;
|
||||
|
@ -696,11 +697,8 @@ static void mesh_plink_timer(unsigned long data)
|
|||
|
||||
static inline void mesh_plink_timer_set(struct sta_info *sta, u32 timeout)
|
||||
{
|
||||
sta->mesh->plink_timer.expires = jiffies + msecs_to_jiffies(timeout);
|
||||
sta->mesh->plink_timer.data = (unsigned long) sta;
|
||||
sta->mesh->plink_timer.function = mesh_plink_timer;
|
||||
sta->mesh->plink_timeout = timeout;
|
||||
add_timer(&sta->mesh->plink_timer);
|
||||
mod_timer(&sta->mesh->plink_timer, jiffies + msecs_to_jiffies(timeout));
|
||||
}
|
||||
|
||||
static bool llid_in_use(struct ieee80211_sub_if_data *sdata,
|
||||
|
|
|
@ -329,10 +329,12 @@ struct sta_info *sta_info_alloc(struct ieee80211_sub_if_data *sdata,
|
|||
sta->mesh = kzalloc(sizeof(*sta->mesh), gfp);
|
||||
if (!sta->mesh)
|
||||
goto free;
|
||||
sta->mesh->plink_sta = sta;
|
||||
spin_lock_init(&sta->mesh->plink_lock);
|
||||
if (ieee80211_vif_is_mesh(&sdata->vif) &&
|
||||
!sdata->u.mesh.user_mpm)
|
||||
init_timer(&sta->mesh->plink_timer);
|
||||
timer_setup(&sta->mesh->plink_timer, mesh_plink_timer,
|
||||
0);
|
||||
sta->mesh->nonpeer_pm = NL80211_MESH_POWER_ACTIVE;
|
||||
}
|
||||
#endif
|
||||
|
|
|
@ -344,6 +344,7 @@ DECLARE_EWMA(mesh_fail_avg, 20, 8)
|
|||
* @plink_state: peer link state
|
||||
* @plink_timeout: timeout of peer link
|
||||
* @plink_timer: peer link watch timer
|
||||
* @plink_sta: peer link watch timer's sta_info
|
||||
* @t_offset: timing offset relative to this host
|
||||
* @t_offset_setpoint: reference timing offset of this sta to be used when
|
||||
* calculating clockdrift
|
||||
|
@ -356,6 +357,7 @@ DECLARE_EWMA(mesh_fail_avg, 20, 8)
|
|||
*/
|
||||
struct mesh_sta {
|
||||
struct timer_list plink_timer;
|
||||
struct sta_info *plink_sta;
|
||||
|
||||
s64 t_offset;
|
||||
s64 t_offset_setpoint;
|
||||
|
|
Loading…
Reference in New Issue