mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2025-02-04 23:35:27 +07:00
Merge branch 'tun-timer-cleanups'
Eric Dumazet says:
====================
tun: timer cleanups
While working on a syzkaller issue that might have been
fixed already by Cong Wang in commit 0ad646c81b
("tun: call dev_get_valid_name() before register_netdevice()")
I made three small changes related to flow_gc_timer.
====================
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
commit
bdd091bab8
@ -454,25 +454,28 @@ static void tun_flow_cleanup(unsigned long data)
|
||||
|
||||
tun_debug(KERN_INFO, tun, "tun_flow_cleanup\n");
|
||||
|
||||
spin_lock_bh(&tun->lock);
|
||||
spin_lock(&tun->lock);
|
||||
for (i = 0; i < TUN_NUM_FLOW_ENTRIES; i++) {
|
||||
struct tun_flow_entry *e;
|
||||
struct hlist_node *n;
|
||||
|
||||
hlist_for_each_entry_safe(e, n, &tun->flows[i], hash_link) {
|
||||
unsigned long this_timer;
|
||||
count++;
|
||||
|
||||
this_timer = e->updated + delay;
|
||||
if (time_before_eq(this_timer, jiffies))
|
||||
if (time_before_eq(this_timer, jiffies)) {
|
||||
tun_flow_delete(tun, e);
|
||||
else if (time_before(this_timer, next_timer))
|
||||
continue;
|
||||
}
|
||||
count++;
|
||||
if (time_before(this_timer, next_timer))
|
||||
next_timer = this_timer;
|
||||
}
|
||||
}
|
||||
|
||||
if (count)
|
||||
mod_timer(&tun->flow_gc_timer, round_jiffies_up(next_timer));
|
||||
spin_unlock_bh(&tun->lock);
|
||||
spin_unlock(&tun->lock);
|
||||
}
|
||||
|
||||
static void tun_flow_update(struct tun_struct *tun, u32 rxhash,
|
||||
@ -1194,8 +1197,6 @@ static void tun_flow_init(struct tun_struct *tun)
|
||||
|
||||
tun->ageing_time = TUN_FLOW_EXPIRE;
|
||||
setup_timer(&tun->flow_gc_timer, tun_flow_cleanup, (unsigned long)tun);
|
||||
mod_timer(&tun->flow_gc_timer,
|
||||
round_jiffies_up(jiffies + tun->ageing_time));
|
||||
}
|
||||
|
||||
static void tun_flow_uninit(struct tun_struct *tun)
|
||||
|
Loading…
Reference in New Issue
Block a user