提交 50c6cc5b 编写于 作者: V Vladimir Oltean 提交者: Jakub Kicinski

net: mscc: ocelot: store a namespaced VCAP filter ID

We will be adding some private VCAP filters that should not interfere in
any way with the filters added using tc-flower. So we need to allocate
some IDs which will not be used by tc.

Currently ocelot uses an u32 id derived from the flow cookie, which in
itself is an unsigned long. This is a problem in itself, since on 64 bit
systems, sizeof(unsigned long)=8, so the driver is already truncating
these.

Create a struct ocelot_vcap_id which contains the full unsigned long
cookie from tc, as well as a boolean that is supposed to namespace the
filters added by tc with the ones that aren't.
Signed-off-by: NVladimir Oltean <vladimir.oltean@nxp.com>
Reviewed-by: NFlorian Fainelli <f.fainelli@gmail.com>
Signed-off-by: NJakub Kicinski <kuba@kernel.org>
上级 0e9bb4e9
...@@ -622,7 +622,8 @@ static int ocelot_flower_parse(struct ocelot *ocelot, int port, bool ingress, ...@@ -622,7 +622,8 @@ static int ocelot_flower_parse(struct ocelot *ocelot, int port, bool ingress,
int ret; int ret;
filter->prio = f->common.prio; filter->prio = f->common.prio;
filter->id = f->cookie; filter->id.cookie = f->cookie;
filter->id.tc_offload = true;
ret = ocelot_flower_parse_action(ocelot, port, ingress, f, filter); ret = ocelot_flower_parse_action(ocelot, port, ingress, f, filter);
if (ret) if (ret)
...@@ -717,7 +718,7 @@ int ocelot_cls_flower_destroy(struct ocelot *ocelot, int port, ...@@ -717,7 +718,7 @@ int ocelot_cls_flower_destroy(struct ocelot *ocelot, int port,
block = &ocelot->block[block_id]; block = &ocelot->block[block_id];
filter = ocelot_vcap_block_find_filter_by_id(block, f->cookie); filter = ocelot_vcap_block_find_filter_by_id(block, f->cookie, true);
if (!filter) if (!filter)
return 0; return 0;
...@@ -741,7 +742,7 @@ int ocelot_cls_flower_stats(struct ocelot *ocelot, int port, ...@@ -741,7 +742,7 @@ int ocelot_cls_flower_stats(struct ocelot *ocelot, int port,
block = &ocelot->block[block_id]; block = &ocelot->block[block_id];
filter = ocelot_vcap_block_find_filter_by_id(block, f->cookie); filter = ocelot_vcap_block_find_filter_by_id(block, f->cookie, true);
if (!filter || filter->type == OCELOT_VCAP_FILTER_DUMMY) if (!filter || filter->type == OCELOT_VCAP_FILTER_DUMMY)
return 0; return 0;
......
...@@ -959,6 +959,12 @@ static void ocelot_vcap_filter_add_to_block(struct ocelot *ocelot, ...@@ -959,6 +959,12 @@ static void ocelot_vcap_filter_add_to_block(struct ocelot *ocelot,
list_add(&filter->list, pos->prev); list_add(&filter->list, pos->prev);
} }
static bool ocelot_vcap_filter_equal(const struct ocelot_vcap_filter *a,
const struct ocelot_vcap_filter *b)
{
return !memcmp(&a->id, &b->id, sizeof(struct ocelot_vcap_id));
}
static int ocelot_vcap_block_get_filter_index(struct ocelot_vcap_block *block, static int ocelot_vcap_block_get_filter_index(struct ocelot_vcap_block *block,
struct ocelot_vcap_filter *filter) struct ocelot_vcap_filter *filter)
{ {
...@@ -966,7 +972,7 @@ static int ocelot_vcap_block_get_filter_index(struct ocelot_vcap_block *block, ...@@ -966,7 +972,7 @@ static int ocelot_vcap_block_get_filter_index(struct ocelot_vcap_block *block,
int index = 0; int index = 0;
list_for_each_entry(tmp, &block->rules, list) { list_for_each_entry(tmp, &block->rules, list) {
if (filter->id == tmp->id) if (ocelot_vcap_filter_equal(filter, tmp))
return index; return index;
index++; index++;
} }
...@@ -991,12 +997,14 @@ ocelot_vcap_block_find_filter_by_index(struct ocelot_vcap_block *block, ...@@ -991,12 +997,14 @@ ocelot_vcap_block_find_filter_by_index(struct ocelot_vcap_block *block,
} }
struct ocelot_vcap_filter * struct ocelot_vcap_filter *
ocelot_vcap_block_find_filter_by_id(struct ocelot_vcap_block *block, int id) ocelot_vcap_block_find_filter_by_id(struct ocelot_vcap_block *block, int cookie,
bool tc_offload)
{ {
struct ocelot_vcap_filter *filter; struct ocelot_vcap_filter *filter;
list_for_each_entry(filter, &block->rules, list) list_for_each_entry(filter, &block->rules, list)
if (filter->id == id) if (filter->id.tc_offload == tc_offload &&
filter->id.cookie == cookie)
return filter; return filter;
return NULL; return NULL;
...@@ -1161,7 +1169,7 @@ static void ocelot_vcap_block_remove_filter(struct ocelot *ocelot, ...@@ -1161,7 +1169,7 @@ static void ocelot_vcap_block_remove_filter(struct ocelot *ocelot,
list_for_each_safe(pos, q, &block->rules) { list_for_each_safe(pos, q, &block->rules) {
tmp = list_entry(pos, struct ocelot_vcap_filter, list); tmp = list_entry(pos, struct ocelot_vcap_filter, list);
if (tmp->id == filter->id) { if (ocelot_vcap_filter_equal(filter, tmp)) {
if (tmp->block_id == VCAP_IS2 && if (tmp->block_id == VCAP_IS2 &&
tmp->action.police_ena) tmp->action.police_ena)
ocelot_vcap_policer_del(ocelot, block, ocelot_vcap_policer_del(ocelot, block,
......
...@@ -15,7 +15,8 @@ ...@@ -15,7 +15,8 @@
int ocelot_vcap_filter_stats_update(struct ocelot *ocelot, int ocelot_vcap_filter_stats_update(struct ocelot *ocelot,
struct ocelot_vcap_filter *rule); struct ocelot_vcap_filter *rule);
struct ocelot_vcap_filter * struct ocelot_vcap_filter *
ocelot_vcap_block_find_filter_by_id(struct ocelot_vcap_block *block, int id); ocelot_vcap_block_find_filter_by_id(struct ocelot_vcap_block *block, int id,
bool tc_offload);
void ocelot_detect_vcap_constants(struct ocelot *ocelot); void ocelot_detect_vcap_constants(struct ocelot *ocelot);
int ocelot_vcap_init(struct ocelot *ocelot); int ocelot_vcap_init(struct ocelot *ocelot);
......
...@@ -648,6 +648,11 @@ enum ocelot_vcap_filter_type { ...@@ -648,6 +648,11 @@ enum ocelot_vcap_filter_type {
OCELOT_VCAP_FILTER_OFFLOAD, OCELOT_VCAP_FILTER_OFFLOAD,
}; };
struct ocelot_vcap_id {
unsigned long cookie;
bool tc_offload;
};
struct ocelot_vcap_filter { struct ocelot_vcap_filter {
struct list_head list; struct list_head list;
...@@ -657,7 +662,7 @@ struct ocelot_vcap_filter { ...@@ -657,7 +662,7 @@ struct ocelot_vcap_filter {
int lookup; int lookup;
u8 pag; u8 pag;
u16 prio; u16 prio;
u32 id; struct ocelot_vcap_id id;
struct ocelot_vcap_action action; struct ocelot_vcap_action action;
struct ocelot_vcap_stats stats; struct ocelot_vcap_stats stats;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册