diff options
author | Guillaume Nault <g.nault@alphalink.fr> | 2013-03-15 21:47:32 +0100 |
---|---|---|
committer | Kozlov Dmitry <xeb@mail.ru> | 2013-03-16 08:34:46 +0400 |
commit | c4fc028fafec4ec0a550ae73c8d9ef7184cf3845 (patch) | |
tree | 1e3067acf5bbfe4c88632a2ec6c6bf5611d19616 /accel-pppd/ctrl/l2tp | |
parent | f27c0f86d0a8137a8ce416b03581e88f651428d1 (diff) | |
download | accel-ppp-c4fc028fafec4ec0a550ae73c8d9ef7184cf3845.tar.gz accel-ppp-c4fc028fafec4ec0a550ae73c8d9ef7184cf3845.zip |
l2tp: Merge incomming and outgoing session starting
Define l2tp_session_place_call() which can start either an incomming
or outgoing session depending on the 'sess->lns_mode' flag. This
removes the need for testing session mode before calling
l2tp_tunnel_start_session().
Signed-off-by: Guillaume Nault <g.nault@alphalink.fr>
Diffstat (limited to 'accel-pppd/ctrl/l2tp')
-rw-r--r-- | accel-pppd/ctrl/l2tp/l2tp.c | 43 |
1 files changed, 24 insertions, 19 deletions
diff --git a/accel-pppd/ctrl/l2tp/l2tp.c b/accel-pppd/ctrl/l2tp/l2tp.c index 91057e2a..1eeb7532 100644 --- a/accel-pppd/ctrl/l2tp/l2tp.c +++ b/accel-pppd/ctrl/l2tp/l2tp.c @@ -2799,38 +2799,43 @@ static int l2tp_recv_SLI(struct l2tp_conn_t *conn, const struct l2tp_packet_t *pack) { if (conn->lns_mode) { - l2tp_conn_log(log_warn, conn); - log_warn("l2tp: unexpected SLI\n"); + log_tunnel(log_warn, conn, "discarding unexpected SLI\n"); + return 0; } + if (conf_verbose) + log_tunnel(log_info1, conn, "handling SLI\n"); + if (l2tp_send_ZLB(conn) < 0) log_tunnel(log_error, conn, "acknowledging SLI failed\n"); return 0; } -static void l2tp_session_incall(void *data) +static void l2tp_session_place_call(void *data) { struct l2tp_sess_t *sess = data; + int res; - if (l2tp_send_ICRQ(sess) < 0) { - log_ppp_error("l2tp: impossible to place call:" - " error while sending ICRQ\n"); - return; - } - sess->state1 = STATE_WAIT_ICRP; -} - -static void l2tp_session_outcall(void *data) -{ - struct l2tp_sess_t *sess = data; + if (sess->lns_mode) + res = l2tp_send_OCRQ(sess); + else + res = l2tp_send_ICRQ(sess); - if (l2tp_send_OCRQ(sess) < 0) { - log_ppp_error("l2tp: impossible to place call:" - " error while sending OCRQ\n"); + if (res < 0) { + log_session(log_error, sess, + "impossible to place %s call:" + " sending %cCRQ failed, freeing session\n", + sess->lns_mode ? "outgoing" : "incoming", + sess->lns_mode ? 'O' : 'I'); + if (l2tp_session_free(sess) < 0) + log_session(log_error, sess, + "impossible to free session," + " session data have been kept\n"); return; } - sess->state1 = STATE_WAIT_OCRP; + + sess->state1 = sess->lns_mode ? STATE_WAIT_OCRP : STATE_WAIT_ICRP; } static void l2tp_tunnel_create_session(void *data) @@ -2852,7 +2857,7 @@ static void l2tp_tunnel_create_session(void *data) } if (l2tp_tunnel_start_session(sess, - conn->lns_mode ? l2tp_session_outcall : l2tp_session_incall, sess) < 0) { + l2tp_session_place_call, sess) < 0) { log_tunnel(log_error, conn, "impossible to create session:" " starting session failed\n"); l2tp_tunnel_cancel_session(sess); |