3 Copyright 2003, CyberTAN Inc. All Rights Reserved
5 This is UNPUBLISHED PROPRIETARY SOURCE CODE of CyberTAN Inc.
6 the contents of this file may not be disclosed to third parties,
7 copied or duplicated in any form without the prior written
8 permission of CyberTAN Inc.
10 This software should be used as a reference only, and it not
11 intended for production use!
13 THIS SOFTWARE IS OFFERED "AS IS", AND CYBERTAN GRANTS NO WARRANTIES OF ANY
14 KIND, EXPRESS OR IMPLIED, BY STATUTE, COMMUNICATION OR OTHERWISE. CYBERTAN
15 SPECIFICALLY DISCLAIMS ANY IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS
16 FOR A SPECIFIC PURPOSE OR NONINFRINGEMENT CONCERNING THIS SOFTWARE
21 Copyright 2005, Broadcom Corporation
24 THIS SOFTWARE IS OFFERED "AS IS", AND BROADCOM GRANTS NO WARRANTIES OF ANY
25 KIND, EXPRESS OR IMPLIED, BY STATUTE, COMMUNICATION OR OTHERWISE. BROADCOM
26 SPECIFICALLY DISCLAIMS ANY IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS
27 FOR A SPECIFIC PURPOSE OR NONINFRINGEMENT CONCERNING THIS SOFTWARE.
32 Modified for Tomato Firmware
33 Portions, Copyright (C) 2006-2009 Jonathan Zarate
39 #include <sys/ioctl.h>
40 #include <arpa/inet.h>
41 #include <sys/sysinfo.h>
45 static const char ppp_linkfile
[] = "/tmp/ppp/link";
46 static const char ppp_optfile
[] = "/tmp/ppp/wanoptions";
49 static const char ppp3g_chatfile
[] = "/tmp/ppp/connect.chat";
53 static void make_secrets(void)
59 user
= nvram_safe_get("ppp_username");
60 pass
= nvram_safe_get("ppp_passwd");
61 if ((f
= fopen("/tmp/ppp/pap-secrets", "w")) != NULL
) {
62 fprintf(f
, "\"%s\" * \"%s\" *\n", user
, pass
);
65 chmod("/tmp/ppp/pap-secrets", 0600);
67 if ((f
= fopen("/tmp/ppp/chap-secrets", "w")) != NULL
) {
68 fprintf(f
, "\"%s\" * \"%s\" *\n", user
, pass
);
71 chmod("/tmp/ppp/chap-secrets", 0600);
74 // -----------------------------------------------------------------------------
76 static int config_pppd(int wan_proto
, int num
)
85 mkdir("/tmp/ppp", 0777);
86 symlink("/sbin/rc", "/tmp/ppp/ip-up");
87 symlink("/sbin/rc", "/tmp/ppp/ip-down");
89 symlink("/sbin/rc", "/tmp/ppp/ipv6-up");
90 symlink("/sbin/rc", "/tmp/ppp/ipv6-down");
92 symlink("/dev/null", "/tmp/ppp/connect-errors");
94 demand
= nvram_get_int("ppp_demand");
96 // Generate options file
97 if ((fp
= fopen(ppp_optfile
, "w")) == NULL
) {
104 if (nvram_match("wan_proto", "ppp3g") ) {
108 "connect \"/usr/sbin/chat -V -t 60 -f %s\"\n"
113 "ipcp-accept-local\n",
114 nvram_safe_get("modem_dev"),
117 if (strlen(nvram_get("ppp_username")) >0 )
118 fprintf(fp
, "user '%s'\n", nvram_get("ppp_username"));
125 "lcp-echo-adaptive\n", // Suppress LCP echo-requests if traffic was received
127 nvram_safe_get("ppp_username"));
135 "defaultroute\n" // Add a default route to the system routing tables, using the peer as the gateway
136 "usepeerdns\n" // Ask the peer for up to 2 DNS server addresses
137 "default-asyncmap\n" // Disable asyncmap negotiation
138 "novj\n" // Disable Van Jacobson style TCP/IP header compression
139 "nobsdcomp\n" // Disable BSD-Compress compression
140 "nodeflate\n" // Disable Deflate compression
141 "noauth\n" // Do not authenticate peer
142 "refuse-eap\n" // Do not use eap
143 "maxfail 0\n" // Never give up
144 "lcp-echo-interval %d\n"// Interval between LCP echo-requests
145 "lcp-echo-failure %d\n" // Tolerance to unanswered echo-requests
147 nvram_get_int("pppoe_lei") ? : 10,
148 nvram_get_int("pppoe_lef") ? : 5,
149 nvram_get_int("debug_ppp") ? "debug\n" : "");
153 if (nvram_match("wan_proto", "ppp3g") && nvram_match("modem_dev", "ttyACM0") ) {
154 //don`t write nopcomp and noaccomp options
159 "nopcomp\n" // Disable protocol field compression
160 "noaccomp\n" // Disable Address/Control compression
169 if (wan_proto
!= WP_L2TP
) {
173 demand
? 30 : (nvram_get_int("ppp_redialperiod") ? : 30));
183 nvram_safe_get("pptp_server_ip"),
184 nvram_get_int("mtu_enable") ? nvram_get_int("wan_mtu") : 1400);
189 "plugin rp-pppoe.so\n"
193 nvram_safe_get("ppp_passwd"),
194 nvram_safe_get("wan_ifname"),
195 nvram_get_int("wan_mtu"), nvram_get_int("wan_mtu"));
196 if (((p
= nvram_get("ppp_service")) != NULL
) && (*p
)) {
197 fprintf(fp
, "rp_pppoe_service '%s'\n", p
);
199 if (((p
= nvram_get("ppp_ac")) != NULL
) && (*p
)) {
200 fprintf(fp
, "rp_pppoe_ac '%s'\n", p
);
202 if (nvram_match("ppp_mlppp", "1")) {
209 if ((cfp
= fopen(ppp3g_chatfile
, "w")) == NULL
) {
210 perror(ppp3g_chatfile
);
214 "ABORT \"NO CARRIER\"\n"
215 "ABORT \"NO DIALTONE\"\n"
216 "ABORT \"NO ERROR\"\n"
217 "ABORT \"NO ANSWER\"\n"
221 /* moved to switch3g script
222 if (strlen(nvram_get("modem_pin")) >0 ) {
225 "OK \"AT+CPIN=%s\"\n"
227 nvram_get("modem_pin"));
231 "OK \"AT&FE0V1X1&D2&C1S0=0\"\n"
235 "OK \"AT&FE0V1X1&D2&C1S0=0\"\n"
239 /* Only send the AT+CGDCONT (define PDP context) command to set
240 * the APN if modem_apn is defined and non-empty. Some ISPs
241 * (ex. BSNL EVDO in India) don't need this (the modem returns
244 if (((p
= nvram_get("modem_apn")) != NULL
) && (*p
)) {
245 fprintf(cfp
, "OK 'AT+CGDCONT=1,\"IP\",\"%s\"'\n", p
);
251 nvram_safe_get("modem_init")
256 if (nvram_match("usb_3g", "1") && nvram_match("wan_proto", "ppp3g")) {
258 if (strlen(nvram_get("wan_gateway")) >0 ) {
259 nvram_set("wan_gateway", "");
269 fprintf(fp
, "nomppe nomppc\n");
270 if (nvram_get_int("mtu_enable"))
271 fprintf(fp
, "mtu %d\n", nvram_get_int("wan_mtu"));
278 "demand\n" // Dial on demand
280 "ipcp-accept-remote\n"
281 "ipcp-accept-local\n"
282 "noipdefault\n" // Disables the default behaviour when no local IP address is specified
283 "ktune\n", // Set /proc/sys/net/ipv4/ip_dynaddr to 1 in demand mode if the local address changes
284 nvram_get_int("ppp_idletime") * 60);
288 switch (get_ipv6_service()) {
290 case IPV6_NATIVE_DHCP
:
291 fprintf(fp
, "+ipv6\n");
295 // User specific options
296 fprintf(fp
, "%s\n", nvram_safe_get("ppp_custom"));
305 static void stop_ppp(void)
309 unlink(ppp_linkfile
);
312 killall_tk("ip-down");
314 killall_tk("ipv6-up");
315 killall_tk("ipv6-down");
317 killall_tk("xl2tpd");
319 killall_tk("listen");
324 static void run_pppd(void)
327 eval("pppd", "file", (char *)ppp_optfile
);
329 if (nvram_get_int("ppp_demand")) {
332 Fixed issue id 7887(or 7787):
333 When DUT is PPTP Connect on Demand mode, it couldn't be trigger from LAN.
339 // Trigger Connect On Demand if user ping pptp server
340 eval("listen", nvram_safe_get("lan_ifname"));
348 // -----------------------------------------------------------------------------
350 inline void stop_pptp(void)
355 void start_pptp(int mode
)
359 if (!using_dhcpc()) stop_dhcpc();
362 if (config_pppd(WP_PPTP
, 0) != 0)
370 // -----------------------------------------------------------------------------
372 void preset_wan(char *ifname
, char *gw
, char *netmask
)
376 /* Delete all default routes */
377 route_del(ifname
, 0, NULL
, NULL
, NULL
);
379 /* try adding a route to gateway first */
380 route_add(ifname
, 0, gw
, NULL
, "255.255.255.255");
382 /* Set default route to gateway if specified */
384 while ((route_add(ifname
, 1, "0.0.0.0", gw
, "0.0.0.0") == 1) && (i
--)) {
387 _dprintf("set default gateway=%s n=%d\n", gw
, i
);
389 /* Add routes to dns servers as well for demand ppp to work */
390 char word
[100], *next
;
391 in_addr_t mask
= inet_addr(netmask
);
392 foreach(word
, nvram_safe_get("wan_get_dns"), next
) {
393 if ((inet_addr(word
) & mask
) != (inet_addr(nvram_safe_get("wan_ipaddr")) & mask
))
394 route_add(ifname
, 0, word
, gw
, "255.255.255.255");
403 // -----------------------------------------------------------------------------
406 // Get the IP, Subnetmask, Geteway from WAN interface and set nvram
407 static void start_tmp_ppp(int num
, char *ifname
)
413 TRACE_PT("begin: num=%d\n", num
);
415 if (num
!= 0) return;
417 // Wait for ppp0 to be created
419 while ((ifconfig(ifname
, IFUP
, NULL
, NULL
) != 0) && (timeout
-- > 0)) {
421 _dprintf("[%d] waiting for %s %d...\n", __LINE__
, ifname
, timeout
);
424 if ((s
= socket(AF_INET
, SOCK_RAW
, IPPROTO_RAW
)) < 0) return;
425 strlcpy(ifr
.ifr_name
, ifname
, IFNAMSIZ
);
427 // Set temporary IP address
429 while (ioctl(s
, SIOCGIFADDR
, &ifr
) && timeout
--){
430 _dprintf("[%d] waiting for %s...\n", __LINE__
, ifname
);
433 nvram_set("wan_ipaddr", inet_ntoa(sin_addr(&(ifr
.ifr_addr
))));
434 nvram_set("wan_netmask", "255.255.255.255");
436 // Set temporary P-t-P address
438 while (ioctl(s
, SIOCGIFDSTADDR
, &ifr
) && timeout
--){
439 _dprintf("[%d] waiting for %s...\n", __LINE__
, ifname
);
442 nvram_set("wan_gateway", inet_ntoa(sin_addr(&(ifr
.ifr_dstaddr
))));
446 start_wan_done(ifname
);
450 void start_pppoe(int num
)
454 TRACE_PT("begin pppoe_num=%d\n", num
);
456 if (num
!= 0) return;
460 snprintf(ifname
, sizeof(ifname
), "ppp%d", num
);
464 if (nvram_match( "wan_proto", "ppp3g") ) {
465 if (config_pppd(WP_PPP3G
, num
) != 0)
470 if (config_pppd(WP_PPPOE
, num
) != 0)
479 if (nvram_get_int("ppp_demand"))
480 start_tmp_ppp(num
, ifname
);
482 ifconfig(ifname
, IFUP
, NULL
, NULL
);
487 void stop_pppoe(void)
495 void stop_singe_pppoe(int num
)
497 _dprintf("%s pppoe_num=%d\n", __FUNCTION__
, num
);
501 if (num
!= 0) return;
503 i
= nvram_get_int("pppoe_pid0");
504 if ((i
> 1) && (kill(i
, SIGTERM
) == 0)) {
507 } while (kill(i
, SIGKILL
) == 0);
510 unlink(ppp_linkfile
);
511 nvram_unset("pppoe_ifname0");
513 nvram_set("wan_get_dns", "");
518 // -----------------------------------------------------------------------------
520 inline void stop_l2tp(void)
525 void start_l2tp(void)
534 if (config_pppd(WP_L2TP
, 0) != 0)
537 demand
= nvram_get_int("ppp_demand");
539 /* Generate XL2TPD configuration file */
540 if ((fp
= fopen("/etc/xl2tpd.conf", "w")) == NULL
)
544 "access control = no\n"
548 "tx bps = 100000000\n"
551 "max redials = 32767\n"
552 "redial timeout = %d\n"
556 nvram_safe_get("l2tp_server_ip"),
558 demand
? 30 : (nvram_get_int("ppp_redialperiod") ? : 30),
559 nvram_get_int("debug_ppp") ? "yes" : "no",
560 nvram_safe_get("xl2tpd_custom"));
561 fappend(fp
, "/etc/xl2tpd.custom");
569 eval("listen", nvram_safe_get("lan_ifname"));
579 // -----------------------------------------------------------------------------
581 char *wan_gateway(void)
583 char *gw
= nvram_safe_get("wan_gateway_get");
584 if ((*gw
== 0) || (strcmp(gw
, "0.0.0.0") == 0))
585 gw
= nvram_safe_get("wan_gateway");
589 // -----------------------------------------------------------------------------
591 // trigger connect on demand
592 void force_to_dial(void)
597 switch (get_wan_proto()) {
599 f_write_string("/var/run/l2tp-control", "c l2tp", 0, 0);
602 eval("ping", "-c", "2", "10.112.112.112");
608 eval("ping", "-c", "2", wan_gateway());
615 // -----------------------------------------------------------------------------
617 static void _do_wan_routes(char *ifname
, char *nvname
, int metric
, int add
)
624 // IP[/MASK] ROUTER IP2[/MASK2] ROUTER2 ...
625 tmp
= routes
= strdup(nvram_safe_get(nvname
));
626 while (tmp
&& *tmp
) {
627 char *ipaddr
, *gateway
, *nmask
;
629 ipaddr
= nmask
= strsep(&tmp
, " ");
630 strcpy(netmask
, "255.255.255.255");
633 ipaddr
= strsep(&nmask
, "/");
634 if (nmask
&& *nmask
) {
635 bits
= strtol(nmask
, &nmask
, 10);
636 if (bits
>= 1 && bits
<= 32) {
637 mask
.s_addr
= htonl(0xffffffff << (32 - bits
));
638 strcpy(netmask
, inet_ntoa(mask
));
642 gateway
= strsep(&tmp
, " ");
644 if (gateway
&& *gateway
) {
646 route_add(ifname
, metric
, ipaddr
, gateway
, netmask
);
648 route_del(ifname
, metric
, ipaddr
, gateway
, netmask
);
654 void do_wan_routes(char *ifname
, int metric
, int add
)
656 if (nvram_get_int("dhcp_routes")) {
657 // Static Routes: IP ROUTER IP2 ROUTER2 ...
658 // Classless Static Routes: IP/MASK ROUTER IP2/MASK2 ROUTER2 ...
659 _do_wan_routes(ifname
, "wan_routes1", metric
, add
);
660 _do_wan_routes(ifname
, "wan_routes2", metric
, add
);
664 // -----------------------------------------------------------------------------
666 const char wan_connecting
[] = "/var/lib/misc/wan.connecting";
668 static int is_sta(int idx
, int unit
, int subunit
, void *param
)
672 if (nvram_match(wl_nvname("mode", unit
, subunit
), "sta")) {
673 *p
= nvram_safe_get(wl_nvname("ifname", unit
, subunit
));
679 void start_wan(int mode
)
695 f_write(wan_connecting
, NULL
, 0, 0, 0);
699 if (!foreach_wif(1, &p
, is_sta
)) {
700 p
= nvram_safe_get("wan_ifnameX");
701 /* vlan ID mapping */
702 if (sscanf(p
, "vlan%d", &vid
) == 1) {
703 vlan0tag
= nvram_get_int("vlan0tag");
704 snprintf(buf
, sizeof(buf
), "vlan%dvid", vid
);
705 vid_map
= nvram_get_int(buf
);
706 if ((vid_map
< 1) || (vid_map
> 4094)) vid_map
= vlan0tag
| vid
;
707 snprintf(buf
, sizeof(buf
), "vlan%d", vid_map
);
710 set_mac(p
, "mac_wan", 1);
712 nvram_set("wan_ifname", p
);
713 nvram_set("wan_ifnames", p
);
717 wan_ifname
= nvram_safe_get("wan_ifname");
718 if (wan_ifname
[0] == 0) {
720 nvram_set("wan_ifname", wan_ifname
);
723 if (strcmp(wan_ifname
, "none") == 0) {
724 nvram_set("wan_proto", "disabled");
725 syslog(LOG_INFO
, "No WAN");
730 wan_proto
= get_wan_proto();
732 // set the default gateway for WAN interface
733 nvram_set("wan_gateway_get", nvram_safe_get("wan_gateway"));
735 if (wan_proto
== WP_DISABLED
) {
736 start_wan_done(wan_ifname
);
740 if ((sd
= socket(AF_INET
, SOCK_RAW
, IPPROTO_RAW
)) < 0) {
760 if (nvram_match("mtu_enable", "0")) {
764 // KDB If we've big fat frames enabled then we *CAN* break the
765 // max MTU on PPP link
766 mtu
= nvram_get_int("wan_mtu");
767 if (!(nvram_get_int("jumbo_frame_enable")) && (mtu
> max
)) mtu
= max
;
768 else if (mtu
< 576) mtu
= 576;
770 sprintf(buf
, "%d", mtu
);
771 nvram_set("wan_mtu", buf
);
772 nvram_set("wan_run_mtu", buf
);
774 // 43011: zhijian 2006-12-25 for CD-Router v3.4 mtu bug of PPTP connection mode
775 /* if (wan_proto == WP_PPTP) {
777 } */ // commented out; checkme -- zzz
779 if (wan_proto
!= WP_PPTP
&& wan_proto
!= WP_L2TP
&& wan_proto
!= WP_PPPOE
) {
780 // Don't set the MTU on the port for PPP connections, it will be set on the link instead
782 strcpy(ifr
.ifr_name
, wan_ifname
);
783 ioctl(sd
, SIOCSIFMTU
, &ifr
);
788 ifconfig(wan_ifname
, IFUP
, NULL
, NULL
);
792 set_host_domain_name();
803 if (wan_proto
== WP_LTE
) {
811 else if (wan_proto
!= WP_DHCP
&& wan_proto
!= WP_LTE
) {
812 ifconfig(wan_ifname
, IFUP
, "0.0.0.0", NULL
);
813 ifconfig(wan_ifname
, IFUP
, nvram_safe_get("wan_ipaddr"), nvram_safe_get("wan_netmask"));
815 p
= nvram_safe_get("wan_gateway");
816 if ((*p
!= 0) && (strcmp(p
, "0.0.0.0") != 0))
817 preset_wan(wan_ifname
, p
, nvram_safe_get("wan_netmask"));
830 nvram_set("wan_iface", wan_ifname
);
831 ifconfig(wan_ifname
, IFUP
, nvram_safe_get("wan_ipaddr"), nvram_safe_get("wan_netmask"));
834 while ((!check_wanup()) && (r
-- > 0)) {
838 start_wan_done(wan_ifname
);
842 // Get current WAN hardware address
843 strlcpy(ifr
.ifr_name
, wan_ifname
, IFNAMSIZ
);
844 if (ioctl(sd
, SIOCGIFHWADDR
, &ifr
) == 0) {
845 nvram_set("wan_hwaddr", ether_etoa(ifr
.ifr_hwaddr
.sa_data
, buf
));
848 /* Set initial QoS mode again now that WAN port is ready. */
855 led(LED_DIAG
, 0); // for 4712, 5325E (?)
856 led(LED_DMZ
, nvram_match("dmz_enable", "1"));
862 void start_wan6_done(const char *wan_ifname
)
864 struct in_addr addr4
;
865 struct in6_addr addr
;
866 static char addr6
[INET6_ADDRSTRLEN
];
868 int service
= get_ipv6_service();
870 if (service
!= IPV6_DISABLED
) {
871 if ((nvram_get_int("ipv6_accept_ra") & 1) != 0)
872 accept_ra(wan_ifname
);
877 eval("ip", "route", "add", "::/0", "dev", (char *)wan_ifname
, "metric", "2048");
879 case IPV6_NATIVE_DHCP
:
880 if (nvram_get_int("ipv6_pdonly") == 1) {
881 eval("ip", "route", "add", "::/0", "dev", (char *)wan_ifname
);
886 case IPV6_ANYCAST_6TO4
:
889 if (service
== IPV6_ANYCAST_6TO4
) {
891 memset(&addr
, 0, sizeof(addr
));
892 inet_aton(get_wanip(), &addr4
);
893 addr
.s6_addr16
[0] = htons(0x2002);
894 ipv6_mapaddr4(&addr
, 16, &addr4
, 0);
895 addr
.s6_addr16
[3] = htons(0x0001);
896 inet_ntop(AF_INET6
, &addr
, addr6
, sizeof(addr6
));
897 nvram_set("ipv6_prefix", addr6
);
900 // FIXME: give it a few seconds for DAD completion
907 // FIXME2?: give it a few seconds for DAD completion
914 // ppp_demand: 0=keep alive, 1=connect on demand (run 'listen')
916 // wan_iface: ppp# (PPPOE, PPP3G, PPTP, L2TP), vlan1 (DHCP, HB, Static, LTE)
918 void start_wan_done(char *wan_ifname
)
926 TRACE_PT("begin wan_ifname=%s\n", wan_ifname
);
929 f_write("/var/lib/misc/wantime", &si
.uptime
, sizeof(si
.uptime
), 0, 0);
931 proto
= get_wan_proto();
933 // delete all default routes
934 route_del(wan_ifname
, 0, NULL
, NULL
, NULL
);
936 if (proto
!= WP_DISABLED
) {
937 // set default route to gateway if specified
940 if (proto
== WP_PPTP
&& !using_dhcpc()) {
941 // For PPTP protocol, we must use ppp_get_ip as gateway, not pptp_server_ip (why ??)
942 if (*gw
== 0 || strcmp(gw
, "0.0.0.0") == 0) gw
= nvram_safe_get("ppp_get_ip");
945 if ((*gw
!= 0) && (strcmp(gw
, "0.0.0.0") != 0)) {
946 if (proto
== WP_DHCP
|| proto
== WP_STATIC
|| proto
== WP_LTE
) {
947 // possibly gateway is over the bridge, try adding a route to gateway first
948 route_add(wan_ifname
, 0, gw
, NULL
, "255.255.255.255");
952 while ((route_add(wan_ifname
, 0, "0.0.0.0", gw
, "0.0.0.0") == 1) && (n
--)) {
955 _dprintf("set default gateway=%s n=%d\n", gw
, n
);
957 // hack: avoid routing cycles, when both peer and server have the same IP
958 if (proto
== WP_PPTP
|| proto
== WP_L2TP
) {
959 // delete gateway route as it's no longer needed
960 route_del(wan_ifname
, 0, gw
, "0.0.0.0", "255.255.255.255");
964 #ifdef THREE_ARP_GRATUATOUS_SUPPORT // from 43011; checkme; commented-out -- zzz
966 // 43011: Alpha add to send Gratuitous ARP when wan_proto is Static IP 2007-04-09
967 if (proto == WP_STATIC)
971 unsigned char wan_mac[6];
973 if (read_iface(nvram_safe_get("wan_iface"), &ifindex, &wan_ip, wan_mac) >= 0)
974 arpping(wan_ip, wan_ip, wan_mac, nvram_safe_get("wan_iface"));
979 if (proto
== WP_PPTP
|| proto
== WP_L2TP
) {
980 route_del(nvram_safe_get("wan_iface"), 0, nvram_safe_get("wan_gateway_get"), NULL
, "255.255.255.255");
981 route_add(nvram_safe_get("wan_iface"), 0, nvram_safe_get("ppp_get_ip"), NULL
, "255.255.255.255");
983 if (proto
== WP_L2TP
) {
984 route_add(nvram_safe_get("wan_ifname"), 0, nvram_safe_get("l2tp_server_ip"), nvram_safe_get("wan_gateway"), "255.255.255.255"); // fixed routing problem in Israel by kanki
995 // and routes supplied via DHCP
996 do_wan_routes(using_dhcpc() ? nvram_safe_get("wan_ifname") : wan_ifname
, 0, 1);
1001 wanup
= check_wanup();
1003 if ((wanup
) || (time(0) < Y2K
)) {
1008 if ((wanup
) || (proto
== WP_DISABLED
)) {
1018 start_wan6_done(get_wan6face());
1021 #ifdef TCONFIG_DNSSEC
1022 if (nvram_match("dnssec_enable", "1")) {
1023 killall("dnsmasq", SIGHUP
);
1035 notice_set("wan", "");
1037 run_nvscript("script_wanup", NULL
, 0);
1040 // We don't need STP after wireless led is lighted // no idea why... toggling it if necessary -- zzz
1041 if (check_hw_type() == HW_BCM4702
) {
1042 eval("brctl", "stp", nvram_safe_get("lan_ifname"), "0");
1043 if (nvram_match("lan_stp", "1"))
1044 eval("brctl", "stp", nvram_safe_get("lan_ifname"), "1");
1045 if(strcmp(nvram_safe_get("lan1_ifname"),"")!=0) {
1046 eval("brctl", "stp", nvram_safe_get("lan1_ifname"), "0");
1047 if (nvram_match("lan1_stp", "1"))
1048 eval("brctl", "stp", nvram_safe_get("lan1_ifname"), "1");
1050 if(strcmp(nvram_safe_get("lan2_ifname"),"")!=0) {
1051 eval("brctl", "stp", nvram_safe_get("lan2_ifname"), "0");
1052 if (nvram_match("lan2_stp", "1"))
1053 eval("brctl", "stp", nvram_safe_get("lan2_ifname"), "1");
1055 if(strcmp(nvram_safe_get("lan3_ifname"),"")!=0) {
1056 eval("brctl", "stp", nvram_safe_get("lan3_ifname"), "0");
1057 if (nvram_match("lan3_stp", "1"))
1058 eval("brctl", "stp", nvram_safe_get("lan3_ifname"), "1");
1070 #ifdef TCONFIG_PPTPD
1071 if (wanup
&& nvram_get_int("pptp_client_enable"))
1072 start_pptp_client();
1075 unlink(wan_connecting
);
1077 new_qoslimit_start(); //!! RAF
1088 TRACE_PT("begin\n");
1094 #ifdef TCONFIG_PPTPD
1101 wan_proto
= get_wan_proto();
1103 if (wan_proto
== WP_LTE
) {
1104 xstart("switch4g", "disconnect");
1107 new_qoslimit_stop(); //!! RAF
1110 stop_upnp(); //!!TB - moved from stop_services()
1119 nvram_set("ipv6_get_dns", "");
1122 /* Kill any WAN client daemons or callbacks */
1129 nvram_set("wan_get_dns", "");
1131 /* Bring down WAN interfaces */
1132 foreach(name
, nvram_safe_get("wan_ifnames"), next
)
1133 ifconfig(name
, 0, "0.0.0.0", NULL
);
1135 SET_LED(RELEASE_IP
);
1136 //notice_set("wan", "");
1137 unlink("/var/notice/wan");
1138 unlink(wan_connecting
);