aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorAndreas Steffen <andreas.steffen@strongswan.org>2007-07-13 09:00:39 +0000
committerAndreas Steffen <andreas.steffen@strongswan.org>2007-07-13 09:00:39 +0000
commitdb61efdbbb2b95b9be4331810fca593e14596108 (patch)
tree9242f78e4726a3ea4b72a9196a7c15b044c7970e /src
parent018219ae3a3be54bc66c51dfb329447f271b5ce3 (diff)
downloadstrongswan-db61efdbbb2b95b9be4331810fca593e14596108.tar.bz2
strongswan-db61efdbbb2b95b9be4331810fca593e14596108.tar.xz
include default route also in src address evaluation
Diffstat (limited to 'src')
-rw-r--r--src/charon/kernel/kernel_interface.c8
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;
}
}