summaryrefslogtreecommitdiff
path: root/accel-pppd/ppp
diff options
context:
space:
mode:
authorKozlov Dmitry <xeb@mail.ru>2011-08-29 00:17:53 +0400
committerKozlov Dmitry <xeb@mail.ru>2011-08-29 00:17:53 +0400
commitf53638854c99e4b6b4b1c167c44fbb6dbfd0c6e7 (patch)
treecee88728fb81d74c1aec712cba785ee383829652 /accel-pppd/ppp
parent059b8b24df39591b96ef10dba735e9c2ad7e118c (diff)
downloadaccel-ppp-xebd-f53638854c99e4b6b4b1c167c44fbb6dbfd0c6e7.tar.gz
accel-ppp-xebd-f53638854c99e4b6b4b1c167c44fbb6dbfd0c6e7.zip
ipv6_dhcp: add routes to delegated prefixes
Diffstat (limited to 'accel-pppd/ppp')
-rw-r--r--accel-pppd/ppp/ipv6cp_opt_intfid.c6
-rw-r--r--accel-pppd/ppp/ppp.c5
-rw-r--r--accel-pppd/ppp/ppp.h1
-rw-r--r--accel-pppd/ppp/ppp_ipv6cp.c3
4 files changed, 10 insertions, 5 deletions
diff --git a/accel-pppd/ppp/ipv6cp_opt_intfid.c b/accel-pppd/ppp/ipv6cp_opt_intfid.c
index cc7ce36..389880a 100644
--- a/accel-pppd/ppp/ipv6cp_opt_intfid.c
+++ b/accel-pppd/ppp/ipv6cp_opt_intfid.c
@@ -37,7 +37,6 @@ struct in6_ifreq {
};
static int urandom_fd;
-static int sock6_fd;
static struct ipv6cp_option_t *ipaddr_init(struct ppp_ipv6cp_t *ipv6cp);
static void ipaddr_free(struct ppp_ipv6cp_t *ipv6cp, struct ipv6cp_option_t *opt);
@@ -372,11 +371,8 @@ static void load_config(void)
static void init()
{
- sock6_fd = socket(AF_INET6, SOCK_DGRAM, 0);
- if (!sock6_fd) {
- log_warn("ppp:ipv6cp: kernel doesn't support ipv6\n");
+ if (sock6_fd < 0)
return;
- }
urandom_fd = open("/dev/urandom", O_RDONLY);
diff --git a/accel-pppd/ppp/ppp.c b/accel-pppd/ppp/ppp.c
index a0f65f1..e6d9788 100644
--- a/accel-pppd/ppp/ppp.c
+++ b/accel-pppd/ppp/ppp.c
@@ -32,6 +32,7 @@ pthread_rwlock_t __export ppp_lock = PTHREAD_RWLOCK_INITIALIZER;
__export LIST_HEAD(ppp_list);
int __export sock_fd;
+int __export sock6_fd;
int __export ppp_shutdown;
@@ -744,6 +745,10 @@ static void init(void)
_exit(EXIT_FAILURE);
}
+ sock6_fd = socket(AF_INET6, SOCK_DGRAM, 0);
+ if (sock6_fd < 0)
+ log_warn("ppp: kernel doesn't support ipv6\n");
+
opt = conf_get_opt("ppp", "seq-file");
if (!opt)
opt = "/var/run/accel-ppp/seq";
diff --git a/accel-pppd/ppp/ppp.h b/accel-pppd/ppp/ppp.h
index 4d3fccd..5246a3e 100644
--- a/accel-pppd/ppp/ppp.h
+++ b/accel-pppd/ppp/ppp.h
@@ -200,4 +200,5 @@ extern struct list_head ppp_list;
extern struct ppp_stat_t ppp_stat;
extern int sock_fd; // internet socket for ioctls
+extern int sock6_fd; // internet socket for ioctls
#endif
diff --git a/accel-pppd/ppp/ppp_ipv6cp.c b/accel-pppd/ppp/ppp_ipv6cp.c
index 816abc4..d60575a 100644
--- a/accel-pppd/ppp/ppp_ipv6cp.c
+++ b/accel-pppd/ppp/ppp_ipv6cp.c
@@ -811,6 +811,9 @@ static void load_config(void)
static void ipv6cp_init(void)
{
+ if (sock6_fd < 0)
+ return;
+
load_config();
triton_event_register_handler(EV_CONFIG_RELOAD, (triton_event_func)load_config);