diff options
author | Christoph Schulz <develop@kristov.de> | 2014-07-15 11:51:03 +0200 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2014-07-16 07:52:35 +0200 |
commit | d762d038497c9df51c19fcbe69b094b3bf8e5568 (patch) | |
tree | 596b35ccd321b8bf3ac51e339fd46e09e61450d5 /drivers | |
parent | Merge branch 'bonding_rcu' (diff) | |
download | linux-d762d038497c9df51c19fcbe69b094b3bf8e5568.tar.xz linux-d762d038497c9df51c19fcbe69b094b3bf8e5568.zip |
net: ppp: reset nextseq counter when enabling SC_MULTILINK
If using a demand-dialled PPP unit for a PPP multilink master, the pppd
daemon needs to reset the sequence counter between two connections. This
allows the daemon to reuse the PPP unit instead of destroying and recreating
it. As there is no API to reset the counter, this patch resets the counter
whenever the SC_MULTILINK flag is set.
Signed-off-by: Christoph Schulz <develop@kristov.de>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/net/ppp/ppp_generic.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/drivers/net/ppp/ppp_generic.c b/drivers/net/ppp/ppp_generic.c index 5c002b1ef169..c38ee903bd59 100644 --- a/drivers/net/ppp/ppp_generic.c +++ b/drivers/net/ppp/ppp_generic.c @@ -661,6 +661,8 @@ static long ppp_ioctl(struct file *file, unsigned int cmd, unsigned long arg) break; ppp_lock(ppp); cflags = ppp->flags & ~val; + if (!(ppp->flags & SC_MULTILINK) && (val & SC_MULTILINK)) + ppp->nextseq = 0; ppp->flags = val & SC_FLAG_BITS; ppp_unlock(ppp); if (cflags & SC_CCP_OPEN) |