diff options
author | Dmitry Kozlov <xeb@mail.ru> | 2015-11-18 12:47:27 +0300 |
---|---|---|
committer | Dmitry Kozlov <xeb@mail.ru> | 2015-11-18 12:47:27 +0300 |
commit | dd6a897125a984498536466174426b18ed870bcc (patch) | |
tree | 5ad33fc1bb4f24a591f575b0a99ac0e988846eb3 | |
parent | cc773ecd1776610e8789e72415cb48d2d203712b (diff) | |
download | accel-ppp-dd6a897125a984498536466174426b18ed870bcc.tar.gz accel-ppp-dd6a897125a984498536466174426b18ed870bcc.zip |
ipoe: do not send immediate Accounting Stop in soft terminate mode
-rw-r--r-- | accel-pppd/ctrl/ipoe/ipoe.c | 6 | ||||
-rw-r--r-- | accel-pppd/include/ap_session.h | 3 | ||||
-rw-r--r-- | accel-pppd/ppp/ppp.c | 30 | ||||
-rw-r--r-- | accel-pppd/ppp/ppp.h | 2 | ||||
-rw-r--r-- | accel-pppd/session.c | 17 |
5 files changed, 36 insertions, 22 deletions
diff --git a/accel-pppd/ctrl/ipoe/ipoe.c b/accel-pppd/ctrl/ipoe/ipoe.c index 94ce4858..59ea87f9 100644 --- a/accel-pppd/ctrl/ipoe/ipoe.c +++ b/accel-pppd/ctrl/ipoe/ipoe.c @@ -1154,7 +1154,7 @@ static void ipoe_session_terminated_pkt(struct dhcpv4_packet *pack) ipoe_session_terminated(ses); } -static void ipoe_session_terminate(struct ap_session *s, int hard) +static int ipoe_session_terminate(struct ap_session *s, int hard) { struct ipoe_session *ses = container_of(s, typeof(*ses), ses); @@ -1162,6 +1162,8 @@ static void ipoe_session_terminate(struct ap_session *s, int hard) ipoe_session_terminated(ses); else ses->terminate = 1; + + return 0; } @@ -3156,7 +3158,7 @@ static void load_config(void) if (opt) conf_lease_timeout = atoi(opt); else - conf_lease_timeout = 660; + conf_lease_timeout = conf_lease_time; opt = conf_get_opt("ipoe", "unit-cache"); if (opt) diff --git a/accel-pppd/include/ap_session.h b/accel-pppd/include/ap_session.h index 41155f1b..8bfe4cd8 100644 --- a/accel-pppd/include/ap_session.h +++ b/accel-pppd/include/ap_session.h @@ -50,7 +50,7 @@ struct ap_ctrl int ppp:1; void (*started)(struct ap_session*); void (*finished)(struct ap_session *); - void (*terminate)(struct ap_session *, int hard); + int (*terminate)(struct ap_session *, int hard); }; struct ap_private @@ -92,6 +92,7 @@ struct ap_session int terminating:1; int terminated:1; + int down:1; int terminate_cause; struct list_head pd_list; diff --git a/accel-pppd/ppp/ppp.c b/accel-pppd/ppp/ppp.c index 3a3b2fcc..c47d8d93 100644 --- a/accel-pppd/ppp/ppp.c +++ b/accel-pppd/ppp/ppp.c @@ -236,13 +236,11 @@ static void destroy_ppp_channel(struct ppp_t *ppp) static void destablish_ppp(struct ppp_t *ppp) { - struct pppunit_cache *uc; + struct pppunit_cache *uc = NULL; if (ppp->unit_fd < 0) goto destroy_channel; - triton_event_fire(EV_SES_PRE_FINISHED, &ppp->ses); - if (conf_unit_cache) { struct ifreq ifr; @@ -256,15 +254,10 @@ static void destablish_ppp(struct ppp_t *ppp) } triton_md_unregister_handler(&ppp->unit_hnd, 0); + uc = mempool_alloc(uc_pool); uc->fd = ppp->unit_fd; uc->unit_idx = ppp->ses.unit_idx; - - pthread_mutex_lock(&uc_lock); - list_add_tail(&uc->entry, &uc_list); - if (++uc_size > conf_unit_cache) - pthread_cond_signal(&uc_cond); - pthread_mutex_unlock(&uc_lock); } else triton_md_unregister_handler(&ppp->unit_hnd, 1); @@ -275,6 +268,14 @@ skip: destroy_channel: destroy_ppp_channel(ppp); + + if (uc) { + pthread_mutex_lock(&uc_lock); + list_add_tail(&uc->entry, &uc_list); + if (++uc_size > conf_unit_cache) + pthread_cond_signal(&uc_cond); + pthread_mutex_unlock(&uc_lock); + } } static void *uc_thread(void *unused) @@ -524,7 +525,7 @@ void __export ppp_layer_finished(struct ppp_t *ppp, struct ppp_layer_data_t *d) destablish_ppp(ppp); } -void __export ppp_terminate(struct ap_session *ses, int hard) +int __export ppp_terminate(struct ap_session *ses, int hard) { struct ppp_t *ppp = container_of(ses, typeof(*ppp), ses); struct layer_node_t *n; @@ -533,7 +534,7 @@ void __export ppp_terminate(struct ap_session *ses, int hard) if (hard) { destablish_ppp(ppp); - return; + return 0; } list_for_each_entry(n,&ppp->layers,entry) { @@ -544,10 +545,11 @@ void __export ppp_terminate(struct ap_session *ses, int hard) } } } - if (s) - return; - destablish_ppp(ppp); + if (!s) + destablish_ppp(ppp); + + return 1; } void __export ppp_register_chan_handler(struct ppp_t *ppp,struct ppp_handler_t *h) diff --git a/accel-pppd/ppp/ppp.h b/accel-pppd/ppp/ppp.h index dfceaccd..f0fbcd34 100644 --- a/accel-pppd/ppp/ppp.h +++ b/accel-pppd/ppp/ppp.h @@ -106,7 +106,7 @@ void ppp_layer_started(struct ppp_t *ppp,struct ppp_layer_data_t*); void ppp_layer_finished(struct ppp_t *ppp,struct ppp_layer_data_t*); void ppp_layer_passive(struct ppp_t *ppp,struct ppp_layer_data_t*); -void ppp_terminate(struct ap_session *ses, int hard); +int ppp_terminate(struct ap_session *ses, int hard); void ppp_register_chan_handler(struct ppp_t *, struct ppp_handler_t *); void ppp_register_unit_handler(struct ppp_t * ,struct ppp_handler_t *); diff --git a/accel-pppd/session.c b/accel-pppd/session.c index da18e434..247c0d77 100644 --- a/accel-pppd/session.c +++ b/accel-pppd/session.c @@ -173,6 +173,13 @@ void __export ap_session_finished(struct ap_session *ses) { ses->terminated = 1; + if (!ses->down) { + ap_session_ifdown(ses); + ap_session_read_stats(ses, NULL); + + triton_event_fire(EV_SES_FINISHING, ses); + } + triton_event_fire(EV_SES_PRE_FINISHED, ses); pthread_rwlock_wrlock(&ses_lock); @@ -275,12 +282,14 @@ void __export ap_session_terminate(struct ap_session *ses, int cause, int hard) log_ppp_debug("terminate\n"); - ap_session_ifdown(ses); - ap_session_read_stats(ses, NULL); + if (ses->ctrl->terminate(ses, hard)) { + ap_session_ifdown(ses); + ap_session_read_stats(ses, NULL); - triton_event_fire(EV_SES_FINISHING, ses); + triton_event_fire(EV_SES_FINISHING, ses); - ses->ctrl->terminate(ses, hard); + ses->down = 1; + } } void ap_shutdown_soft(void (*cb)(void)) |