1 /* SPDX-License-Identifier: BSD-3-Clause
2 * Copyright(c) 2018 Netronome Systems, Inc.
12 #define GENMASK_ULL(h, l) \
13 (((~0ULL) - (1ULL << (l)) + 1) & \
14 (~0ULL >> (64 - 1 - (h))))
16 #define __bf_shf(x) (__builtin_ffsll(x) - 1)
18 #define FIELD_GET(_mask, _reg) \
20 typeof(_mask) _x = (_mask); \
21 (typeof(_x))(((_reg) & (_x)) >> __bf_shf(_x)); \
24 #define FIELD_FIT(_mask, _val) \
26 typeof(_mask) _x = (_mask); \
27 !((((typeof(_x))_val) << __bf_shf(_x)) & ~(_x)); \
30 #define FIELD_PREP(_mask, _val) \
32 typeof(_mask) _x = (_mask); \
33 ((typeof(_x))(_val) << __bf_shf(_x)) & (_x); \
36 /* Offsets relative to the CSR base */
37 #define NSP_STATUS 0x00
38 #define NSP_STATUS_MAGIC GENMASK_ULL(63, 48)
39 #define NSP_STATUS_MAJOR GENMASK_ULL(47, 44)
40 #define NSP_STATUS_MINOR GENMASK_ULL(43, 32)
41 #define NSP_STATUS_CODE GENMASK_ULL(31, 16)
42 #define NSP_STATUS_RESULT GENMASK_ULL(15, 8)
43 #define NSP_STATUS_BUSY BIT_ULL(0)
45 #define NSP_COMMAND 0x08
46 #define NSP_COMMAND_OPTION GENMASK_ULL(63, 32)
47 #define NSP_COMMAND_CODE GENMASK_ULL(31, 16)
48 #define NSP_COMMAND_START BIT_ULL(0)
50 /* CPP address to retrieve the data from */
51 #define NSP_BUFFER 0x10
52 #define NSP_BUFFER_CPP GENMASK_ULL(63, 40)
53 #define NSP_BUFFER_PCIE GENMASK_ULL(39, 38)
54 #define NSP_BUFFER_ADDRESS GENMASK_ULL(37, 0)
56 #define NSP_DFLT_BUFFER 0x18
58 #define NSP_DFLT_BUFFER_CONFIG 0x20
59 #define NSP_DFLT_BUFFER_SIZE_MB GENMASK_ULL(7, 0)
61 #define NSP_MAGIC 0xab10
65 #define NSP_CODE_MAJOR GENMASK(15, 12)
66 #define NSP_CODE_MINOR GENMASK(11, 0)
69 SPCODE_NOOP = 0, /* No operation */
70 SPCODE_SOFT_RESET = 1, /* Soft reset the NFP */
71 SPCODE_FW_DEFAULT = 2, /* Load default (UNDI) FW */
72 SPCODE_PHY_INIT = 3, /* Initialize the PHY */
73 SPCODE_MAC_INIT = 4, /* Initialize the MAC */
74 SPCODE_PHY_RXADAPT = 5, /* Re-run PHY RX Adaptation */
75 SPCODE_FW_LOAD = 6, /* Load fw from buffer, len in option */
76 SPCODE_ETH_RESCAN = 7, /* Rescan ETHs, write ETH_TABLE to buf */
77 SPCODE_ETH_CONTROL = 8, /* Update media config from buffer */
78 SPCODE_NSP_SENSORS = 12, /* Read NSP sensor(s) */
79 SPCODE_NSP_IDENTIFY = 13, /* Read NSP version */
86 { 6010, "could not map to phy for port" },
87 { 6011, "not an allowed rate/lanes for port" },
88 { 6012, "not an allowed rate/lanes for port" },
89 { 6013, "high/low error, change other port first" },
90 { 6014, "config not found in flash" },
95 struct nfp_resource *res;
101 /* Eth table config state */
107 struct nfp_nsp *nfp_nsp_open(struct nfp_cpp *cpp);
108 void nfp_nsp_close(struct nfp_nsp *state);
109 uint16_t nfp_nsp_get_abi_ver_major(struct nfp_nsp *state);
110 uint16_t nfp_nsp_get_abi_ver_minor(struct nfp_nsp *state);
111 int nfp_nsp_wait(struct nfp_nsp *state);
112 int nfp_nsp_device_soft_reset(struct nfp_nsp *state);
113 int nfp_nsp_load_fw(struct nfp_nsp *state, void *buf, unsigned int size);
114 int nfp_nsp_mac_reinit(struct nfp_nsp *state);
115 int nfp_nsp_read_identify(struct nfp_nsp *state, void *buf, unsigned int size);
116 int nfp_nsp_read_sensors(struct nfp_nsp *state, unsigned int sensor_mask,
117 void *buf, unsigned int size);
119 static inline int nfp_nsp_has_mac_reinit(struct nfp_nsp *state)
121 return nfp_nsp_get_abi_ver_minor(state) > 20;
124 enum nfp_eth_interface {
125 NFP_INTERFACE_NONE = 0,
126 NFP_INTERFACE_SFP = 1,
127 NFP_INTERFACE_SFPP = 10,
128 NFP_INTERFACE_SFP28 = 28,
129 NFP_INTERFACE_QSFP = 40,
130 NFP_INTERFACE_CXP = 100,
131 NFP_INTERFACE_QSFP28 = 112,
135 NFP_MEDIA_DAC_PASSIVE = 0,
136 NFP_MEDIA_DAC_ACTIVE,
143 NFP_ANEG_25G_CONSORTIUM,
149 NFP_FEC_AUTO_BIT = 0,
151 NFP_FEC_REED_SOLOMON_BIT,
152 NFP_FEC_DISABLED_BIT,
155 #define NFP_FEC_AUTO BIT(NFP_FEC_AUTO_BIT)
156 #define NFP_FEC_BASER BIT(NFP_FEC_BASER_BIT)
157 #define NFP_FEC_REED_SOLOMON BIT(NFP_FEC_REED_SOLOMON_BIT)
158 #define NFP_FEC_DISABLED BIT(NFP_FEC_DISABLED_BIT)
163 * struct nfp_eth_table - ETH table information
164 * @count: number of table entries
165 * @max_index: max of @index fields of all @ports
166 * @ports: table of ports
168 * @eth_index: port index according to legacy ethX numbering
169 * @index: chip-wide first channel index
171 * @base: first channel index (within NBI)
172 * @lanes: number of channels
173 * @speed: interface speed (in Mbps)
174 * @interface: interface (module) plugged in
175 * @media: media type of the @interface
176 * @fec: forward error correction mode
177 * @aneg: auto negotiation mode
178 * @mac_addr: interface MAC address
179 * @label_port: port id
180 * @label_subport: id of interface within port (for split ports)
181 * @enabled: is enabled?
182 * @tx_enabled: is TX enabled?
183 * @rx_enabled: is RX enabled?
184 * @override_changed: is media reconfig pending?
186 * @port_type: one of %PORT_* defines for ethtool
187 * @port_lanes: total number of lanes on the port (sum of lanes of all subports)
188 * @is_split: is interface part of a split port
189 * @fec_modes_supported: bitmap of FEC modes supported
191 struct nfp_eth_table {
193 unsigned int max_index;
194 struct nfp_eth_table_port {
195 unsigned int eth_index;
202 unsigned int interface;
203 enum nfp_eth_media media;
205 enum nfp_eth_fec fec;
206 enum nfp_eth_aneg aneg;
208 uint8_t mac_addr[ETH_ALEN];
211 uint8_t label_subport;
217 int override_changed;
219 /* Computed fields */
222 unsigned int port_lanes;
226 unsigned int fec_modes_supported;
230 struct nfp_eth_table *nfp_eth_read_ports(struct nfp_cpp *cpp);
232 int nfp_eth_set_mod_enable(struct nfp_cpp *cpp, unsigned int idx, int enable);
233 int nfp_eth_set_configured(struct nfp_cpp *cpp, unsigned int idx,
236 nfp_eth_set_fec(struct nfp_cpp *cpp, unsigned int idx, enum nfp_eth_fec mode);
238 int nfp_nsp_read_eth_table(struct nfp_nsp *state, void *buf, unsigned int size);
239 int nfp_nsp_write_eth_table(struct nfp_nsp *state, const void *buf,
241 void nfp_nsp_config_set_state(struct nfp_nsp *state, void *entries,
243 void nfp_nsp_config_clear_state(struct nfp_nsp *state);
244 void nfp_nsp_config_set_modified(struct nfp_nsp *state, int modified);
245 void *nfp_nsp_config_entries(struct nfp_nsp *state);
246 int nfp_nsp_config_modified(struct nfp_nsp *state);
247 unsigned int nfp_nsp_config_idx(struct nfp_nsp *state);
249 static inline int nfp_eth_can_support_fec(struct nfp_eth_table_port *eth_port)
251 return !!eth_port->fec_modes_supported;
254 static inline unsigned int
255 nfp_eth_supported_fec_modes(struct nfp_eth_table_port *eth_port)
257 return eth_port->fec_modes_supported;
260 struct nfp_nsp *nfp_eth_config_start(struct nfp_cpp *cpp, unsigned int idx);
261 int nfp_eth_config_commit_end(struct nfp_nsp *nsp);
262 void nfp_eth_config_cleanup_end(struct nfp_nsp *nsp);
264 int __nfp_eth_set_aneg(struct nfp_nsp *nsp, enum nfp_eth_aneg mode);
265 int __nfp_eth_set_speed(struct nfp_nsp *nsp, unsigned int speed);
266 int __nfp_eth_set_split(struct nfp_nsp *nsp, unsigned int lanes);
269 * struct nfp_nsp_identify - NSP static information
270 * @version: opaque version string
271 * @flags: version flags
272 * @br_primary: branch id of primary bootloader
273 * @br_secondary: branch id of secondary bootloader
274 * @br_nsp: branch id of NSP
275 * @primary: version of primarary bootloader
276 * @secondary: version id of secondary bootloader
277 * @nsp: version id of NSP
278 * @sensor_mask: mask of present sensors available on NIC
280 struct nfp_nsp_identify {
284 uint8_t br_secondary;
289 uint64_t sensor_mask;
292 struct nfp_nsp_identify *__nfp_nsp_identify(struct nfp_nsp *nsp);
294 enum nfp_nsp_sensor_id {
295 NFP_SENSOR_CHIP_TEMPERATURE,
296 NFP_SENSOR_ASSEMBLY_POWER,
297 NFP_SENSOR_ASSEMBLY_12V_POWER,
298 NFP_SENSOR_ASSEMBLY_3V3_POWER,
301 int nfp_hwmon_read_sensor(struct nfp_cpp *cpp, enum nfp_nsp_sensor_id id,