Fix failure during enable/disable of features 80/12580/2
authorMatthew Smith <mgsmith@netgate.com>
Tue, 15 May 2018 20:51:30 +0000 (15:51 -0500)
committerDave Wallace <dwallacelf@gmail.com>
Thu, 17 May 2018 16:31:15 +0000 (16:31 +0000)
commitc3267ed944b47c5894be916cb9a440413b8802f8
treebea8ae35fd16cafe1cf7c508c549d76bd5a07062
parent19be50ed9f7dc838f6c5720de9b5df6ef36b0cf3
Fix failure during enable/disable of features

vnet_feature_enable_disable_with_index() checks the
return status of vnet_config_{add,del}_feature().
If the config string heap index returned is the same
index that was in use prior to the add/delete, it is
concluded that a failure occurred and processing of
the feature stops.

Sometimes the config index that is returned
can legitimately be the same index that was in used
before the add/delete. The old list of features can
have its heap entry deallocated before a new entry for
the new list is allocated. The heap entry for the new
list can be the entry that was deallocated while
deleting the old one.

Make vnet_config_{add,del}_feature() return ~0 on
failure. Look for that return value as an indication
that an error occurred in
vnet_enable_disable_feature_by_index().

Change-Id: I88bb3ff88a76971c1b5e5ece74784ce8ba78373c
Signed-off-by: Matthew Smith <mgsmith@netgate.com>
src/vnet/config.c
src/vnet/feature/feature.c