2015-10-16 20:01:37 +08:00
|
|
|
/*
|
|
|
|
* drivers/net/ethernet/mellanox/mlxsw/spectrum.h
|
2017-02-03 17:29:07 +08:00
|
|
|
* Copyright (c) 2015-2017 Mellanox Technologies. All rights reserved.
|
|
|
|
* Copyright (c) 2015-2017 Jiri Pirko <jiri@mellanox.com>
|
2015-10-16 20:01:37 +08:00
|
|
|
* Copyright (c) 2015 Ido Schimmel <idosch@mellanox.com>
|
|
|
|
* Copyright (c) 2015 Elad Raz <eladr@mellanox.com>
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions are met:
|
|
|
|
*
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
|
|
|
* 3. Neither the names of the copyright holders nor the names of its
|
|
|
|
* contributors may be used to endorse or promote products derived from
|
|
|
|
* this software without specific prior written permission.
|
|
|
|
*
|
|
|
|
* Alternatively, this software may be distributed under the terms of the
|
|
|
|
* GNU General Public License ("GPL") version 2 as published by the Free
|
|
|
|
* Software Foundation.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
|
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
|
|
|
|
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
|
|
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
|
|
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
|
|
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
|
|
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
|
|
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
|
|
* POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _MLXSW_SPECTRUM_H
|
|
|
|
#define _MLXSW_SPECTRUM_H
|
|
|
|
|
|
|
|
#include <linux/types.h>
|
|
|
|
#include <linux/netdevice.h>
|
2016-07-05 17:27:39 +08:00
|
|
|
#include <linux/rhashtable.h>
|
2015-10-16 20:01:37 +08:00
|
|
|
#include <linux/bitops.h>
|
|
|
|
#include <linux/if_vlan.h>
|
2015-12-15 23:03:37 +08:00
|
|
|
#include <linux/list.h>
|
2016-04-06 23:10:10 +08:00
|
|
|
#include <linux/dcbnl.h>
|
2016-07-04 14:23:04 +08:00
|
|
|
#include <linux/in6.h>
|
2016-09-26 18:52:31 +08:00
|
|
|
#include <linux/notifier.h>
|
2017-01-23 18:07:11 +08:00
|
|
|
#include <net/psample.h>
|
2017-02-03 17:29:09 +08:00
|
|
|
#include <net/pkt_cls.h>
|
2017-11-06 14:23:48 +08:00
|
|
|
#include <net/red.h>
|
2015-10-16 20:01:37 +08:00
|
|
|
|
2016-01-11 04:06:28 +08:00
|
|
|
#include "port.h"
|
2015-10-16 20:01:37 +08:00
|
|
|
#include "core.h"
|
2017-02-03 17:29:07 +08:00
|
|
|
#include "core_acl_flex_keys.h"
|
|
|
|
#include "core_acl_flex_actions.h"
|
2015-10-16 20:01:37 +08:00
|
|
|
|
2017-05-26 14:37:39 +08:00
|
|
|
#define MLXSW_SP_FID_8021D_MAX 1024
|
2015-12-15 23:03:37 +08:00
|
|
|
|
2016-01-11 04:06:26 +08:00
|
|
|
#define MLXSW_SP_MID_MAX 7000
|
|
|
|
|
2016-02-27 00:32:31 +08:00
|
|
|
#define MLXSW_SP_PORTS_PER_CLUSTER_MAX 4
|
|
|
|
|
|
|
|
#define MLXSW_SP_PORT_BASE_SPEED 25000 /* Mb/s */
|
|
|
|
|
2017-10-23 05:11:49 +08:00
|
|
|
#define MLXSW_SP_KVD_LINEAR_SIZE 98304 /* entries */
|
2016-09-20 17:16:52 +08:00
|
|
|
#define MLXSW_SP_KVD_GRANULARITY 128
|
2016-07-05 17:27:46 +08:00
|
|
|
|
2018-01-15 15:59:07 +08:00
|
|
|
#define MLXSW_SP_RESOURCE_NAME_KVD "kvd"
|
|
|
|
#define MLXSW_SP_RESOURCE_NAME_KVD_LINEAR "linear"
|
|
|
|
#define MLXSW_SP_RESOURCE_NAME_KVD_HASH_SINGLE "hash_single"
|
|
|
|
#define MLXSW_SP_RESOURCE_NAME_KVD_HASH_DOUBLE "hash_double"
|
2018-02-20 15:44:22 +08:00
|
|
|
#define MLXSW_SP_RESOURCE_NAME_KVD_LINEAR_SINGLES "singles"
|
|
|
|
#define MLXSW_SP_RESOURCE_NAME_KVD_LINEAR_CHUNKS "chunks"
|
|
|
|
#define MLXSW_SP_RESOURCE_NAME_KVD_LINEAR_LARGE_CHUNKS "large_chunks"
|
2018-01-15 15:59:07 +08:00
|
|
|
|
|
|
|
enum mlxsw_sp_resource_id {
|
2018-04-01 22:34:59 +08:00
|
|
|
MLXSW_SP_RESOURCE_KVD = 1,
|
2018-01-15 15:59:07 +08:00
|
|
|
MLXSW_SP_RESOURCE_KVD_LINEAR,
|
|
|
|
MLXSW_SP_RESOURCE_KVD_HASH_SINGLE,
|
|
|
|
MLXSW_SP_RESOURCE_KVD_HASH_DOUBLE,
|
2018-02-20 15:44:22 +08:00
|
|
|
MLXSW_SP_RESOURCE_KVD_LINEAR_SINGLE,
|
|
|
|
MLXSW_SP_RESOURCE_KVD_LINEAR_CHUNKS,
|
|
|
|
MLXSW_SP_RESOURCE_KVD_LINEAR_LARGE_CHUNKS,
|
2018-01-15 15:59:07 +08:00
|
|
|
};
|
|
|
|
|
2015-10-16 20:01:37 +08:00
|
|
|
struct mlxsw_sp_port;
|
2017-03-10 15:53:39 +08:00
|
|
|
struct mlxsw_sp_rif;
|
2018-02-13 18:27:48 +08:00
|
|
|
struct mlxsw_sp_span_entry;
|
2015-10-16 20:01:37 +08:00
|
|
|
|
2015-12-03 19:12:28 +08:00
|
|
|
struct mlxsw_sp_upper {
|
|
|
|
struct net_device *dev;
|
|
|
|
unsigned int ref_count;
|
|
|
|
};
|
|
|
|
|
2017-05-26 14:37:39 +08:00
|
|
|
enum mlxsw_sp_rif_type {
|
|
|
|
MLXSW_SP_RIF_TYPE_SUBPORT,
|
|
|
|
MLXSW_SP_RIF_TYPE_VLAN,
|
|
|
|
MLXSW_SP_RIF_TYPE_FID,
|
2017-09-03 05:49:19 +08:00
|
|
|
MLXSW_SP_RIF_TYPE_IPIP_LB, /* IP-in-IP loopback. */
|
2017-05-26 14:37:39 +08:00
|
|
|
MLXSW_SP_RIF_TYPE_MAX,
|
|
|
|
};
|
|
|
|
|
|
|
|
enum mlxsw_sp_fid_type {
|
|
|
|
MLXSW_SP_FID_TYPE_8021Q,
|
|
|
|
MLXSW_SP_FID_TYPE_8021D,
|
|
|
|
MLXSW_SP_FID_TYPE_RFID,
|
|
|
|
MLXSW_SP_FID_TYPE_DUMMY,
|
|
|
|
MLXSW_SP_FID_TYPE_MAX,
|
2015-12-15 23:03:37 +08:00
|
|
|
};
|
|
|
|
|
2016-01-11 04:06:28 +08:00
|
|
|
struct mlxsw_sp_mid {
|
|
|
|
struct list_head list;
|
|
|
|
unsigned char addr[ETH_ALEN];
|
2016-10-30 17:09:22 +08:00
|
|
|
u16 fid;
|
2016-01-11 04:06:28 +08:00
|
|
|
u16 mid;
|
2017-09-20 22:15:06 +08:00
|
|
|
bool in_hw;
|
2017-09-20 22:15:02 +08:00
|
|
|
unsigned long *ports_in_mid; /* bits array */
|
2016-01-11 04:06:28 +08:00
|
|
|
};
|
|
|
|
|
2016-07-21 18:03:17 +08:00
|
|
|
enum mlxsw_sp_port_mall_action_type {
|
|
|
|
MLXSW_SP_PORT_MALL_MIRROR,
|
2017-01-23 18:07:11 +08:00
|
|
|
MLXSW_SP_PORT_MALL_SAMPLE,
|
2016-07-21 18:03:17 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
struct mlxsw_sp_port_mall_mirror_tc_entry {
|
2018-02-27 21:53:41 +08:00
|
|
|
int span_id;
|
2016-07-21 18:03:17 +08:00
|
|
|
bool ingress;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct mlxsw_sp_port_mall_tc_entry {
|
|
|
|
struct list_head list;
|
|
|
|
unsigned long cookie;
|
|
|
|
enum mlxsw_sp_port_mall_action_type type;
|
|
|
|
union {
|
|
|
|
struct mlxsw_sp_port_mall_mirror_tc_entry mirror;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2017-05-17 01:38:24 +08:00
|
|
|
struct mlxsw_sp_sb;
|
2017-05-17 01:38:26 +08:00
|
|
|
struct mlxsw_sp_bridge;
|
2017-05-17 01:38:25 +08:00
|
|
|
struct mlxsw_sp_router;
|
2017-09-27 14:23:18 +08:00
|
|
|
struct mlxsw_sp_mr;
|
2017-02-03 17:29:07 +08:00
|
|
|
struct mlxsw_sp_acl;
|
2017-03-11 16:42:51 +08:00
|
|
|
struct mlxsw_sp_counter_pool;
|
2017-05-26 14:37:39 +08:00
|
|
|
struct mlxsw_sp_fid_core;
|
2017-10-23 05:11:44 +08:00
|
|
|
struct mlxsw_sp_kvdl;
|
2018-07-09 04:51:16 +08:00
|
|
|
struct mlxsw_sp_kvdl_ops;
|
2018-07-09 04:51:19 +08:00
|
|
|
struct mlxsw_sp_mr_tcam_ops;
|
2018-07-09 04:51:20 +08:00
|
|
|
struct mlxsw_sp_acl_tcam_ops;
|
2017-02-03 17:29:07 +08:00
|
|
|
|
2015-10-16 20:01:37 +08:00
|
|
|
struct mlxsw_sp {
|
|
|
|
struct mlxsw_sp_port **ports;
|
|
|
|
struct mlxsw_core *core;
|
|
|
|
const struct mlxsw_bus_info *bus_info;
|
|
|
|
unsigned char base_mac[ETH_ALEN];
|
2016-09-20 17:16:50 +08:00
|
|
|
struct mlxsw_sp_upper *lags;
|
2017-11-21 16:42:21 +08:00
|
|
|
int *port_to_module;
|
2017-05-17 01:38:24 +08:00
|
|
|
struct mlxsw_sp_sb *sb;
|
2017-05-17 01:38:26 +08:00
|
|
|
struct mlxsw_sp_bridge *bridge;
|
2017-05-17 01:38:25 +08:00
|
|
|
struct mlxsw_sp_router *router;
|
2017-09-27 14:23:17 +08:00
|
|
|
struct mlxsw_sp_mr *mr;
|
2017-09-19 16:00:09 +08:00
|
|
|
struct mlxsw_afa *afa;
|
2017-02-03 17:29:07 +08:00
|
|
|
struct mlxsw_sp_acl *acl;
|
2017-05-26 14:37:39 +08:00
|
|
|
struct mlxsw_sp_fid_core *fid_core;
|
2017-10-23 05:11:44 +08:00
|
|
|
struct mlxsw_sp_kvdl *kvdl;
|
2017-10-16 22:26:35 +08:00
|
|
|
struct notifier_block netdevice_nb;
|
2016-07-21 18:03:17 +08:00
|
|
|
|
2017-03-11 16:42:51 +08:00
|
|
|
struct mlxsw_sp_counter_pool *counter_pool;
|
2016-07-21 18:03:17 +08:00
|
|
|
struct {
|
|
|
|
struct mlxsw_sp_span_entry *entries;
|
|
|
|
int entries_count;
|
|
|
|
} span;
|
2018-07-09 04:51:16 +08:00
|
|
|
const struct mlxsw_sp_kvdl_ops *kvdl_ops;
|
2018-07-08 15:00:19 +08:00
|
|
|
const struct mlxsw_afa_ops *afa_ops;
|
2018-07-09 04:51:22 +08:00
|
|
|
const struct mlxsw_afk_ops *afk_ops;
|
2018-07-09 04:51:19 +08:00
|
|
|
const struct mlxsw_sp_mr_tcam_ops *mr_tcam_ops;
|
2018-07-09 04:51:20 +08:00
|
|
|
const struct mlxsw_sp_acl_tcam_ops *acl_tcam_ops;
|
2015-10-16 20:01:37 +08:00
|
|
|
};
|
|
|
|
|
2015-12-03 19:12:28 +08:00
|
|
|
static inline struct mlxsw_sp_upper *
|
|
|
|
mlxsw_sp_lag_get(struct mlxsw_sp *mlxsw_sp, u16 lag_id)
|
|
|
|
{
|
|
|
|
return &mlxsw_sp->lags[lag_id];
|
|
|
|
}
|
|
|
|
|
2015-10-16 20:01:37 +08:00
|
|
|
struct mlxsw_sp_port_pcpu_stats {
|
|
|
|
u64 rx_packets;
|
|
|
|
u64 rx_bytes;
|
|
|
|
u64 tx_packets;
|
|
|
|
u64 tx_bytes;
|
|
|
|
struct u64_stats_sync syncp;
|
|
|
|
u32 tx_dropped;
|
|
|
|
};
|
|
|
|
|
2017-01-23 18:07:11 +08:00
|
|
|
struct mlxsw_sp_port_sample {
|
|
|
|
struct psample_group __rcu *psample_group;
|
|
|
|
u32 trunc_size;
|
|
|
|
u32 rate;
|
|
|
|
bool truncate;
|
|
|
|
};
|
|
|
|
|
mlxsw: spectrum: Replace vPorts with Port-VLAN
As explained in the cover letter, since the introduction of the bridge
offload in the mlxsw driver, information related to the offloaded bridge
and bridge ports was stored in the individual port struct,
mlxsw_sp_port.
This lead to a bloated struct storing both physical properties of the
port (e.g., autoneg status) as well as logical properties of an upper
bridge port (e.g., learning, mrouter indication). While this might work
well for simple devices, it proved to be hard to extend when stacked
devices were taken into account and more advanced use-cases (e.g., IGMP
snooping) considered.
This patch removes the excess information from the above struct and
instead stores it in more appropriate structs that represent the bridge
port, the bridge itself and a VLAN configured on the bridge port.
The membership of a port in a bridge is denoted using the Port-VLAN
struct, which points to the bridge port and also member in the bridge
VLAN group of the VLAN it represents. This allows us to completely
remove the vPort abstraction and consolidate many of the code paths
relating to VLAN-aware and unaware bridges.
Note that the FID / vFID code is currently duplicated, but this will
soon go away when the common FID core will be introduced.
Signed-off-by: Ido Schimmel <idosch@mellanox.com>
Signed-off-by: Jiri Pirko <jiri@mellanox.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2017-05-26 14:37:31 +08:00
|
|
|
struct mlxsw_sp_bridge_port;
|
2017-05-26 14:37:39 +08:00
|
|
|
struct mlxsw_sp_fid;
|
mlxsw: spectrum: Replace vPorts with Port-VLAN
As explained in the cover letter, since the introduction of the bridge
offload in the mlxsw driver, information related to the offloaded bridge
and bridge ports was stored in the individual port struct,
mlxsw_sp_port.
This lead to a bloated struct storing both physical properties of the
port (e.g., autoneg status) as well as logical properties of an upper
bridge port (e.g., learning, mrouter indication). While this might work
well for simple devices, it proved to be hard to extend when stacked
devices were taken into account and more advanced use-cases (e.g., IGMP
snooping) considered.
This patch removes the excess information from the above struct and
instead stores it in more appropriate structs that represent the bridge
port, the bridge itself and a VLAN configured on the bridge port.
The membership of a port in a bridge is denoted using the Port-VLAN
struct, which points to the bridge port and also member in the bridge
VLAN group of the VLAN it represents. This allows us to completely
remove the vPort abstraction and consolidate many of the code paths
relating to VLAN-aware and unaware bridges.
Note that the FID / vFID code is currently duplicated, but this will
soon go away when the common FID core will be introduced.
Signed-off-by: Ido Schimmel <idosch@mellanox.com>
Signed-off-by: Jiri Pirko <jiri@mellanox.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2017-05-26 14:37:31 +08:00
|
|
|
|
2017-05-26 14:37:26 +08:00
|
|
|
struct mlxsw_sp_port_vlan {
|
|
|
|
struct list_head list;
|
|
|
|
struct mlxsw_sp_port *mlxsw_sp_port;
|
|
|
|
struct mlxsw_sp_fid *fid;
|
2018-02-28 20:12:11 +08:00
|
|
|
unsigned int ref_count;
|
2017-05-26 14:37:26 +08:00
|
|
|
u16 vid;
|
mlxsw: spectrum: Replace vPorts with Port-VLAN
As explained in the cover letter, since the introduction of the bridge
offload in the mlxsw driver, information related to the offloaded bridge
and bridge ports was stored in the individual port struct,
mlxsw_sp_port.
This lead to a bloated struct storing both physical properties of the
port (e.g., autoneg status) as well as logical properties of an upper
bridge port (e.g., learning, mrouter indication). While this might work
well for simple devices, it proved to be hard to extend when stacked
devices were taken into account and more advanced use-cases (e.g., IGMP
snooping) considered.
This patch removes the excess information from the above struct and
instead stores it in more appropriate structs that represent the bridge
port, the bridge itself and a VLAN configured on the bridge port.
The membership of a port in a bridge is denoted using the Port-VLAN
struct, which points to the bridge port and also member in the bridge
VLAN group of the VLAN it represents. This allows us to completely
remove the vPort abstraction and consolidate many of the code paths
relating to VLAN-aware and unaware bridges.
Note that the FID / vFID code is currently duplicated, but this will
soon go away when the common FID core will be introduced.
Signed-off-by: Ido Schimmel <idosch@mellanox.com>
Signed-off-by: Jiri Pirko <jiri@mellanox.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2017-05-26 14:37:31 +08:00
|
|
|
struct mlxsw_sp_bridge_port *bridge_port;
|
|
|
|
struct list_head bridge_vlan_node;
|
2017-05-26 14:37:26 +08:00
|
|
|
};
|
|
|
|
|
2017-11-06 14:23:47 +08:00
|
|
|
/* No need an internal lock; At worse - miss a single periodic iteration */
|
|
|
|
struct mlxsw_sp_port_xstats {
|
|
|
|
u64 ecn;
|
|
|
|
u64 wred_drop[TC_MAX_QUEUE];
|
|
|
|
u64 tail_drop[TC_MAX_QUEUE];
|
|
|
|
u64 backlog[TC_MAX_QUEUE];
|
2018-02-28 17:44:59 +08:00
|
|
|
u64 tx_bytes[IEEE_8021QAZ_MAX_TCS];
|
|
|
|
u64 tx_packets[IEEE_8021QAZ_MAX_TCS];
|
2017-11-06 14:23:47 +08:00
|
|
|
};
|
|
|
|
|
2015-10-16 20:01:37 +08:00
|
|
|
struct mlxsw_sp_port {
|
|
|
|
struct net_device *dev;
|
|
|
|
struct mlxsw_sp_port_pcpu_stats __percpu *pcpu_stats;
|
|
|
|
struct mlxsw_sp *mlxsw_sp;
|
|
|
|
u8 local_port;
|
mlxsw: spectrum: Replace vPorts with Port-VLAN
As explained in the cover letter, since the introduction of the bridge
offload in the mlxsw driver, information related to the offloaded bridge
and bridge ports was stored in the individual port struct,
mlxsw_sp_port.
This lead to a bloated struct storing both physical properties of the
port (e.g., autoneg status) as well as logical properties of an upper
bridge port (e.g., learning, mrouter indication). While this might work
well for simple devices, it proved to be hard to extend when stacked
devices were taken into account and more advanced use-cases (e.g., IGMP
snooping) considered.
This patch removes the excess information from the above struct and
instead stores it in more appropriate structs that represent the bridge
port, the bridge itself and a VLAN configured on the bridge port.
The membership of a port in a bridge is denoted using the Port-VLAN
struct, which points to the bridge port and also member in the bridge
VLAN group of the VLAN it represents. This allows us to completely
remove the vPort abstraction and consolidate many of the code paths
relating to VLAN-aware and unaware bridges.
Note that the FID / vFID code is currently duplicated, but this will
soon go away when the common FID core will be introduced.
Signed-off-by: Ido Schimmel <idosch@mellanox.com>
Signed-off-by: Jiri Pirko <jiri@mellanox.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2017-05-26 14:37:31 +08:00
|
|
|
u8 lagged:1,
|
2016-02-27 00:32:31 +08:00
|
|
|
split:1;
|
2015-10-16 20:01:37 +08:00
|
|
|
u16 pvid;
|
2015-12-03 19:12:28 +08:00
|
|
|
u16 lag_id;
|
2016-04-06 23:10:14 +08:00
|
|
|
struct {
|
|
|
|
u8 tx_pause:1,
|
2016-09-12 19:26:23 +08:00
|
|
|
rx_pause:1,
|
|
|
|
autoneg:1;
|
2016-04-06 23:10:14 +08:00
|
|
|
} link;
|
2016-04-06 23:10:10 +08:00
|
|
|
struct {
|
|
|
|
struct ieee_ets *ets;
|
2016-04-06 23:10:11 +08:00
|
|
|
struct ieee_maxrate *maxrate;
|
2016-04-06 23:10:16 +08:00
|
|
|
struct ieee_pfc *pfc;
|
2016-04-06 23:10:10 +08:00
|
|
|
} dcb;
|
2016-06-09 15:51:40 +08:00
|
|
|
struct {
|
|
|
|
u8 module;
|
|
|
|
u8 width;
|
|
|
|
u8 lane;
|
|
|
|
} mapping;
|
2016-07-21 18:03:17 +08:00
|
|
|
/* TC handles */
|
|
|
|
struct list_head mall_tc_list;
|
2016-09-16 21:05:38 +08:00
|
|
|
struct {
|
|
|
|
#define MLXSW_HW_STATS_UPDATE_TIME HZ
|
2017-10-26 16:55:32 +08:00
|
|
|
struct rtnl_link_stats64 stats;
|
2017-11-06 14:23:47 +08:00
|
|
|
struct mlxsw_sp_port_xstats xstats;
|
2016-09-16 21:05:38 +08:00
|
|
|
struct delayed_work update_dw;
|
2017-10-26 16:55:32 +08:00
|
|
|
} periodic_hw_stats;
|
2017-01-23 18:07:11 +08:00
|
|
|
struct mlxsw_sp_port_sample *sample;
|
2017-05-26 14:37:26 +08:00
|
|
|
struct list_head vlans_list;
|
2018-01-10 21:59:57 +08:00
|
|
|
struct mlxsw_sp_qdisc *root_qdisc;
|
2018-02-28 17:44:58 +08:00
|
|
|
struct mlxsw_sp_qdisc *tclass_qdiscs;
|
2017-12-06 16:41:12 +08:00
|
|
|
unsigned acl_rule_count;
|
2018-01-17 18:46:56 +08:00
|
|
|
struct mlxsw_sp_acl_block *ing_acl_block;
|
|
|
|
struct mlxsw_sp_acl_block *eg_acl_block;
|
2015-10-16 20:01:37 +08:00
|
|
|
};
|
|
|
|
|
2016-04-06 23:10:14 +08:00
|
|
|
static inline bool
|
|
|
|
mlxsw_sp_port_is_pause_en(const struct mlxsw_sp_port *mlxsw_sp_port)
|
|
|
|
{
|
|
|
|
return mlxsw_sp_port->link.tx_pause || mlxsw_sp_port->link.rx_pause;
|
|
|
|
}
|
|
|
|
|
2015-12-03 19:12:28 +08:00
|
|
|
static inline struct mlxsw_sp_port *
|
|
|
|
mlxsw_sp_port_lagged_get(struct mlxsw_sp *mlxsw_sp, u16 lag_id, u8 port_index)
|
|
|
|
{
|
|
|
|
struct mlxsw_sp_port *mlxsw_sp_port;
|
|
|
|
u8 local_port;
|
|
|
|
|
|
|
|
local_port = mlxsw_core_lag_mapping_get(mlxsw_sp->core,
|
|
|
|
lag_id, port_index);
|
|
|
|
mlxsw_sp_port = mlxsw_sp->ports[local_port];
|
|
|
|
return mlxsw_sp_port && mlxsw_sp_port->lagged ? mlxsw_sp_port : NULL;
|
|
|
|
}
|
|
|
|
|
2017-05-26 14:37:26 +08:00
|
|
|
static inline struct mlxsw_sp_port_vlan *
|
|
|
|
mlxsw_sp_port_vlan_find_by_vid(const struct mlxsw_sp_port *mlxsw_sp_port,
|
|
|
|
u16 vid)
|
|
|
|
{
|
|
|
|
struct mlxsw_sp_port_vlan *mlxsw_sp_port_vlan;
|
|
|
|
|
|
|
|
list_for_each_entry(mlxsw_sp_port_vlan, &mlxsw_sp_port->vlans_list,
|
|
|
|
list) {
|
|
|
|
if (mlxsw_sp_port_vlan->vid == vid)
|
|
|
|
return mlxsw_sp_port_vlan;
|
|
|
|
}
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2017-05-26 14:37:39 +08:00
|
|
|
enum mlxsw_sp_flood_type {
|
|
|
|
MLXSW_SP_FLOOD_TYPE_UC,
|
|
|
|
MLXSW_SP_FLOOD_TYPE_BC,
|
|
|
|
MLXSW_SP_FLOOD_TYPE_MC,
|
2015-10-16 20:01:37 +08:00
|
|
|
};
|
|
|
|
|
2017-06-04 22:53:38 +08:00
|
|
|
/* spectrum_buffers.c */
|
2015-10-16 20:01:37 +08:00
|
|
|
int mlxsw_sp_buffers_init(struct mlxsw_sp *mlxsw_sp);
|
2016-04-15 00:19:24 +08:00
|
|
|
void mlxsw_sp_buffers_fini(struct mlxsw_sp *mlxsw_sp);
|
2015-10-16 20:01:37 +08:00
|
|
|
int mlxsw_sp_port_buffers_init(struct mlxsw_sp_port *mlxsw_sp_port);
|
2016-04-15 00:19:24 +08:00
|
|
|
int mlxsw_sp_sb_pool_get(struct mlxsw_core *mlxsw_core,
|
|
|
|
unsigned int sb_index, u16 pool_index,
|
|
|
|
struct devlink_sb_pool_info *pool_info);
|
|
|
|
int mlxsw_sp_sb_pool_set(struct mlxsw_core *mlxsw_core,
|
|
|
|
unsigned int sb_index, u16 pool_index, u32 size,
|
|
|
|
enum devlink_sb_threshold_type threshold_type);
|
|
|
|
int mlxsw_sp_sb_port_pool_get(struct mlxsw_core_port *mlxsw_core_port,
|
|
|
|
unsigned int sb_index, u16 pool_index,
|
|
|
|
u32 *p_threshold);
|
|
|
|
int mlxsw_sp_sb_port_pool_set(struct mlxsw_core_port *mlxsw_core_port,
|
|
|
|
unsigned int sb_index, u16 pool_index,
|
|
|
|
u32 threshold);
|
|
|
|
int mlxsw_sp_sb_tc_pool_bind_get(struct mlxsw_core_port *mlxsw_core_port,
|
|
|
|
unsigned int sb_index, u16 tc_index,
|
|
|
|
enum devlink_sb_pool_type pool_type,
|
|
|
|
u16 *p_pool_index, u32 *p_threshold);
|
|
|
|
int mlxsw_sp_sb_tc_pool_bind_set(struct mlxsw_core_port *mlxsw_core_port,
|
|
|
|
unsigned int sb_index, u16 tc_index,
|
|
|
|
enum devlink_sb_pool_type pool_type,
|
|
|
|
u16 pool_index, u32 threshold);
|
2016-04-15 00:19:30 +08:00
|
|
|
int mlxsw_sp_sb_occ_snapshot(struct mlxsw_core *mlxsw_core,
|
|
|
|
unsigned int sb_index);
|
|
|
|
int mlxsw_sp_sb_occ_max_clear(struct mlxsw_core *mlxsw_core,
|
|
|
|
unsigned int sb_index);
|
|
|
|
int mlxsw_sp_sb_occ_port_pool_get(struct mlxsw_core_port *mlxsw_core_port,
|
|
|
|
unsigned int sb_index, u16 pool_index,
|
|
|
|
u32 *p_cur, u32 *p_max);
|
|
|
|
int mlxsw_sp_sb_occ_tc_port_bind_get(struct mlxsw_core_port *mlxsw_core_port,
|
|
|
|
unsigned int sb_index, u16 tc_index,
|
|
|
|
enum devlink_sb_pool_type pool_type,
|
|
|
|
u32 *p_cur, u32 *p_max);
|
2017-05-17 01:38:24 +08:00
|
|
|
u32 mlxsw_sp_cells_bytes(const struct mlxsw_sp *mlxsw_sp, u32 cells);
|
|
|
|
u32 mlxsw_sp_bytes_cells(const struct mlxsw_sp *mlxsw_sp, u32 bytes);
|
2015-10-16 20:01:37 +08:00
|
|
|
|
2017-06-04 22:53:38 +08:00
|
|
|
/* spectrum_switchdev.c */
|
2015-10-16 20:01:37 +08:00
|
|
|
int mlxsw_sp_switchdev_init(struct mlxsw_sp *mlxsw_sp);
|
|
|
|
void mlxsw_sp_switchdev_fini(struct mlxsw_sp *mlxsw_sp);
|
|
|
|
void mlxsw_sp_port_switchdev_init(struct mlxsw_sp_port *mlxsw_sp_port);
|
|
|
|
void mlxsw_sp_port_switchdev_fini(struct mlxsw_sp_port *mlxsw_sp_port);
|
2016-07-04 14:23:13 +08:00
|
|
|
int mlxsw_sp_rif_fdb_op(struct mlxsw_sp *mlxsw_sp, const char *mac, u16 fid,
|
|
|
|
bool adding);
|
mlxsw: spectrum: Replace vPorts with Port-VLAN
As explained in the cover letter, since the introduction of the bridge
offload in the mlxsw driver, information related to the offloaded bridge
and bridge ports was stored in the individual port struct,
mlxsw_sp_port.
This lead to a bloated struct storing both physical properties of the
port (e.g., autoneg status) as well as logical properties of an upper
bridge port (e.g., learning, mrouter indication). While this might work
well for simple devices, it proved to be hard to extend when stacked
devices were taken into account and more advanced use-cases (e.g., IGMP
snooping) considered.
This patch removes the excess information from the above struct and
instead stores it in more appropriate structs that represent the bridge
port, the bridge itself and a VLAN configured on the bridge port.
The membership of a port in a bridge is denoted using the Port-VLAN
struct, which points to the bridge port and also member in the bridge
VLAN group of the VLAN it represents. This allows us to completely
remove the vPort abstraction and consolidate many of the code paths
relating to VLAN-aware and unaware bridges.
Note that the FID / vFID code is currently duplicated, but this will
soon go away when the common FID core will be introduced.
Signed-off-by: Ido Schimmel <idosch@mellanox.com>
Signed-off-by: Jiri Pirko <jiri@mellanox.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2017-05-26 14:37:31 +08:00
|
|
|
void
|
|
|
|
mlxsw_sp_port_vlan_bridge_leave(struct mlxsw_sp_port_vlan *mlxsw_sp_port_vlan);
|
|
|
|
int mlxsw_sp_port_bridge_join(struct mlxsw_sp_port *mlxsw_sp_port,
|
|
|
|
struct net_device *brport_dev,
|
2017-10-08 17:57:56 +08:00
|
|
|
struct net_device *br_dev,
|
|
|
|
struct netlink_ext_ack *extack);
|
mlxsw: spectrum: Replace vPorts with Port-VLAN
As explained in the cover letter, since the introduction of the bridge
offload in the mlxsw driver, information related to the offloaded bridge
and bridge ports was stored in the individual port struct,
mlxsw_sp_port.
This lead to a bloated struct storing both physical properties of the
port (e.g., autoneg status) as well as logical properties of an upper
bridge port (e.g., learning, mrouter indication). While this might work
well for simple devices, it proved to be hard to extend when stacked
devices were taken into account and more advanced use-cases (e.g., IGMP
snooping) considered.
This patch removes the excess information from the above struct and
instead stores it in more appropriate structs that represent the bridge
port, the bridge itself and a VLAN configured on the bridge port.
The membership of a port in a bridge is denoted using the Port-VLAN
struct, which points to the bridge port and also member in the bridge
VLAN group of the VLAN it represents. This allows us to completely
remove the vPort abstraction and consolidate many of the code paths
relating to VLAN-aware and unaware bridges.
Note that the FID / vFID code is currently duplicated, but this will
soon go away when the common FID core will be introduced.
Signed-off-by: Ido Schimmel <idosch@mellanox.com>
Signed-off-by: Jiri Pirko <jiri@mellanox.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2017-05-26 14:37:31 +08:00
|
|
|
void mlxsw_sp_port_bridge_leave(struct mlxsw_sp_port *mlxsw_sp_port,
|
|
|
|
struct net_device *brport_dev,
|
|
|
|
struct net_device *br_dev);
|
2017-12-25 16:05:33 +08:00
|
|
|
bool mlxsw_sp_bridge_device_is_offloaded(const struct mlxsw_sp *mlxsw_sp,
|
|
|
|
const struct net_device *br_dev);
|
mlxsw: spectrum: Replace vPorts with Port-VLAN
As explained in the cover letter, since the introduction of the bridge
offload in the mlxsw driver, information related to the offloaded bridge
and bridge ports was stored in the individual port struct,
mlxsw_sp_port.
This lead to a bloated struct storing both physical properties of the
port (e.g., autoneg status) as well as logical properties of an upper
bridge port (e.g., learning, mrouter indication). While this might work
well for simple devices, it proved to be hard to extend when stacked
devices were taken into account and more advanced use-cases (e.g., IGMP
snooping) considered.
This patch removes the excess information from the above struct and
instead stores it in more appropriate structs that represent the bridge
port, the bridge itself and a VLAN configured on the bridge port.
The membership of a port in a bridge is denoted using the Port-VLAN
struct, which points to the bridge port and also member in the bridge
VLAN group of the VLAN it represents. This allows us to completely
remove the vPort abstraction and consolidate many of the code paths
relating to VLAN-aware and unaware bridges.
Note that the FID / vFID code is currently duplicated, but this will
soon go away when the common FID core will be introduced.
Signed-off-by: Ido Schimmel <idosch@mellanox.com>
Signed-off-by: Jiri Pirko <jiri@mellanox.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2017-05-26 14:37:31 +08:00
|
|
|
|
2017-06-04 22:53:38 +08:00
|
|
|
/* spectrum.c */
|
2016-04-06 23:10:10 +08:00
|
|
|
int mlxsw_sp_port_ets_set(struct mlxsw_sp_port *mlxsw_sp_port,
|
|
|
|
enum mlxsw_reg_qeec_hr hr, u8 index, u8 next_index,
|
|
|
|
bool dwrr, u8 dwrr_weight);
|
|
|
|
int mlxsw_sp_port_prio_tc_set(struct mlxsw_sp_port *mlxsw_sp_port,
|
|
|
|
u8 switch_prio, u8 tclass);
|
|
|
|
int __mlxsw_sp_port_headroom_set(struct mlxsw_sp_port *mlxsw_sp_port, int mtu,
|
2016-04-06 23:10:16 +08:00
|
|
|
u8 *prio_tc, bool pause_en,
|
|
|
|
struct ieee_pfc *my_pfc);
|
2016-04-06 23:10:11 +08:00
|
|
|
int mlxsw_sp_port_ets_maxrate_set(struct mlxsw_sp_port *mlxsw_sp_port,
|
|
|
|
enum mlxsw_reg_qeec_hr hr, u8 index,
|
|
|
|
u8 next_index, u32 maxrate);
|
2018-04-29 15:56:09 +08:00
|
|
|
enum mlxsw_reg_spms_state mlxsw_sp_stp_spms_state(u8 stp_state);
|
2017-05-17 01:38:31 +08:00
|
|
|
int mlxsw_sp_port_vid_stp_set(struct mlxsw_sp_port *mlxsw_sp_port, u16 vid,
|
|
|
|
u8 state);
|
2017-05-26 14:37:39 +08:00
|
|
|
int mlxsw_sp_port_vp_mode_set(struct mlxsw_sp_port *mlxsw_sp_port, bool enable);
|
2017-05-17 01:38:31 +08:00
|
|
|
int mlxsw_sp_port_vid_learning_set(struct mlxsw_sp_port *mlxsw_sp_port, u16 vid,
|
|
|
|
bool learn_enable);
|
2017-05-17 01:38:34 +08:00
|
|
|
int mlxsw_sp_port_pvid_set(struct mlxsw_sp_port *mlxsw_sp_port, u16 vid);
|
mlxsw: spectrum: Replace vPorts with Port-VLAN
As explained in the cover letter, since the introduction of the bridge
offload in the mlxsw driver, information related to the offloaded bridge
and bridge ports was stored in the individual port struct,
mlxsw_sp_port.
This lead to a bloated struct storing both physical properties of the
port (e.g., autoneg status) as well as logical properties of an upper
bridge port (e.g., learning, mrouter indication). While this might work
well for simple devices, it proved to be hard to extend when stacked
devices were taken into account and more advanced use-cases (e.g., IGMP
snooping) considered.
This patch removes the excess information from the above struct and
instead stores it in more appropriate structs that represent the bridge
port, the bridge itself and a VLAN configured on the bridge port.
The membership of a port in a bridge is denoted using the Port-VLAN
struct, which points to the bridge port and also member in the bridge
VLAN group of the VLAN it represents. This allows us to completely
remove the vPort abstraction and consolidate many of the code paths
relating to VLAN-aware and unaware bridges.
Note that the FID / vFID code is currently duplicated, but this will
soon go away when the common FID core will be introduced.
Signed-off-by: Ido Schimmel <idosch@mellanox.com>
Signed-off-by: Jiri Pirko <jiri@mellanox.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2017-05-26 14:37:31 +08:00
|
|
|
struct mlxsw_sp_port_vlan *
|
|
|
|
mlxsw_sp_port_vlan_get(struct mlxsw_sp_port *mlxsw_sp_port, u16 vid);
|
|
|
|
void mlxsw_sp_port_vlan_put(struct mlxsw_sp_port_vlan *mlxsw_sp_port_vlan);
|
2017-06-04 22:53:38 +08:00
|
|
|
int mlxsw_sp_port_vlan_set(struct mlxsw_sp_port *mlxsw_sp_port, u16 vid_begin,
|
|
|
|
u16 vid_end, bool is_member, bool untagged);
|
|
|
|
int mlxsw_sp_flow_counter_get(struct mlxsw_sp *mlxsw_sp,
|
|
|
|
unsigned int counter_index, u64 *packets,
|
|
|
|
u64 *bytes);
|
|
|
|
int mlxsw_sp_flow_counter_alloc(struct mlxsw_sp *mlxsw_sp,
|
|
|
|
unsigned int *p_counter_index);
|
|
|
|
void mlxsw_sp_flow_counter_free(struct mlxsw_sp *mlxsw_sp,
|
|
|
|
unsigned int counter_index);
|
|
|
|
bool mlxsw_sp_port_dev_check(const struct net_device *dev);
|
|
|
|
struct mlxsw_sp *mlxsw_sp_lower_get(struct net_device *dev);
|
|
|
|
struct mlxsw_sp_port *mlxsw_sp_port_dev_lower_find(struct net_device *dev);
|
|
|
|
struct mlxsw_sp_port *mlxsw_sp_port_lower_dev_hold(struct net_device *dev);
|
|
|
|
void mlxsw_sp_port_dev_put(struct mlxsw_sp_port *mlxsw_sp_port);
|
2017-06-08 14:44:20 +08:00
|
|
|
struct mlxsw_sp_port *mlxsw_sp_port_dev_lower_find_rcu(struct net_device *dev);
|
2015-10-16 20:01:37 +08:00
|
|
|
|
2017-06-04 22:53:38 +08:00
|
|
|
/* spectrum_dcb.c */
|
2016-04-06 23:10:09 +08:00
|
|
|
#ifdef CONFIG_MLXSW_SPECTRUM_DCB
|
|
|
|
int mlxsw_sp_port_dcb_init(struct mlxsw_sp_port *mlxsw_sp_port);
|
|
|
|
void mlxsw_sp_port_dcb_fini(struct mlxsw_sp_port *mlxsw_sp_port);
|
|
|
|
#else
|
|
|
|
static inline int mlxsw_sp_port_dcb_init(struct mlxsw_sp_port *mlxsw_sp_port)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
static inline void mlxsw_sp_port_dcb_fini(struct mlxsw_sp_port *mlxsw_sp_port)
|
|
|
|
{}
|
|
|
|
#endif
|
|
|
|
|
2017-06-04 22:53:38 +08:00
|
|
|
/* spectrum_router.c */
|
2016-07-02 17:00:15 +08:00
|
|
|
int mlxsw_sp_router_init(struct mlxsw_sp *mlxsw_sp);
|
|
|
|
void mlxsw_sp_router_fini(struct mlxsw_sp *mlxsw_sp);
|
2017-03-10 15:53:39 +08:00
|
|
|
int mlxsw_sp_netdevice_router_port_event(struct net_device *dev);
|
|
|
|
int mlxsw_sp_inetaddr_event(struct notifier_block *unused,
|
|
|
|
unsigned long event, void *ptr);
|
2017-10-19 00:56:55 +08:00
|
|
|
int mlxsw_sp_inetaddr_valid_event(struct notifier_block *unused,
|
|
|
|
unsigned long event, void *ptr);
|
2017-07-18 16:10:13 +08:00
|
|
|
int mlxsw_sp_inet6addr_event(struct notifier_block *unused,
|
|
|
|
unsigned long event, void *ptr);
|
2017-10-19 00:56:55 +08:00
|
|
|
int mlxsw_sp_inet6addr_valid_event(struct notifier_block *unused,
|
|
|
|
unsigned long event, void *ptr);
|
2017-05-01 00:47:14 +08:00
|
|
|
int mlxsw_sp_netdevice_vrf_event(struct net_device *l3_dev, unsigned long event,
|
|
|
|
struct netdev_notifier_changeupper_info *info);
|
2017-11-03 17:03:29 +08:00
|
|
|
bool mlxsw_sp_netdev_is_ipip_ol(const struct mlxsw_sp *mlxsw_sp,
|
|
|
|
const struct net_device *dev);
|
2017-11-03 17:03:41 +08:00
|
|
|
bool mlxsw_sp_netdev_is_ipip_ul(const struct mlxsw_sp *mlxsw_sp,
|
|
|
|
const struct net_device *dev);
|
2017-11-03 17:03:36 +08:00
|
|
|
int mlxsw_sp_netdevice_ipip_ol_event(struct mlxsw_sp *mlxsw_sp,
|
|
|
|
struct net_device *l3_dev,
|
|
|
|
unsigned long event,
|
|
|
|
struct netdev_notifier_info *info);
|
2017-11-03 17:03:41 +08:00
|
|
|
int
|
|
|
|
mlxsw_sp_netdevice_ipip_ul_event(struct mlxsw_sp *mlxsw_sp,
|
|
|
|
struct net_device *l3_dev,
|
|
|
|
unsigned long event,
|
|
|
|
struct netdev_notifier_info *info);
|
2017-05-26 14:37:39 +08:00
|
|
|
void
|
|
|
|
mlxsw_sp_port_vlan_router_leave(struct mlxsw_sp_port_vlan *mlxsw_sp_port_vlan);
|
2017-05-26 14:37:40 +08:00
|
|
|
void mlxsw_sp_rif_destroy(struct mlxsw_sp_rif *rif);
|
2016-07-02 17:00:15 +08:00
|
|
|
|
2017-06-04 22:53:38 +08:00
|
|
|
/* spectrum_kvdl.c */
|
2018-07-09 04:51:17 +08:00
|
|
|
enum mlxsw_sp_kvdl_entry_type {
|
|
|
|
MLXSW_SP_KVDL_ENTRY_TYPE_ADJ,
|
|
|
|
MLXSW_SP_KVDL_ENTRY_TYPE_ACTSET,
|
|
|
|
MLXSW_SP_KVDL_ENTRY_TYPE_PBS,
|
|
|
|
MLXSW_SP_KVDL_ENTRY_TYPE_MCRIGR,
|
|
|
|
};
|
|
|
|
|
|
|
|
static inline unsigned int
|
|
|
|
mlxsw_sp_kvdl_entry_size(enum mlxsw_sp_kvdl_entry_type type)
|
|
|
|
{
|
|
|
|
switch (type) {
|
|
|
|
case MLXSW_SP_KVDL_ENTRY_TYPE_ADJ: /* fall through */
|
|
|
|
case MLXSW_SP_KVDL_ENTRY_TYPE_ACTSET: /* fall through */
|
|
|
|
case MLXSW_SP_KVDL_ENTRY_TYPE_PBS: /* fall through */
|
|
|
|
case MLXSW_SP_KVDL_ENTRY_TYPE_MCRIGR: /* fall through */
|
|
|
|
default:
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-07-09 04:51:16 +08:00
|
|
|
struct mlxsw_sp_kvdl_ops {
|
|
|
|
size_t priv_size;
|
|
|
|
int (*init)(struct mlxsw_sp *mlxsw_sp, void *priv);
|
|
|
|
void (*fini)(struct mlxsw_sp *mlxsw_sp, void *priv);
|
|
|
|
int (*alloc)(struct mlxsw_sp *mlxsw_sp, void *priv,
|
2018-07-09 04:51:17 +08:00
|
|
|
enum mlxsw_sp_kvdl_entry_type type,
|
2018-07-09 04:51:16 +08:00
|
|
|
unsigned int entry_count, u32 *p_entry_index);
|
|
|
|
void (*free)(struct mlxsw_sp *mlxsw_sp, void *priv,
|
2018-07-09 04:51:17 +08:00
|
|
|
enum mlxsw_sp_kvdl_entry_type type,
|
2018-07-09 04:51:18 +08:00
|
|
|
unsigned int entry_count, int entry_index);
|
2018-07-09 04:51:16 +08:00
|
|
|
int (*alloc_size_query)(struct mlxsw_sp *mlxsw_sp, void *priv,
|
2018-07-09 04:51:17 +08:00
|
|
|
enum mlxsw_sp_kvdl_entry_type type,
|
2018-07-09 04:51:16 +08:00
|
|
|
unsigned int entry_count,
|
2018-07-09 04:51:17 +08:00
|
|
|
unsigned int *p_alloc_count);
|
2018-07-09 04:51:16 +08:00
|
|
|
int (*resources_register)(struct mlxsw_sp *mlxsw_sp, void *priv);
|
|
|
|
};
|
|
|
|
|
2017-10-23 05:11:44 +08:00
|
|
|
int mlxsw_sp_kvdl_init(struct mlxsw_sp *mlxsw_sp);
|
|
|
|
void mlxsw_sp_kvdl_fini(struct mlxsw_sp *mlxsw_sp);
|
2018-07-09 04:51:17 +08:00
|
|
|
int mlxsw_sp_kvdl_alloc(struct mlxsw_sp *mlxsw_sp,
|
|
|
|
enum mlxsw_sp_kvdl_entry_type type,
|
|
|
|
unsigned int entry_count, u32 *p_entry_index);
|
|
|
|
void mlxsw_sp_kvdl_free(struct mlxsw_sp *mlxsw_sp,
|
|
|
|
enum mlxsw_sp_kvdl_entry_type type,
|
2018-07-09 04:51:18 +08:00
|
|
|
unsigned int entry_count, int entry_index);
|
2018-07-09 04:51:17 +08:00
|
|
|
int mlxsw_sp_kvdl_alloc_count_query(struct mlxsw_sp *mlxsw_sp,
|
|
|
|
enum mlxsw_sp_kvdl_entry_type type,
|
|
|
|
unsigned int entry_count,
|
|
|
|
unsigned int *p_alloc_count);
|
2018-07-09 04:51:16 +08:00
|
|
|
|
|
|
|
/* spectrum1_kvdl.c */
|
|
|
|
extern const struct mlxsw_sp_kvdl_ops mlxsw_sp1_kvdl_ops;
|
|
|
|
int mlxsw_sp1_kvdl_resources_register(struct mlxsw_core *mlxsw_core);
|
2016-07-05 17:27:47 +08:00
|
|
|
|
2017-02-03 17:29:07 +08:00
|
|
|
struct mlxsw_sp_acl_rule_info {
|
|
|
|
unsigned int priority;
|
|
|
|
struct mlxsw_afk_element_values values;
|
|
|
|
struct mlxsw_afa_block *act_block;
|
2017-03-11 16:42:58 +08:00
|
|
|
unsigned int counter_index;
|
2017-02-03 17:29:07 +08:00
|
|
|
};
|
|
|
|
|
2018-01-17 18:46:56 +08:00
|
|
|
struct mlxsw_sp_acl_block;
|
2017-02-03 17:29:07 +08:00
|
|
|
struct mlxsw_sp_acl_ruleset;
|
|
|
|
|
2017-06-04 22:53:38 +08:00
|
|
|
/* spectrum_acl.c */
|
2018-07-09 04:51:21 +08:00
|
|
|
enum mlxsw_sp_acl_profile {
|
|
|
|
MLXSW_SP_ACL_PROFILE_FLOWER,
|
|
|
|
};
|
|
|
|
|
2017-06-04 22:53:38 +08:00
|
|
|
struct mlxsw_afk *mlxsw_sp_acl_afk(struct mlxsw_sp_acl *acl);
|
2018-01-17 18:46:56 +08:00
|
|
|
struct mlxsw_sp *mlxsw_sp_acl_block_mlxsw_sp(struct mlxsw_sp_acl_block *block);
|
|
|
|
unsigned int mlxsw_sp_acl_block_rule_count(struct mlxsw_sp_acl_block *block);
|
|
|
|
void mlxsw_sp_acl_block_disable_inc(struct mlxsw_sp_acl_block *block);
|
|
|
|
void mlxsw_sp_acl_block_disable_dec(struct mlxsw_sp_acl_block *block);
|
|
|
|
bool mlxsw_sp_acl_block_disabled(struct mlxsw_sp_acl_block *block);
|
|
|
|
struct mlxsw_sp_acl_block *mlxsw_sp_acl_block_create(struct mlxsw_sp *mlxsw_sp,
|
|
|
|
struct net *net);
|
|
|
|
void mlxsw_sp_acl_block_destroy(struct mlxsw_sp_acl_block *block);
|
|
|
|
int mlxsw_sp_acl_block_bind(struct mlxsw_sp *mlxsw_sp,
|
|
|
|
struct mlxsw_sp_acl_block *block,
|
|
|
|
struct mlxsw_sp_port *mlxsw_sp_port,
|
|
|
|
bool ingress);
|
|
|
|
int mlxsw_sp_acl_block_unbind(struct mlxsw_sp *mlxsw_sp,
|
|
|
|
struct mlxsw_sp_acl_block *block,
|
|
|
|
struct mlxsw_sp_port *mlxsw_sp_port,
|
|
|
|
bool ingress);
|
2017-02-03 17:29:07 +08:00
|
|
|
struct mlxsw_sp_acl_ruleset *
|
2018-01-17 18:46:56 +08:00
|
|
|
mlxsw_sp_acl_ruleset_lookup(struct mlxsw_sp *mlxsw_sp,
|
|
|
|
struct mlxsw_sp_acl_block *block, u32 chain_index,
|
2017-08-23 16:08:21 +08:00
|
|
|
enum mlxsw_sp_acl_profile profile);
|
|
|
|
struct mlxsw_sp_acl_ruleset *
|
2018-01-17 18:46:56 +08:00
|
|
|
mlxsw_sp_acl_ruleset_get(struct mlxsw_sp *mlxsw_sp,
|
|
|
|
struct mlxsw_sp_acl_block *block, u32 chain_index,
|
2017-02-03 17:29:07 +08:00
|
|
|
enum mlxsw_sp_acl_profile profile);
|
|
|
|
void mlxsw_sp_acl_ruleset_put(struct mlxsw_sp *mlxsw_sp,
|
|
|
|
struct mlxsw_sp_acl_ruleset *ruleset);
|
2017-08-23 16:08:20 +08:00
|
|
|
u16 mlxsw_sp_acl_ruleset_group_id(struct mlxsw_sp_acl_ruleset *ruleset);
|
2017-02-03 17:29:07 +08:00
|
|
|
|
|
|
|
struct mlxsw_sp_acl_rule_info *
|
|
|
|
mlxsw_sp_acl_rulei_create(struct mlxsw_sp_acl *acl);
|
|
|
|
void mlxsw_sp_acl_rulei_destroy(struct mlxsw_sp_acl_rule_info *rulei);
|
|
|
|
int mlxsw_sp_acl_rulei_commit(struct mlxsw_sp_acl_rule_info *rulei);
|
|
|
|
void mlxsw_sp_acl_rulei_priority(struct mlxsw_sp_acl_rule_info *rulei,
|
|
|
|
unsigned int priority);
|
|
|
|
void mlxsw_sp_acl_rulei_keymask_u32(struct mlxsw_sp_acl_rule_info *rulei,
|
|
|
|
enum mlxsw_afk_element element,
|
|
|
|
u32 key_value, u32 mask_value);
|
|
|
|
void mlxsw_sp_acl_rulei_keymask_buf(struct mlxsw_sp_acl_rule_info *rulei,
|
|
|
|
enum mlxsw_afk_element element,
|
|
|
|
const char *key_value,
|
|
|
|
const char *mask_value, unsigned int len);
|
2017-09-25 16:58:20 +08:00
|
|
|
int mlxsw_sp_acl_rulei_act_continue(struct mlxsw_sp_acl_rule_info *rulei);
|
|
|
|
int mlxsw_sp_acl_rulei_act_jump(struct mlxsw_sp_acl_rule_info *rulei,
|
|
|
|
u16 group_id);
|
2018-03-09 21:33:52 +08:00
|
|
|
int mlxsw_sp_acl_rulei_act_terminate(struct mlxsw_sp_acl_rule_info *rulei);
|
2017-02-03 17:29:07 +08:00
|
|
|
int mlxsw_sp_acl_rulei_act_drop(struct mlxsw_sp_acl_rule_info *rulei);
|
2017-06-06 20:12:06 +08:00
|
|
|
int mlxsw_sp_acl_rulei_act_trap(struct mlxsw_sp_acl_rule_info *rulei);
|
2018-01-19 16:24:52 +08:00
|
|
|
int mlxsw_sp_acl_rulei_act_mirror(struct mlxsw_sp *mlxsw_sp,
|
|
|
|
struct mlxsw_sp_acl_rule_info *rulei,
|
|
|
|
struct mlxsw_sp_acl_block *block,
|
|
|
|
struct net_device *out_dev);
|
2017-02-03 17:29:07 +08:00
|
|
|
int mlxsw_sp_acl_rulei_act_fwd(struct mlxsw_sp *mlxsw_sp,
|
|
|
|
struct mlxsw_sp_acl_rule_info *rulei,
|
|
|
|
struct net_device *out_dev);
|
2017-03-09 16:25:19 +08:00
|
|
|
int mlxsw_sp_acl_rulei_act_vlan(struct mlxsw_sp *mlxsw_sp,
|
|
|
|
struct mlxsw_sp_acl_rule_info *rulei,
|
|
|
|
u32 action, u16 vid, u16 proto, u8 prio);
|
2017-03-11 16:42:58 +08:00
|
|
|
int mlxsw_sp_acl_rulei_act_count(struct mlxsw_sp *mlxsw_sp,
|
|
|
|
struct mlxsw_sp_acl_rule_info *rulei);
|
2017-04-18 22:55:32 +08:00
|
|
|
int mlxsw_sp_acl_rulei_act_fid_set(struct mlxsw_sp *mlxsw_sp,
|
|
|
|
struct mlxsw_sp_acl_rule_info *rulei,
|
|
|
|
u16 fid);
|
2017-02-03 17:29:07 +08:00
|
|
|
|
|
|
|
struct mlxsw_sp_acl_rule;
|
|
|
|
|
|
|
|
struct mlxsw_sp_acl_rule *
|
|
|
|
mlxsw_sp_acl_rule_create(struct mlxsw_sp *mlxsw_sp,
|
|
|
|
struct mlxsw_sp_acl_ruleset *ruleset,
|
|
|
|
unsigned long cookie);
|
|
|
|
void mlxsw_sp_acl_rule_destroy(struct mlxsw_sp *mlxsw_sp,
|
|
|
|
struct mlxsw_sp_acl_rule *rule);
|
|
|
|
int mlxsw_sp_acl_rule_add(struct mlxsw_sp *mlxsw_sp,
|
|
|
|
struct mlxsw_sp_acl_rule *rule);
|
|
|
|
void mlxsw_sp_acl_rule_del(struct mlxsw_sp *mlxsw_sp,
|
|
|
|
struct mlxsw_sp_acl_rule *rule);
|
|
|
|
struct mlxsw_sp_acl_rule *
|
|
|
|
mlxsw_sp_acl_rule_lookup(struct mlxsw_sp *mlxsw_sp,
|
|
|
|
struct mlxsw_sp_acl_ruleset *ruleset,
|
|
|
|
unsigned long cookie);
|
|
|
|
struct mlxsw_sp_acl_rule_info *
|
|
|
|
mlxsw_sp_acl_rule_rulei(struct mlxsw_sp_acl_rule *rule);
|
2017-03-11 16:42:58 +08:00
|
|
|
int mlxsw_sp_acl_rule_get_stats(struct mlxsw_sp *mlxsw_sp,
|
|
|
|
struct mlxsw_sp_acl_rule *rule,
|
|
|
|
u64 *packets, u64 *bytes, u64 *last_use);
|
2017-02-03 17:29:07 +08:00
|
|
|
|
2017-05-26 14:37:39 +08:00
|
|
|
struct mlxsw_sp_fid *mlxsw_sp_acl_dummy_fid(struct mlxsw_sp *mlxsw_sp);
|
|
|
|
|
2017-02-03 17:29:07 +08:00
|
|
|
int mlxsw_sp_acl_init(struct mlxsw_sp *mlxsw_sp);
|
|
|
|
void mlxsw_sp_acl_fini(struct mlxsw_sp *mlxsw_sp);
|
|
|
|
|
2017-06-04 22:53:38 +08:00
|
|
|
/* spectrum_acl_tcam.c */
|
2018-07-09 04:51:21 +08:00
|
|
|
struct mlxsw_sp_acl_tcam;
|
2018-07-09 04:51:20 +08:00
|
|
|
struct mlxsw_sp_acl_tcam_region;
|
|
|
|
|
|
|
|
struct mlxsw_sp_acl_tcam_ops {
|
|
|
|
enum mlxsw_reg_ptar_key_type key_type;
|
2018-07-09 04:51:21 +08:00
|
|
|
size_t priv_size;
|
|
|
|
int (*init)(struct mlxsw_sp *mlxsw_sp, void *priv,
|
|
|
|
struct mlxsw_sp_acl_tcam *tcam);
|
|
|
|
void (*fini)(struct mlxsw_sp *mlxsw_sp, void *priv);
|
2018-07-09 04:51:20 +08:00
|
|
|
size_t region_priv_size;
|
|
|
|
int (*region_init)(struct mlxsw_sp *mlxsw_sp, void *region_priv,
|
|
|
|
struct mlxsw_sp_acl_tcam_region *region);
|
|
|
|
void (*region_fini)(struct mlxsw_sp *mlxsw_sp, void *region_priv);
|
|
|
|
size_t chunk_priv_size;
|
|
|
|
void (*chunk_init)(void *region_priv, void *chunk_priv,
|
|
|
|
unsigned int priority);
|
|
|
|
void (*chunk_fini)(void *chunk_priv);
|
|
|
|
size_t entry_priv_size;
|
|
|
|
int (*entry_add)(struct mlxsw_sp *mlxsw_sp,
|
|
|
|
void *region_priv, void *chunk_priv,
|
|
|
|
void *entry_priv,
|
|
|
|
struct mlxsw_sp_acl_rule_info *rulei);
|
|
|
|
void (*entry_del)(struct mlxsw_sp *mlxsw_sp,
|
|
|
|
void *region_priv, void *chunk_priv,
|
|
|
|
void *entry_priv);
|
|
|
|
int (*entry_activity_get)(struct mlxsw_sp *mlxsw_sp,
|
|
|
|
void *region_priv, void *entry_priv,
|
|
|
|
bool *activity);
|
|
|
|
};
|
|
|
|
|
|
|
|
/* spectrum1_acl_tcam.c */
|
|
|
|
extern const struct mlxsw_sp_acl_tcam_ops mlxsw_sp1_acl_tcam_ops;
|
2017-02-03 17:29:07 +08:00
|
|
|
|
2018-07-08 15:00:19 +08:00
|
|
|
/* spectrum_acl_flex_actions.c */
|
|
|
|
extern const struct mlxsw_afa_ops mlxsw_sp1_act_afa_ops;
|
|
|
|
|
2018-07-09 04:51:22 +08:00
|
|
|
/* spectrum_acl_flex_keys.c */
|
|
|
|
extern const struct mlxsw_afk_ops mlxsw_sp1_afk_ops;
|
|
|
|
|
2017-06-04 22:53:38 +08:00
|
|
|
/* spectrum_flower.c */
|
2018-01-17 18:46:56 +08:00
|
|
|
int mlxsw_sp_flower_replace(struct mlxsw_sp *mlxsw_sp,
|
|
|
|
struct mlxsw_sp_acl_block *block,
|
2017-08-07 16:15:29 +08:00
|
|
|
struct tc_cls_flower_offload *f);
|
2018-01-17 18:46:56 +08:00
|
|
|
void mlxsw_sp_flower_destroy(struct mlxsw_sp *mlxsw_sp,
|
|
|
|
struct mlxsw_sp_acl_block *block,
|
2017-02-03 17:29:09 +08:00
|
|
|
struct tc_cls_flower_offload *f);
|
2018-01-17 18:46:56 +08:00
|
|
|
int mlxsw_sp_flower_stats(struct mlxsw_sp *mlxsw_sp,
|
|
|
|
struct mlxsw_sp_acl_block *block,
|
2017-03-11 16:42:59 +08:00
|
|
|
struct tc_cls_flower_offload *f);
|
2017-02-03 17:29:09 +08:00
|
|
|
|
2017-11-06 14:23:45 +08:00
|
|
|
/* spectrum_qdisc.c */
|
2018-01-10 21:59:57 +08:00
|
|
|
int mlxsw_sp_tc_qdisc_init(struct mlxsw_sp_port *mlxsw_sp_port);
|
|
|
|
void mlxsw_sp_tc_qdisc_fini(struct mlxsw_sp_port *mlxsw_sp_port);
|
2017-11-06 14:23:45 +08:00
|
|
|
int mlxsw_sp_setup_tc_red(struct mlxsw_sp_port *mlxsw_sp_port,
|
|
|
|
struct tc_red_qopt_offload *p);
|
2018-01-14 19:33:16 +08:00
|
|
|
int mlxsw_sp_setup_tc_prio(struct mlxsw_sp_port *mlxsw_sp_port,
|
|
|
|
struct tc_prio_qopt_offload *p);
|
2017-11-06 14:23:45 +08:00
|
|
|
|
2017-06-04 22:53:38 +08:00
|
|
|
/* spectrum_fid.c */
|
2017-05-26 14:37:39 +08:00
|
|
|
int mlxsw_sp_fid_flood_set(struct mlxsw_sp_fid *fid,
|
|
|
|
enum mlxsw_sp_flood_type packet_type, u8 local_port,
|
|
|
|
bool member);
|
|
|
|
int mlxsw_sp_fid_port_vid_map(struct mlxsw_sp_fid *fid,
|
|
|
|
struct mlxsw_sp_port *mlxsw_sp_port, u16 vid);
|
|
|
|
void mlxsw_sp_fid_port_vid_unmap(struct mlxsw_sp_fid *fid,
|
|
|
|
struct mlxsw_sp_port *mlxsw_sp_port, u16 vid);
|
|
|
|
enum mlxsw_sp_rif_type mlxsw_sp_fid_rif_type(const struct mlxsw_sp_fid *fid);
|
|
|
|
u16 mlxsw_sp_fid_index(const struct mlxsw_sp_fid *fid);
|
|
|
|
enum mlxsw_sp_fid_type mlxsw_sp_fid_type(const struct mlxsw_sp_fid *fid);
|
|
|
|
void mlxsw_sp_fid_rif_set(struct mlxsw_sp_fid *fid, struct mlxsw_sp_rif *rif);
|
2017-05-26 14:37:40 +08:00
|
|
|
enum mlxsw_sp_rif_type
|
|
|
|
mlxsw_sp_fid_type_rif_type(const struct mlxsw_sp *mlxsw_sp,
|
|
|
|
enum mlxsw_sp_fid_type type);
|
|
|
|
u16 mlxsw_sp_fid_8021q_vid(const struct mlxsw_sp_fid *fid);
|
2017-05-26 14:37:39 +08:00
|
|
|
struct mlxsw_sp_fid *mlxsw_sp_fid_8021q_get(struct mlxsw_sp *mlxsw_sp, u16 vid);
|
|
|
|
struct mlxsw_sp_fid *mlxsw_sp_fid_8021d_get(struct mlxsw_sp *mlxsw_sp,
|
|
|
|
int br_ifindex);
|
|
|
|
struct mlxsw_sp_fid *mlxsw_sp_fid_rfid_get(struct mlxsw_sp *mlxsw_sp,
|
|
|
|
u16 rif_index);
|
|
|
|
struct mlxsw_sp_fid *mlxsw_sp_fid_dummy_get(struct mlxsw_sp *mlxsw_sp);
|
|
|
|
void mlxsw_sp_fid_put(struct mlxsw_sp_fid *fid);
|
|
|
|
int mlxsw_sp_port_fids_init(struct mlxsw_sp_port *mlxsw_sp_port);
|
|
|
|
void mlxsw_sp_port_fids_fini(struct mlxsw_sp_port *mlxsw_sp_port);
|
|
|
|
int mlxsw_sp_fids_init(struct mlxsw_sp *mlxsw_sp);
|
|
|
|
void mlxsw_sp_fids_fini(struct mlxsw_sp *mlxsw_sp);
|
|
|
|
|
2018-07-09 04:51:19 +08:00
|
|
|
/* spectrum_mr.c */
|
|
|
|
enum mlxsw_sp_mr_route_prio {
|
|
|
|
MLXSW_SP_MR_ROUTE_PRIO_SG,
|
|
|
|
MLXSW_SP_MR_ROUTE_PRIO_STARG,
|
|
|
|
MLXSW_SP_MR_ROUTE_PRIO_CATCHALL,
|
|
|
|
__MLXSW_SP_MR_ROUTE_PRIO_MAX
|
|
|
|
};
|
|
|
|
|
|
|
|
#define MLXSW_SP_MR_ROUTE_PRIO_MAX (__MLXSW_SP_MR_ROUTE_PRIO_MAX - 1)
|
|
|
|
|
|
|
|
struct mlxsw_sp_mr_route_key;
|
|
|
|
|
|
|
|
struct mlxsw_sp_mr_tcam_ops {
|
|
|
|
size_t priv_size;
|
|
|
|
int (*init)(struct mlxsw_sp *mlxsw_sp, void *priv);
|
|
|
|
void (*fini)(void *priv);
|
|
|
|
size_t route_priv_size;
|
|
|
|
int (*route_create)(struct mlxsw_sp *mlxsw_sp, void *priv,
|
|
|
|
void *route_priv,
|
|
|
|
struct mlxsw_sp_mr_route_key *key,
|
|
|
|
struct mlxsw_afa_block *afa_block,
|
|
|
|
enum mlxsw_sp_mr_route_prio prio);
|
|
|
|
void (*route_destroy)(struct mlxsw_sp *mlxsw_sp, void *priv,
|
|
|
|
void *route_priv,
|
|
|
|
struct mlxsw_sp_mr_route_key *key);
|
|
|
|
int (*route_update)(struct mlxsw_sp *mlxsw_sp, void *route_priv,
|
|
|
|
struct mlxsw_sp_mr_route_key *key,
|
|
|
|
struct mlxsw_afa_block *afa_block);
|
|
|
|
};
|
|
|
|
|
|
|
|
/* spectrum1_mr_tcam.c */
|
|
|
|
extern const struct mlxsw_sp_mr_tcam_ops mlxsw_sp1_mr_tcam_ops;
|
|
|
|
|
2015-10-16 20:01:37 +08:00
|
|
|
#endif
|