Commit f4ad1c46 authored by Grégoire Henry's avatar Grégoire Henry

kernel.c : Fix kernel_route(MODIFY) on OSX.

parent 6972e002
...@@ -265,9 +265,17 @@ kernel_route(int operation, const unsigned char *dest, unsigned short plen, ...@@ -265,9 +265,17 @@ kernel_route(int operation, const unsigned char *dest, unsigned short plen,
memcmp(newgate, gate, 16) == 0 && newifindex == ifindex) memcmp(newgate, gate, 16) == 0 && newifindex == ifindex)
return 0; return 0;
metric = newmetric; if(operation == ROUTE_MODIFY) {
gate = newgate; metric = newmetric;
ifindex = newifindex; gate = newgate;
ifindex = newifindex;
}
debugf("kernel_route: %s %s/%d metric %d dev %d nexthop %s\n",
operation == ROUTE_ADD ? "add" :
operation == ROUTE_FLUSH ? "flush" : "change",
format_address(dest), plen, metric, ifindex,
format_address(gate));
if(kernel_socket < 0) kernel_setup_socket(1); if(kernel_socket < 0) kernel_setup_socket(1);
...@@ -280,7 +288,7 @@ kernel_route(int operation, const unsigned char *dest, unsigned short plen, ...@@ -280,7 +288,7 @@ kernel_route(int operation, const unsigned char *dest, unsigned short plen,
case ROUTE_ADD: case ROUTE_ADD:
rtm->rtm_type = RTM_ADD; break; rtm->rtm_type = RTM_ADD; break;
case ROUTE_MODIFY: case ROUTE_MODIFY:
rtm->rtm_type = RTM_DELETE; break; rtm->rtm_type = RTM_CHANGE; break;
default: default:
return -1; return -1;
}; };
...@@ -303,7 +311,10 @@ kernel_route(int operation, const unsigned char *dest, unsigned short plen, ...@@ -303,7 +311,10 @@ kernel_route(int operation, const unsigned char *dest, unsigned short plen,
rtm->rtm_index = ifindex_lo; rtm->rtm_index = ifindex_lo;
} }
rtm->rtm_seq = ++seq; rtm->rtm_seq = ++seq;
rtm->rtm_addrs = RTA_DST | RTA_GATEWAY | RTA_NETMASK; rtm->rtm_addrs = RTA_DST | RTA_GATEWAY;
if(!(operation == ROUTE_MODIFY && plen == 128)) {
rtm->rtm_addrs |= RTA_NETMASK;
}
rtm->rtm_rmx.rmx_hopcount = metric; rtm->rtm_rmx.rmx_hopcount = metric;
rtm->rtm_inits = RTV_HOPCOUNT; rtm->rtm_inits = RTV_HOPCOUNT;
...@@ -324,10 +335,12 @@ kernel_route(int operation, const unsigned char *dest, unsigned short plen, ...@@ -324,10 +335,12 @@ kernel_route(int operation, const unsigned char *dest, unsigned short plen,
SET_IN6_LINKLOCAL_IFINDEX (sin6->sin6_addr, ifindex); SET_IN6_LINKLOCAL_IFINDEX (sin6->sin6_addr, ifindex);
sin6 = (struct sockaddr_in6 *)((char *)sin6 + ROUNDUP(sin6->sin6_len)); sin6 = (struct sockaddr_in6 *)((char *)sin6 + ROUNDUP(sin6->sin6_len));
/* Netmask */ /* Netmask */
sin6->sin6_len = sizeof(struct sockaddr_in6); if((rtm->rtm_addrs | RTA_NETMASK) != 0) {
sin6->sin6_family = AF_INET6; sin6->sin6_len = sizeof(struct sockaddr_in6);
plen2mask(plen, &sin6->sin6_addr); sin6->sin6_family = AF_INET6;
sin6 = (struct sockaddr_in6 *)((char *)sin6 + ROUNDUP(sin6->sin6_len)); plen2mask(plen, &sin6->sin6_addr);
sin6 = (struct sockaddr_in6 *)((char *)sin6 + ROUNDUP(sin6->sin6_len));
}
len = (char *)sin6 - (char *)msg; len = (char *)sin6 - (char *)msg;
rtm->rtm_msglen = len; rtm->rtm_msglen = len;
......
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