Skip to content

Commit e1da961

Browse files
idoschdavem330
authored andcommitted
mlxsw: core_acl: Avoid defining static variable in header file
The static array 'mlxsw_afk_element_infos' in 'core_acl_flex_keys.h' is copied to each file that includes the header, but not all use it. This results in the following warnings when compiling with W=1: drivers/net/ethernet/mellanox/mlxsw//core_acl_flex_keys.h:76:44: warning: ‘mlxsw_afk_element_infos’ defined but not used [-Wunused-const-variable=] One way to suppress the warning is to mark the array with '__maybe_unused', but another option is to remove it from the header file entirely. Change 'struct mlxsw_afk_element_inst' to store the key to the array ('element') instead of the array value keyed by 'element'. Adjust the different users accordingly. Signed-off-by: Ido Schimmel <[email protected]> Reviewed-by: Jiri Pirko <[email protected]> Signed-off-by: David S. Miller <[email protected]>
1 parent bdb373c commit e1da961

File tree

2 files changed

+47
-39
lines changed

2 files changed

+47
-39
lines changed

drivers/net/ethernet/mellanox/mlxsw/core_acl_flex_keys.c

Lines changed: 45 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -9,6 +9,41 @@
99
#include "item.h"
1010
#include "core_acl_flex_keys.h"
1111

12+
/* For the purpose of the driver, define an internal storage scratchpad
13+
* that will be used to store key/mask values. For each defined element type
14+
* define an internal storage geometry.
15+
*
16+
* When adding new elements, MLXSW_AFK_ELEMENT_STORAGE_SIZE must be increased
17+
* accordingly.
18+
*/
19+
static const struct mlxsw_afk_element_info mlxsw_afk_element_infos[] = {
20+
MLXSW_AFK_ELEMENT_INFO_U32(SRC_SYS_PORT, 0x00, 16, 16),
21+
MLXSW_AFK_ELEMENT_INFO_BUF(DMAC_32_47, 0x04, 2),
22+
MLXSW_AFK_ELEMENT_INFO_BUF(DMAC_0_31, 0x06, 4),
23+
MLXSW_AFK_ELEMENT_INFO_BUF(SMAC_32_47, 0x0A, 2),
24+
MLXSW_AFK_ELEMENT_INFO_BUF(SMAC_0_31, 0x0C, 4),
25+
MLXSW_AFK_ELEMENT_INFO_U32(ETHERTYPE, 0x00, 0, 16),
26+
MLXSW_AFK_ELEMENT_INFO_U32(IP_PROTO, 0x10, 0, 8),
27+
MLXSW_AFK_ELEMENT_INFO_U32(VID, 0x10, 8, 12),
28+
MLXSW_AFK_ELEMENT_INFO_U32(PCP, 0x10, 20, 3),
29+
MLXSW_AFK_ELEMENT_INFO_U32(TCP_FLAGS, 0x10, 23, 9),
30+
MLXSW_AFK_ELEMENT_INFO_U32(DST_L4_PORT, 0x14, 0, 16),
31+
MLXSW_AFK_ELEMENT_INFO_U32(SRC_L4_PORT, 0x14, 16, 16),
32+
MLXSW_AFK_ELEMENT_INFO_U32(IP_TTL_, 0x18, 0, 8),
33+
MLXSW_AFK_ELEMENT_INFO_U32(IP_ECN, 0x18, 9, 2),
34+
MLXSW_AFK_ELEMENT_INFO_U32(IP_DSCP, 0x18, 11, 6),
35+
MLXSW_AFK_ELEMENT_INFO_U32(VIRT_ROUTER_8_10, 0x18, 17, 3),
36+
MLXSW_AFK_ELEMENT_INFO_U32(VIRT_ROUTER_0_7, 0x18, 20, 8),
37+
MLXSW_AFK_ELEMENT_INFO_BUF(SRC_IP_96_127, 0x20, 4),
38+
MLXSW_AFK_ELEMENT_INFO_BUF(SRC_IP_64_95, 0x24, 4),
39+
MLXSW_AFK_ELEMENT_INFO_BUF(SRC_IP_32_63, 0x28, 4),
40+
MLXSW_AFK_ELEMENT_INFO_BUF(SRC_IP_0_31, 0x2C, 4),
41+
MLXSW_AFK_ELEMENT_INFO_BUF(DST_IP_96_127, 0x30, 4),
42+
MLXSW_AFK_ELEMENT_INFO_BUF(DST_IP_64_95, 0x34, 4),
43+
MLXSW_AFK_ELEMENT_INFO_BUF(DST_IP_32_63, 0x38, 4),
44+
MLXSW_AFK_ELEMENT_INFO_BUF(DST_IP_0_31, 0x3C, 4),
45+
};
46+
1247
struct mlxsw_afk {
1348
struct list_head key_info_list;
1449
unsigned int max_blocks;
@@ -26,13 +61,15 @@ static bool mlxsw_afk_blocks_check(struct mlxsw_afk *mlxsw_afk)
2661
const struct mlxsw_afk_block *block = &mlxsw_afk->blocks[i];
2762

2863
for (j = 0; j < block->instances_count; j++) {
64+
const struct mlxsw_afk_element_info *elinfo;
2965
struct mlxsw_afk_element_inst *elinst;
3066

3167
elinst = &block->instances[j];
32-
if (elinst->type != elinst->info->type ||
68+
elinfo = &mlxsw_afk_element_infos[elinst->element];
69+
if (elinst->type != elinfo->type ||
3370
(!elinst->avoid_size_check &&
3471
elinst->item.size.bits !=
35-
elinst->info->item.size.bits))
72+
elinfo->item.size.bits))
3673
return false;
3774
}
3875
}
@@ -116,7 +153,7 @@ static void mlxsw_afk_picker_count_hits(struct mlxsw_afk *mlxsw_afk,
116153
struct mlxsw_afk_element_inst *elinst;
117154

118155
elinst = &block->instances[j];
119-
if (elinst->info->element == element) {
156+
if (elinst->element == element) {
120157
__set_bit(element, picker->hits[i].element);
121158
picker->hits[i].total++;
122159
}
@@ -301,7 +338,7 @@ mlxsw_afk_block_elinst_get(const struct mlxsw_afk_block *block,
301338
struct mlxsw_afk_element_inst *elinst;
302339

303340
elinst = &block->instances[i];
304-
if (elinst->info->element == element)
341+
if (elinst->element == element)
305342
return elinst;
306343
}
307344
return NULL;
@@ -409,9 +446,12 @@ static void
409446
mlxsw_sp_afk_encode_one(const struct mlxsw_afk_element_inst *elinst,
410447
char *output, char *storage, int u32_diff)
411448
{
412-
const struct mlxsw_item *storage_item = &elinst->info->item;
413449
const struct mlxsw_item *output_item = &elinst->item;
450+
const struct mlxsw_afk_element_info *elinfo;
451+
const struct mlxsw_item *storage_item;
414452

453+
elinfo = &mlxsw_afk_element_infos[elinst->element];
454+
storage_item = &elinfo->item;
415455
if (elinst->type == MLXSW_AFK_ELEMENT_TYPE_U32)
416456
mlxsw_sp_afk_encode_u32(storage_item, output_item,
417457
storage, output, u32_diff);

drivers/net/ethernet/mellanox/mlxsw/core_acl_flex_keys.h

Lines changed: 2 additions & 34 deletions
Original file line numberDiff line numberDiff line change
@@ -69,42 +69,10 @@ struct mlxsw_afk_element_info {
6969
MLXSW_AFK_ELEMENT_INFO(MLXSW_AFK_ELEMENT_TYPE_BUF, \
7070
_element, _offset, 0, _size)
7171

72-
/* For the purpose of the driver, define an internal storage scratchpad
73-
* that will be used to store key/mask values. For each defined element type
74-
* define an internal storage geometry.
75-
*/
76-
static const struct mlxsw_afk_element_info mlxsw_afk_element_infos[] = {
77-
MLXSW_AFK_ELEMENT_INFO_U32(SRC_SYS_PORT, 0x00, 16, 16),
78-
MLXSW_AFK_ELEMENT_INFO_BUF(DMAC_32_47, 0x04, 2),
79-
MLXSW_AFK_ELEMENT_INFO_BUF(DMAC_0_31, 0x06, 4),
80-
MLXSW_AFK_ELEMENT_INFO_BUF(SMAC_32_47, 0x0A, 2),
81-
MLXSW_AFK_ELEMENT_INFO_BUF(SMAC_0_31, 0x0C, 4),
82-
MLXSW_AFK_ELEMENT_INFO_U32(ETHERTYPE, 0x00, 0, 16),
83-
MLXSW_AFK_ELEMENT_INFO_U32(IP_PROTO, 0x10, 0, 8),
84-
MLXSW_AFK_ELEMENT_INFO_U32(VID, 0x10, 8, 12),
85-
MLXSW_AFK_ELEMENT_INFO_U32(PCP, 0x10, 20, 3),
86-
MLXSW_AFK_ELEMENT_INFO_U32(TCP_FLAGS, 0x10, 23, 9),
87-
MLXSW_AFK_ELEMENT_INFO_U32(DST_L4_PORT, 0x14, 0, 16),
88-
MLXSW_AFK_ELEMENT_INFO_U32(SRC_L4_PORT, 0x14, 16, 16),
89-
MLXSW_AFK_ELEMENT_INFO_U32(IP_TTL_, 0x18, 0, 8),
90-
MLXSW_AFK_ELEMENT_INFO_U32(IP_ECN, 0x18, 9, 2),
91-
MLXSW_AFK_ELEMENT_INFO_U32(IP_DSCP, 0x18, 11, 6),
92-
MLXSW_AFK_ELEMENT_INFO_U32(VIRT_ROUTER_8_10, 0x18, 17, 3),
93-
MLXSW_AFK_ELEMENT_INFO_U32(VIRT_ROUTER_0_7, 0x18, 20, 8),
94-
MLXSW_AFK_ELEMENT_INFO_BUF(SRC_IP_96_127, 0x20, 4),
95-
MLXSW_AFK_ELEMENT_INFO_BUF(SRC_IP_64_95, 0x24, 4),
96-
MLXSW_AFK_ELEMENT_INFO_BUF(SRC_IP_32_63, 0x28, 4),
97-
MLXSW_AFK_ELEMENT_INFO_BUF(SRC_IP_0_31, 0x2C, 4),
98-
MLXSW_AFK_ELEMENT_INFO_BUF(DST_IP_96_127, 0x30, 4),
99-
MLXSW_AFK_ELEMENT_INFO_BUF(DST_IP_64_95, 0x34, 4),
100-
MLXSW_AFK_ELEMENT_INFO_BUF(DST_IP_32_63, 0x38, 4),
101-
MLXSW_AFK_ELEMENT_INFO_BUF(DST_IP_0_31, 0x3C, 4),
102-
};
103-
10472
#define MLXSW_AFK_ELEMENT_STORAGE_SIZE 0x40
10573

10674
struct mlxsw_afk_element_inst { /* element instance in actual block */
107-
const struct mlxsw_afk_element_info *info;
75+
enum mlxsw_afk_element element;
10876
enum mlxsw_afk_element_type type;
10977
struct mlxsw_item item; /* element geometry in block */
11078
int u32_key_diff; /* in case value needs to be adjusted before write
@@ -116,7 +84,7 @@ struct mlxsw_afk_element_inst { /* element instance in actual block */
11684
#define MLXSW_AFK_ELEMENT_INST(_type, _element, _offset, \
11785
_shift, _size, _u32_key_diff, _avoid_size_check) \
11886
{ \
119-
.info = &mlxsw_afk_element_infos[MLXSW_AFK_ELEMENT_##_element], \
87+
.element = MLXSW_AFK_ELEMENT_##_element, \
12088
.type = _type, \
12189
.item = { \
12290
.offset = _offset, \

0 commit comments

Comments
 (0)