Commit 5a262efc authored by Juliusz Chroboczek's avatar Juliusz Chroboczek

Move multicast membership management to network_up.

parent f311f9f6
...@@ -91,7 +91,6 @@ int ...@@ -91,7 +91,6 @@ int
main(int argc, char **argv) main(int argc, char **argv)
{ {
struct sockaddr_in6 sin6; struct sockaddr_in6 sin6;
struct ipv6_mreq mreq;
int i, rc, fd; int i, rc, fd;
static unsigned char *buf; static unsigned char *buf;
struct timeval check_neighbours_time; struct timeval check_neighbours_time;
...@@ -355,17 +354,6 @@ main(int argc, char **argv) ...@@ -355,17 +354,6 @@ main(int argc, char **argv)
goto fail; goto fail;
} }
memset(&mreq, 0, sizeof(mreq));
memcpy(&mreq.ipv6mr_multiaddr, protocol_group, 16);
mreq.ipv6mr_interface = ifindex;
rc = setsockopt(protocol_socket, IPPROTO_IPV6, IPV6_JOIN_GROUP,
(char*)&mreq, sizeof(mreq));
if(rc < 0) {
perror("setsockopt(IPV6_JOIN_GROUP)");
goto fail;
}
mtu = kernel_interface_mtu(*arg, ifindex); mtu = kernel_interface_mtu(*arg, ifindex);
if(mtu < 0) { if(mtu < 0) {
fprintf(stderr, "Warning: couldn't get MTU of interface %s (%d).\n", fprintf(stderr, "Warning: couldn't get MTU of interface %s (%d).\n",
......
...@@ -23,6 +23,11 @@ THE SOFTWARE. ...@@ -23,6 +23,11 @@ THE SOFTWARE.
#include <string.h> #include <string.h>
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <sys/ioctl.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <net/if.h>
#include <arpa/inet.h>
#include "babel.h" #include "babel.h"
#include "util.h" #include "util.h"
...@@ -126,6 +131,7 @@ static int ...@@ -126,6 +131,7 @@ static int
network_up(struct network *net, int up) network_up(struct network *net, int up)
{ {
int mtu, rc, wired; int mtu, rc, wired;
struct ipv6_mreq mreq;
if(up == net->up) if(up == net->up)
return 0; return 0;
...@@ -133,6 +139,12 @@ network_up(struct network *net, int up) ...@@ -133,6 +139,12 @@ network_up(struct network *net, int up)
net->up = up; net->up = up;
if(up) { if(up) {
if(net->ifindex <= 0) {
fprintf(stderr,
"Upping unknown interface %s.\n", net->ifname);
return network_up(net, 0);
}
mtu = kernel_interface_mtu(net->ifname, net->ifindex); mtu = kernel_interface_mtu(net->ifname, net->ifindex);
if(mtu < 0) { if(mtu < 0) {
fprintf(stderr, "Warning: couldn't get MTU of interface %s (%d).\n", fprintf(stderr, "Warning: couldn't get MTU of interface %s (%d).\n",
...@@ -169,13 +181,33 @@ network_up(struct network *net, int up) ...@@ -169,13 +181,33 @@ network_up(struct network *net, int up)
net->wired = wired; net->wired = wired;
net->cost = wired ? 128 : 256; net->cost = wired ? 128 : 256;
update_hello_interval(net); update_hello_interval(net);
memset(&mreq, 0, sizeof(mreq));
memcpy(&mreq.ipv6mr_multiaddr, protocol_group, 16);
mreq.ipv6mr_interface = net->ifindex;
rc = setsockopt(protocol_socket, IPPROTO_IPV6, IPV6_JOIN_GROUP,
(char*)&mreq, sizeof(mreq));
if(rc < 0) {
perror("setsockopt(IPV6_JOIN_GROUP)");
/* But don't bail out for now. */
}
} else { } else {
net->buffered = 0; net->buffered = 0;
net->bufsize = 0; net->bufsize = 0;
free(net->sendbuf); free(net->sendbuf);
net->sendbuf = NULL; net->sendbuf = NULL;
if(net->ifindex > 0) {
memset(&mreq, 0, sizeof(mreq));
memcpy(&mreq.ipv6mr_multiaddr, protocol_group, 16);
mreq.ipv6mr_interface = net->ifindex;
rc = setsockopt(protocol_socket, IPPROTO_IPV6, IPV6_LEAVE_GROUP,
(char*)&mreq, sizeof(mreq));
if(rc < 0) {
perror("setsockopt(IPV6_LEAVE_GROUP)");
}
}
} }
if(!up) if(!up)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment