From cbbd45a52f61ab94453205270d78df128d2f6258 Mon Sep 17 00:00:00 2001 From: Brendan O'Dea Date: Thu, 19 Jan 2006 21:00:24 +0000 Subject: [PATCH] handle LCP NAK of magic-number --- Changes | 1 + ppp.c | 12 +++++++++++- 2 files changed, 12 insertions(+), 1 deletion(-) diff --git a/Changes b/Changes index b37bb45..d10fb30 100644 --- a/Changes +++ b/Changes @@ -1,6 +1,7 @@ * Fri Jan 20 2006 Brendan O'Dea 2.1.16 - Send configured magic-no in LCP EchoReq when LCP is opened. - Correct addition of single IP to pool (Jonathan Yarden). +- Handle LCP NAK of magic-number. * Mon Dec 19 2005 Brendan O'Dea 2.1.15 - Drop backtrace. diff --git a/ppp.c b/ppp.c index 34985c7..0ab2305 100644 --- a/ppp.c +++ b/ppp.c @@ -1,6 +1,6 @@ // L2TPNS PPP Stuff -char const *cvs_id_ppp = "$Id: ppp.c,v 1.91 2005-12-15 14:23:03 bodea Exp $"; +char const *cvs_id_ppp = "$Id: ppp.c,v 1.92 2006-01-19 21:00:24 bodea Exp $"; #include #include @@ -794,6 +794,16 @@ void processlcp(sessionidt s, tunnelidt t, uint8_t *p, uint16_t l) break; + case 5: // Magic-Number + if (*p == ConfigNak) + { + session[s].magic = ntohl(*(uint32_t *)(o + 2)); + LOG(3, s, t, " Remote requested magic-no %x\n", session[s].magic); + if (!session[s].magic) session[s].magic = time_now; // Netgear DG814 sends zero?? + break; + } + // ConfigRej: fallthrough + default: LOG(2, s, t, "LCP: remote sent %s for type %u?\n", ppp_code(*p), type); sessionshutdown(s, "Unable to negotiate LCP.", 3, 0); -- 2.20.1