diff options
author | Dmitry Kozlov <xeb@mail.ru> | 2016-11-29 15:53:12 +0300 |
---|---|---|
committer | Dmitry Kozlov <xeb@mail.ru> | 2016-11-29 15:53:12 +0300 |
commit | 77fb7e670f32ca8967dc0c33e5c78721b08465ef (patch) | |
tree | 12ccc454caefa17b92c26f2ec2499655a8f66d8a /accel-pppd/ctrl/ipoe | |
parent | 44885639c470cec2d17bf4ee543ea7fc326d66e3 (diff) | |
download | accel-ppp-77fb7e670f32ca8967dc0c33e5c78721b08465ef.tar.gz accel-ppp-77fb7e670f32ca8967dc0c33e5c78721b08465ef.zip |
ipoe: assign point-to-point addresses to non-shared physical interface (prevents route cleaning by interface renaming)
Diffstat (limited to 'accel-pppd/ctrl/ipoe')
-rw-r--r-- | accel-pppd/ctrl/ipoe/ipoe.c | 27 |
1 files changed, 9 insertions, 18 deletions
diff --git a/accel-pppd/ctrl/ipoe/ipoe.c b/accel-pppd/ctrl/ipoe/ipoe.c index 0231678a..4ec77e9e 100644 --- a/accel-pppd/ctrl/ipoe/ipoe.c +++ b/accel-pppd/ctrl/ipoe/ipoe.c @@ -156,7 +156,6 @@ static int conf_proto; static LIST_HEAD(conf_offer_delay); static const char *conf_vlan_name; static int conf_ip_unnumbered; -static int conf_ip_unnumbered_peer_mode; static int conf_check_mac_change; static int conf_soft_terminate; static int conf_calling_sid = SID_MAC; @@ -889,16 +888,7 @@ static void __ipoe_session_activate(struct ipoe_session *ses) if (ses->ifindex == -1) { if (serv->opt_ifcfg) - if(conf_ip_unnumbered && conf_ip_unnumbered_peer_mode) { - ipaddr_add_peer(serv->ifindex, ses->router, 32, ses->yiaddr); - } else { - ipaddr_add(serv->ifindex, ses->router, conf_ip_unnumbered ? 32 : ses->mask); - } - else if (!conf_ip_unnumbered) - iproute_add(serv->ifindex, ses->router, ses->yiaddr, 0, conf_proto, ses->mask); - - if (conf_ip_unnumbered && !conf_ip_unnumbered_peer_mode) - iproute_add(serv->ifindex, serv->opt_src ?: ses->router, ses->yiaddr, 0, conf_proto, 32); + ipaddr_add_peer(serv->ifindex, ses->router, 32, ses->yiaddr); } else ses->ctrl.dont_ifcfg = 0; @@ -931,6 +921,13 @@ static void __ipoe_session_activate(struct ipoe_session *ses) ap_session_activate(&ses->ses); + if (ses->ifindex == -1) { + if (!conf_ip_unnumbered) + iproute_add(serv->ifindex, ses->router, ses->yiaddr, 0, conf_proto, ses->mask); + else if (!serv->opt_ifcfg) + iproute_add(serv->ifindex, serv->opt_src ?: ses->router, ses->yiaddr, 0, conf_proto, 32); + } + if (ses->l4_redirect) ipoe_change_l4_redirect(ses, 0); @@ -2681,7 +2678,7 @@ static void add_interface(const char *ifname, int ifindex, const char *opt, int ioctl(sock_fd, SIOCGIFFLAGS, &ifr); - if ((ifr.ifr_flags & IFF_UP) && opt_shared == 0) { + if ((ifr.ifr_flags & IFF_UP) && opt_shared == 0 && opt_ifcfg) { int flags = ifr.ifr_flags; ifr.ifr_flags &= ~IFF_UP; @@ -3484,12 +3481,6 @@ static void load_config(void) else conf_ip_unnumbered = 1; - opt = conf_get_opt("ipoe", "ip-unnumbered-peer-mode"); - if (opt) - conf_ip_unnumbered_peer_mode = atoi(opt); - else - conf_ip_unnumbered_peer_mode = 0; - opt = conf_get_opt("ipoe", "idle-timeout"); if (opt) conf_idle_timeout = atoi(opt); |