diff options
author | Andreas Steffen <andreas.steffen@strongswan.org> | 2007-07-13 09:00:39 +0000 |
---|---|---|
committer | Andreas Steffen <andreas.steffen@strongswan.org> | 2007-07-13 09:00:39 +0000 |
commit | db61efdbbb2b95b9be4331810fca593e14596108 (patch) | |
tree | 9242f78e4726a3ea4b72a9196a7c15b044c7970e /src/charon/kernel | |
parent | 018219ae3a3be54bc66c51dfb329447f271b5ce3 (diff) | |
download | strongswan-db61efdbbb2b95b9be4331810fca593e14596108.tar.bz2 strongswan-db61efdbbb2b95b9be4331810fca593e14596108.tar.xz |
include default route also in src address evaluation
Diffstat (limited to 'src/charon/kernel')
-rw-r--r-- | src/charon/kernel/kernel_interface.c | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/src/charon/kernel/kernel_interface.c b/src/charon/kernel/kernel_interface.c index fd23fe5d9..18e67cdfb 100644 --- a/src/charon/kernel/kernel_interface.c +++ b/src/charon/kernel/kernel_interface.c @@ -1530,8 +1530,9 @@ static host_t *get_route(private_kernel_interface_t *this, host_t *dest, /* apply the route if: * - it is not from our own ipsec routing table - * - its destination net contains our destination * - is better than a previous one + * - is the default route or + * - its destination net contains our destination */ if (msg->rtm_table != IPSEC_ROUTING_TABLE && msg->rtm_dst_len > best @@ -1567,12 +1568,11 @@ 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 (rta_dst.ptr - && addr_in_subnet(ip, rta_dst, msg->rtm_dst_len)) + if (msg->rtm_dst_len == 0 + || addr_in_subnet(ip, rta_dst, msg->rtm_dst_len)) { DESTROY_IF(src); src = addr->ip->clone(addr->ip); - best = msg->rtm_dst_len; break; } } |