summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKozlov Dmitry <xeb@mail.ru>2012-03-14 16:59:30 +0400
committerKozlov Dmitry <xeb@mail.ru>2012-03-14 16:59:30 +0400
commitd77729c3d6d4e646e0eb629a81faca90d61eea0c (patch)
tree742e0103bb1a2441819ed9e37908e88d05aa8eb3
parent144650e729bb733393f2cc32f99569ce5dc068b8 (diff)
downloadaccel-ppp-xebd-d77729c3d6d4e646e0eb629a81faca90d61eea0c.tar.gz
accel-ppp-xebd-d77729c3d6d4e646e0eb629a81faca90d61eea0c.zip
ppp: move ip address release to proper place
-rw-r--r--accel-pppd/ppp/ipcp_opt_ipaddr.c3
-rw-r--r--accel-pppd/ppp/ipv6cp_opt_intfid.c3
-rw-r--r--accel-pppd/ppp/ppp.c11
3 files changed, 11 insertions, 6 deletions
diff --git a/accel-pppd/ppp/ipcp_opt_ipaddr.c b/accel-pppd/ppp/ipcp_opt_ipaddr.c
index 1455744..a05dd99 100644
--- a/accel-pppd/ppp/ipcp_opt_ipaddr.c
+++ b/accel-pppd/ppp/ipcp_opt_ipaddr.c
@@ -58,9 +58,6 @@ static void ipaddr_free(struct ppp_ipcp_t *ipcp, struct ipcp_option_t *opt)
{
struct ipaddr_option_t *ipaddr_opt = container_of(opt, typeof(*ipaddr_opt), opt);
- if (ipcp->ppp->ipv4)
- ipdb_put_ipv4(ipcp->ppp, ipcp->ppp->ipv4);
-
_free(ipaddr_opt);
}
diff --git a/accel-pppd/ppp/ipv6cp_opt_intfid.c b/accel-pppd/ppp/ipv6cp_opt_intfid.c
index 0d3d751..3215efc 100644
--- a/accel-pppd/ppp/ipv6cp_opt_intfid.c
+++ b/accel-pppd/ppp/ipv6cp_opt_intfid.c
@@ -79,9 +79,6 @@ static void ipaddr_free(struct ppp_ipv6cp_t *ipv6cp, struct ipv6cp_option_t *opt
{
struct ipaddr_option_t *ipaddr_opt=container_of(opt,typeof(*ipaddr_opt),opt);
- if (ipv6cp->ppp->ipv6)
- ipdb_put_ipv6(ipv6cp->ppp, ipv6cp->ppp->ipv6);
-
_free(ipaddr_opt);
}
diff --git a/accel-pppd/ppp/ppp.c b/accel-pppd/ppp/ppp.c
index 3ab7166..178f33c 100644
--- a/accel-pppd/ppp/ppp.c
+++ b/accel-pppd/ppp/ppp.c
@@ -18,6 +18,7 @@
#include "events.h"
#include "ppp.h"
#include "ppp_fsm.h"
+#include "ipdb.h"
#include "log.h"
#include "spinlock.h"
#include "mempool.h"
@@ -255,6 +256,16 @@ static void destablish_ppp(struct ppp_t *ppp)
ppp->ipv6_pool_name = NULL;
}
+ if (ppp->ipv4) {
+ ipdb_put_ipv4(ppp, ppp->ipv4);
+ ppp->ipv4 = NULL;
+ }
+
+ if (ppp->ipv6) {
+ ipdb_put_ipv6(ppp, ppp->ipv6);
+ ppp->ipv6 = NULL;
+ }
+
if (ppp_shutdown && !ppp_stat.starting && !ppp_stat.active && !ppp_stat.finishing)
kill(getpid(), SIGTERM);
}