X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=src%2Fvnet%2Ffib%2Ffib_attached_export.c;h=574131de66a037609bb0b202ab2e3bbe05e8a19c;hb=32e1c010b0c34fd0984f7fc45fae648a182025c5;hp=c389ea43febb0a2552808892be29fb433212436f;hpb=7cd468a3d7dee7d6c92f69a0bb7061ae208ec727;p=vpp.git diff --git a/src/vnet/fib/fib_attached_export.c b/src/vnet/fib/fib_attached_export.c index c389ea43feb..574131de66a 100644 --- a/src/vnet/fib/fib_attached_export.c +++ b/src/vnet/fib/fib_attached_export.c @@ -244,6 +244,12 @@ fib_attached_export_import (fib_entry_t *fib_entry, { fib_entry_delegate_t *fed; fib_ae_import_t *import; + fib_node_index_t fei; + + /* + * save index for later post-realloc retreival + */ + fei = fib_entry_get_index(fib_entry); pool_get(fib_ae_import_pool, import); @@ -292,11 +298,13 @@ fib_attached_export_import (fib_entry_t *fib_entry, /* * track the entry in the export table so we can update appropriately - * when it changes + * when it changes. + * Exporting prefixes will have allocated new fib_entry_t objects, so the pool + * may have realloc'd. */ + fib_entry = fib_entry_get(fei); import->faei_export_sibling = - fib_entry_cover_track(fib_entry_get(import->faei_export_entry), - fib_entry_get_index(fib_entry)); + fib_entry_cover_track(fib_entry_get(import->faei_export_entry), fei); fed = fib_entry_delegate_find_or_add(fib_entry, FIB_ENTRY_DELEGATE_ATTACHED_IMPORT);