summaryrefslogtreecommitdiff
path: root/accel-pppd/ppp/ppp.c
diff options
context:
space:
mode:
Diffstat (limited to 'accel-pppd/ppp/ppp.c')
-rw-r--r--accel-pppd/ppp/ppp.c23
1 files changed, 18 insertions, 5 deletions
diff --git a/accel-pppd/ppp/ppp.c b/accel-pppd/ppp/ppp.c
index 6329b89c..91c4aa7d 100644
--- a/accel-pppd/ppp/ppp.c
+++ b/accel-pppd/ppp/ppp.c
@@ -162,17 +162,18 @@ int __export establish_ppp(struct ppp_t *ppp)
ppp->chan_hnd.read = ppp_chan_read;
ppp->unit_hnd.fd = ppp->unit_fd;
ppp->unit_hnd.read = ppp_unit_read;
- triton_md_register_handler(ppp->ses.ctrl->ctx, &ppp->chan_hnd);
- triton_md_register_handler(ppp->ses.ctrl->ctx, &ppp->unit_hnd);
-
- triton_md_enable_handler(&ppp->chan_hnd, MD_MODE_READ);
- triton_md_enable_handler(&ppp->unit_hnd, MD_MODE_READ);
log_ppp_debug("ppp established\n");
if (ap_session_starting(&ppp->ses))
goto exit_close_unit;
+ triton_md_register_handler(ppp->ses.ctrl->ctx, &ppp->chan_hnd);
+ triton_md_register_handler(ppp->ses.ctrl->ctx, &ppp->unit_hnd);
+
+ triton_md_enable_handler(&ppp->chan_hnd, MD_MODE_READ);
+ triton_md_enable_handler(&ppp->unit_hnd, MD_MODE_READ);
+
start_first_layer(ppp);
return 0;
@@ -197,6 +198,17 @@ static void destablish_ppp(struct ppp_t *ppp)
triton_md_unregister_handler(&ppp->chan_hnd, 1);
if (conf_unit_cache) {
+ struct ifreq ifr;
+
+ sprintf(ifr.ifr_newname, "ppp%i", ppp->ses.unit_idx);
+ if (strcmp(ifr.ifr_newname, ppp->ses.ifname)) {
+ strncpy(ifr.ifr_name, ppp->ses.ifname, IFNAMSIZ);
+ if (ioctl(sock_fd, SIOCSIFNAME, &ifr)) {
+ triton_md_unregister_handler(&ppp->unit_hnd, 1);
+ goto skip;
+ }
+ }
+
triton_md_unregister_handler(&ppp->unit_hnd, 0);
uc = mempool_alloc(uc_pool);
uc->fd = ppp->unit_fd;
@@ -210,6 +222,7 @@ static void destablish_ppp(struct ppp_t *ppp)
} else
triton_md_unregister_handler(&ppp->unit_hnd, 1);
+skip:
close(ppp->fd);
ppp->fd = -1;
ppp->chan_fd = -1;