aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/bnx2x/bnx2x_link.h
diff options
context:
space:
mode:
authorGlenn Elliott <gelliott@cs.unc.edu>2012-03-04 19:47:13 -0500
committerGlenn Elliott <gelliott@cs.unc.edu>2012-03-04 19:47:13 -0500
commitc71c03bda1e86c9d5198c5d83f712e695c4f2a1e (patch)
treeecb166cb3e2b7e2adb3b5e292245fefd23381ac8 /drivers/net/bnx2x/bnx2x_link.h
parentea53c912f8a86a8567697115b6a0d8152beee5c8 (diff)
parent6a00f206debf8a5c8899055726ad127dbeeed098 (diff)
Merge branch 'mpi-master' into wip-k-fmlpwip-k-fmlp
Conflicts: litmus/sched_cedf.c
Diffstat (limited to 'drivers/net/bnx2x/bnx2x_link.h')
-rw-r--r--drivers/net/bnx2x/bnx2x_link.h317
1 files changed, 255 insertions, 62 deletions
diff --git a/drivers/net/bnx2x/bnx2x_link.h b/drivers/net/bnx2x/bnx2x_link.h
index 40c2981de8ed..92f36b6950dc 100644
--- a/drivers/net/bnx2x/bnx2x_link.h
+++ b/drivers/net/bnx2x/bnx2x_link.h
@@ -1,4 +1,4 @@
1/* Copyright 2008-2009 Broadcom Corporation 1/* Copyright 2008-2011 Broadcom Corporation
2 * 2 *
3 * Unless you and Broadcom execute a separate written software license 3 * Unless you and Broadcom execute a separate written software license
4 * agreement governing use of this software, this software is licensed to you 4 * agreement governing use of this software, this software is licensed to you
@@ -22,7 +22,8 @@
22/***********************************************************/ 22/***********************************************************/
23/* Defines */ 23/* Defines */
24/***********************************************************/ 24/***********************************************************/
25#define DEFAULT_PHY_DEV_ADDR 3 25#define DEFAULT_PHY_DEV_ADDR 3
26#define E2_DEFAULT_PHY_DEV_ADDR 5
26 27
27 28
28 29
@@ -32,7 +33,7 @@
32#define BNX2X_FLOW_CTRL_BOTH PORT_FEATURE_FLOW_CONTROL_BOTH 33#define BNX2X_FLOW_CTRL_BOTH PORT_FEATURE_FLOW_CONTROL_BOTH
33#define BNX2X_FLOW_CTRL_NONE PORT_FEATURE_FLOW_CONTROL_NONE 34#define BNX2X_FLOW_CTRL_NONE PORT_FEATURE_FLOW_CONTROL_NONE
34 35
35#define SPEED_AUTO_NEG 0 36#define SPEED_AUTO_NEG 0
36#define SPEED_12000 12000 37#define SPEED_12000 12000
37#define SPEED_12500 12500 38#define SPEED_12500 12500
38#define SPEED_13000 13000 39#define SPEED_13000 13000
@@ -43,12 +44,156 @@
43#define SFP_EEPROM_VENDOR_NAME_SIZE 16 44#define SFP_EEPROM_VENDOR_NAME_SIZE 16
44#define SFP_EEPROM_VENDOR_OUI_ADDR 0x25 45#define SFP_EEPROM_VENDOR_OUI_ADDR 0x25
45#define SFP_EEPROM_VENDOR_OUI_SIZE 3 46#define SFP_EEPROM_VENDOR_OUI_SIZE 3
46#define SFP_EEPROM_PART_NO_ADDR 0x28 47#define SFP_EEPROM_PART_NO_ADDR 0x28
47#define SFP_EEPROM_PART_NO_SIZE 16 48#define SFP_EEPROM_PART_NO_SIZE 16
48#define PWR_FLT_ERR_MSG_LEN 250 49#define PWR_FLT_ERR_MSG_LEN 250
50
51#define XGXS_EXT_PHY_TYPE(ext_phy_config) \
52 ((ext_phy_config) & PORT_HW_CFG_XGXS_EXT_PHY_TYPE_MASK)
53#define XGXS_EXT_PHY_ADDR(ext_phy_config) \
54 (((ext_phy_config) & PORT_HW_CFG_XGXS_EXT_PHY_ADDR_MASK) >> \
55 PORT_HW_CFG_XGXS_EXT_PHY_ADDR_SHIFT)
56#define SERDES_EXT_PHY_TYPE(ext_phy_config) \
57 ((ext_phy_config) & PORT_HW_CFG_SERDES_EXT_PHY_TYPE_MASK)
58
59/* Single Media Direct board is the plain 577xx board with CX4/RJ45 jacks */
60#define SINGLE_MEDIA_DIRECT(params) (params->num_phys == 1)
61/* Single Media board contains single external phy */
62#define SINGLE_MEDIA(params) (params->num_phys == 2)
63/* Dual Media board contains two external phy with different media */
64#define DUAL_MEDIA(params) (params->num_phys == 3)
65#define FW_PARAM_MDIO_CTRL_OFFSET 16
66#define FW_PARAM_SET(phy_addr, phy_type, mdio_access) \
67 (phy_addr | phy_type | mdio_access << FW_PARAM_MDIO_CTRL_OFFSET)
68
69#define PFC_BRB_MAC_PAUSE_XOFF_THRESHOLD_PAUSEABLE 170
70#define PFC_BRB_MAC_PAUSE_XOFF_THRESHOLD_NON_PAUSEABLE 0
71
72#define PFC_BRB_MAC_PAUSE_XON_THRESHOLD_PAUSEABLE 250
73#define PFC_BRB_MAC_PAUSE_XON_THRESHOLD_NON_PAUSEABLE 0
74
75#define PFC_BRB_MAC_FULL_XOFF_THRESHOLD_PAUSEABLE 10
76#define PFC_BRB_MAC_FULL_XOFF_THRESHOLD_NON_PAUSEABLE 90
77
78#define PFC_BRB_MAC_FULL_XON_THRESHOLD_PAUSEABLE 50
79#define PFC_BRB_MAC_FULL_XON_THRESHOLD_NON_PAUSEABLE 250
80
81#define PFC_BRB_FULL_LB_XOFF_THRESHOLD 170
82#define PFC_BRB_FULL_LB_XON_THRESHOLD 250
83
49/***********************************************************/ 84/***********************************************************/
50/* Structs */ 85/* Structs */
51/***********************************************************/ 86/***********************************************************/
87#define INT_PHY 0
88#define EXT_PHY1 1
89#define EXT_PHY2 2
90#define MAX_PHYS 3
91
92/* Same configuration is shared between the XGXS and the first external phy */
93#define LINK_CONFIG_SIZE (MAX_PHYS - 1)
94#define LINK_CONFIG_IDX(_phy_idx) ((_phy_idx == INT_PHY) ? \
95 0 : (_phy_idx - 1))
96/***********************************************************/
97/* bnx2x_phy struct */
98/* Defines the required arguments and function per phy */
99/***********************************************************/
100struct link_vars;
101struct link_params;
102struct bnx2x_phy;
103
104typedef u8 (*config_init_t)(struct bnx2x_phy *phy, struct link_params *params,
105 struct link_vars *vars);
106typedef u8 (*read_status_t)(struct bnx2x_phy *phy, struct link_params *params,
107 struct link_vars *vars);
108typedef void (*link_reset_t)(struct bnx2x_phy *phy,
109 struct link_params *params);
110typedef void (*config_loopback_t)(struct bnx2x_phy *phy,
111 struct link_params *params);
112typedef u8 (*format_fw_ver_t)(u32 raw, u8 *str, u16 *len);
113typedef void (*hw_reset_t)(struct bnx2x_phy *phy, struct link_params *params);
114typedef void (*set_link_led_t)(struct bnx2x_phy *phy,
115 struct link_params *params, u8 mode);
116typedef void (*phy_specific_func_t)(struct bnx2x_phy *phy,
117 struct link_params *params, u32 action);
118
119struct bnx2x_phy {
120 u32 type;
121
122 /* Loaded during init */
123 u8 addr;
124
125 u8 flags;
126 /* Require HW lock */
127#define FLAGS_HW_LOCK_REQUIRED (1<<0)
128 /* No Over-Current detection */
129#define FLAGS_NOC (1<<1)
130 /* Fan failure detection required */
131#define FLAGS_FAN_FAILURE_DET_REQ (1<<2)
132 /* Initialize first the XGXS and only then the phy itself */
133#define FLAGS_INIT_XGXS_FIRST (1<<3)
134#define FLAGS_REARM_LATCH_SIGNAL (1<<6)
135#define FLAGS_SFP_NOT_APPROVED (1<<7)
136
137 u8 def_md_devad;
138 u8 reserved;
139 /* preemphasis values for the rx side */
140 u16 rx_preemphasis[4];
141
142 /* preemphasis values for the tx side */
143 u16 tx_preemphasis[4];
144
145 /* EMAC address for access MDIO */
146 u32 mdio_ctrl;
147
148 u32 supported;
149
150 u32 media_type;
151#define ETH_PHY_UNSPECIFIED 0x0
152#define ETH_PHY_SFP_FIBER 0x1
153#define ETH_PHY_XFP_FIBER 0x2
154#define ETH_PHY_DA_TWINAX 0x3
155#define ETH_PHY_BASE_T 0x4
156#define ETH_PHY_NOT_PRESENT 0xff
157
158 /* The address in which version is located*/
159 u32 ver_addr;
160
161 u16 req_flow_ctrl;
162
163 u16 req_line_speed;
164
165 u32 speed_cap_mask;
166
167 u16 req_duplex;
168 u16 rsrv;
169 /* Called per phy/port init, and it configures LASI, speed, autoneg,
170 duplex, flow control negotiation, etc. */
171 config_init_t config_init;
172
173 /* Called due to interrupt. It determines the link, speed */
174 read_status_t read_status;
175
176 /* Called when driver is unloading. Should reset the phy */
177 link_reset_t link_reset;
178
179 /* Set the loopback configuration for the phy */
180 config_loopback_t config_loopback;
181
182 /* Format the given raw number into str up to len */
183 format_fw_ver_t format_fw_ver;
184
185 /* Reset the phy (both ports) */
186 hw_reset_t hw_reset;
187
188 /* Set link led mode (on/off/oper)*/
189 set_link_led_t set_link_led;
190
191 /* PHY Specific tasks */
192 phy_specific_func_t phy_specific_func;
193#define DISABLE_TX 1
194#define ENABLE_TX 2
195};
196
52/* Inputs parameters to the CLC */ 197/* Inputs parameters to the CLC */
53struct link_params { 198struct link_params {
54 199
@@ -56,59 +201,57 @@ struct link_params {
56 201
57 /* Default / User Configuration */ 202 /* Default / User Configuration */
58 u8 loopback_mode; 203 u8 loopback_mode;
59#define LOOPBACK_NONE 0 204#define LOOPBACK_NONE 0
60#define LOOPBACK_EMAC 1 205#define LOOPBACK_EMAC 1
61#define LOOPBACK_BMAC 2 206#define LOOPBACK_BMAC 2
62#define LOOPBACK_XGXS_10 3 207#define LOOPBACK_XGXS 3
63#define LOOPBACK_EXT_PHY 4 208#define LOOPBACK_EXT_PHY 4
64#define LOOPBACK_EXT 5 209#define LOOPBACK_EXT 5
65 210#define LOOPBACK_UMAC 6
66 u16 req_duplex; 211#define LOOPBACK_XMAC 7
67 u16 req_flow_ctrl;
68 u16 req_fc_auto_adv; /* Should be set to TX / BOTH when
69 req_flow_ctrl is set to AUTO */
70 u16 req_line_speed; /* Also determine AutoNeg */
71 212
72 /* Device parameters */ 213 /* Device parameters */
73 u8 mac_addr[6]; 214 u8 mac_addr[6];
74 215
216 u16 req_duplex[LINK_CONFIG_SIZE];
217 u16 req_flow_ctrl[LINK_CONFIG_SIZE];
218
219 u16 req_line_speed[LINK_CONFIG_SIZE]; /* Also determine AutoNeg */
220
75 /* shmem parameters */ 221 /* shmem parameters */
76 u32 shmem_base; 222 u32 shmem_base;
77 u32 speed_cap_mask; 223 u32 shmem2_base;
224 u32 speed_cap_mask[LINK_CONFIG_SIZE];
78 u32 switch_cfg; 225 u32 switch_cfg;
79#define SWITCH_CFG_1G PORT_FEATURE_CON_SWITCH_1G_SWITCH 226#define SWITCH_CFG_1G PORT_FEATURE_CON_SWITCH_1G_SWITCH
80#define SWITCH_CFG_10G PORT_FEATURE_CON_SWITCH_10G_SWITCH 227#define SWITCH_CFG_10G PORT_FEATURE_CON_SWITCH_10G_SWITCH
81#define SWITCH_CFG_AUTO_DETECT PORT_FEATURE_CON_SWITCH_AUTO_DETECT 228#define SWITCH_CFG_AUTO_DETECT PORT_FEATURE_CON_SWITCH_AUTO_DETECT
82 229
83 u16 hw_led_mode; /* part of the hw_config read from the shmem */
84
85 /* phy_addr populated by the phy_init function */
86 u8 phy_addr;
87 /*u8 reserved1;*/
88
89 u32 lane_config; 230 u32 lane_config;
90 u32 ext_phy_config;
91#define XGXS_EXT_PHY_TYPE(ext_phy_config) \
92 ((ext_phy_config) & PORT_HW_CFG_XGXS_EXT_PHY_TYPE_MASK)
93#define XGXS_EXT_PHY_ADDR(ext_phy_config) \
94 (((ext_phy_config) & PORT_HW_CFG_XGXS_EXT_PHY_ADDR_MASK) >> \
95 PORT_HW_CFG_XGXS_EXT_PHY_ADDR_SHIFT)
96#define SERDES_EXT_PHY_TYPE(ext_phy_config) \
97 ((ext_phy_config) & PORT_HW_CFG_SERDES_EXT_PHY_TYPE_MASK)
98 231
99 /* Phy register parameter */ 232 /* Phy register parameter */
100 u32 chip_id; 233 u32 chip_id;
101 234
102 u16 xgxs_config_rx[4]; /* preemphasis values for the rx side */ 235 /* features */
103 u16 xgxs_config_tx[4]; /* preemphasis values for the tx side */
104
105 u32 feature_config_flags; 236 u32 feature_config_flags;
106#define FEATURE_CONFIG_OVERRIDE_PREEMPHASIS_ENABLED (1<<0) 237#define FEATURE_CONFIG_OVERRIDE_PREEMPHASIS_ENABLED (1<<0)
107#define FEATURE_CONFIG_BC_SUPPORTS_OPT_MDL_VRFY (1<<2) 238#define FEATURE_CONFIG_PFC_ENABLED (1<<1)
108#define FEATURE_CONFIG_BCM8727_NOC (1<<3) 239#define FEATURE_CONFIG_BC_SUPPORTS_OPT_MDL_VRFY (1<<2)
240#define FEATURE_CONFIG_BC_SUPPORTS_DUAL_PHY_OPT_MDL_VRFY (1<<3)
241 /* Will be populated during common init */
242 struct bnx2x_phy phy[MAX_PHYS];
243
244 /* Will be populated during common init */
245 u8 num_phys;
246
247 u8 rsrv;
248 u16 hw_led_mode; /* part of the hw_config read from the shmem */
249 u32 multi_phy_config;
109 250
110 /* Device pointer passed to all callback functions */ 251 /* Device pointer passed to all callback functions */
111 struct bnx2x *bp; 252 struct bnx2x *bp;
253 u16 req_fc_auto_adv; /* Should be set to TX / BOTH when
254 req_flow_ctrl is set to AUTO */
112}; 255};
113 256
114/* Output parameters */ 257/* Output parameters */
@@ -129,12 +272,6 @@ struct link_vars {
129 u16 flow_ctrl; 272 u16 flow_ctrl;
130 u16 ieee_fc; 273 u16 ieee_fc;
131 274
132 u32 autoneg;
133#define AUTO_NEG_DISABLED 0x0
134#define AUTO_NEG_ENABLED 0x1
135#define AUTO_NEG_COMPLETE 0x2
136#define AUTO_NEG_PARALLEL_DETECTION_USED 0x3
137
138 /* The same definitions as the shmem parameter */ 275 /* The same definitions as the shmem parameter */
139 u32 link_status; 276 u32 link_status;
140}; 277};
@@ -142,8 +279,6 @@ struct link_vars {
142/***********************************************************/ 279/***********************************************************/
143/* Functions */ 280/* Functions */
144/***********************************************************/ 281/***********************************************************/
145
146/* Initialize the phy */
147u8 bnx2x_phy_init(struct link_params *input, struct link_vars *output); 282u8 bnx2x_phy_init(struct link_params *input, struct link_vars *output);
148 283
149/* Reset the link. Should be called when driver or interface goes down 284/* Reset the link. Should be called when driver or interface goes down
@@ -155,17 +290,15 @@ u8 bnx2x_link_reset(struct link_params *params, struct link_vars *vars,
155/* bnx2x_link_update should be called upon link interrupt */ 290/* bnx2x_link_update should be called upon link interrupt */
156u8 bnx2x_link_update(struct link_params *input, struct link_vars *output); 291u8 bnx2x_link_update(struct link_params *input, struct link_vars *output);
157 292
158/* use the following cl45 functions to read/write from external_phy 293/* use the following phy functions to read/write from external_phy
159 In order to use it to read/write internal phy registers, use 294 In order to use it to read/write internal phy registers, use
160 DEFAULT_PHY_DEV_ADDR as devad, and (_bank + (_addr & 0xf)) as 295 DEFAULT_PHY_DEV_ADDR as devad, and (_bank + (_addr & 0xf)) as
161 Use ext_phy_type of 0 in case of cl22 over cl45
162 the register */ 296 the register */
163u8 bnx2x_cl45_read(struct bnx2x *bp, u8 port, u32 ext_phy_type, 297u8 bnx2x_phy_read(struct link_params *params, u8 phy_addr,
164 u8 phy_addr, u8 devad, u16 reg, u16 *ret_val); 298 u8 devad, u16 reg, u16 *ret_val);
165
166u8 bnx2x_cl45_write(struct bnx2x *bp, u8 port, u32 ext_phy_type,
167 u8 phy_addr, u8 devad, u16 reg, u16 val);
168 299
300u8 bnx2x_phy_write(struct link_params *params, u8 phy_addr,
301 u8 devad, u16 reg, u16 val);
169/* Reads the link_status from the shmem, 302/* Reads the link_status from the shmem,
170 and update the link vars accordingly */ 303 and update the link vars accordingly */
171void bnx2x_link_status_update(struct link_params *input, 304void bnx2x_link_status_update(struct link_params *input,
@@ -178,11 +311,12 @@ u8 bnx2x_get_ext_phy_fw_version(struct link_params *params, u8 driver_loaded,
178 Basically, the CLC takes care of the led for the link, but in case one needs 311 Basically, the CLC takes care of the led for the link, but in case one needs
179 to set/unset the led unnaturally, set the "mode" to LED_MODE_OPER to 312 to set/unset the led unnaturally, set the "mode" to LED_MODE_OPER to
180 blink the led, and LED_MODE_OFF to set the led off.*/ 313 blink the led, and LED_MODE_OFF to set the led off.*/
181u8 bnx2x_set_led(struct link_params *params, u8 mode, u32 speed); 314u8 bnx2x_set_led(struct link_params *params, struct link_vars *vars,
182#define LED_MODE_OFF 0 315 u8 mode, u32 speed);
183#define LED_MODE_OPER 2 316#define LED_MODE_OFF 0
184 317#define LED_MODE_ON 1
185u8 bnx2x_override_led_value(struct bnx2x *bp, u8 port, u32 led_idx, u32 value); 318#define LED_MODE_OPER 2
319#define LED_MODE_FRONT_PANEL_OFF 3
186 320
187/* bnx2x_handle_module_detect_int should be called upon module detection 321/* bnx2x_handle_module_detect_int should be called upon module detection
188 interrupt */ 322 interrupt */
@@ -190,17 +324,76 @@ void bnx2x_handle_module_detect_int(struct link_params *params);
190 324
191/* Get the actual link status. In case it returns 0, link is up, 325/* Get the actual link status. In case it returns 0, link is up,
192 otherwise link is down*/ 326 otherwise link is down*/
193u8 bnx2x_test_link(struct link_params *input, struct link_vars *vars); 327u8 bnx2x_test_link(struct link_params *input, struct link_vars *vars,
328 u8 is_serdes);
194 329
195/* One-time initialization for external phy after power up */ 330/* One-time initialization for external phy after power up */
196u8 bnx2x_common_init_phy(struct bnx2x *bp, u32 shmem_base); 331u8 bnx2x_common_init_phy(struct bnx2x *bp, u32 shmem_base_path[],
332 u32 shmem2_base_path[], u32 chip_id);
197 333
198/* Reset the external PHY using GPIO */ 334/* Reset the external PHY using GPIO */
199void bnx2x_ext_phy_hw_reset(struct bnx2x *bp, u8 port); 335void bnx2x_ext_phy_hw_reset(struct bnx2x *bp, u8 port);
200 336
201void bnx2x_sfx7101_sp_sw_reset(struct bnx2x *bp, u8 port, u8 phy_addr); 337/* Reset the external of SFX7101 */
338void bnx2x_sfx7101_sp_sw_reset(struct bnx2x *bp, struct bnx2x_phy *phy);
339
340/* Read "byte_cnt" bytes from address "addr" from the SFP+ EEPROM */
341u8 bnx2x_read_sfp_module_eeprom(struct bnx2x_phy *phy,
342 struct link_params *params, u16 addr,
343 u8 byte_cnt, u8 *o_buf);
344
345void bnx2x_hw_reset_phy(struct link_params *params);
346
347/* Checks if HW lock is required for this phy/board type */
348u8 bnx2x_hw_lock_required(struct bnx2x *bp, u32 shmem_base,
349 u32 shmem2_base);
350
351/* Check swap bit and adjust PHY order */
352u32 bnx2x_phy_selection(struct link_params *params);
353
354/* Probe the phys on board, and populate them in "params" */
355u8 bnx2x_phy_probe(struct link_params *params);
356/* Checks if fan failure detection is required on one of the phys on board */
357u8 bnx2x_fan_failure_det_req(struct bnx2x *bp, u32 shmem_base,
358 u32 shmem2_base, u8 port);
359
360/* PFC port configuration params */
361struct bnx2x_nig_brb_pfc_port_params {
362 /* NIG */
363 u32 pause_enable;
364 u32 llfc_out_en;
365 u32 llfc_enable;
366 u32 pkt_priority_to_cos;
367 u32 rx_cos0_priority_mask;
368 u32 rx_cos1_priority_mask;
369 u32 llfc_high_priority_classes;
370 u32 llfc_low_priority_classes;
371 /* BRB */
372 u32 cos0_pauseable;
373 u32 cos1_pauseable;
374};
375
376/**
377 * Used to update the PFC attributes in EMAC, BMAC, NIG and BRB
378 * when link is already up
379 */
380void bnx2x_update_pfc(struct link_params *params,
381 struct link_vars *vars,
382 struct bnx2x_nig_brb_pfc_port_params *pfc_params);
383
384
385/* Used to configure the ETS to disable */
386void bnx2x_ets_disabled(struct link_params *params);
387
388/* Used to configure the ETS to BW limited */
389void bnx2x_ets_bw_limit(const struct link_params *params, const u32 cos0_bw,
390 const u32 cos1_bw);
202 391
203u8 bnx2x_read_sfp_module_eeprom(struct link_params *params, u16 addr, 392/* Used to configure the ETS to strict */
204 u8 byte_cnt, u8 *o_buf); 393u8 bnx2x_ets_strict(const struct link_params *params, const u8 strict_cos);
205 394
395/* Read pfc statistic*/
396void bnx2x_pfc_statistic(struct link_params *params, struct link_vars *vars,
397 u32 pfc_frames_sent[2],
398 u32 pfc_frames_received[2]);
206#endif /* BNX2X_LINK_H */ 399#endif /* BNX2X_LINK_H */