From: Martin Willi Date: Wed, 23 Sep 2009 09:18:30 +0000 (+0200) Subject: Fixed a crash in source address lookup X-Git-Tag: 4.3.5rc1~110 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=0406ed7a166e732f1b237ecf6198922825f027a7;p=thirdparty%2Fstrongswan.git Fixed a crash in source address lookup --- diff --git a/src/charon/plugins/kernel_netlink/kernel_netlink_net.c b/src/charon/plugins/kernel_netlink/kernel_netlink_net.c index d9331276c3..ab2ca7d13a 100644 --- a/src/charon/plugins/kernel_netlink/kernel_netlink_net.c +++ b/src/charon/plugins/kernel_netlink/kernel_netlink_net.c @@ -861,15 +861,18 @@ static host_t *get_route(private_kernel_netlink_net_t *this, host_t *dest, { /* got a source address */ new_src = host_create_from_chunk(msg->rtm_family, rta_src, 0); - if (get_vip_refcount(this, src)) - { /* skip source address if it is installed by us */ - new_src->destroy(new_src); - } - else + if (new_src) { - DESTROY_IF(src); - src = new_src; - best = msg->rtm_dst_len; + if (get_vip_refcount(this, new_src)) + { /* skip source address if it is installed by us */ + new_src->destroy(new_src); + } + else + { + DESTROY_IF(src); + src = new_src; + best = msg->rtm_dst_len; + } } continue; }