diff options
author | Martin Willi <martin@strongswan.org> | 2008-08-21 15:17:45 +0000 |
---|---|---|
committer | Martin Willi <martin@strongswan.org> | 2008-08-21 15:17:45 +0000 |
commit | 3e45b3a1ad0df3d00418be1fa43bd7911eff89a3 (patch) | |
tree | 08313c2794748d7a3b094541443918af799b2ec7 /src/charon | |
parent | b848f0377c3b76aeb4d4aefd9b818e05ae4e24e2 (diff) | |
download | strongswan-3e45b3a1ad0df3d00418be1fa43bd7911eff89a3.tar.bz2 strongswan-3e45b3a1ad0df3d00418be1fa43bd7911eff89a3.tar.xz |
do not return IPv6 src addresses for IPv4 destinations
Diffstat (limited to 'src/charon')
-rw-r--r-- | src/charon/kernel/kernel_interface.c | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/src/charon/kernel/kernel_interface.c b/src/charon/kernel/kernel_interface.c index ca3bec246..2db391c94 100644 --- a/src/charon/kernel/kernel_interface.c +++ b/src/charon/kernel/kernel_interface.c @@ -1790,8 +1790,10 @@ static host_t *get_route(private_kernel_interface_t *this, host_t *dest, while (addrs->iterate(addrs, (void**)&addr)) { chunk_t ip = addr->ip->get_address(addr->ip); - if (msg->rtm_dst_len == 0 - || addr_in_subnet(ip, rta_dst, msg->rtm_dst_len)) + if ((msg->rtm_dst_len == 0 && + addr->ip->get_family(addr->ip) == + dest->get_family(dest)) || + addr_in_subnet(ip, rta_dst, msg->rtm_dst_len)) { DESTROY_IF(src); src = addr->ip->clone(addr->ip); |