lisp: fix use-after-free 93/28393/1
authorBenoît Ganne <bganne@cisco.com>
Thu, 16 Apr 2020 10:39:39 +0000 (12:39 +0200)
committerAndrew Yourtchenko <ayourtch@gmail.com>
Thu, 13 Aug 2020 17:20:47 +0000 (17:20 +0000)
Type: fix

Change-Id: I42c3e3514ba50d40e09ee688d083f3e78fa0713a
Signed-off-by: Benoît Ganne <bganne@cisco.com>
(cherry picked from commit 101fc278c3b7009c42574a25b96c4fb7fcd15e39)

src/vnet/lisp-cp/control.c

index d2cc8da..3cb5f13 100644 (file)
@@ -1398,19 +1398,19 @@ vnet_lisp_del_mapping (gid_address_t * eid, u32 * res_map_index)
   gid_address_copy (&m_args->eid, eid);
   m_args->locator_set_index = old_map->locator_set_index;
 
-  /* delete mapping associated from map-cache */
-  vnet_lisp_map_cache_add_del (m_args, 0);
-
   ls_args->is_add = 0;
   ls_args->index = old_map->locator_set_index;
 
-  /* delete locator set */
-  vnet_lisp_add_del_locator_set (ls_args, 0);
-
   /* delete timer associated to the mapping if any */
   if (old_map->timer_set)
     mapping_delete_timer (lcm, mi);
 
+  /* delete locator set */
+  vnet_lisp_add_del_locator_set (ls_args, 0);
+
+  /* delete mapping associated from map-cache */
+  vnet_lisp_map_cache_add_del (m_args, 0);
+
   /* return old mapping index */
   if (res_map_index)
     res_map_index[0] = mi;
@@ -2004,8 +2004,8 @@ vnet_lisp_add_del_locator (vnet_lisp_add_del_locator_set_args_t * a,
              removed = 1;
              remove_locator_from_locator_set (ls, locit, ls_index, loc_id);
            }
-         if (0 == loc->local &&
-             !gid_address_cmp (&loc->address, &itloc->address))
+         else if (0 == loc->local &&
+                  !gid_address_cmp (&loc->address, &itloc->address))
            {
              removed = 1;
              remove_locator_from_locator_set (ls, locit, ls_index, loc_id);