Commit ed5672d8 authored by Xiaoliang Yang's avatar Xiaoliang Yang Committed by David S. Miller

net: mscc: ocelot: return error if VCAP filter is not found

Although it doesn't look like it is possible to hit these conditions
from user space, there are 2 separate, but related, issues.

First, the ocelot_vcap_block_get_filter_index function, née
ocelot_ace_rule_get_index_id prior to the aae4e500 ("net: mscc:
ocelot: generalize the "ACE/ACL" names") rename, does not do what the
author probably intended. If the desired filter entry is not present in
the ACL block, this function returns an index equal to the total number
of filters, instead of -1, which is maybe what was intended, judging
from the curious initialization with -1, and the "++index" idioms.
Either way, none of the callers seems to expect this behavior.

Second issue, the callers don't actually check the return value at all.
So in case the filter is not found in the rule list, propagate the
return code.

So update the callers and also take the opportunity to get rid of the
odd coding idioms that appear to work but don't.
Signed-off-by: default avatarXiaoliang Yang <xiaoliang.yang_1@nxp.com>
Signed-off-by: default avatarVladimir Oltean <vladimir.oltean@nxp.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 3c0e37a9
...@@ -726,14 +726,15 @@ static int ocelot_vcap_block_get_filter_index(struct ocelot_vcap_block *block, ...@@ -726,14 +726,15 @@ static int ocelot_vcap_block_get_filter_index(struct ocelot_vcap_block *block,
struct ocelot_vcap_filter *filter) struct ocelot_vcap_filter *filter)
{ {
struct ocelot_vcap_filter *tmp; struct ocelot_vcap_filter *tmp;
int index = -1; int index = 0;
list_for_each_entry(tmp, &block->rules, list) { list_for_each_entry(tmp, &block->rules, list) {
++index;
if (filter->id == tmp->id) if (filter->id == tmp->id)
break;
}
return index; return index;
index++;
}
return -ENOENT;
} }
static struct ocelot_vcap_filter* static struct ocelot_vcap_filter*
...@@ -877,6 +878,8 @@ int ocelot_vcap_filter_add(struct ocelot *ocelot, ...@@ -877,6 +878,8 @@ int ocelot_vcap_filter_add(struct ocelot *ocelot,
/* Get the index of the inserted filter */ /* Get the index of the inserted filter */
index = ocelot_vcap_block_get_filter_index(block, filter); index = ocelot_vcap_block_get_filter_index(block, filter);
if (index < 0)
return index;
/* Move down the rules to make place for the new filter */ /* Move down the rules to make place for the new filter */
for (i = block->count - 1; i > index; i--) { for (i = block->count - 1; i > index; i--) {
...@@ -924,6 +927,8 @@ int ocelot_vcap_filter_del(struct ocelot *ocelot, ...@@ -924,6 +927,8 @@ int ocelot_vcap_filter_del(struct ocelot *ocelot,
/* Gets index of the filter */ /* Gets index of the filter */
index = ocelot_vcap_block_get_filter_index(block, filter); index = ocelot_vcap_block_get_filter_index(block, filter);
if (index < 0)
return index;
/* Delete filter */ /* Delete filter */
ocelot_vcap_block_remove_filter(ocelot, block, filter); ocelot_vcap_block_remove_filter(ocelot, block, filter);
...@@ -950,6 +955,9 @@ int ocelot_vcap_filter_stats_update(struct ocelot *ocelot, ...@@ -950,6 +955,9 @@ int ocelot_vcap_filter_stats_update(struct ocelot *ocelot,
int index; int index;
index = ocelot_vcap_block_get_filter_index(block, filter); index = ocelot_vcap_block_get_filter_index(block, filter);
if (index < 0)
return index;
is2_entry_get(ocelot, filter, index); is2_entry_get(ocelot, filter, index);
/* After we get the result we need to clear the counters */ /* After we get the result we need to clear the counters */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment