| /* SPDX-License-Identifier: GPL-2.0+ */ |
| /* Microchip Sparx5 Switch driver |
| * |
| * Copyright (c) 2022 Microchip Technology Inc. and its subsidiaries. |
| */ |
| |
| #ifndef __SPARX5_TC_H__ |
| #define __SPARX5_TC_H__ |
| |
| #include <net/flow_offload.h> |
| #include <net/pkt_cls.h> |
| #include <linux/netdevice.h> |
| |
| /* Controls how PORT_MASK is applied */ |
| enum SPX5_PORT_MASK_MODE { |
| SPX5_PMM_OR_DSTMASK, |
| SPX5_PMM_AND_VLANMASK, |
| SPX5_PMM_REPLACE_PGID, |
| SPX5_PMM_REPLACE_ALL, |
| SPX5_PMM_REDIR_PGID, |
| SPX5_PMM_OR_PGID_MASK, |
| }; |
| |
| /* Controls ES0 forwarding */ |
| enum SPX5_FORWARDING_SEL { |
| SPX5_FWSEL_NO_ACTION, |
| SPX5_FWSEL_COPY_TO_LOOPBACK, |
| SPX5_FWSEL_REDIRECT_TO_LOOPBACK, |
| SPX5_FWSEL_DISCARD, |
| }; |
| |
| /* Controls tag A (outer tagging) */ |
| enum SPX5_OUTER_TAG_SEL { |
| SPX5_OTAG_PORT, |
| SPX5_OTAG_TAG_A, |
| SPX5_OTAG_FORCED_PORT, |
| SPX5_OTAG_UNTAG, |
| }; |
| |
| /* Selects TPID for ES0 tag A */ |
| enum SPX5_TPID_A_SEL { |
| SPX5_TPID_A_8100, |
| SPX5_TPID_A_88A8, |
| SPX5_TPID_A_CUST1, |
| SPX5_TPID_A_CUST2, |
| SPX5_TPID_A_CUST3, |
| SPX5_TPID_A_CLASSIFIED, |
| }; |
| |
| /* Selects VID for ES0 tag A */ |
| enum SPX5_VID_A_SEL { |
| SPX5_VID_A_CLASSIFIED, |
| SPX5_VID_A_VAL, |
| SPX5_VID_A_IFH, |
| SPX5_VID_A_RESERVED, |
| }; |
| |
| /* Select PCP source for ES0 tag A */ |
| enum SPX5_PCP_A_SEL { |
| SPX5_PCP_A_CLASSIFIED, |
| SPX5_PCP_A_VAL, |
| SPX5_PCP_A_RESERVED, |
| SPX5_PCP_A_POPPED, |
| SPX5_PCP_A_MAPPED_0, |
| SPX5_PCP_A_MAPPED_1, |
| SPX5_PCP_A_MAPPED_2, |
| SPX5_PCP_A_MAPPED_3, |
| }; |
| |
| /* Select DEI source for ES0 tag A */ |
| enum SPX5_DEI_A_SEL { |
| SPX5_DEI_A_CLASSIFIED, |
| SPX5_DEI_A_VAL, |
| SPX5_DEI_A_REW, |
| SPX5_DEI_A_POPPED, |
| SPX5_DEI_A_MAPPED_0, |
| SPX5_DEI_A_MAPPED_1, |
| SPX5_DEI_A_MAPPED_2, |
| SPX5_DEI_A_MAPPED_3, |
| }; |
| |
| /* Controls tag B (inner tagging) */ |
| enum SPX5_INNER_TAG_SEL { |
| SPX5_ITAG_NO_PUSH, |
| SPX5_ITAG_PUSH_B_TAG, |
| }; |
| |
| /* Selects TPID for ES0 tag B. */ |
| enum SPX5_TPID_B_SEL { |
| SPX5_TPID_B_8100, |
| SPX5_TPID_B_88A8, |
| SPX5_TPID_B_CUST1, |
| SPX5_TPID_B_CUST2, |
| SPX5_TPID_B_CUST3, |
| SPX5_TPID_B_CLASSIFIED, |
| }; |
| |
| int sparx5_port_setup_tc(struct net_device *ndev, enum tc_setup_type type, |
| void *type_data); |
| |
| int sparx5_tc_matchall(struct net_device *ndev, |
| struct tc_cls_matchall_offload *tmo, |
| bool ingress); |
| |
| int sparx5_tc_flower(struct net_device *ndev, struct flow_cls_offload *fco, |
| bool ingress); |
| |
| #endif /* __SPARX5_TC_H__ */ |