L2BD/API:fix bd dump to ignore unknown bd_id

Change-Id: I417dfeba902ca8c3a080773942d4d2ce4335a9c1
Signed-off-by: Eyal Bari <ebari@cisco.com>
This commit is contained in:
Eyal Bari
2017-05-14 10:38:39 +03:00
committed by Neale Ranns
parent 8aa1879651
commit 259fca789a

View File

@ -406,27 +406,32 @@ vl_api_bridge_domain_dump_t_handler (vl_api_bridge_domain_dump_t * mp)
{
bd_main_t *bdm = &bd_main;
l2input_main_t *l2im = &l2input_main;
unix_shared_memory_queue_t *q;
l2_bridge_domain_t *bd_config;
u32 bd_id, bd_index;
u32 end;
q = vl_api_client_index_to_input_queue (mp->client_index);
unix_shared_memory_queue_t *q =
vl_api_client_index_to_input_queue (mp->client_index);
if (q == 0)
return;
bd_id = ntohl (mp->bd_id);
u32 bd_id = ntohl (mp->bd_id);
if (bd_id == 0)
return;
bd_index = (bd_id == ~0) ? 0 : bd_find_index (bdm, bd_id);
ASSERT (bd_index != ~0);
end = (bd_id == ~0) ? vec_len (l2im->bd_configs) : bd_index + 1;
u32 bd_index, end;
if (bd_id == ~0)
bd_index = 0, end = vec_len (l2im->bd_configs);
else
{
bd_index = bd_find_index (bdm, bd_id);
if (bd_index == ~0)
return;
end = bd_index + 1;
}
for (; bd_index < end; bd_index++)
{
bd_config = l2input_bd_config_from_index (l2im, bd_index);
l2_bridge_domain_t *bd_config =
l2input_bd_config_from_index (l2im, bd_index);
/* skip dummy bd_id 0 */
if (bd_config && (bd_config->bd_id > 0))
{
@ -451,26 +456,22 @@ vl_api_bridge_flags_t_handler (vl_api_bridge_flags_t * mp)
bd_main_t *bdm = &bd_main;
vl_api_bridge_flags_reply_t *rmp;
int rv = 0;
u32 bd_id = ntohl (mp->bd_id);
u32 bd_index;
u32 flags = ntohl (mp->feature_bitmap);
uword *p;
u32 flags = ntohl (mp->feature_bitmap);
u32 bd_id = ntohl (mp->bd_id);
if (bd_id == 0)
{
rv = VNET_API_ERROR_BD_NOT_MODIFIABLE;
goto out;
}
p = hash_get (bdm->bd_index_by_bd_id, bd_id);
if (p == 0)
u32 bd_index = bd_find_index (bdm, bd_id);
if (bd_index == ~0)
{
rv = VNET_API_ERROR_NO_SUCH_ENTRY;
goto out;
}
bd_index = p[0];
bd_set_flags (vm, bd_index, flags, mp->is_set);
out: