summaryrefslogtreecommitdiff
path: root/accel-pppd/ctrl/ipoe/ipoe.c
diff options
context:
space:
mode:
authorDmitry Kozlov <xeb@mail.ru>2015-11-24 11:47:43 +0300
committerDmitry Kozlov <xeb@mail.ru>2015-11-24 11:47:43 +0300
commit19dc965d29c7ec17929b8713d021b76107fdf557 (patch)
tree9cbdb9481c791b840bfdc684bbce6620b61e5818 /accel-pppd/ctrl/ipoe/ipoe.c
parentdd0d5ed51e5351d7be2cbdf86b04965b7bcb136b (diff)
parent9b79c7978796c0be8e443863bc277390353e5eaa (diff)
downloadaccel-ppp-19dc965d29c7ec17929b8713d021b76107fdf557.tar.gz
accel-ppp-19dc965d29c7ec17929b8713d021b76107fdf557.zip
Merge branch 'master' of /home/dima/Projects/accel-ppp into vlanmon
Diffstat (limited to 'accel-pppd/ctrl/ipoe/ipoe.c')
-rw-r--r--accel-pppd/ctrl/ipoe/ipoe.c38
1 files changed, 26 insertions, 12 deletions
diff --git a/accel-pppd/ctrl/ipoe/ipoe.c b/accel-pppd/ctrl/ipoe/ipoe.c
index 46ab130d..14bda1f5 100644
--- a/accel-pppd/ctrl/ipoe/ipoe.c
+++ b/accel-pppd/ctrl/ipoe/ipoe.c
@@ -577,15 +577,12 @@ cont:
if (ses->serv->opt_nat)
ses->ses.ipv4 = ipdb_get_ipv4(&ses->ses);
- if (ses->serv->opt_shared == 0 && (!ses->ses.ipv4 || ses->ses.ipv4->peer_addr == ses->yiaddr)) {
- strncpy(ses->ses.ifname, ses->serv->ifname, AP_IFNAME_LEN);
- ses->ses.ifindex = ses->serv->ifindex;
- } else if (ses->ifindex == -1) {
+ if (ses->serv->opt_shared == 0 && ses->ses.ipv4 && ses->ses.ipv4->peer_addr != ses->yiaddr) {
if (ipoe_create_interface(ses))
return;
- }
- ap_session_set_ifindex(&ses->ses);
+ ap_session_set_ifindex(&ses->ses);
+ }
if (ses->dhcpv4_request && ses->serv->dhcpv4_relay) {
dhcpv4_relay_send(ses->serv->dhcpv4_relay, ses->dhcpv4_request, ses->relay_server_id, ses->serv->ifname, conf_agent_remote_id);
@@ -1093,12 +1090,6 @@ static void ipoe_session_finished(struct ap_session *s)
log_ppp_info1("ipoe: session finished\n");
- pthread_mutex_lock(&ses->serv->lock);
- list_del(&ses->entry);
- if ((ses->serv->vid || ses->serv->need_close) && list_empty(&ses->serv->sessions))
- triton_context_call(&ses->serv->ctx, (triton_event_func)ipoe_serv_release, ses->serv);
- pthread_mutex_unlock(&ses->serv->lock);
-
if (ses->ifindex != -1) {
if (uc_size < conf_unit_cache && ipoe_nl_modify(ses->ifindex, 0, 0, "", NULL)) {
uc = mempool_alloc(uc_pool);
@@ -1126,6 +1117,29 @@ static void ipoe_session_finished(struct ap_session *s)
triton_event_fire(EV_CTRL_FINISHED, s);
+ if (s->ifindex == ses->serv->ifindex && strcmp(s->ifname, ses->serv->ifname)) {
+ struct ifreq ifr;
+
+ strcpy(ifr.ifr_name, s->ifname);
+
+ ioctl(sock_fd, SIOCGIFFLAGS, &ifr);
+ ifr.ifr_flags &= ~IFF_UP;
+ ioctl(sock_fd, SIOCSIFFLAGS, &ifr);
+
+ strcpy(ifr.ifr_newname, ses->serv->ifname);
+ ioctl(sock_fd, SIOCSIFNAME, &ifr);
+
+ strcpy(ifr.ifr_name, ses->serv->ifname);
+ ifr.ifr_flags |= IFF_UP;
+ ioctl(sock_fd, SIOCSIFFLAGS, &ifr);
+ }
+
+ pthread_mutex_lock(&ses->serv->lock);
+ list_del(&ses->entry);
+ if ((ses->serv->vid || ses->serv->need_close) && list_empty(&ses->serv->sessions))
+ triton_context_call(&ses->serv->ctx, (triton_event_func)ipoe_serv_release, ses->serv);
+ pthread_mutex_unlock(&ses->serv->lock);
+
triton_context_call(&ses->ctx, (triton_event_func)ipoe_session_free, ses);
}