Skip to content

Commit d03b79f

Browse files
edumazetkuba-moo
authored andcommitted
net: atm: fix /proc/net/atm/lec handling
/proc/net/atm/lec must ensure safety against dev_lec[] changes. It appears it had dev_put() calls without prior dev_hold(), leading to imbalance and UAF. Fixes: 1da177e4c3f4 ("Linux-2.6.12-rc2") Signed-off-by: Eric Dumazet <[email protected]> Acked-by: Francois Romieu <[email protected]> # Minor atm contributor Link: https://patch.msgid.link/[email protected] Signed-off-by: Jakub Kicinski <[email protected]>
1 parent d13a382 commit d03b79f

File tree

1 file changed

+3
-2
lines changed

1 file changed

+3
-2
lines changed

net/atm/lec.c

Lines changed: 3 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -909,7 +909,6 @@ static void *lec_itf_walk(struct lec_state *state, loff_t *l)
909909
v = (dev && netdev_priv(dev)) ?
910910
lec_priv_walk(state, l, netdev_priv(dev)) : NULL;
911911
if (!v && dev) {
912-
dev_put(dev);
913912
/* Partial state reset for the next time we get called */
914913
dev = NULL;
915914
}
@@ -933,6 +932,7 @@ static void *lec_seq_start(struct seq_file *seq, loff_t *pos)
933932
{
934933
struct lec_state *state = seq->private;
935934

935+
mutex_lock(&lec_mutex);
936936
state->itf = 0;
937937
state->dev = NULL;
938938
state->locked = NULL;
@@ -950,8 +950,9 @@ static void lec_seq_stop(struct seq_file *seq, void *v)
950950
if (state->dev) {
951951
spin_unlock_irqrestore(&state->locked->lec_arp_lock,
952952
state->flags);
953-
dev_put(state->dev);
953+
state->dev = NULL;
954954
}
955+
mutex_unlock(&lec_mutex);
955956
}
956957

957958
static void *lec_seq_next(struct seq_file *seq, void *v, loff_t *pos)

0 commit comments

Comments
 (0)