2012-06-19 17:03:24 +00:00
|
|
|
pppd: Cap MTU to the user configured value
|
|
|
|
|
|
|
|
This patchs caps the calculated MTU value in lcp.c to the user specified "mru"
|
|
|
|
option value. Without this patch pppd would advertise a different MTU value
|
|
|
|
compared to what is set on the local interface in some cases.
|
|
|
|
|
|
|
|
Signed-off-by: Jo-Philipp Wich <jow@openwrt.org>
|
|
|
|
|
2009-05-21 10:49:21 +00:00
|
|
|
--- a/pppd/lcp.c
|
|
|
|
+++ b/pppd/lcp.c
|
|
|
|
@@ -1904,12 +1904,12 @@ lcp_up(f)
|
2009-05-20 22:36:38 +00:00
|
|
|
* the interface MTU is set to the lowest of that, the
|
|
|
|
* MTU we want to use, and our link MRU.
|
|
|
|
*/
|
|
|
|
- mtu = ho->neg_mru? ho->mru: PPP_MRU;
|
|
|
|
+ mtu = MIN(ho->neg_mru? ho->mru: PPP_MRU, ao->mru);
|
|
|
|
mru = go->neg_mru? MAX(wo->mru, go->mru): PPP_MRU;
|
|
|
|
#ifdef HAVE_MULTILINK
|
|
|
|
if (!(multilink && go->neg_mrru && ho->neg_mrru))
|
|
|
|
#endif /* HAVE_MULTILINK */
|
|
|
|
- netif_set_mtu(f->unit, MIN(MIN(mtu, mru), ao->mru));
|
|
|
|
+ netif_set_mtu(f->unit, MIN(mtu, mru));
|
|
|
|
ppp_send_config(f->unit, mtu,
|
|
|
|
(ho->neg_asyncmap? ho->asyncmap: 0xffffffff),
|
|
|
|
ho->neg_pcompression, ho->neg_accompression);
|