Merge branch 'dpaa2-switch-next'
Ioana Ciornei says: ==================== dpaa2-switch: CPU terminated traffic and move out of staging This patch set adds support for Rx/Tx capabilities on DPAA2 switch port interfaces as well as fixing up some major blunders in how we take care of the switching domains. The last patch actually moves the driver out of staging now that the minimum requirements are met. I am sending this directly towards the net-next tree so that I can use the rest of the development cycle adding new features on top of the current driver without worrying about merge conflicts between the staging and net-next tree. The control interface is comprised of 3 queues in total: Rx, Rx error and Tx confirmation. In this patch set we only enable Rx and Tx conf. All switch ports share the same queues when frames are redirected to the CPU. Information regarding the ingress switch port is passed through frame metadata - the flow context field of the descriptor. NAPI instances are also shared between switch net_devices and are enabled when at least on one of the switch ports .dev_open() was called and disabled when no switch port is still up. Since the last version of this feature was submitted to the list, I reworked how the switching and flooding domains are taken care of by the driver, thus the switch is now able to also add the control port (the queues that the CPU can dequeue from) into the flooding domains of a port (broadcast, unknown unicast etc). With this, we are able to receive and sent traffic from the switch interfaces. Also, the capability to properly partition the DPSW object into multiple switching domains was added so that when not under a bridge, the ports are not actually capable to switch between them. This is possible by adding a private FDB table per switch interface. When multiple switch interfaces are under the same bridge, they will all use the same FDB table. Another thing that is fixed in this patch set is how the driver handles VLAN awareness. The DPAA2 switch is not capable to run as VLAN unaware but this was not reflected in how the driver responded to requests to change the VLAN awareness. In the last patch, this is fixed by describing the switch interfaces as Rx VLAN filtering on [fixed] and declining any request to join a VLAN unaware bridge. ==================== Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
commit
eeada4105d
@ -5473,11 +5473,11 @@ F: drivers/net/ethernet/freescale/dpaa2/dpmac*
|
||||
F: drivers/net/ethernet/freescale/dpaa2/dpni*
|
||||
|
||||
DPAA2 ETHERNET SWITCH DRIVER
|
||||
M: Ioana Radulescu <ruxandra.radulescu@nxp.com>
|
||||
M: Ioana Ciornei <ioana.ciornei@nxp.com>
|
||||
L: linux-kernel@vger.kernel.org
|
||||
L: netdev@vger.kernel.org
|
||||
S: Maintained
|
||||
F: drivers/staging/fsl-dpaa2/ethsw
|
||||
F: drivers/net/ethernet/freescale/dpaa2/dpaa2-switch*
|
||||
F: drivers/net/ethernet/freescale/dpaa2/dpsw*
|
||||
|
||||
DPT_I2O SCSI RAID DRIVER
|
||||
M: Adaptec OEM Raid Solutions <aacraid@microsemi.com>
|
||||
|
@ -29,3 +29,11 @@ config FSL_DPAA2_PTP_CLOCK
|
||||
help
|
||||
This driver adds support for using the DPAA2 1588 timer module
|
||||
as a PTP clock.
|
||||
|
||||
config FSL_DPAA2_SWITCH
|
||||
tristate "Freescale DPAA2 Ethernet Switch"
|
||||
depends on BRIDGE || BRIDGE=n
|
||||
depends on NET_SWITCHDEV
|
||||
help
|
||||
Driver for Freescale DPAA2 Ethernet Switch. This driver manages
|
||||
switch objects discovered on the Freeescale MC bus.
|
||||
|
@ -5,11 +5,13 @@
|
||||
|
||||
obj-$(CONFIG_FSL_DPAA2_ETH) += fsl-dpaa2-eth.o
|
||||
obj-$(CONFIG_FSL_DPAA2_PTP_CLOCK) += fsl-dpaa2-ptp.o
|
||||
obj-$(CONFIG_FSL_DPAA2_SWITCH) += fsl-dpaa2-switch.o
|
||||
|
||||
fsl-dpaa2-eth-objs := dpaa2-eth.o dpaa2-ethtool.o dpni.o dpaa2-mac.o dpmac.o dpaa2-eth-devlink.o
|
||||
fsl-dpaa2-eth-${CONFIG_FSL_DPAA2_ETH_DCB} += dpaa2-eth-dcb.o
|
||||
fsl-dpaa2-eth-${CONFIG_DEBUG_FS} += dpaa2-eth-debugfs.o
|
||||
fsl-dpaa2-ptp-objs := dpaa2-ptp.o dprtc.o
|
||||
fsl-dpaa2-switch-objs := dpaa2-switch.o dpaa2-switch-ethtool.o dpsw.o
|
||||
|
||||
# Needed by the tracing framework
|
||||
CFLAGS_dpaa2-eth.o := -I$(src)
|
||||
|
@ -9,7 +9,7 @@
|
||||
|
||||
#include <linux/ethtool.h>
|
||||
|
||||
#include "ethsw.h"
|
||||
#include "dpaa2-switch.h"
|
||||
|
||||
static struct {
|
||||
enum dpsw_counter id;
|
File diff suppressed because it is too large
Load Diff
178
drivers/net/ethernet/freescale/dpaa2/dpaa2-switch.h
Normal file
178
drivers/net/ethernet/freescale/dpaa2/dpaa2-switch.h
Normal file
@ -0,0 +1,178 @@
|
||||
/* SPDX-License-Identifier: GPL-2.0 */
|
||||
/*
|
||||
* DPAA2 Ethernet Switch declarations
|
||||
*
|
||||
* Copyright 2014-2016 Freescale Semiconductor Inc.
|
||||
* Copyright 2017-2021 NXP
|
||||
*
|
||||
*/
|
||||
|
||||
#ifndef __ETHSW_H
|
||||
#define __ETHSW_H
|
||||
|
||||
#include <linux/netdevice.h>
|
||||
#include <linux/etherdevice.h>
|
||||
#include <linux/rtnetlink.h>
|
||||
#include <linux/if_vlan.h>
|
||||
#include <uapi/linux/if_bridge.h>
|
||||
#include <net/switchdev.h>
|
||||
#include <linux/if_bridge.h>
|
||||
#include <linux/fsl/mc.h>
|
||||
#include <soc/fsl/dpaa2-io.h>
|
||||
|
||||
#include "dpsw.h"
|
||||
|
||||
/* Number of IRQs supported */
|
||||
#define DPSW_IRQ_NUM 2
|
||||
|
||||
/* Port is member of VLAN */
|
||||
#define ETHSW_VLAN_MEMBER 1
|
||||
/* VLAN to be treated as untagged on egress */
|
||||
#define ETHSW_VLAN_UNTAGGED 2
|
||||
/* Untagged frames will be assigned to this VLAN */
|
||||
#define ETHSW_VLAN_PVID 4
|
||||
/* VLAN configured on the switch */
|
||||
#define ETHSW_VLAN_GLOBAL 8
|
||||
|
||||
/* Maximum Frame Length supported by HW (currently 10k) */
|
||||
#define DPAA2_MFL (10 * 1024)
|
||||
#define ETHSW_MAX_FRAME_LENGTH (DPAA2_MFL - VLAN_ETH_HLEN - ETH_FCS_LEN)
|
||||
#define ETHSW_L2_MAX_FRM(mtu) ((mtu) + VLAN_ETH_HLEN + ETH_FCS_LEN)
|
||||
|
||||
#define ETHSW_FEATURE_MAC_ADDR BIT(0)
|
||||
|
||||
/* Number of receive queues (one RX and one TX_CONF) */
|
||||
#define DPAA2_SWITCH_RX_NUM_FQS 2
|
||||
|
||||
/* Hardware requires alignment for ingress/egress buffer addresses */
|
||||
#define DPAA2_SWITCH_RX_BUF_RAW_SIZE PAGE_SIZE
|
||||
#define DPAA2_SWITCH_RX_BUF_TAILROOM \
|
||||
SKB_DATA_ALIGN(sizeof(struct skb_shared_info))
|
||||
#define DPAA2_SWITCH_RX_BUF_SIZE \
|
||||
(DPAA2_SWITCH_RX_BUF_RAW_SIZE - DPAA2_SWITCH_RX_BUF_TAILROOM)
|
||||
|
||||
#define DPAA2_SWITCH_STORE_SIZE 16
|
||||
|
||||
/* Buffer management */
|
||||
#define BUFS_PER_CMD 7
|
||||
#define DPAA2_ETHSW_NUM_BUFS (1024 * BUFS_PER_CMD)
|
||||
#define DPAA2_ETHSW_REFILL_THRESH (DPAA2_ETHSW_NUM_BUFS * 5 / 6)
|
||||
|
||||
/* Number of times to retry DPIO portal operations while waiting
|
||||
* for portal to finish executing current command and become
|
||||
* available. We want to avoid being stuck in a while loop in case
|
||||
* hardware becomes unresponsive, but not give up too easily if
|
||||
* the portal really is busy for valid reasons
|
||||
*/
|
||||
#define DPAA2_SWITCH_SWP_BUSY_RETRIES 1000
|
||||
|
||||
/* Hardware annotation buffer size */
|
||||
#define DPAA2_SWITCH_HWA_SIZE 64
|
||||
/* Software annotation buffer size */
|
||||
#define DPAA2_SWITCH_SWA_SIZE 64
|
||||
|
||||
#define DPAA2_SWITCH_TX_BUF_ALIGN 64
|
||||
|
||||
#define DPAA2_SWITCH_TX_DATA_OFFSET \
|
||||
(DPAA2_SWITCH_HWA_SIZE + DPAA2_SWITCH_SWA_SIZE)
|
||||
|
||||
#define DPAA2_SWITCH_NEEDED_HEADROOM \
|
||||
(DPAA2_SWITCH_TX_DATA_OFFSET + DPAA2_SWITCH_TX_BUF_ALIGN)
|
||||
|
||||
extern const struct ethtool_ops dpaa2_switch_port_ethtool_ops;
|
||||
|
||||
struct ethsw_core;
|
||||
|
||||
struct dpaa2_switch_fq {
|
||||
struct ethsw_core *ethsw;
|
||||
enum dpsw_queue_type type;
|
||||
struct dpaa2_io_store *store;
|
||||
struct dpaa2_io_notification_ctx nctx;
|
||||
struct napi_struct napi;
|
||||
u32 fqid;
|
||||
};
|
||||
|
||||
struct dpaa2_switch_fdb {
|
||||
struct net_device *bridge_dev;
|
||||
u16 fdb_id;
|
||||
bool in_use;
|
||||
};
|
||||
|
||||
/* Per port private data */
|
||||
struct ethsw_port_priv {
|
||||
struct net_device *netdev;
|
||||
u16 idx;
|
||||
struct ethsw_core *ethsw_data;
|
||||
u8 link_state;
|
||||
u8 stp_state;
|
||||
bool flood;
|
||||
|
||||
u8 vlans[VLAN_VID_MASK + 1];
|
||||
u16 pvid;
|
||||
u16 tx_qdid;
|
||||
|
||||
struct dpaa2_switch_fdb *fdb;
|
||||
};
|
||||
|
||||
/* Switch data */
|
||||
struct ethsw_core {
|
||||
struct device *dev;
|
||||
struct fsl_mc_io *mc_io;
|
||||
u16 dpsw_handle;
|
||||
struct dpsw_attr sw_attr;
|
||||
u16 major, minor;
|
||||
unsigned long features;
|
||||
int dev_id;
|
||||
struct ethsw_port_priv **ports;
|
||||
struct iommu_domain *iommu_domain;
|
||||
|
||||
u8 vlans[VLAN_VID_MASK + 1];
|
||||
|
||||
struct workqueue_struct *workqueue;
|
||||
|
||||
struct dpaa2_switch_fq fq[DPAA2_SWITCH_RX_NUM_FQS];
|
||||
struct fsl_mc_device *dpbp_dev;
|
||||
int buf_count;
|
||||
u16 bpid;
|
||||
int napi_users;
|
||||
|
||||
struct dpaa2_switch_fdb *fdbs;
|
||||
};
|
||||
|
||||
static inline bool dpaa2_switch_supports_cpu_traffic(struct ethsw_core *ethsw)
|
||||
{
|
||||
if (ethsw->sw_attr.options & DPSW_OPT_CTRL_IF_DIS) {
|
||||
dev_err(ethsw->dev, "Control Interface is disabled, cannot probe\n");
|
||||
return false;
|
||||
}
|
||||
|
||||
if (ethsw->sw_attr.flooding_cfg != DPSW_FLOODING_PER_FDB) {
|
||||
dev_err(ethsw->dev, "Flooding domain is not per FDB, cannot probe\n");
|
||||
return false;
|
||||
}
|
||||
|
||||
if (ethsw->sw_attr.broadcast_cfg != DPSW_BROADCAST_PER_FDB) {
|
||||
dev_err(ethsw->dev, "Broadcast domain is not per FDB, cannot probe\n");
|
||||
return false;
|
||||
}
|
||||
|
||||
if (ethsw->sw_attr.max_fdbs < ethsw->sw_attr.num_ifs) {
|
||||
dev_err(ethsw->dev, "The number of FDBs is lower than the number of ports, cannot probe\n");
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
bool dpaa2_switch_port_dev_check(const struct net_device *netdev);
|
||||
|
||||
int dpaa2_switch_port_vlans_add(struct net_device *netdev,
|
||||
const struct switchdev_obj_port_vlan *vlan);
|
||||
|
||||
int dpaa2_switch_port_vlans_del(struct net_device *netdev,
|
||||
const struct switchdev_obj_port_vlan *vlan);
|
||||
|
||||
typedef int dpaa2_switch_fdb_cb_t(struct ethsw_port_priv *port_priv,
|
||||
struct fdb_dump_entry *fdb_entry,
|
||||
void *data);
|
||||
#endif /* __ETHSW_H */
|
@ -1,16 +1,18 @@
|
||||
/* SPDX-License-Identifier: GPL-2.0 */
|
||||
/*
|
||||
* Copyright 2014-2016 Freescale Semiconductor Inc.
|
||||
* Copyright 2017-2020 NXP
|
||||
* Copyright 2017-2021 NXP
|
||||
*
|
||||
*/
|
||||
|
||||
#ifndef __FSL_DPSW_CMD_H
|
||||
#define __FSL_DPSW_CMD_H
|
||||
|
||||
#include "dpsw.h"
|
||||
|
||||
/* DPSW Version */
|
||||
#define DPSW_VER_MAJOR 8
|
||||
#define DPSW_VER_MINOR 5
|
||||
#define DPSW_VER_MINOR 9
|
||||
|
||||
#define DPSW_CMD_BASE_VERSION 1
|
||||
#define DPSW_CMD_VERSION_2 2
|
||||
@ -27,7 +29,7 @@
|
||||
|
||||
#define DPSW_CMDID_ENABLE DPSW_CMD_ID(0x002)
|
||||
#define DPSW_CMDID_DISABLE DPSW_CMD_ID(0x003)
|
||||
#define DPSW_CMDID_GET_ATTR DPSW_CMD_ID(0x004)
|
||||
#define DPSW_CMDID_GET_ATTR DPSW_CMD_V2(0x004)
|
||||
#define DPSW_CMDID_RESET DPSW_CMD_ID(0x005)
|
||||
|
||||
#define DPSW_CMDID_SET_IRQ_ENABLE DPSW_CMD_ID(0x012)
|
||||
@ -45,18 +47,18 @@
|
||||
#define DPSW_CMDID_IF_ENABLE DPSW_CMD_ID(0x03D)
|
||||
#define DPSW_CMDID_IF_DISABLE DPSW_CMD_ID(0x03E)
|
||||
|
||||
#define DPSW_CMDID_IF_GET_ATTR DPSW_CMD_ID(0x042)
|
||||
|
||||
#define DPSW_CMDID_IF_SET_MAX_FRAME_LENGTH DPSW_CMD_ID(0x044)
|
||||
|
||||
#define DPSW_CMDID_IF_GET_LINK_STATE DPSW_CMD_ID(0x046)
|
||||
#define DPSW_CMDID_IF_SET_FLOODING DPSW_CMD_ID(0x047)
|
||||
#define DPSW_CMDID_IF_SET_BROADCAST DPSW_CMD_ID(0x048)
|
||||
|
||||
#define DPSW_CMDID_IF_GET_TCI DPSW_CMD_ID(0x04A)
|
||||
|
||||
#define DPSW_CMDID_IF_SET_LINK_CFG DPSW_CMD_ID(0x04C)
|
||||
|
||||
#define DPSW_CMDID_VLAN_ADD DPSW_CMD_ID(0x060)
|
||||
#define DPSW_CMDID_VLAN_ADD_IF DPSW_CMD_ID(0x061)
|
||||
#define DPSW_CMDID_VLAN_ADD_IF DPSW_CMD_V2(0x061)
|
||||
#define DPSW_CMDID_VLAN_ADD_IF_UNTAGGED DPSW_CMD_ID(0x062)
|
||||
|
||||
#define DPSW_CMDID_VLAN_REMOVE_IF DPSW_CMD_ID(0x064)
|
||||
@ -64,17 +66,26 @@
|
||||
#define DPSW_CMDID_VLAN_REMOVE_IF_FLOODING DPSW_CMD_ID(0x066)
|
||||
#define DPSW_CMDID_VLAN_REMOVE DPSW_CMD_ID(0x067)
|
||||
|
||||
#define DPSW_CMDID_FDB_ADD DPSW_CMD_ID(0x082)
|
||||
#define DPSW_CMDID_FDB_REMOVE DPSW_CMD_ID(0x083)
|
||||
#define DPSW_CMDID_FDB_ADD_UNICAST DPSW_CMD_ID(0x084)
|
||||
#define DPSW_CMDID_FDB_REMOVE_UNICAST DPSW_CMD_ID(0x085)
|
||||
#define DPSW_CMDID_FDB_ADD_MULTICAST DPSW_CMD_ID(0x086)
|
||||
#define DPSW_CMDID_FDB_REMOVE_MULTICAST DPSW_CMD_ID(0x087)
|
||||
#define DPSW_CMDID_FDB_SET_LEARNING_MODE DPSW_CMD_ID(0x088)
|
||||
#define DPSW_CMDID_FDB_DUMP DPSW_CMD_ID(0x08A)
|
||||
|
||||
#define DPSW_CMDID_IF_GET_PORT_MAC_ADDR DPSW_CMD_ID(0x0A7)
|
||||
#define DPSW_CMDID_IF_GET_PRIMARY_MAC_ADDR DPSW_CMD_ID(0x0A8)
|
||||
#define DPSW_CMDID_IF_SET_PRIMARY_MAC_ADDR DPSW_CMD_ID(0x0A9)
|
||||
|
||||
#define DPSW_CMDID_CTRL_IF_GET_ATTR DPSW_CMD_ID(0x0A0)
|
||||
#define DPSW_CMDID_CTRL_IF_SET_POOLS DPSW_CMD_ID(0x0A1)
|
||||
#define DPSW_CMDID_CTRL_IF_ENABLE DPSW_CMD_ID(0x0A2)
|
||||
#define DPSW_CMDID_CTRL_IF_DISABLE DPSW_CMD_ID(0x0A3)
|
||||
#define DPSW_CMDID_CTRL_IF_SET_QUEUE DPSW_CMD_ID(0x0A6)
|
||||
|
||||
#define DPSW_CMDID_SET_EGRESS_FLOOD DPSW_CMD_ID(0x0AC)
|
||||
|
||||
/* Macros for accessing command fields smaller than 1byte */
|
||||
#define DPSW_MASK(field) \
|
||||
GENMASK(DPSW_##field##_SHIFT + DPSW_##field##_SIZE - 1, \
|
||||
@ -169,6 +180,12 @@ struct dpsw_cmd_clear_irq_status {
|
||||
#define DPSW_COMPONENT_TYPE_SHIFT 0
|
||||
#define DPSW_COMPONENT_TYPE_SIZE 4
|
||||
|
||||
#define DPSW_FLOODING_CFG_SHIFT 0
|
||||
#define DPSW_FLOODING_CFG_SIZE 4
|
||||
|
||||
#define DPSW_BROADCAST_CFG_SHIFT 4
|
||||
#define DPSW_BROADCAST_CFG_SIZE 4
|
||||
|
||||
struct dpsw_rsp_get_attr {
|
||||
/* cmd word 0 */
|
||||
__le16 num_ifs;
|
||||
@ -186,23 +203,15 @@ struct dpsw_rsp_get_attr {
|
||||
u8 max_meters_per_if;
|
||||
/* from LSB only the first 4 bits */
|
||||
u8 component_type;
|
||||
__le16 pad;
|
||||
/* [0:3] - flooding configuration
|
||||
* [4:7] - broadcast configuration
|
||||
*/
|
||||
u8 repl_cfg;
|
||||
u8 pad;
|
||||
/* cmd word 3 */
|
||||
__le64 options;
|
||||
};
|
||||
|
||||
struct dpsw_cmd_if_set_flooding {
|
||||
__le16 if_id;
|
||||
/* from LSB: enable:1 */
|
||||
u8 enable;
|
||||
};
|
||||
|
||||
struct dpsw_cmd_if_set_broadcast {
|
||||
__le16 if_id;
|
||||
/* from LSB: enable:1 */
|
||||
u8 enable;
|
||||
};
|
||||
|
||||
#define DPSW_VLAN_ID_SHIFT 0
|
||||
#define DPSW_VLAN_ID_SIZE 12
|
||||
#define DPSW_DEI_SHIFT 12
|
||||
@ -255,6 +264,28 @@ struct dpsw_cmd_if {
|
||||
__le16 if_id;
|
||||
};
|
||||
|
||||
#define DPSW_ADMIT_UNTAGGED_SHIFT 0
|
||||
#define DPSW_ADMIT_UNTAGGED_SIZE 4
|
||||
#define DPSW_ENABLED_SHIFT 5
|
||||
#define DPSW_ENABLED_SIZE 1
|
||||
#define DPSW_ACCEPT_ALL_VLAN_SHIFT 6
|
||||
#define DPSW_ACCEPT_ALL_VLAN_SIZE 1
|
||||
|
||||
struct dpsw_rsp_if_get_attr {
|
||||
/* cmd word 0 */
|
||||
/* from LSB: admit_untagged:4 enabled:1 accept_all_vlan:1 */
|
||||
u8 conf;
|
||||
u8 pad1;
|
||||
u8 num_tcs;
|
||||
u8 pad2;
|
||||
__le16 qdid;
|
||||
/* cmd word 1 */
|
||||
__le32 options;
|
||||
__le32 pad3;
|
||||
/* cmd word 2 */
|
||||
__le32 rate;
|
||||
};
|
||||
|
||||
struct dpsw_cmd_if_set_max_frame_length {
|
||||
__le16 if_id;
|
||||
__le16 frame_length;
|
||||
@ -295,6 +326,16 @@ struct dpsw_vlan_add {
|
||||
__le16 vlan_id;
|
||||
};
|
||||
|
||||
struct dpsw_cmd_vlan_add_if {
|
||||
/* cmd word 0 */
|
||||
__le16 options;
|
||||
__le16 vlan_id;
|
||||
__le16 fdb_id;
|
||||
__le16 pad0;
|
||||
/* cmd word 1-4 */
|
||||
__le64 if_id;
|
||||
};
|
||||
|
||||
struct dpsw_cmd_vlan_manage_if {
|
||||
/* cmd word 0 */
|
||||
__le16 pad0;
|
||||
@ -311,7 +352,7 @@ struct dpsw_cmd_vlan_remove {
|
||||
|
||||
struct dpsw_cmd_fdb_add {
|
||||
__le32 pad;
|
||||
__le16 fdb_aging_time;
|
||||
__le16 fdb_ageing_time;
|
||||
__le16 num_fdb_entries;
|
||||
};
|
||||
|
||||
@ -350,15 +391,6 @@ struct dpsw_cmd_fdb_multicast_op {
|
||||
__le64 if_id[4];
|
||||
};
|
||||
|
||||
#define DPSW_LEARNING_MODE_SHIFT 0
|
||||
#define DPSW_LEARNING_MODE_SIZE 4
|
||||
|
||||
struct dpsw_cmd_fdb_set_learning_mode {
|
||||
__le16 fdb_id;
|
||||
/* only the first 4 bits from LSB */
|
||||
u8 mode;
|
||||
};
|
||||
|
||||
struct dpsw_cmd_fdb_dump {
|
||||
__le16 fdb_id;
|
||||
__le16 pad0;
|
||||
@ -371,6 +403,36 @@ struct dpsw_rsp_fdb_dump {
|
||||
__le16 num_entries;
|
||||
};
|
||||
|
||||
struct dpsw_rsp_ctrl_if_get_attr {
|
||||
__le64 pad;
|
||||
__le32 rx_fqid;
|
||||
__le32 rx_err_fqid;
|
||||
__le32 tx_err_conf_fqid;
|
||||
};
|
||||
|
||||
#define DPSW_BACKUP_POOL(val, order) (((val) & 0x1) << (order))
|
||||
struct dpsw_cmd_ctrl_if_set_pools {
|
||||
u8 num_dpbp;
|
||||
u8 backup_pool_mask;
|
||||
__le16 pad;
|
||||
__le32 dpbp_id[DPSW_MAX_DPBP];
|
||||
__le16 buffer_size[DPSW_MAX_DPBP];
|
||||
};
|
||||
|
||||
#define DPSW_DEST_TYPE_SHIFT 0
|
||||
#define DPSW_DEST_TYPE_SIZE 4
|
||||
|
||||
struct dpsw_cmd_ctrl_if_set_queue {
|
||||
__le32 dest_id;
|
||||
u8 dest_priority;
|
||||
u8 pad;
|
||||
/* from LSB: dest_type:4 */
|
||||
u8 dest_type;
|
||||
u8 qtype;
|
||||
__le64 user_ctx;
|
||||
__le32 options;
|
||||
};
|
||||
|
||||
struct dpsw_rsp_get_api_version {
|
||||
__le16 version_major;
|
||||
__le16 version_minor;
|
||||
@ -386,5 +448,11 @@ struct dpsw_cmd_if_set_mac_addr {
|
||||
u8 mac_addr[6];
|
||||
};
|
||||
|
||||
struct dpsw_cmd_set_egress_flood {
|
||||
__le16 fdb_id;
|
||||
u8 flood_type;
|
||||
u8 pad[5];
|
||||
__le64 if_id;
|
||||
};
|
||||
#pragma pack(pop)
|
||||
#endif /* __FSL_DPSW_CMD_H */
|
@ -1,7 +1,7 @@
|
||||
// SPDX-License-Identifier: GPL-2.0
|
||||
/*
|
||||
* Copyright 2014-2016 Freescale Semiconductor Inc.
|
||||
* Copyright 2017-2018 NXP
|
||||
* Copyright 2017-2021 NXP
|
||||
*
|
||||
*/
|
||||
|
||||
@ -351,9 +351,9 @@ int dpsw_get_attributes(struct fsl_mc_io *mc_io,
|
||||
attr->max_fdb_mc_groups = le16_to_cpu(rsp_params->max_fdb_mc_groups);
|
||||
attr->max_meters_per_if = rsp_params->max_meters_per_if;
|
||||
attr->options = le64_to_cpu(rsp_params->options);
|
||||
attr->component_type = dpsw_get_field(rsp_params->component_type,
|
||||
COMPONENT_TYPE);
|
||||
|
||||
attr->component_type = dpsw_get_field(rsp_params->component_type, COMPONENT_TYPE);
|
||||
attr->flooding_cfg = dpsw_get_field(rsp_params->repl_cfg, FLOODING_CFG);
|
||||
attr->broadcast_cfg = dpsw_get_field(rsp_params->repl_cfg, BROADCAST_CFG);
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -431,68 +431,6 @@ int dpsw_if_get_link_state(struct fsl_mc_io *mc_io,
|
||||
return 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* dpsw_if_set_flooding() - Enable Disable flooding for particular interface
|
||||
* @mc_io: Pointer to MC portal's I/O object
|
||||
* @cmd_flags: Command flags; one or more of 'MC_CMD_FLAG_'
|
||||
* @token: Token of DPSW object
|
||||
* @if_id: Interface Identifier
|
||||
* @en: 1 - enable, 0 - disable
|
||||
*
|
||||
* Return: Completion status. '0' on Success; Error code otherwise.
|
||||
*/
|
||||
int dpsw_if_set_flooding(struct fsl_mc_io *mc_io,
|
||||
u32 cmd_flags,
|
||||
u16 token,
|
||||
u16 if_id,
|
||||
u8 en)
|
||||
{
|
||||
struct fsl_mc_command cmd = { 0 };
|
||||
struct dpsw_cmd_if_set_flooding *cmd_params;
|
||||
|
||||
/* prepare command */
|
||||
cmd.header = mc_encode_cmd_header(DPSW_CMDID_IF_SET_FLOODING,
|
||||
cmd_flags,
|
||||
token);
|
||||
cmd_params = (struct dpsw_cmd_if_set_flooding *)cmd.params;
|
||||
cmd_params->if_id = cpu_to_le16(if_id);
|
||||
dpsw_set_field(cmd_params->enable, ENABLE, en);
|
||||
|
||||
/* send command to mc*/
|
||||
return mc_send_command(mc_io, &cmd);
|
||||
}
|
||||
|
||||
/**
|
||||
* dpsw_if_set_broadcast() - Enable/disable broadcast for particular interface
|
||||
* @mc_io: Pointer to MC portal's I/O object
|
||||
* @cmd_flags: Command flags; one or more of 'MC_CMD_FLAG_'
|
||||
* @token: Token of DPSW object
|
||||
* @if_id: Interface Identifier
|
||||
* @en: 1 - enable, 0 - disable
|
||||
*
|
||||
* Return: Completion status. '0' on Success; Error code otherwise.
|
||||
*/
|
||||
int dpsw_if_set_broadcast(struct fsl_mc_io *mc_io,
|
||||
u32 cmd_flags,
|
||||
u16 token,
|
||||
u16 if_id,
|
||||
u8 en)
|
||||
{
|
||||
struct fsl_mc_command cmd = { 0 };
|
||||
struct dpsw_cmd_if_set_broadcast *cmd_params;
|
||||
|
||||
/* prepare command */
|
||||
cmd.header = mc_encode_cmd_header(DPSW_CMDID_IF_SET_BROADCAST,
|
||||
cmd_flags,
|
||||
token);
|
||||
cmd_params = (struct dpsw_cmd_if_set_broadcast *)cmd.params;
|
||||
cmd_params->if_id = cpu_to_le16(if_id);
|
||||
dpsw_set_field(cmd_params->enable, ENABLE, en);
|
||||
|
||||
/* send command to mc*/
|
||||
return mc_send_command(mc_io, &cmd);
|
||||
}
|
||||
|
||||
/**
|
||||
* dpsw_if_set_tci() - Set default VLAN Tag Control Information (TCI)
|
||||
* @mc_io: Pointer to MC portal's I/O object
|
||||
@ -704,6 +642,47 @@ int dpsw_if_disable(struct fsl_mc_io *mc_io,
|
||||
return mc_send_command(mc_io, &cmd);
|
||||
}
|
||||
|
||||
/**
|
||||
* dpsw_if_get_attributes() - Function obtains attributes of interface
|
||||
* @mc_io: Pointer to MC portal's I/O object
|
||||
* @cmd_flags: Command flags; one or more of 'MC_CMD_FLAG_'
|
||||
* @token: Token of DPSW object
|
||||
* @if_id: Interface Identifier
|
||||
* @attr: Returned interface attributes
|
||||
*
|
||||
* Return: Completion status. '0' on Success; Error code otherwise.
|
||||
*/
|
||||
int dpsw_if_get_attributes(struct fsl_mc_io *mc_io, u32 cmd_flags, u16 token,
|
||||
u16 if_id, struct dpsw_if_attr *attr)
|
||||
{
|
||||
struct dpsw_rsp_if_get_attr *rsp_params;
|
||||
struct fsl_mc_command cmd = { 0 };
|
||||
struct dpsw_cmd_if *cmd_params;
|
||||
int err;
|
||||
|
||||
cmd.header = mc_encode_cmd_header(DPSW_CMDID_IF_GET_ATTR, cmd_flags,
|
||||
token);
|
||||
cmd_params = (struct dpsw_cmd_if *)cmd.params;
|
||||
cmd_params->if_id = cpu_to_le16(if_id);
|
||||
|
||||
err = mc_send_command(mc_io, &cmd);
|
||||
if (err)
|
||||
return err;
|
||||
|
||||
rsp_params = (struct dpsw_rsp_if_get_attr *)cmd.params;
|
||||
attr->num_tcs = rsp_params->num_tcs;
|
||||
attr->rate = le32_to_cpu(rsp_params->rate);
|
||||
attr->options = le32_to_cpu(rsp_params->options);
|
||||
attr->qdid = le16_to_cpu(rsp_params->qdid);
|
||||
attr->enabled = dpsw_get_field(rsp_params->conf, ENABLED);
|
||||
attr->accept_all_vlan = dpsw_get_field(rsp_params->conf,
|
||||
ACCEPT_ALL_VLAN);
|
||||
attr->admit_untagged = dpsw_get_field(rsp_params->conf,
|
||||
ADMIT_UNTAGGED);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* dpsw_if_set_max_frame_length() - Set Maximum Receive frame length.
|
||||
* @mc_io: Pointer to MC portal's I/O object
|
||||
@ -945,6 +924,66 @@ int dpsw_vlan_remove(struct fsl_mc_io *mc_io,
|
||||
return mc_send_command(mc_io, &cmd);
|
||||
}
|
||||
|
||||
/**
|
||||
* dpsw_fdb_add() - Add FDB to switch and Returns handle to FDB table for
|
||||
* the reference
|
||||
* @mc_io: Pointer to MC portal's I/O object
|
||||
* @cmd_flags: Command flags; one or more of 'MC_CMD_FLAG_'
|
||||
* @token: Token of DPSW object
|
||||
* @fdb_id: Returned Forwarding Database Identifier
|
||||
* @cfg: FDB Configuration
|
||||
*
|
||||
* Return: Completion status. '0' on Success; Error code otherwise.
|
||||
*/
|
||||
int dpsw_fdb_add(struct fsl_mc_io *mc_io, u32 cmd_flags, u16 token, u16 *fdb_id,
|
||||
const struct dpsw_fdb_cfg *cfg)
|
||||
{
|
||||
struct dpsw_cmd_fdb_add *cmd_params;
|
||||
struct dpsw_rsp_fdb_add *rsp_params;
|
||||
struct fsl_mc_command cmd = { 0 };
|
||||
int err;
|
||||
|
||||
cmd.header = mc_encode_cmd_header(DPSW_CMDID_FDB_ADD,
|
||||
cmd_flags,
|
||||
token);
|
||||
cmd_params = (struct dpsw_cmd_fdb_add *)cmd.params;
|
||||
cmd_params->fdb_ageing_time = cpu_to_le16(cfg->fdb_ageing_time);
|
||||
cmd_params->num_fdb_entries = cpu_to_le16(cfg->num_fdb_entries);
|
||||
|
||||
err = mc_send_command(mc_io, &cmd);
|
||||
if (err)
|
||||
return err;
|
||||
|
||||
rsp_params = (struct dpsw_rsp_fdb_add *)cmd.params;
|
||||
*fdb_id = le16_to_cpu(rsp_params->fdb_id);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* dpsw_fdb_remove() - Remove FDB from switch
|
||||
* @mc_io: Pointer to MC portal's I/O object
|
||||
* @cmd_flags: Command flags; one or more of 'MC_CMD_FLAG_'
|
||||
* @token: Token of DPSW object
|
||||
* @fdb_id: Forwarding Database Identifier
|
||||
*
|
||||
* Return: Completion status. '0' on Success; Error code otherwise.
|
||||
*/
|
||||
int dpsw_fdb_remove(struct fsl_mc_io *mc_io, u32 cmd_flags, u16 token, u16 fdb_id)
|
||||
{
|
||||
struct dpsw_cmd_fdb_remove *cmd_params;
|
||||
struct fsl_mc_command cmd = { 0 };
|
||||
|
||||
/* prepare command */
|
||||
cmd.header = mc_encode_cmd_header(DPSW_CMDID_FDB_REMOVE,
|
||||
cmd_flags,
|
||||
token);
|
||||
cmd_params = (struct dpsw_cmd_fdb_remove *)cmd.params;
|
||||
cmd_params->fdb_id = cpu_to_le16(fdb_id);
|
||||
|
||||
return mc_send_command(mc_io, &cmd);
|
||||
}
|
||||
|
||||
/**
|
||||
* dpsw_fdb_add_unicast() - Function adds an unicast entry into MAC lookup table
|
||||
* @mc_io: Pointer to MC portal's I/O object
|
||||
@ -1152,33 +1191,97 @@ int dpsw_fdb_remove_multicast(struct fsl_mc_io *mc_io,
|
||||
}
|
||||
|
||||
/**
|
||||
* dpsw_fdb_set_learning_mode() - Define FDB learning mode
|
||||
* dpsw_ctrl_if_get_attributes() - Obtain control interface attributes
|
||||
* @mc_io: Pointer to MC portal's I/O object
|
||||
* @cmd_flags: Command flags; one or more of 'MC_CMD_FLAG_'
|
||||
* @token: Token of DPSW object
|
||||
* @fdb_id: Forwarding Database Identifier
|
||||
* @mode: Learning mode
|
||||
* @attr: Returned control interface attributes
|
||||
*
|
||||
* Return: Completion status. '0' on Success; Error code otherwise.
|
||||
* Return: '0' on Success; Error code otherwise.
|
||||
*/
|
||||
int dpsw_fdb_set_learning_mode(struct fsl_mc_io *mc_io,
|
||||
u32 cmd_flags,
|
||||
u16 token,
|
||||
u16 fdb_id,
|
||||
enum dpsw_fdb_learning_mode mode)
|
||||
int dpsw_ctrl_if_get_attributes(struct fsl_mc_io *mc_io, u32 cmd_flags,
|
||||
u16 token, struct dpsw_ctrl_if_attr *attr)
|
||||
{
|
||||
struct dpsw_rsp_ctrl_if_get_attr *rsp_params;
|
||||
struct fsl_mc_command cmd = { 0 };
|
||||
struct dpsw_cmd_fdb_set_learning_mode *cmd_params;
|
||||
int err;
|
||||
|
||||
/* prepare command */
|
||||
cmd.header = mc_encode_cmd_header(DPSW_CMDID_FDB_SET_LEARNING_MODE,
|
||||
cmd.header = mc_encode_cmd_header(DPSW_CMDID_CTRL_IF_GET_ATTR,
|
||||
cmd_flags, token);
|
||||
|
||||
err = mc_send_command(mc_io, &cmd);
|
||||
if (err)
|
||||
return err;
|
||||
|
||||
rsp_params = (struct dpsw_rsp_ctrl_if_get_attr *)cmd.params;
|
||||
attr->rx_fqid = le32_to_cpu(rsp_params->rx_fqid);
|
||||
attr->rx_err_fqid = le32_to_cpu(rsp_params->rx_err_fqid);
|
||||
attr->tx_err_conf_fqid = le32_to_cpu(rsp_params->tx_err_conf_fqid);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* dpsw_ctrl_if_set_pools() - Set control interface buffer pools
|
||||
* @mc_io: Pointer to MC portal's I/O object
|
||||
* @cmd_flags: Command flags; one or more of 'MC_CMD_FLAG_'
|
||||
* @token: Token of DPSW object
|
||||
* @cfg: Buffer pools configuration
|
||||
*
|
||||
* Return: '0' on Success; Error code otherwise.
|
||||
*/
|
||||
int dpsw_ctrl_if_set_pools(struct fsl_mc_io *mc_io, u32 cmd_flags, u16 token,
|
||||
const struct dpsw_ctrl_if_pools_cfg *cfg)
|
||||
{
|
||||
struct dpsw_cmd_ctrl_if_set_pools *cmd_params;
|
||||
struct fsl_mc_command cmd = { 0 };
|
||||
int i;
|
||||
|
||||
cmd.header = mc_encode_cmd_header(DPSW_CMDID_CTRL_IF_SET_POOLS,
|
||||
cmd_flags, token);
|
||||
cmd_params = (struct dpsw_cmd_ctrl_if_set_pools *)cmd.params;
|
||||
cmd_params->num_dpbp = cfg->num_dpbp;
|
||||
for (i = 0; i < DPSW_MAX_DPBP; i++) {
|
||||
cmd_params->dpbp_id[i] = cpu_to_le32(cfg->pools[i].dpbp_id);
|
||||
cmd_params->buffer_size[i] =
|
||||
cpu_to_le16(cfg->pools[i].buffer_size);
|
||||
cmd_params->backup_pool_mask |=
|
||||
DPSW_BACKUP_POOL(cfg->pools[i].backup_pool, i);
|
||||
}
|
||||
|
||||
return mc_send_command(mc_io, &cmd);
|
||||
}
|
||||
|
||||
/**
|
||||
* dpsw_ctrl_if_set_queue() - Set Rx queue configuration
|
||||
* @mc_io: Pointer to MC portal's I/O object
|
||||
* @cmd_flags: Command flags; one or more of 'MC_CMD_FLAG_'
|
||||
* @token: Token of dpsw object
|
||||
* @qtype: dpsw_queue_type of the targeted queue
|
||||
* @cfg: Rx queue configuration
|
||||
*
|
||||
* Return: '0' on Success; Error code otherwise.
|
||||
*/
|
||||
int dpsw_ctrl_if_set_queue(struct fsl_mc_io *mc_io, u32 cmd_flags, u16 token,
|
||||
enum dpsw_queue_type qtype,
|
||||
const struct dpsw_ctrl_if_queue_cfg *cfg)
|
||||
{
|
||||
struct dpsw_cmd_ctrl_if_set_queue *cmd_params;
|
||||
struct fsl_mc_command cmd = { 0 };
|
||||
|
||||
cmd.header = mc_encode_cmd_header(DPSW_CMDID_CTRL_IF_SET_QUEUE,
|
||||
cmd_flags,
|
||||
token);
|
||||
cmd_params = (struct dpsw_cmd_fdb_set_learning_mode *)cmd.params;
|
||||
cmd_params->fdb_id = cpu_to_le16(fdb_id);
|
||||
dpsw_set_field(cmd_params->mode, LEARNING_MODE, mode);
|
||||
cmd_params = (struct dpsw_cmd_ctrl_if_set_queue *)cmd.params;
|
||||
cmd_params->dest_id = cpu_to_le32(cfg->dest_cfg.dest_id);
|
||||
cmd_params->dest_priority = cfg->dest_cfg.priority;
|
||||
cmd_params->qtype = qtype;
|
||||
cmd_params->user_ctx = cpu_to_le64(cfg->user_ctx);
|
||||
cmd_params->options = cpu_to_le32(cfg->options);
|
||||
dpsw_set_field(cmd_params->dest_type,
|
||||
DEST_TYPE,
|
||||
cfg->dest_cfg.dest_type);
|
||||
|
||||
/* send command to mc*/
|
||||
return mc_send_command(mc_io, &cmd);
|
||||
}
|
||||
|
||||
@ -1320,3 +1423,64 @@ int dpsw_if_set_primary_mac_addr(struct fsl_mc_io *mc_io, u32 cmd_flags,
|
||||
/* send command to mc*/
|
||||
return mc_send_command(mc_io, &cmd);
|
||||
}
|
||||
|
||||
/**
|
||||
* dpsw_ctrl_if_enable() - Enable control interface
|
||||
* @mc_io: Pointer to MC portal's I/O object
|
||||
* @cmd_flags: Command flags; one or more of 'MC_CMD_FLAG_'
|
||||
* @token: Token of DPSW object
|
||||
*
|
||||
* Return: '0' on Success; Error code otherwise.
|
||||
*/
|
||||
int dpsw_ctrl_if_enable(struct fsl_mc_io *mc_io, u32 cmd_flags, u16 token)
|
||||
{
|
||||
struct fsl_mc_command cmd = { 0 };
|
||||
|
||||
cmd.header = mc_encode_cmd_header(DPSW_CMDID_CTRL_IF_ENABLE, cmd_flags,
|
||||
token);
|
||||
|
||||
return mc_send_command(mc_io, &cmd);
|
||||
}
|
||||
|
||||
/**
|
||||
* dpsw_ctrl_if_disable() - Function disables control interface
|
||||
* @mc_io: Pointer to MC portal's I/O object
|
||||
* @cmd_flags: Command flags; one or more of 'MC_CMD_FLAG_'
|
||||
* @token: Token of DPSW object
|
||||
*
|
||||
* Return: '0' on Success; Error code otherwise.
|
||||
*/
|
||||
int dpsw_ctrl_if_disable(struct fsl_mc_io *mc_io, u32 cmd_flags, u16 token)
|
||||
{
|
||||
struct fsl_mc_command cmd = { 0 };
|
||||
|
||||
cmd.header = mc_encode_cmd_header(DPSW_CMDID_CTRL_IF_DISABLE,
|
||||
cmd_flags,
|
||||
token);
|
||||
|
||||
return mc_send_command(mc_io, &cmd);
|
||||
}
|
||||
|
||||
/**
|
||||
* dpsw_set_egress_flood() - Set egress parameters associated with an FDB ID
|
||||
* @mc_io: Pointer to MC portal's I/O object
|
||||
* @cmd_flags: Command flags; one or more of 'MC_CMD_FLAG_'
|
||||
* @token: Token of DPSW object
|
||||
* @cfg: Egress flooding configuration
|
||||
*
|
||||
* Return: '0' on Success; Error code otherwise.
|
||||
*/
|
||||
int dpsw_set_egress_flood(struct fsl_mc_io *mc_io, u32 cmd_flags, u16 token,
|
||||
const struct dpsw_egress_flood_cfg *cfg)
|
||||
{
|
||||
struct dpsw_cmd_set_egress_flood *cmd_params;
|
||||
struct fsl_mc_command cmd = { 0 };
|
||||
|
||||
cmd.header = mc_encode_cmd_header(DPSW_CMDID_SET_EGRESS_FLOOD, cmd_flags, token);
|
||||
cmd_params = (struct dpsw_cmd_set_egress_flood *)cmd.params;
|
||||
cmd_params->fdb_id = cpu_to_le16(cfg->fdb_id);
|
||||
cmd_params->flood_type = cfg->flood_type;
|
||||
build_if_id_bitmap(&cmd_params->if_id, cfg->if_id, cfg->num_ifs);
|
||||
|
||||
return mc_send_command(mc_io, &cmd);
|
||||
}
|
@ -1,7 +1,7 @@
|
||||
/* SPDX-License-Identifier: GPL-2.0 */
|
||||
/*
|
||||
* Copyright 2014-2016 Freescale Semiconductor Inc.
|
||||
* Copyright 2017-2018 NXP
|
||||
* Copyright 2017-2021 NXP
|
||||
*
|
||||
*/
|
||||
|
||||
@ -75,6 +75,35 @@ enum dpsw_component_type {
|
||||
DPSW_COMPONENT_TYPE_S_VLAN
|
||||
};
|
||||
|
||||
/**
|
||||
* enum dpsw_flooding_cfg - flooding configuration requested
|
||||
* @DPSW_FLOODING_PER_VLAN: Flooding replicators are allocated per VLAN and
|
||||
* interfaces present in each of them can be configured using
|
||||
* dpsw_vlan_add_if_flooding()/dpsw_vlan_remove_if_flooding().
|
||||
* This is the default configuration.
|
||||
*
|
||||
* @DPSW_FLOODING_PER_FDB: Flooding replicators are allocated per FDB and
|
||||
* interfaces present in each of them can be configured using
|
||||
* dpsw_set_egress_flood().
|
||||
*/
|
||||
enum dpsw_flooding_cfg {
|
||||
DPSW_FLOODING_PER_VLAN = 0,
|
||||
DPSW_FLOODING_PER_FDB,
|
||||
};
|
||||
|
||||
/**
|
||||
* enum dpsw_broadcast_cfg - broadcast configuration requested
|
||||
* @DPSW_BROADCAST_PER_OBJECT: There is only one broadcast replicator per DPSW
|
||||
* object. This is the default configuration.
|
||||
* @DPSW_BROADCAST_PER_FDB: Broadcast replicators are allocated per FDB and
|
||||
* interfaces present in each of them can be configured using
|
||||
* dpsw_set_egress_flood().
|
||||
*/
|
||||
enum dpsw_broadcast_cfg {
|
||||
DPSW_BROADCAST_PER_OBJECT = 0,
|
||||
DPSW_BROADCAST_PER_FDB,
|
||||
};
|
||||
|
||||
int dpsw_enable(struct fsl_mc_io *mc_io,
|
||||
u32 cmd_flags,
|
||||
u16 token);
|
||||
@ -153,6 +182,8 @@ int dpsw_clear_irq_status(struct fsl_mc_io *mc_io,
|
||||
* @num_vlans: Current number of VLANs
|
||||
* @num_fdbs: Current number of FDBs
|
||||
* @component_type: Component type of this bridge
|
||||
* @flooding_cfg: Flooding configuration (PER_VLAN - default, PER_FDB)
|
||||
* @broadcast_cfg: Broadcast configuration (PER_OBJECT - default, PER_FDB)
|
||||
*/
|
||||
struct dpsw_attr {
|
||||
int id;
|
||||
@ -168,6 +199,8 @@ struct dpsw_attr {
|
||||
u16 num_vlans;
|
||||
u8 num_fdbs;
|
||||
enum dpsw_component_type component_type;
|
||||
enum dpsw_flooding_cfg flooding_cfg;
|
||||
enum dpsw_broadcast_cfg broadcast_cfg;
|
||||
};
|
||||
|
||||
int dpsw_get_attributes(struct fsl_mc_io *mc_io,
|
||||
@ -175,6 +208,81 @@ int dpsw_get_attributes(struct fsl_mc_io *mc_io,
|
||||
u16 token,
|
||||
struct dpsw_attr *attr);
|
||||
|
||||
/**
|
||||
* struct dpsw_ctrl_if_attr - Control interface attributes
|
||||
* @rx_fqid: Receive FQID
|
||||
* @rx_err_fqid: Receive error FQID
|
||||
* @tx_err_conf_fqid: Transmit error and confirmation FQID
|
||||
*/
|
||||
struct dpsw_ctrl_if_attr {
|
||||
u32 rx_fqid;
|
||||
u32 rx_err_fqid;
|
||||
u32 tx_err_conf_fqid;
|
||||
};
|
||||
|
||||
int dpsw_ctrl_if_get_attributes(struct fsl_mc_io *mc_io, u32 cmd_flags,
|
||||
u16 token, struct dpsw_ctrl_if_attr *attr);
|
||||
|
||||
enum dpsw_queue_type {
|
||||
DPSW_QUEUE_RX,
|
||||
DPSW_QUEUE_TX_ERR_CONF,
|
||||
DPSW_QUEUE_RX_ERR,
|
||||
};
|
||||
|
||||
/**
|
||||
* Maximum number of DPBP
|
||||
*/
|
||||
#define DPSW_MAX_DPBP 8
|
||||
|
||||
/**
|
||||
* struct dpsw_ctrl_if_pools_cfg - Control interface buffer pools configuration
|
||||
* @num_dpbp: Number of DPBPs
|
||||
* @pools: Array of buffer pools parameters; The number of valid entries
|
||||
* must match 'num_dpbp' value
|
||||
* @pools.dpbp_id: DPBP object ID
|
||||
* @pools.buffer_size: Buffer size
|
||||
* @pools.backup_pool: Backup pool
|
||||
*/
|
||||
struct dpsw_ctrl_if_pools_cfg {
|
||||
u8 num_dpbp;
|
||||
struct {
|
||||
int dpbp_id;
|
||||
u16 buffer_size;
|
||||
int backup_pool;
|
||||
} pools[DPSW_MAX_DPBP];
|
||||
};
|
||||
|
||||
int dpsw_ctrl_if_set_pools(struct fsl_mc_io *mc_io, u32 cmd_flags, u16 token,
|
||||
const struct dpsw_ctrl_if_pools_cfg *cfg);
|
||||
|
||||
#define DPSW_CTRL_IF_QUEUE_OPT_USER_CTX 0x00000001
|
||||
#define DPSW_CTRL_IF_QUEUE_OPT_DEST 0x00000002
|
||||
|
||||
enum dpsw_ctrl_if_dest {
|
||||
DPSW_CTRL_IF_DEST_NONE = 0,
|
||||
DPSW_CTRL_IF_DEST_DPIO = 1,
|
||||
};
|
||||
|
||||
struct dpsw_ctrl_if_dest_cfg {
|
||||
enum dpsw_ctrl_if_dest dest_type;
|
||||
int dest_id;
|
||||
u8 priority;
|
||||
};
|
||||
|
||||
struct dpsw_ctrl_if_queue_cfg {
|
||||
u32 options;
|
||||
u64 user_ctx;
|
||||
struct dpsw_ctrl_if_dest_cfg dest_cfg;
|
||||
};
|
||||
|
||||
int dpsw_ctrl_if_set_queue(struct fsl_mc_io *mc_io, u32 cmd_flags, u16 token,
|
||||
enum dpsw_queue_type qtype,
|
||||
const struct dpsw_ctrl_if_queue_cfg *cfg);
|
||||
|
||||
int dpsw_ctrl_if_enable(struct fsl_mc_io *mc_io, u32 cmd_flags, u16 token);
|
||||
|
||||
int dpsw_ctrl_if_disable(struct fsl_mc_io *mc_io, u32 cmd_flags, u16 token);
|
||||
|
||||
/**
|
||||
* enum dpsw_action - Action selection for special/control frames
|
||||
* @DPSW_ACTION_DROP: Drop frame
|
||||
@ -235,18 +343,6 @@ int dpsw_if_get_link_state(struct fsl_mc_io *mc_io,
|
||||
u16 if_id,
|
||||
struct dpsw_link_state *state);
|
||||
|
||||
int dpsw_if_set_flooding(struct fsl_mc_io *mc_io,
|
||||
u32 cmd_flags,
|
||||
u16 token,
|
||||
u16 if_id,
|
||||
u8 en);
|
||||
|
||||
int dpsw_if_set_broadcast(struct fsl_mc_io *mc_io,
|
||||
u32 cmd_flags,
|
||||
u16 token,
|
||||
u16 if_id,
|
||||
u8 en);
|
||||
|
||||
/**
|
||||
* struct dpsw_tci_cfg - Tag Control Information (TCI) configuration
|
||||
* @pcp: Priority Code Point (PCP): a 3-bit field which refers
|
||||
@ -372,6 +468,34 @@ int dpsw_if_disable(struct fsl_mc_io *mc_io,
|
||||
u16 token,
|
||||
u16 if_id);
|
||||
|
||||
/**
|
||||
* struct dpsw_if_attr - Structure representing DPSW interface attributes
|
||||
* @num_tcs: Number of traffic classes
|
||||
* @rate: Transmit rate in bits per second
|
||||
* @options: Interface configuration options (bitmap)
|
||||
* @enabled: Indicates if interface is enabled
|
||||
* @accept_all_vlan: The device discards/accepts incoming frames
|
||||
* for VLANs that do not include this interface
|
||||
* @admit_untagged: When set to 'DPSW_ADMIT_ONLY_VLAN_TAGGED', the device
|
||||
* discards untagged frames or priority-tagged frames received on
|
||||
* this interface;
|
||||
* When set to 'DPSW_ADMIT_ALL', untagged frames or priority-
|
||||
* tagged frames received on this interface are accepted
|
||||
* @qdid: control frames transmit qdid
|
||||
*/
|
||||
struct dpsw_if_attr {
|
||||
u8 num_tcs;
|
||||
u32 rate;
|
||||
u32 options;
|
||||
int enabled;
|
||||
int accept_all_vlan;
|
||||
enum dpsw_accepted_frames admit_untagged;
|
||||
u16 qdid;
|
||||
};
|
||||
|
||||
int dpsw_if_get_attributes(struct fsl_mc_io *mc_io, u32 cmd_flags, u16 token,
|
||||
u16 if_id, struct dpsw_if_attr *attr);
|
||||
|
||||
int dpsw_if_set_max_frame_length(struct fsl_mc_io *mc_io,
|
||||
u32 cmd_flags,
|
||||
u16 token,
|
||||
@ -392,6 +516,8 @@ int dpsw_vlan_add(struct fsl_mc_io *mc_io,
|
||||
u16 vlan_id,
|
||||
const struct dpsw_vlan_cfg *cfg);
|
||||
|
||||
#define DPSW_VLAN_ADD_IF_OPT_FDB_ID 0x0001
|
||||
|
||||
/**
|
||||
* struct dpsw_vlan_if_cfg - Set of VLAN Interfaces
|
||||
* @num_ifs: The number of interfaces that are assigned to the egress
|
||||
@ -401,7 +527,9 @@ int dpsw_vlan_add(struct fsl_mc_io *mc_io,
|
||||
*/
|
||||
struct dpsw_vlan_if_cfg {
|
||||
u16 num_ifs;
|
||||
u16 options;
|
||||
u16 if_id[DPSW_MAX_IF];
|
||||
u16 fdb_id;
|
||||
};
|
||||
|
||||
int dpsw_vlan_add_if(struct fsl_mc_io *mc_io,
|
||||
@ -555,23 +683,17 @@ enum dpsw_fdb_learning_mode {
|
||||
DPSW_FDB_LEARNING_MODE_SECURE = 3
|
||||
};
|
||||
|
||||
int dpsw_fdb_set_learning_mode(struct fsl_mc_io *mc_io,
|
||||
u32 cmd_flags,
|
||||
u16 token,
|
||||
u16 fdb_id,
|
||||
enum dpsw_fdb_learning_mode mode);
|
||||
|
||||
/**
|
||||
* struct dpsw_fdb_attr - FDB Attributes
|
||||
* @max_fdb_entries: Number of FDB entries
|
||||
* @fdb_aging_time: Aging time in seconds
|
||||
* @fdb_ageing_time: Ageing time in seconds
|
||||
* @learning_mode: Learning mode
|
||||
* @num_fdb_mc_groups: Current number of multicast groups
|
||||
* @max_fdb_mc_groups: Maximum number of multicast groups
|
||||
*/
|
||||
struct dpsw_fdb_attr {
|
||||
u16 max_fdb_entries;
|
||||
u16 fdb_aging_time;
|
||||
u16 fdb_ageing_time;
|
||||
enum dpsw_fdb_learning_mode learning_mode;
|
||||
u16 num_fdb_mc_groups;
|
||||
u16 max_fdb_mc_groups;
|
||||
@ -591,4 +713,39 @@ int dpsw_if_get_primary_mac_addr(struct fsl_mc_io *mc_io, u32 cmd_flags,
|
||||
int dpsw_if_set_primary_mac_addr(struct fsl_mc_io *mc_io, u32 cmd_flags,
|
||||
u16 token, u16 if_id, u8 mac_addr[6]);
|
||||
|
||||
/**
|
||||
* struct dpsw_fdb_cfg - FDB Configuration
|
||||
* @num_fdb_entries: Number of FDB entries
|
||||
* @fdb_ageing_time: Ageing time in seconds
|
||||
*/
|
||||
struct dpsw_fdb_cfg {
|
||||
u16 num_fdb_entries;
|
||||
u16 fdb_ageing_time;
|
||||
};
|
||||
|
||||
int dpsw_fdb_add(struct fsl_mc_io *mc_io, u32 cmd_flags, u16 token, u16 *fdb_id,
|
||||
const struct dpsw_fdb_cfg *cfg);
|
||||
|
||||
int dpsw_fdb_remove(struct fsl_mc_io *mc_io, u32 cmd_flags, u16 token, u16 fdb_id);
|
||||
|
||||
/**
|
||||
* enum dpsw_flood_type - Define the flood type of a DPSW object
|
||||
* @DPSW_BROADCAST: Broadcast flooding
|
||||
* @DPSW_FLOODING: Unknown flooding
|
||||
*/
|
||||
enum dpsw_flood_type {
|
||||
DPSW_BROADCAST = 0,
|
||||
DPSW_FLOODING,
|
||||
};
|
||||
|
||||
struct dpsw_egress_flood_cfg {
|
||||
u16 fdb_id;
|
||||
enum dpsw_flood_type flood_type;
|
||||
u16 num_ifs;
|
||||
u16 if_id[DPSW_MAX_IF];
|
||||
};
|
||||
|
||||
int dpsw_set_egress_flood(struct fsl_mc_io *mc_io, u32 cmd_flags, u16 token,
|
||||
const struct dpsw_egress_flood_cfg *cfg);
|
||||
|
||||
#endif /* __FSL_DPSW_H */
|
@ -78,8 +78,6 @@ source "drivers/staging/clocking-wizard/Kconfig"
|
||||
|
||||
source "drivers/staging/fbtft/Kconfig"
|
||||
|
||||
source "drivers/staging/fsl-dpaa2/Kconfig"
|
||||
|
||||
source "drivers/staging/most/Kconfig"
|
||||
|
||||
source "drivers/staging/ks7010/Kconfig"
|
||||
|
@ -29,7 +29,6 @@ obj-$(CONFIG_GS_FPGABOOT) += gs_fpgaboot/
|
||||
obj-$(CONFIG_UNISYSSPAR) += unisys/
|
||||
obj-$(CONFIG_COMMON_CLK_XLNX_CLKWZRD) += clocking-wizard/
|
||||
obj-$(CONFIG_FB_TFT) += fbtft/
|
||||
obj-$(CONFIG_FSL_DPAA2) += fsl-dpaa2/
|
||||
obj-$(CONFIG_MOST) += most/
|
||||
obj-$(CONFIG_KS7010) += ks7010/
|
||||
obj-$(CONFIG_GREYBUS) += greybus/
|
||||
|
@ -1,19 +0,0 @@
|
||||
# SPDX-License-Identifier: GPL-2.0
|
||||
#
|
||||
# Freescale DataPath Acceleration Architecture Gen2 (DPAA2) drivers
|
||||
#
|
||||
|
||||
config FSL_DPAA2
|
||||
bool "Freescale DPAA2 devices"
|
||||
depends on FSL_MC_BUS
|
||||
help
|
||||
Build drivers for Freescale DataPath Acceleration
|
||||
Architecture (DPAA2) family of SoCs.
|
||||
|
||||
config FSL_DPAA2_ETHSW
|
||||
tristate "Freescale DPAA2 Ethernet Switch"
|
||||
depends on FSL_DPAA2
|
||||
depends on NET_SWITCHDEV
|
||||
help
|
||||
Driver for Freescale DPAA2 Ethernet Switch. Select
|
||||
BRIDGE to have support for bridge tools.
|
@ -1,6 +0,0 @@
|
||||
# SPDX-License-Identifier: GPL-2.0
|
||||
#
|
||||
# Freescale DataPath Acceleration Architecture Gen2 (DPAA2) drivers
|
||||
#
|
||||
|
||||
obj-$(CONFIG_FSL_DPAA2_ETHSW) += ethsw/
|
@ -1,10 +0,0 @@
|
||||
# SPDX-License-Identifier: GPL-2.0
|
||||
#
|
||||
# Makefile for the Freescale DPAA2 Ethernet Switch
|
||||
#
|
||||
# Copyright 2014-2017 Freescale Semiconductor Inc.
|
||||
# Copyright 2017-2018 NXP
|
||||
|
||||
obj-$(CONFIG_FSL_DPAA2_ETHSW) += dpaa2-ethsw.o
|
||||
|
||||
dpaa2-ethsw-objs := ethsw.o ethsw-ethtool.o dpsw.o
|
@ -1,106 +0,0 @@
|
||||
DPAA2 Ethernet Switch driver
|
||||
============================
|
||||
|
||||
This file provides documentation for the DPAA2 Ethernet Switch driver
|
||||
|
||||
|
||||
Contents
|
||||
========
|
||||
Supported Platforms
|
||||
Architecture Overview
|
||||
Creating an Ethernet Switch
|
||||
Features
|
||||
|
||||
|
||||
Supported Platforms
|
||||
===================
|
||||
This driver provides networking support for Freescale LS2085A, LS2088A
|
||||
DPAA2 SoCs.
|
||||
|
||||
|
||||
Architecture Overview
|
||||
=====================
|
||||
The Ethernet Switch in the DPAA2 architecture consists of several hardware
|
||||
resources that provide the functionality. These are allocated and
|
||||
configured via the Management Complex (MC) portals. MC abstracts most of
|
||||
these resources as DPAA2 objects and exposes ABIs through which they can
|
||||
be configured and controlled.
|
||||
|
||||
For a more detailed description of the DPAA2 architecture and its object
|
||||
abstractions see:
|
||||
drivers/staging/fsl-mc/README.txt
|
||||
|
||||
The Ethernet Switch is built on top of a Datapath Switch (DPSW) object.
|
||||
|
||||
Configuration interface:
|
||||
|
||||
---------------------
|
||||
| DPAA2 Switch driver |
|
||||
---------------------
|
||||
.
|
||||
.
|
||||
----------
|
||||
| DPSW API |
|
||||
----------
|
||||
. software
|
||||
================= . ==============
|
||||
. hardware
|
||||
---------------------
|
||||
| MC hardware portals |
|
||||
---------------------
|
||||
.
|
||||
.
|
||||
------
|
||||
| DPSW |
|
||||
------
|
||||
|
||||
Driver uses the switch device driver model and exposes each switch port as
|
||||
a network interface, which can be included in a bridge. Traffic switched
|
||||
between ports is offloaded into the hardware. Exposed network interfaces
|
||||
are not used for I/O, they are used just for configuration. This
|
||||
limitation is going to be addressed in the future.
|
||||
|
||||
The DPSW can have ports connected to DPNIs or to PHYs via DPMACs.
|
||||
|
||||
|
||||
[ethA] [ethB] [ethC] [ethD] [ethE] [ethF]
|
||||
: : : : : :
|
||||
: : : : : :
|
||||
[eth drv] [eth drv] [ ethsw drv ]
|
||||
: : : : : : kernel
|
||||
========================================================================
|
||||
: : : : : : hardware
|
||||
[DPNI] [DPNI] [============= DPSW =================]
|
||||
| | | | | |
|
||||
| ---------- | [DPMAC] [DPMAC]
|
||||
------------------------------- | |
|
||||
| |
|
||||
[PHY] [PHY]
|
||||
|
||||
For a more detailed description of the Ethernet switch device driver model
|
||||
see:
|
||||
Documentation/networking/switchdev.rst
|
||||
|
||||
Creating an Ethernet Switch
|
||||
===========================
|
||||
A device is created for the switch objects probed on the MC bus. Each DPSW
|
||||
has a number of properties which determine the configuration options and
|
||||
associated hardware resources.
|
||||
|
||||
A DPSW object (and the other DPAA2 objects needed for a DPAA2 switch) can
|
||||
be added to a container on the MC bus in one of two ways: statically,
|
||||
through a Datapath Layout Binary file (DPL) that is parsed by MC at boot
|
||||
time; or created dynamically at runtime, via the DPAA2 objects APIs.
|
||||
|
||||
Features
|
||||
========
|
||||
Driver configures DPSW to perform hardware switching offload of
|
||||
unicast/multicast/broadcast (VLAN tagged or untagged) traffic between its
|
||||
ports.
|
||||
|
||||
It allows configuration of hardware learning, flooding, multicast groups,
|
||||
port VLAN configuration and STP state.
|
||||
|
||||
Static entries can be added/removed from the FDB.
|
||||
|
||||
Hardware statistics for each port are provided through ethtool -S option.
|
@ -1,13 +0,0 @@
|
||||
* Add I/O capabilities on switch port netdevices. This will allow control
|
||||
traffic to reach the CPU.
|
||||
* Add ACL to redirect control traffic to CPU.
|
||||
* Add support for multiple FDBs and switch port partitioning
|
||||
* MC firmware uprev; the DPAA2 objects used by the Ethernet Switch driver
|
||||
need to be kept in sync with binary interface changes in MC
|
||||
* refine README file
|
||||
* cleanup
|
||||
|
||||
NOTE: At least first three of the above are required before getting the
|
||||
DPAA2 Ethernet Switch driver out of staging. Another requirement is that
|
||||
dpio driver is moved to drivers/soc (this is required for I/O).
|
||||
|
@ -1,80 +0,0 @@
|
||||
/* SPDX-License-Identifier: GPL-2.0 */
|
||||
/*
|
||||
* DPAA2 Ethernet Switch declarations
|
||||
*
|
||||
* Copyright 2014-2016 Freescale Semiconductor Inc.
|
||||
* Copyright 2017-2018 NXP
|
||||
*
|
||||
*/
|
||||
|
||||
#ifndef __ETHSW_H
|
||||
#define __ETHSW_H
|
||||
|
||||
#include <linux/netdevice.h>
|
||||
#include <linux/etherdevice.h>
|
||||
#include <linux/rtnetlink.h>
|
||||
#include <linux/if_vlan.h>
|
||||
#include <uapi/linux/if_bridge.h>
|
||||
#include <net/switchdev.h>
|
||||
#include <linux/if_bridge.h>
|
||||
|
||||
#include "dpsw.h"
|
||||
|
||||
/* Number of IRQs supported */
|
||||
#define DPSW_IRQ_NUM 2
|
||||
|
||||
/* Port is member of VLAN */
|
||||
#define ETHSW_VLAN_MEMBER 1
|
||||
/* VLAN to be treated as untagged on egress */
|
||||
#define ETHSW_VLAN_UNTAGGED 2
|
||||
/* Untagged frames will be assigned to this VLAN */
|
||||
#define ETHSW_VLAN_PVID 4
|
||||
/* VLAN configured on the switch */
|
||||
#define ETHSW_VLAN_GLOBAL 8
|
||||
|
||||
/* Maximum Frame Length supported by HW (currently 10k) */
|
||||
#define DPAA2_MFL (10 * 1024)
|
||||
#define ETHSW_MAX_FRAME_LENGTH (DPAA2_MFL - VLAN_ETH_HLEN - ETH_FCS_LEN)
|
||||
#define ETHSW_L2_MAX_FRM(mtu) ((mtu) + VLAN_ETH_HLEN + ETH_FCS_LEN)
|
||||
|
||||
#define ETHSW_FEATURE_MAC_ADDR BIT(0)
|
||||
|
||||
extern const struct ethtool_ops dpaa2_switch_port_ethtool_ops;
|
||||
|
||||
struct ethsw_core;
|
||||
|
||||
/* Per port private data */
|
||||
struct ethsw_port_priv {
|
||||
struct net_device *netdev;
|
||||
u16 idx;
|
||||
struct ethsw_core *ethsw_data;
|
||||
u8 link_state;
|
||||
u8 stp_state;
|
||||
bool flood;
|
||||
|
||||
u8 vlans[VLAN_VID_MASK + 1];
|
||||
u16 pvid;
|
||||
struct net_device *bridge_dev;
|
||||
};
|
||||
|
||||
/* Switch data */
|
||||
struct ethsw_core {
|
||||
struct device *dev;
|
||||
struct fsl_mc_io *mc_io;
|
||||
u16 dpsw_handle;
|
||||
struct dpsw_attr sw_attr;
|
||||
u16 major, minor;
|
||||
unsigned long features;
|
||||
int dev_id;
|
||||
struct ethsw_port_priv **ports;
|
||||
|
||||
u8 vlans[VLAN_VID_MASK + 1];
|
||||
bool learning;
|
||||
|
||||
struct notifier_block port_nb;
|
||||
struct notifier_block port_switchdev_nb;
|
||||
struct notifier_block port_switchdevb_nb;
|
||||
struct workqueue_struct *workqueue;
|
||||
};
|
||||
|
||||
#endif /* __ETHSW_H */
|
Loading…
x
Reference in New Issue
Block a user