Loading...
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 | /* SPDX-License-Identifier: GPL-2.0-only */ /* * Copyright (C) 2013-2014 Chelsio Communications. All rights reserved. * * Written by Anish Bhatt (anish@chelsio.com) */ #ifndef __CXGB4_DCB_H #define __CXGB4_DCB_H #include <linux/netdevice.h> #include <linux/dcbnl.h> #include <net/dcbnl.h> #ifdef CONFIG_CHELSIO_T4_DCB #define CXGB4_DCBX_FW_SUPPORT \ (DCB_CAP_DCBX_VER_CEE | \ DCB_CAP_DCBX_VER_IEEE | \ DCB_CAP_DCBX_LLD_MANAGED) #define CXGB4_DCBX_HOST_SUPPORT \ (DCB_CAP_DCBX_VER_CEE | \ DCB_CAP_DCBX_VER_IEEE | \ DCB_CAP_DCBX_HOST) #define CXGB4_MAX_PRIORITY CXGB4_MAX_DCBX_APP_SUPPORTED #define CXGB4_MAX_TCS CXGB4_MAX_DCBX_APP_SUPPORTED #define INIT_PORT_DCB_CMD(__pcmd, __port, __op, __action) \ do { \ memset(&(__pcmd), 0, sizeof(__pcmd)); \ (__pcmd).op_to_portid = \ cpu_to_be32(FW_CMD_OP_V(FW_PORT_CMD) | \ FW_CMD_REQUEST_F | \ FW_CMD_##__op##_F | \ FW_PORT_CMD_PORTID_V(__port)); \ (__pcmd).action_to_len16 = \ cpu_to_be32(FW_PORT_CMD_ACTION_V(__action) | \ FW_LEN16(pcmd)); \ } while (0) #define INIT_PORT_DCB_READ_PEER_CMD(__pcmd, __port) \ INIT_PORT_DCB_CMD(__pcmd, __port, READ, FW_PORT_ACTION_DCB_READ_RECV) #define INIT_PORT_DCB_READ_LOCAL_CMD(__pcmd, __port) \ INIT_PORT_DCB_CMD(__pcmd, __port, READ, FW_PORT_ACTION_DCB_READ_TRANS) #define INIT_PORT_DCB_READ_SYNC_CMD(__pcmd, __port) \ INIT_PORT_DCB_CMD(__pcmd, __port, READ, FW_PORT_ACTION_DCB_READ_DET) #define INIT_PORT_DCB_WRITE_CMD(__pcmd, __port) \ INIT_PORT_DCB_CMD(__pcmd, __port, EXEC, FW_PORT_ACTION_L2_DCB_CFG) #define IEEE_FAUX_SYNC(__dev, __dcb) \ do { \ if ((__dcb)->dcb_version == FW_PORT_DCB_VER_IEEE) \ cxgb4_dcb_state_fsm((__dev), \ CXGB4_DCB_INPUT_FW_ALLSYNCED); \ } while (0) /* States we can be in for a port's Data Center Bridging. */ enum cxgb4_dcb_state { CXGB4_DCB_STATE_START, /* initial unknown state */ CXGB4_DCB_STATE_HOST, /* we're using Host DCB (if at all) */ CXGB4_DCB_STATE_FW_INCOMPLETE, /* using firmware DCB, incomplete */ CXGB4_DCB_STATE_FW_ALLSYNCED, /* using firmware DCB, all sync'ed */ }; /* Data Center Bridging state input for the Finite State Machine. */ enum cxgb4_dcb_state_input { /* Input from the firmware. */ CXGB4_DCB_INPUT_FW_DISABLED, /* firmware DCB disabled */ CXGB4_DCB_INPUT_FW_ENABLED, /* firmware DCB enabled */ CXGB4_DCB_INPUT_FW_INCOMPLETE, /* firmware reports incomplete DCB */ CXGB4_DCB_INPUT_FW_ALLSYNCED, /* firmware reports all sync'ed */ }; /* Firmware DCB messages that we've received so far ... */ enum cxgb4_dcb_fw_msgs { CXGB4_DCB_FW_PGID = 0x01, CXGB4_DCB_FW_PGRATE = 0x02, CXGB4_DCB_FW_PRIORATE = 0x04, CXGB4_DCB_FW_PFC = 0x08, CXGB4_DCB_FW_APP_ID = 0x10, }; #define CXGB4_MAX_DCBX_APP_SUPPORTED 8 /* Data Center Bridging support; */ struct port_dcb_info { enum cxgb4_dcb_state state; /* DCB State Machine */ enum cxgb4_dcb_fw_msgs msgs; /* DCB Firmware messages received */ unsigned int supported; /* OS DCB capabilities supported */ bool enabled; /* OS Enabled state */ /* Cached copies of DCB information sent by the firmware (in Host * Native Endian format). */ u32 pgid; /* Priority Group[0..7] */ u8 dcb_version; /* Running DCBx version */ u8 pfcen; /* Priority Flow Control[0..7] */ u8 pg_num_tcs_supported; /* max PG Traffic Classes */ u8 pfc_num_tcs_supported; /* max PFC Traffic Classes */ u8 pgrate[8]; /* Priority Group Rate[0..7] */ u8 priorate[8]; /* Priority Rate[0..7] */ u8 tsa[8]; /* TSA Algorithm[0..7] */ struct app_priority { /* Application Information */ u8 user_prio_map; /* Priority Map bitfield */ u8 sel_field; /* Protocol ID interpretation */ u16 protocolid; /* Protocol ID */ } app_priority[CXGB4_MAX_DCBX_APP_SUPPORTED]; }; void cxgb4_dcb_state_init(struct net_device *); void cxgb4_dcb_version_init(struct net_device *); void cxgb4_dcb_reset(struct net_device *dev); void cxgb4_dcb_state_fsm(struct net_device *, enum cxgb4_dcb_state_input); void cxgb4_dcb_handle_fw_update(struct adapter *, const struct fw_port_cmd *); void cxgb4_dcb_set_caps(struct adapter *, const struct fw_port_cmd *); extern const struct dcbnl_rtnl_ops cxgb4_dcb_ops; static inline __u8 bitswap_1(unsigned char val) { return ((val & 0x80) >> 7) | ((val & 0x40) >> 5) | ((val & 0x20) >> 3) | ((val & 0x10) >> 1) | ((val & 0x08) << 1) | ((val & 0x04) << 3) | ((val & 0x02) << 5) | ((val & 0x01) << 7); } extern const char * const dcb_ver_array[]; #define CXGB4_DCB_ENABLED true #else /* !CONFIG_CHELSIO_T4_DCB */ static inline void cxgb4_dcb_state_init(struct net_device *dev) { } #define CXGB4_DCB_ENABLED false #endif /* !CONFIG_CHELSIO_T4_DCB */ #endif /* __CXGB4_DCB_H */ |