diff options
author | Gabriel Oginski <gabrielx.oginski@intel.com> | 2023-02-14 08:41:07 +0000 |
---|---|---|
committer | Fan Zhang <fanzhang.oss@gmail.com> | 2023-02-27 13:40:05 +0000 |
commit | 9cb3e15c9f5b0eed296c3517c6475bd17a33441e (patch) | |
tree | 153a9752619fd576170d8ce26b2312bec4e46b5a /extras/strongswan/vpp_sswan/kernel_vpp_ipsec.c | |
parent | a10437fcccc58626d00aa3814ccf18313a5b1a17 (diff) |
vpp-swan: fix segmentation fault in arp function
This patch adds a missing file descriptor free handler to prevent
invalid dereferencing in the future
Type: fix
Signed-off-by: Gabriel Oginski <gabrielx.oginski@intel.com>
Change-Id: Idc809a70b1fedec9a06446344d5481d467c78c19
Diffstat (limited to 'extras/strongswan/vpp_sswan/kernel_vpp_ipsec.c')
-rw-r--r-- | extras/strongswan/vpp_sswan/kernel_vpp_ipsec.c | 27 |
1 files changed, 22 insertions, 5 deletions
diff --git a/extras/strongswan/vpp_sswan/kernel_vpp_ipsec.c b/extras/strongswan/vpp_sswan/kernel_vpp_ipsec.c index 2a0d86d7ef0..a51edcbc247 100644 --- a/extras/strongswan/vpp_sswan/kernel_vpp_ipsec.c +++ b/extras/strongswan/vpp_sswan/kernel_vpp_ipsec.c @@ -217,8 +217,8 @@ set_arp (char *ipStr, char *if_name, bool add) { char *out = NULL; int out_len = 0; - vl_api_ip_neighbor_add_del_t *mp; - vl_api_ip_neighbor_add_del_reply_t *rmp; + vl_api_ip_neighbor_add_del_t *mp = NULL; + vl_api_ip_neighbor_add_del_reply_t *rmp = NULL; int rc = SUCCESS; uint32_t sw_if_index = ~0; @@ -231,12 +231,13 @@ set_arp (char *ipStr, char *if_name, bool add) unsigned char mac[8] = { 0, }; - uint32_t addr; + uint32_t addr = 0; if (if_name == NULL || ipStr == NULL) { DBG2 (DBG_KNL, "para is null\n"); rc = FAILED; + goto error; } DBG2 (DBG_KNL, "from kernel read mac\n"); @@ -250,7 +251,7 @@ set_arp (char *ipStr, char *if_name, bool add) } fp = fopen (file, "rb"); - while ((nread = getline (&buffer, &len, fp)) != -1) + while (fp && ((nread = getline (&buffer, &len, fp)) != -1)) { sscanf (buffer, "%s %*s %*s %s %*s %*s", &buf[0], &buf[1]); inet_aton (&buf[0], &addr); @@ -273,6 +274,7 @@ set_arp (char *ipStr, char *if_name, bool add) { DBG1 (DBG_KNL, "vac %s neighbor entry", add ? "adding" : "removing"); + fclose (fp); goto error; } rmp = (void *) out; @@ -280,17 +282,32 @@ set_arp (char *ipStr, char *if_name, bool add) { DBG1 (DBG_KNL, "%s neighbor add rv:%d", add ? "add" : "remove", ntohl (rmp->retval)); + fclose (fp); goto error; } fclose (fp); + free (out); + vl_msg_api_free (mp); + free (buffer); + return rc; } } - return rc; + + if (fp != NULL) + { + fclose (fp); + fp = NULL; + } error: free (out); vl_msg_api_free (mp); + if (buffer != NULL) + { + free (buffer); + buffer = NULL; + } return rc; } |