summaryrefslogtreecommitdiff
path: root/accel-pppd/ctrl/ipoe
diff options
context:
space:
mode:
authorDmitry Kozlov <xeb@mail.ru>2016-11-29 15:53:12 +0300
committerDmitry Kozlov <xeb@mail.ru>2016-11-29 15:53:12 +0300
commit77fb7e670f32ca8967dc0c33e5c78721b08465ef (patch)
tree12ccc454caefa17b92c26f2ec2499655a8f66d8a /accel-pppd/ctrl/ipoe
parent44885639c470cec2d17bf4ee543ea7fc326d66e3 (diff)
downloadaccel-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.c27
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);