diff options
Diffstat (limited to 'drivers/net/netxen/netxen_nic_ethtool.c')
-rw-r--r-- | drivers/net/netxen/netxen_nic_ethtool.c | 89 |
1 files changed, 58 insertions, 31 deletions
diff --git a/drivers/net/netxen/netxen_nic_ethtool.c b/drivers/net/netxen/netxen_nic_ethtool.c index caf6cc15b241..f3fc35cf8af7 100644 --- a/drivers/net/netxen/netxen_nic_ethtool.c +++ b/drivers/net/netxen/netxen_nic_ethtool.c | |||
@@ -53,6 +53,9 @@ struct netxen_nic_stats { | |||
53 | #define NETXEN_NIC_STAT(m) sizeof(((struct netxen_port *)0)->m), \ | 53 | #define NETXEN_NIC_STAT(m) sizeof(((struct netxen_port *)0)->m), \ |
54 | offsetof(struct netxen_port, m) | 54 | offsetof(struct netxen_port, m) |
55 | 55 | ||
56 | #define NETXEN_NIC_PORT_WINDOW 0x10000 | ||
57 | #define NETXEN_NIC_INVALID_DATA 0xDEADBEEF | ||
58 | |||
56 | static const struct netxen_nic_stats netxen_nic_gstrings_stats[] = { | 59 | static const struct netxen_nic_stats netxen_nic_gstrings_stats[] = { |
57 | {"rcvd_bad_skb", NETXEN_NIC_STAT(stats.rcvdbadskb)}, | 60 | {"rcvd_bad_skb", NETXEN_NIC_STAT(stats.rcvdbadskb)}, |
58 | {"xmit_called", NETXEN_NIC_STAT(stats.xmitcalled)}, | 61 | {"xmit_called", NETXEN_NIC_STAT(stats.xmitcalled)}, |
@@ -111,9 +114,9 @@ netxen_nic_get_drvinfo(struct net_device *dev, struct ethtool_drvinfo *drvinfo) | |||
111 | { | 114 | { |
112 | struct netxen_port *port = netdev_priv(dev); | 115 | struct netxen_port *port = netdev_priv(dev); |
113 | struct netxen_adapter *adapter = port->adapter; | 116 | struct netxen_adapter *adapter = port->adapter; |
114 | uint32_t fw_major = 0; | 117 | u32 fw_major = 0; |
115 | uint32_t fw_minor = 0; | 118 | u32 fw_minor = 0; |
116 | uint32_t fw_build = 0; | 119 | u32 fw_build = 0; |
117 | 120 | ||
118 | strncpy(drvinfo->driver, "netxen_nic", 32); | 121 | strncpy(drvinfo->driver, "netxen_nic", 32); |
119 | strncpy(drvinfo->version, NETXEN_NIC_LINUX_VERSIONID, 32); | 122 | strncpy(drvinfo->version, NETXEN_NIC_LINUX_VERSIONID, 32); |
@@ -136,6 +139,8 @@ netxen_nic_get_settings(struct net_device *dev, struct ethtool_cmd *ecmd) | |||
136 | { | 139 | { |
137 | struct netxen_port *port = netdev_priv(dev); | 140 | struct netxen_port *port = netdev_priv(dev); |
138 | struct netxen_adapter *adapter = port->adapter; | 141 | struct netxen_adapter *adapter = port->adapter; |
142 | struct netxen_board_info *boardinfo; | ||
143 | boardinfo = &adapter->ahw.boardcfg; | ||
139 | 144 | ||
140 | /* read which mode */ | 145 | /* read which mode */ |
141 | if (adapter->ahw.board_type == NETXEN_NIC_GBE) { | 146 | if (adapter->ahw.board_type == NETXEN_NIC_GBE) { |
@@ -144,16 +149,12 @@ netxen_nic_get_settings(struct net_device *dev, struct ethtool_cmd *ecmd) | |||
144 | SUPPORTED_100baseT_Half | | 149 | SUPPORTED_100baseT_Half | |
145 | SUPPORTED_100baseT_Full | | 150 | SUPPORTED_100baseT_Full | |
146 | SUPPORTED_1000baseT_Half | | 151 | SUPPORTED_1000baseT_Half | |
147 | SUPPORTED_1000baseT_Full | | 152 | SUPPORTED_1000baseT_Full); |
148 | SUPPORTED_TP | | ||
149 | SUPPORTED_MII | SUPPORTED_Autoneg); | ||
150 | 153 | ||
151 | ecmd->advertising = (ADVERTISED_100baseT_Half | | 154 | ecmd->advertising = (ADVERTISED_100baseT_Half | |
152 | ADVERTISED_100baseT_Full | | 155 | ADVERTISED_100baseT_Full | |
153 | ADVERTISED_1000baseT_Half | | 156 | ADVERTISED_1000baseT_Half | |
154 | ADVERTISED_1000baseT_Full | | 157 | ADVERTISED_1000baseT_Full); |
155 | ADVERTISED_TP | | ||
156 | ADVERTISED_MII | ADVERTISED_Autoneg); | ||
157 | 158 | ||
158 | ecmd->port = PORT_TP; | 159 | ecmd->port = PORT_TP; |
159 | 160 | ||
@@ -162,16 +163,7 @@ netxen_nic_get_settings(struct net_device *dev, struct ethtool_cmd *ecmd) | |||
162 | ecmd->duplex = port->link_duplex; | 163 | ecmd->duplex = port->link_duplex; |
163 | } else | 164 | } else |
164 | return -EIO; /* link absent */ | 165 | return -EIO; /* link absent */ |
165 | 166 | } else if (adapter->ahw.board_type == NETXEN_NIC_XGBE) { | |
166 | ecmd->phy_address = port->portnum; | ||
167 | ecmd->transceiver = XCVR_EXTERNAL; | ||
168 | |||
169 | /* get autoneg settings */ | ||
170 | ecmd->autoneg = port->link_autoneg; | ||
171 | return 0; | ||
172 | } | ||
173 | |||
174 | if (adapter->ahw.board_type == NETXEN_NIC_XGBE) { | ||
175 | ecmd->supported = (SUPPORTED_TP | | 167 | ecmd->supported = (SUPPORTED_TP | |
176 | SUPPORTED_1000baseT_Full | | 168 | SUPPORTED_1000baseT_Full | |
177 | SUPPORTED_10000baseT_Full); | 169 | SUPPORTED_10000baseT_Full); |
@@ -182,13 +174,47 @@ netxen_nic_get_settings(struct net_device *dev, struct ethtool_cmd *ecmd) | |||
182 | 174 | ||
183 | ecmd->speed = SPEED_10000; | 175 | ecmd->speed = SPEED_10000; |
184 | ecmd->duplex = DUPLEX_FULL; | 176 | ecmd->duplex = DUPLEX_FULL; |
185 | ecmd->phy_address = port->portnum; | ||
186 | ecmd->transceiver = XCVR_EXTERNAL; | ||
187 | ecmd->autoneg = AUTONEG_DISABLE; | 177 | ecmd->autoneg = AUTONEG_DISABLE; |
188 | return 0; | 178 | } else |
179 | return -EIO; | ||
180 | |||
181 | ecmd->phy_address = port->portnum; | ||
182 | ecmd->transceiver = XCVR_EXTERNAL; | ||
183 | |||
184 | switch ((netxen_brdtype_t) boardinfo->board_type) { | ||
185 | case NETXEN_BRDTYPE_P2_SB35_4G: | ||
186 | case NETXEN_BRDTYPE_P2_SB31_2G: | ||
187 | ecmd->supported |= SUPPORTED_Autoneg; | ||
188 | ecmd->advertising |= ADVERTISED_Autoneg; | ||
189 | case NETXEN_BRDTYPE_P2_SB31_10G_CX4: | ||
190 | ecmd->supported |= SUPPORTED_TP; | ||
191 | ecmd->advertising |= ADVERTISED_TP; | ||
192 | ecmd->port = PORT_TP; | ||
193 | ecmd->autoneg = (boardinfo->board_type == | ||
194 | NETXEN_BRDTYPE_P2_SB31_10G_CX4) ? | ||
195 | (AUTONEG_DISABLE) : (port->link_autoneg); | ||
196 | break; | ||
197 | case NETXEN_BRDTYPE_P2_SB31_10G_HMEZ: | ||
198 | case NETXEN_BRDTYPE_P2_SB31_10G_IMEZ: | ||
199 | ecmd->supported |= SUPPORTED_MII; | ||
200 | ecmd->advertising |= ADVERTISED_MII; | ||
201 | ecmd->port = PORT_FIBRE; | ||
202 | ecmd->autoneg = AUTONEG_DISABLE; | ||
203 | break; | ||
204 | case NETXEN_BRDTYPE_P2_SB31_10G: | ||
205 | ecmd->supported |= SUPPORTED_FIBRE; | ||
206 | ecmd->advertising |= ADVERTISED_FIBRE; | ||
207 | ecmd->port = PORT_FIBRE; | ||
208 | ecmd->autoneg = AUTONEG_DISABLE; | ||
209 | break; | ||
210 | default: | ||
211 | printk("ERROR: Unsupported board model %d\n", | ||
212 | (netxen_brdtype_t) boardinfo->board_type); | ||
213 | return -EIO; | ||
214 | |||
189 | } | 215 | } |
190 | 216 | ||
191 | return -EIO; | 217 | return 0; |
192 | } | 218 | } |
193 | 219 | ||
194 | static int | 220 | static int |
@@ -371,7 +397,7 @@ netxen_nic_get_regs(struct net_device *dev, struct ethtool_regs *regs, void *p) | |||
371 | for (i = 3; niu_registers[mode].reg[i - 3] != -1; i++) { | 397 | for (i = 3; niu_registers[mode].reg[i - 3] != -1; i++) { |
372 | /* GB: port specific registers */ | 398 | /* GB: port specific registers */ |
373 | if (mode == 0 && i >= 19) | 399 | if (mode == 0 && i >= 19) |
374 | window = port->portnum * 0x10000; | 400 | window = port->portnum * NETXEN_NIC_PORT_WINDOW; |
375 | 401 | ||
376 | NETXEN_NIC_LOCKED_READ_REG(niu_registers[mode]. | 402 | NETXEN_NIC_LOCKED_READ_REG(niu_registers[mode]. |
377 | reg[i - 3] + window, | 403 | reg[i - 3] + window, |
@@ -385,7 +411,8 @@ static void | |||
385 | netxen_nic_get_wol(struct net_device *dev, struct ethtool_wolinfo *wol) | 411 | netxen_nic_get_wol(struct net_device *dev, struct ethtool_wolinfo *wol) |
386 | { | 412 | { |
387 | wol->supported = WAKE_UCAST | WAKE_MCAST | WAKE_BCAST | WAKE_MAGIC; | 413 | wol->supported = WAKE_UCAST | WAKE_MCAST | WAKE_BCAST | WAKE_MAGIC; |
388 | wol->wolopts = 0; /* options can be added depending upon the mode */ | 414 | /* options can be added depending upon the mode */ |
415 | wol->wolopts = 0; | ||
389 | } | 416 | } |
390 | 417 | ||
391 | static u32 netxen_nic_get_link(struct net_device *dev) | 418 | static u32 netxen_nic_get_link(struct net_device *dev) |
@@ -531,9 +558,9 @@ static int netxen_nic_reg_test(struct net_device *dev) | |||
531 | 558 | ||
532 | save = data_read; | 559 | save = data_read; |
533 | if (data_read) | 560 | if (data_read) |
534 | data_written = data_read & 0xDEADBEEF; | 561 | data_written = data_read & NETXEN_NIC_INVALID_DATA; |
535 | else | 562 | else |
536 | data_written = 0xDEADBEEF; | 563 | data_written = NETXEN_NIC_INVALID_DATA; |
537 | netxen_nic_write_w0(adapter, | 564 | netxen_nic_write_w0(adapter, |
538 | NETXEN_NIU_GB_MII_MGMT_STATUS(port-> | 565 | NETXEN_NIU_GB_MII_MGMT_STATUS(port-> |
539 | portnum), | 566 | portnum), |
@@ -559,9 +586,9 @@ static int netxen_nic_reg_test(struct net_device *dev) | |||
559 | 586 | ||
560 | save = data_read; | 587 | save = data_read; |
561 | if (data_read) | 588 | if (data_read) |
562 | data_written = data_read & 0xDEADBEEF; | 589 | data_written = data_read & NETXEN_NIC_INVALID_DATA; |
563 | else | 590 | else |
564 | data_written = 0xDEADBEEF; | 591 | data_written = NETXEN_NIC_INVALID_DATA; |
565 | netxen_nic_write_w0(adapter, | 592 | netxen_nic_write_w0(adapter, |
566 | NETXEN_NIU_GB_MII_MGMT_INDICATE(port-> | 593 | NETXEN_NIU_GB_MII_MGMT_INDICATE(port-> |
567 | portnum), | 594 | portnum), |
@@ -587,9 +614,9 @@ static int netxen_nic_reg_test(struct net_device *dev) | |||
587 | 614 | ||
588 | save = data_read; | 615 | save = data_read; |
589 | if (data_read) | 616 | if (data_read) |
590 | data_written = data_read & 0xDEADBEEF; | 617 | data_written = data_read & NETXEN_NIC_INVALID_DATA; |
591 | else | 618 | else |
592 | data_written = 0xDEADBEEF; | 619 | data_written = NETXEN_NIC_INVALID_DATA; |
593 | netxen_nic_write_w0(adapter, | 620 | netxen_nic_write_w0(adapter, |
594 | NETXEN_NIU_GB_INTERFACE_STATUS(port-> | 621 | NETXEN_NIU_GB_INTERFACE_STATUS(port-> |
595 | portnum), | 622 | portnum), |