/* SPDX-License-Identifier: GPL-2.0 */ /* * Copyright 2014-2016 Freescale Semiconductor Inc. * 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 9 #define DPSW_CMD_BASE_VERSION 1 #define DPSW_CMD_VERSION_2 2 #define DPSW_CMD_ID_OFFSET 4 #define DPSW_CMD_ID(id) (((id) << DPSW_CMD_ID_OFFSET) | DPSW_CMD_BASE_VERSION) #define DPSW_CMD_V2(id) (((id) << DPSW_CMD_ID_OFFSET) | DPSW_CMD_VERSION_2) /* Command IDs */ #define DPSW_CMDID_CLOSE DPSW_CMD_ID(0x800) #define DPSW_CMDID_OPEN DPSW_CMD_ID(0x802) #define DPSW_CMDID_GET_API_VERSION DPSW_CMD_ID(0xa02) #define DPSW_CMDID_ENABLE DPSW_CMD_ID(0x002) #define DPSW_CMDID_DISABLE DPSW_CMD_ID(0x003) #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) #define DPSW_CMDID_SET_IRQ_MASK DPSW_CMD_ID(0x014) #define DPSW_CMDID_GET_IRQ_STATUS DPSW_CMD_ID(0x016) #define DPSW_CMDID_CLEAR_IRQ_STATUS DPSW_CMD_ID(0x017) #define DPSW_CMDID_SET_REFLECTION_IF DPSW_CMD_ID(0x022) #define DPSW_CMDID_IF_SET_TCI DPSW_CMD_ID(0x030) #define DPSW_CMDID_IF_SET_STP DPSW_CMD_ID(0x031) #define DPSW_CMDID_IF_GET_COUNTER DPSW_CMD_V2(0x034) #define DPSW_CMDID_IF_ADD_REFLECTION DPSW_CMD_ID(0x037) #define DPSW_CMDID_IF_REMOVE_REFLECTION DPSW_CMD_ID(0x038) #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_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_V2(0x061) #define DPSW_CMDID_VLAN_ADD_IF_UNTAGGED DPSW_CMD_ID(0x062) #define DPSW_CMDID_VLAN_REMOVE_IF DPSW_CMD_ID(0x064) #define DPSW_CMDID_VLAN_REMOVE_IF_UNTAGGED DPSW_CMD_ID(0x065) #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_DUMP DPSW_CMD_ID(0x08A) #define DPSW_CMDID_ACL_ADD DPSW_CMD_ID(0x090) #define DPSW_CMDID_ACL_REMOVE DPSW_CMD_ID(0x091) #define DPSW_CMDID_ACL_ADD_ENTRY DPSW_CMD_ID(0x092) #define DPSW_CMDID_ACL_REMOVE_ENTRY DPSW_CMD_ID(0x093) #define DPSW_CMDID_ACL_ADD_IF DPSW_CMD_ID(0x094) #define DPSW_CMDID_ACL_REMOVE_IF DPSW_CMD_ID(0x095) #define DPSW_CMDID_IF_GET_PORT_MAC_ADDR DPSW_CMD_ID(0x0A7) #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) #define DPSW_CMDID_IF_SET_LEARNING_MODE DPSW_CMD_ID(0x0AD) /* Macros for accessing command fields smaller than 1byte */ #define DPSW_MASK(field) \ GENMASK(DPSW_##field##_SHIFT + DPSW_##field##_SIZE - 1, \ DPSW_##field##_SHIFT) #define dpsw_set_field(var, field, val) \ ((var) |= (((val) << DPSW_##field##_SHIFT) & DPSW_MASK(field))) #define dpsw_get_field(var, field) \ (((var) & DPSW_MASK(field)) >> DPSW_##field##_SHIFT) #define dpsw_get_bit(var, bit) \ (((var) >> (bit)) & GENMASK(0, 0)) #pragma pack(push, 1) struct dpsw_cmd_open { __le32 dpsw_id; }; #define DPSW_COMPONENT_TYPE_SHIFT 0 #define DPSW_COMPONENT_TYPE_SIZE 4 struct dpsw_cmd_create { /* cmd word 0 */ __le16 num_ifs; u8 max_fdbs; u8 max_meters_per_if; /* from LSB: only the first 4 bits */ u8 component_type; u8 pad[3]; /* cmd word 1 */ __le16 max_vlans; __le16 max_fdb_entries; __le16 fdb_aging_time; __le16 max_fdb_mc_groups; /* cmd word 2 */ __le64 options; }; struct dpsw_cmd_destroy { __le32 dpsw_id; }; #define DPSW_ENABLE_SHIFT 0 #define DPSW_ENABLE_SIZE 1 struct dpsw_rsp_is_enabled { /* from LSB: enable:1 */ u8 enabled; }; struct dpsw_cmd_set_irq_enable { u8 enable_state; u8 pad[3]; u8 irq_index; }; struct dpsw_cmd_get_irq_enable { __le32 pad; u8 irq_index; }; struct dpsw_rsp_get_irq_enable { u8 enable_state; }; struct dpsw_cmd_set_irq_mask { __le32 mask; u8 irq_index; }; struct dpsw_cmd_get_irq_mask { __le32 pad; u8 irq_index; }; struct dpsw_rsp_get_irq_mask { __le32 mask; }; struct dpsw_cmd_get_irq_status { __le32 status; u8 irq_index; }; struct dpsw_rsp_get_irq_status { __le32 status; }; struct dpsw_cmd_clear_irq_status { __le32 status; u8 irq_index; }; #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; u8 max_fdbs; u8 num_fdbs; __le16 max_vlans; __le16 num_vlans; /* cmd word 1 */ __le16 max_fdb_entries; __le16 fdb_aging_time; __le32 dpsw_id; /* cmd word 2 */ __le16 mem_size; __le16 max_fdb_mc_groups; u8 max_meters_per_if; /* from LSB only the first 4 bits */ u8 component_type; /* [0:3] - flooding configuration * [4:7] - broadcast configuration */ u8 repl_cfg; u8 pad; /* cmd word 3 */ __le64 options; }; #define DPSW_VLAN_ID_SHIFT 0 #define DPSW_VLAN_ID_SIZE 12 #define DPSW_DEI_SHIFT 12 #define DPSW_DEI_SIZE 1 #define DPSW_PCP_SHIFT 13 #define DPSW_PCP_SIZE 3 struct dpsw_cmd_if_set_tci { __le16 if_id; /* from LSB: VLAN_ID:12 DEI:1 PCP:3 */ __le16 conf; }; struct dpsw_cmd_if_get_tci { __le16 if_id; }; struct dpsw_rsp_if_get_tci { __le16 pad; __le16 vlan_id; u8 dei; u8 pcp; }; #define DPSW_STATE_SHIFT 0 #define DPSW_STATE_SIZE 4 struct dpsw_cmd_if_set_stp { __le16 if_id; __le16 vlan_id; /* only the first LSB 4 bits */ u8 state; }; #define DPSW_COUNTER_TYPE_SHIFT 0 #define DPSW_COUNTER_TYPE_SIZE 5 struct dpsw_cmd_if_get_counter { __le16 if_id; /* from LSB: type:5 */ u8 type; }; struct dpsw_rsp_if_get_counter { __le64 pad; __le64 counter; }; 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; }; struct dpsw_cmd_if_set_link_cfg { /* cmd word 0 */ __le16 if_id; u8 pad[6]; /* cmd word 1 */ __le32 rate; __le32 pad1; /* cmd word 2 */ __le64 options; }; struct dpsw_cmd_if_get_link_state { __le16 if_id; }; #define DPSW_UP_SHIFT 0 #define DPSW_UP_SIZE 1 struct dpsw_rsp_if_get_link_state { /* cmd word 0 */ __le32 pad0; u8 up; u8 pad1[3]; /* cmd word 1 */ __le32 rate; __le32 pad2; /* cmd word 2 */ __le64 options; }; struct dpsw_vlan_add { __le16 fdb_id; __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; __le16 vlan_id; __le32 pad1; /* cmd word 1-4 */ __le64 if_id; }; struct dpsw_cmd_vlan_remove { __le16 pad; __le16 vlan_id; }; struct dpsw_cmd_fdb_add { __le32 pad; __le16 fdb_ageing_time; __le16 num_fdb_entries; }; struct dpsw_rsp_fdb_add { __le16 fdb_id; }; struct dpsw_cmd_fdb_remove { __le16 fdb_id; }; #define DPSW_ENTRY_TYPE_SHIFT 0 #define DPSW_ENTRY_TYPE_SIZE 4 struct dpsw_cmd_fdb_unicast_op { /* cmd word 0 */ __le16 fdb_id; u8 mac_addr[6]; /* cmd word 1 */ __le16 if_egress; /* only the first 4 bits from LSB */ u8 type; }; struct dpsw_cmd_fdb_multicast_op { /* cmd word 0 */ __le16 fdb_id; __le16 num_ifs; /* only the first 4 bits from LSB */ u8 type; u8 pad[3]; /* cmd word 1 */ u8 mac_addr[6]; __le16 pad2; /* cmd word 2-5 */ __le64 if_id; }; struct dpsw_cmd_fdb_dump { __le16 fdb_id; __le16 pad0; __le32 pad1; __le64 iova_addr; __le32 iova_size; }; 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; }; struct dpsw_rsp_if_get_mac_addr { __le16 pad; u8 mac_addr[6]; }; struct dpsw_cmd_set_egress_flood { __le16 fdb_id; u8 flood_type; u8 pad[5]; __le64 if_id; }; #define DPSW_LEARNING_MODE_SHIFT 0 #define DPSW_LEARNING_MODE_SIZE 4 struct dpsw_cmd_if_set_learning_mode { __le16 if_id; /* only the first 4 bits from LSB */ u8 mode; }; struct dpsw_cmd_acl_add { __le16 pad; __le16 max_entries; }; struct dpsw_rsp_acl_add { __le16 acl_id; }; struct dpsw_cmd_acl_remove { __le16 acl_id; }; struct dpsw_cmd_acl_if { __le16 acl_id; __le16 num_ifs; __le32 pad; __le64 if_id; }; struct dpsw_prep_acl_entry { u8 match_l2_dest_mac[6]; __le16 match_l2_tpid; u8 match_l2_source_mac[6]; __le16 match_l2_vlan_id; __le32 match_l3_dest_ip; __le32 match_l3_source_ip; __le16 match_l4_dest_port; __le16 match_l4_source_port; __le16 match_l2_ether_type; u8 match_l2_pcp_dei; u8 match_l3_dscp; u8 mask_l2_dest_mac[6]; __le16 mask_l2_tpid; u8 mask_l2_source_mac[6]; __le16 mask_l2_vlan_id; __le32 mask_l3_dest_ip; __le32 mask_l3_source_ip; __le16 mask_l4_dest_port; __le16 mask_l4_source_port; __le16 mask_l2_ether_type; u8 mask_l2_pcp_dei; u8 mask_l3_dscp; u8 match_l3_protocol; u8 mask_l3_protocol; }; #define DPSW_RESULT_ACTION_SHIFT 0 #define DPSW_RESULT_ACTION_SIZE 4 struct dpsw_cmd_acl_entry { __le16 acl_id; __le16 result_if_id; __le32 precedence; /* from LSB only the first 4 bits */ u8 result_action; u8 pad[7]; __le64 pad2[4]; __le64 key_iova; }; struct dpsw_cmd_set_reflection_if { __le16 if_id; }; #define DPSW_FILTER_SHIFT 0 #define DPSW_FILTER_SIZE 2 struct dpsw_cmd_if_reflection { __le16 if_id; __le16 vlan_id; /* only 2 bits from the LSB */ u8 filter; }; #pragma pack(pop) #endif /* __FSL_DPSW_CMD_H */