From e4e7cdf5eba8d68ffe620056517d15fef21074cf Mon Sep 17 00:00:00 2001 From: Dmitry Kozlov Date: Mon, 20 Dec 2010 12:02:22 +0300 Subject: ppp: start echo again after lcp went down --- accel-pptpd/extra/pppd_compat.c | 8 ++++---- accel-pptpd/ppp/ppp_lcp.c | 5 ++--- 2 files changed, 6 insertions(+), 7 deletions(-) diff --git a/accel-pptpd/extra/pppd_compat.c b/accel-pptpd/extra/pppd_compat.c index 07ff0751..3a28c939 100644 --- a/accel-pptpd/extra/pppd_compat.c +++ b/accel-pptpd/extra/pppd_compat.c @@ -126,8 +126,8 @@ static void ev_ppp_pre_up(struct ppp_t *ppp) pid_t pid; char *argv[8]; char *env[2]; - char ipaddr[16]; - char peer_ipaddr[16]; + char ipaddr[17]; + char peer_ipaddr[17]; char peername[64]; struct pppd_compat_pd_t *pd = find_pd(ppp); @@ -318,8 +318,8 @@ static void ev_radius_coa(struct ev_radius_t *ev) pid_t pid; char *argv[8]; char *env[2]; - char ipaddr[16]; - char peer_ipaddr[16]; + char ipaddr[17]; + char peer_ipaddr[17]; char peername[64]; struct pppd_compat_pd_t *pd = find_pd(ev->ppp); diff --git a/accel-pptpd/ppp/ppp_lcp.c b/accel-pptpd/ppp/ppp_lcp.c index 334f6c88..bf5ab7a8 100644 --- a/accel-pptpd/ppp/ppp_lcp.c +++ b/accel-pptpd/ppp/ppp_lcp.c @@ -161,9 +161,8 @@ static void lcp_layer_up(struct ppp_fsm_t *fsm) if (!lcp->started) { lcp->started = 1; ppp_layer_started(lcp->ppp, &lcp->ld); - - start_echo(lcp); } + start_echo(lcp); } static void lcp_layer_down(struct ppp_fsm_t *fsm) @@ -629,7 +628,7 @@ static void start_echo(struct ppp_lcp_t *lcp) lcp->echo_timer.period = lcp->echo_interval * 1000; lcp->echo_timer.expire = send_echo_request; - if (lcp->echo_timer.period) + if (lcp->echo_timer.period && !lcp->echo_timer.tpd) triton_timer_add(lcp->ppp->ctrl->ctx, &lcp->echo_timer, 0); } static void stop_echo(struct ppp_lcp_t *lcp) -- cgit v1.2.3