summaryrefslogtreecommitdiff
path: root/accel-pppd/ctrl/l2tp/l2tp.c
diff options
context:
space:
mode:
authorGuillaume Nault <g.nault@alphalink.fr>2013-03-15 21:47:47 +0100
committerKozlov Dmitry <xeb@mail.ru>2013-03-16 08:34:46 +0400
commit4ae5fc3b6cf03b6ba256be486911a9e90af870d6 (patch)
tree2a692055112ad983a988a89927629ebf28f657f8 /accel-pppd/ctrl/l2tp/l2tp.c
parent26064c2ef465821de6e2866bdcedd2774e6993e5 (diff)
downloadaccel-ppp-xebd-4ae5fc3b6cf03b6ba256be486911a9e90af870d6.tar.gz
accel-ppp-xebd-4ae5fc3b6cf03b6ba256be486911a9e90af870d6.zip
l2tp: Centralise management of session establishment timers
Start and stop session timeout timers in l2tp_tunnel_start_session() and l2tp_session_connect(). This unifies timers management across the four different ways of creating sessions. Signed-off-by: Guillaume Nault <g.nault@alphalink.fr>
Diffstat (limited to 'accel-pppd/ctrl/l2tp/l2tp.c')
-rw-r--r--accel-pppd/ctrl/l2tp/l2tp.c46
1 files changed, 14 insertions, 32 deletions
diff --git a/accel-pppd/ctrl/l2tp/l2tp.c b/accel-pppd/ctrl/l2tp/l2tp.c
index 586a252..c16304b 100644
--- a/accel-pppd/ctrl/l2tp/l2tp.c
+++ b/accel-pppd/ctrl/l2tp/l2tp.c
@@ -904,13 +904,18 @@ static int l2tp_tunnel_start_session(struct l2tp_sess_t *sess,
if (triton_context_register(&sess->sctx, &sess->ppp.ses) < 0) {
log_tunnel(log_error, conn, "impossible to start new session:"
" context registration failed\n");
- return -1;
+ goto err;
}
triton_context_wakeup(&sess->sctx);
+ if (triton_timer_add(&sess->sctx, &sess->timeout_timer, 0) < 0) {
+ log_tunnel(log_error, conn, "impossible to start new session:"
+ " setting session establishment timer failed\n");
+ goto err_ctx;
+ }
if (triton_context_call(&sess->sctx, start_func, start_param) < 0) {
log_tunnel(log_error, conn, "impossible to start new session:"
" call to session context failed\n");
- goto out_err;
+ goto err_ctx_timer;
}
__sync_add_and_fetch(&stat_starting, 1);
@@ -918,8 +923,11 @@ static int l2tp_tunnel_start_session(struct l2tp_sess_t *sess,
return 0;
-out_err:
+err_ctx_timer:
+ triton_timer_del(&sess->timeout_timer);
+err_ctx:
triton_context_unregister(&sess->sctx);
+err:
return -1;
}
@@ -1186,6 +1194,9 @@ static int l2tp_session_connect(struct l2tp_sess_t *sess)
triton_event_fire(EV_CTRL_STARTED, &sess->ppp.ses);
+ if (sess->timeout_timer.tpd)
+ triton_timer_del(&sess->timeout_timer);
+
if (establish_ppp(&sess->ppp)) {
log_session(log_error, sess, "impossible to connect session:"
"PPP establishment failed\n");
@@ -1647,16 +1658,6 @@ static int l2tp_send_ICRQ(struct l2tp_sess_t *sess)
return -1;
}
- if (!sess->timeout_timer.tpd) {
- if (triton_timer_add(&sess->sctx, &sess->timeout_timer, 0) < 0)
- log_session(log_warn, sess, "ICRQ: setting session"
- " establishment timer failed\n");
- } else {
- if (triton_timer_mod(&sess->timeout_timer, 0) < 0)
- log_session(log_warn, sess, "ICRQ: resetting session"
- " establishment timer failed\n");
- }
-
return 0;
out_err:
@@ -1688,11 +1689,6 @@ static int l2tp_send_ICRP(struct l2tp_sess_t *sess)
" sending packet failed\n");
}
- if (!sess->timeout_timer.tpd)
- triton_timer_add(&sess->sctx, &sess->timeout_timer, 0);
- else
- triton_timer_mod(&sess->timeout_timer, 0);
-
return 0;
out_err:
@@ -1797,16 +1793,6 @@ static int l2tp_send_OCRQ(struct l2tp_sess_t *sess)
return -1;
}
- if (!sess->timeout_timer.tpd) {
- if (triton_timer_add(&sess->sctx, &sess->timeout_timer, 0) < 0)
- log_session(log_warn, sess, "OCRQ: setting session"
- " establishment timer failed\n");
- } else {
- if (triton_timer_mod(&sess->timeout_timer, 0) < 0)
- log_session(log_warn, sess, "OCRQ: resetting session"
- " establishment timer failed\n");
- }
-
return 0;
out_err:
@@ -2436,7 +2422,6 @@ static int l2tp_recv_ICRP(struct l2tp_sess_t *sess,
return -1;
}
- triton_timer_del(&sess->timeout_timer);
list_for_each_entry(attr, &pack->attrs, entry) {
switch(attr->attr->id) {
@@ -2534,8 +2519,6 @@ static int l2tp_recv_ICCN(struct l2tp_sess_t *sess,
return -1;
}
- triton_timer_del(&sess->timeout_timer);
-
return 0;
}
@@ -2745,7 +2728,6 @@ static int l2tp_recv_OCCN(struct l2tp_sess_t *sess,
return 0;
}
- triton_timer_del(&sess->timeout_timer);
list_for_each_entry(attr, &pack->attrs, entry) {
switch (attr->attr->id) {