1 /*******************************************************************************
4 Copyright(c) 1999 - 2002 Intel Corporation. All rights reserved.
6 This program is free software; you can redistribute it and/or modify it
7 under the terms of the GNU General Public License as published by the Free
8 Software Foundation; either version 2 of the License, or (at your option)
11 This program is distributed in the hope that it will be useful, but WITHOUT
12 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
13 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
16 You should have received a copy of the GNU General Public License along with
17 this program; if not, write to the Free Software Foundation, Inc., 59
18 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
20 The full GNU General Public License is included in this distribution in the
24 Linux NICS <linux.nics@intel.com>
25 Intel Corporation, 5200 N.E. Elam Young Parkway, Hillsboro, OR 97124-6497
27 *******************************************************************************/
34 * o Feature: Added user-settable knob for interrupt throttle rate (ITR).
35 * o Cleanup: removed large static array allocations.
36 * o Cleanup: C99 struct initializer format.
37 * o Bug fix: restore VLAN settings when interface is brought up.
38 * o Bug fix: return cleanly in probe if error in detecting MAC type.
39 * o Bug fix: Wake up on magic packet by default only if enabled in eeprom.
40 * o Bug fix: Validate MAC address in set_mac.
41 * o Bug fix: Throw away zero-length Tx skbs.
42 * o Bug fix: Make ethtool EEPROM acceses work on older versions of ethtool.
45 * o Clean up: use members of pci_device rather than direct calls to
46 * pci_read_config_word.
47 * o Bug fix: changed default flow control settings.
48 * o Clean up: ethtool file now has an inclusive list for adapters in the
49 * Wake-On-LAN capabilities instead of an exclusive list.
50 * o Bug fix: miscellaneous WoL bug fixes.
51 * o Added software interrupt for clearing rx ring
52 * o Bug fix: easier to undo "forcing" of 1000/fd using ethtool.
53 * o Now setting netdev->mem_end in e1000_probe.
54 * o Clean up: Moved tx_timeout from interrupt context to process context
55 * using schedule_task.
60 char e1000_driver_name[] = "e1000";
61 char e1000_driver_string[] = "Intel(R) PRO/1000 Network Driver";
62 char e1000_driver_version[] = "4.4.19-k2";
63 char e1000_copyright[] = "Copyright (c) 1999-2002 Intel Corporation.";
65 /* e1000_pci_tbl - PCI Device ID Table
67 * Private driver_data field (last one) stores an index into e1000_strings
68 * Wildcard entries (PCI_ANY_ID) should come last
69 * Last entry must be all 0s
71 * { Vendor ID, Device ID, SubVendor ID, SubDevice ID,
72 * Class, Class Mask, String Index }
74 static struct pci_device_id e1000_pci_tbl[] __devinitdata = {
75 /* Intel(R) PRO/1000 Network Connection */
76 {0x8086, 0x1000, 0x8086, 0x1000, 0, 0, 0},
77 {0x8086, 0x1001, 0x8086, 0x1003, 0, 0, 0},
78 {0x8086, 0x1004, 0x8086, 0x1004, 0, 0, 0},
79 {0x8086, 0x1008, 0x8086, 0x1107, 0, 0, 0},
80 {0x8086, 0x1009, 0x8086, 0x1109, 0, 0, 0},
81 {0x8086, 0x100C, 0x8086, 0x1112, 0, 0, 0},
82 {0x8086, 0x100E, 0x8086, 0x001E, 0, 0, 0},
83 /* Compaq Gigabit Ethernet Server Adapter */
84 {0x8086, 0x1000, 0x0E11, PCI_ANY_ID, 0, 0, 1},
85 {0x8086, 0x1001, 0x0E11, PCI_ANY_ID, 0, 0, 1},
86 {0x8086, 0x1004, 0x0E11, PCI_ANY_ID, 0, 0, 1},
87 /* IBM Mobile, Desktop & Server Adapters */
88 {0x8086, 0x1000, 0x1014, PCI_ANY_ID, 0, 0, 2},
89 {0x8086, 0x1001, 0x1014, PCI_ANY_ID, 0, 0, 2},
90 {0x8086, 0x1004, 0x1014, PCI_ANY_ID, 0, 0, 2},
92 {0x8086, 0x1000, PCI_ANY_ID, PCI_ANY_ID, 0, 0, 0},
93 {0x8086, 0x1001, PCI_ANY_ID, PCI_ANY_ID, 0, 0, 0},
94 {0x8086, 0x1004, PCI_ANY_ID, PCI_ANY_ID, 0, 0, 0},
95 {0x8086, 0x1008, PCI_ANY_ID, PCI_ANY_ID, 0, 0, 0},
96 {0x8086, 0x1009, PCI_ANY_ID, PCI_ANY_ID, 0, 0, 0},
97 {0x8086, 0x100C, PCI_ANY_ID, PCI_ANY_ID, 0, 0, 0},
98 {0x8086, 0x100D, PCI_ANY_ID, PCI_ANY_ID, 0, 0, 0},
99 {0x8086, 0x100E, PCI_ANY_ID, PCI_ANY_ID, 0, 0, 0},
100 {0x8086, 0x100F, PCI_ANY_ID, PCI_ANY_ID, 0, 0, 0},
101 {0x8086, 0x1011, PCI_ANY_ID, PCI_ANY_ID, 0, 0, 0},
102 {0x8086, 0x1010, PCI_ANY_ID, PCI_ANY_ID, 0, 0, 0},
103 {0x8086, 0x1012, PCI_ANY_ID, PCI_ANY_ID, 0, 0, 0},
104 {0x8086, 0x1016, PCI_ANY_ID, PCI_ANY_ID, 0, 0, 0},
105 {0x8086, 0x1017, PCI_ANY_ID, PCI_ANY_ID, 0, 0, 0},
106 {0x8086, 0x101E, PCI_ANY_ID, PCI_ANY_ID, 0, 0, 0},
107 /* required last entry */
111 MODULE_DEVICE_TABLE(pci, e1000_pci_tbl);
113 static char *e1000_strings[] = {
114 "Intel(R) PRO/1000 Network Connection",
115 "Compaq Gigabit Ethernet Server Adapter",
116 "IBM Mobile, Desktop & Server Adapters"
119 /* Local Function Prototypes */
121 int e1000_up(struct e1000_adapter *adapter);
122 void e1000_down(struct e1000_adapter *adapter);
123 void e1000_reset(struct e1000_adapter *adapter);
125 static int e1000_init_module(void);
126 static void e1000_exit_module(void);
127 static int e1000_probe(struct pci_dev *pdev, const struct pci_device_id *ent);
128 static void e1000_remove(struct pci_dev *pdev);
129 static int e1000_sw_init(struct e1000_adapter *adapter);
130 static int e1000_open(struct net_device *netdev);
131 static int e1000_close(struct net_device *netdev);
132 static int e1000_setup_tx_resources(struct e1000_adapter *adapter);
133 static int e1000_setup_rx_resources(struct e1000_adapter *adapter);
134 static void e1000_configure_tx(struct e1000_adapter *adapter);
135 static void e1000_configure_rx(struct e1000_adapter *adapter);
136 static void e1000_setup_rctl(struct e1000_adapter *adapter);
137 static void e1000_clean_tx_ring(struct e1000_adapter *adapter);
138 static void e1000_clean_rx_ring(struct e1000_adapter *adapter);
139 static void e1000_free_tx_resources(struct e1000_adapter *adapter);
140 static void e1000_free_rx_resources(struct e1000_adapter *adapter);
141 static void e1000_set_multi(struct net_device *netdev);
142 static void e1000_update_phy_info(unsigned long data);
143 static void e1000_watchdog(unsigned long data);
144 static int e1000_xmit_frame(struct sk_buff *skb, struct net_device *netdev);
145 static struct net_device_stats * e1000_get_stats(struct net_device *netdev);
146 static int e1000_change_mtu(struct net_device *netdev, int new_mtu);
147 static int e1000_set_mac(struct net_device *netdev, void *p);
148 static void e1000_update_stats(struct e1000_adapter *adapter);
149 static inline void e1000_irq_disable(struct e1000_adapter *adapter);
150 static inline void e1000_irq_enable(struct e1000_adapter *adapter);
151 static void e1000_intr(int irq, void *data, struct pt_regs *regs);
152 static void e1000_clean_tx_irq(struct e1000_adapter *adapter);
153 static void e1000_clean_rx_irq(struct e1000_adapter *adapter);
154 static void e1000_alloc_rx_buffers(struct e1000_adapter *adapter);
155 static int e1000_ioctl(struct net_device *netdev, struct ifreq *ifr, int cmd);
156 static void e1000_enter_82542_rst(struct e1000_adapter *adapter);
157 static void e1000_leave_82542_rst(struct e1000_adapter *adapter);
158 static inline void e1000_rx_checksum(struct e1000_adapter *adapter,
159 struct e1000_rx_desc *rx_desc,
160 struct sk_buff *skb);
161 static void e1000_tx_timeout(struct net_device *dev);
162 static void e1000_tx_timeout_task(struct net_device *dev);
164 static void e1000_vlan_rx_register(struct net_device *netdev, struct vlan_group *grp);
165 static void e1000_vlan_rx_add_vid(struct net_device *netdev, uint16_t vid);
166 static void e1000_vlan_rx_kill_vid(struct net_device *netdev, uint16_t vid);
167 static void e1000_restore_vlan(struct e1000_adapter *adapter);
169 static int e1000_notify_reboot(struct notifier_block *, unsigned long event, void *ptr);
170 static int e1000_suspend(struct pci_dev *pdev, uint32_t state);
172 static int e1000_resume(struct pci_dev *pdev);
175 struct notifier_block e1000_notifier_reboot = {
176 .notifier_call = e1000_notify_reboot,
181 /* Exported from other modules */
183 extern void e1000_check_options(struct e1000_adapter *adapter);
184 extern int e1000_ethtool_ioctl(struct net_device *netdev, struct ifreq *ifr);
186 static struct pci_driver e1000_driver = {
187 .name = e1000_driver_name,
188 .id_table = e1000_pci_tbl,
189 .probe = e1000_probe,
190 .remove = __devexit_p(e1000_remove),
191 /* Power Managment Hooks */
193 .suspend = e1000_suspend,
194 .resume = e1000_resume
198 MODULE_AUTHOR("Intel Corporation, <linux.nics@intel.com>");
199 MODULE_DESCRIPTION("Intel(R) PRO/1000 Network Driver");
200 MODULE_LICENSE("GPL");
203 * e1000_init_module - Driver Registration Routine
205 * e1000_init_module is the first routine called when the driver is
206 * loaded. All it does is register with the PCI subsystem.
210 e1000_init_module(void)
213 printk(KERN_INFO "%s - version %s\n",
214 e1000_driver_string, e1000_driver_version);
216 printk(KERN_INFO "%s\n", e1000_copyright);
218 ret = pci_module_init(&e1000_driver);
220 register_reboot_notifier(&e1000_notifier_reboot);
224 module_init(e1000_init_module);
227 * e1000_exit_module - Driver Exit Cleanup Routine
229 * e1000_exit_module is called just before the driver is removed
234 e1000_exit_module(void)
236 unregister_reboot_notifier(&e1000_notifier_reboot);
237 pci_unregister_driver(&e1000_driver);
240 module_exit(e1000_exit_module);
244 e1000_up(struct e1000_adapter *adapter)
246 struct net_device *netdev = adapter->netdev;
248 if(request_irq(netdev->irq, &e1000_intr, SA_SHIRQ | SA_SAMPLE_RANDOM,
249 netdev->name, netdev))
252 /* hardware has been reset, we need to reload some things */
254 e1000_set_multi(netdev);
255 e1000_restore_vlan(adapter);
257 e1000_configure_tx(adapter);
258 e1000_setup_rctl(adapter);
259 e1000_configure_rx(adapter);
260 e1000_alloc_rx_buffers(adapter);
262 mod_timer(&adapter->watchdog_timer, jiffies);
263 e1000_irq_enable(adapter);
269 e1000_down(struct e1000_adapter *adapter)
271 struct net_device *netdev = adapter->netdev;
273 e1000_irq_disable(adapter);
274 free_irq(netdev->irq, netdev);
275 del_timer_sync(&adapter->watchdog_timer);
276 del_timer_sync(&adapter->phy_info_timer);
277 adapter->link_speed = 0;
278 adapter->link_duplex = 0;
279 netif_carrier_off(netdev);
280 netif_stop_queue(netdev);
282 e1000_reset(adapter);
283 e1000_clean_tx_ring(adapter);
284 e1000_clean_rx_ring(adapter);
288 e1000_reset(struct e1000_adapter *adapter)
290 /* Repartition Pba for greater than 9k mtu
291 * To take effect CTRL.RST is required.
294 if(adapter->rx_buffer_len > E1000_RXBUFFER_8192)
295 E1000_WRITE_REG(&adapter->hw, PBA, E1000_JUMBO_PBA);
297 E1000_WRITE_REG(&adapter->hw, PBA, E1000_DEFAULT_PBA);
299 adapter->hw.fc = adapter->hw.original_fc;
300 e1000_reset_hw(&adapter->hw);
301 if(adapter->hw.mac_type >= e1000_82544)
302 E1000_WRITE_REG(&adapter->hw, WUC, 0);
303 e1000_init_hw(&adapter->hw);
304 e1000_reset_adaptive(&adapter->hw);
305 e1000_phy_get_info(&adapter->hw, &adapter->phy_info);
309 * e1000_probe - Device Initialization Routine
310 * @pdev: PCI device information struct
311 * @ent: entry in e1000_pci_tbl
313 * Returns 0 on success, negative on failure
315 * e1000_probe initializes an adapter identified by a pci_dev structure.
316 * The OS initialization, configuring of the adapter private structure,
317 * and a hardware reset occur.
321 e1000_probe(struct pci_dev *pdev,
322 const struct pci_device_id *ent)
324 struct net_device *netdev;
325 struct e1000_adapter *adapter;
326 static int cards_found = 0;
327 unsigned long mmio_start;
331 uint16_t eeprom_data;
333 if((i = pci_enable_device(pdev)))
336 if(!(i = pci_set_dma_mask(pdev, PCI_DMA_64BIT))) {
339 if((i = pci_set_dma_mask(pdev, PCI_DMA_32BIT))) {
340 E1000_ERR("No usable DMA configuration, aborting\n");
346 if((i = pci_request_regions(pdev, e1000_driver_name)))
349 pci_set_master(pdev);
351 netdev = alloc_etherdev(sizeof(struct e1000_adapter));
353 goto err_alloc_etherdev;
355 SET_MODULE_OWNER(netdev);
357 pci_set_drvdata(pdev, netdev);
358 adapter = netdev->priv;
359 adapter->netdev = netdev;
360 adapter->pdev = pdev;
361 adapter->hw.back = adapter;
363 mmio_start = pci_resource_start(pdev, BAR_0);
364 mmio_len = pci_resource_len(pdev, BAR_0);
366 adapter->hw.hw_addr = ioremap(mmio_start, mmio_len);
367 if(!adapter->hw.hw_addr)
370 for(i = BAR_1; i <= BAR_5; i++) {
371 if(pci_resource_len(pdev, i) == 0)
373 if(pci_resource_flags(pdev, i) & IORESOURCE_IO) {
374 adapter->hw.io_base = pci_resource_start(pdev, i);
379 netdev->open = &e1000_open;
380 netdev->stop = &e1000_close;
381 netdev->hard_start_xmit = &e1000_xmit_frame;
382 netdev->get_stats = &e1000_get_stats;
383 netdev->set_multicast_list = &e1000_set_multi;
384 netdev->set_mac_address = &e1000_set_mac;
385 netdev->change_mtu = &e1000_change_mtu;
386 netdev->do_ioctl = &e1000_ioctl;
387 netdev->tx_timeout = &e1000_tx_timeout;
388 netdev->watchdog_timeo = HZ;
389 netdev->vlan_rx_register = e1000_vlan_rx_register;
390 netdev->vlan_rx_add_vid = e1000_vlan_rx_add_vid;
391 netdev->vlan_rx_kill_vid = e1000_vlan_rx_kill_vid;
393 netdev->irq = pdev->irq;
394 netdev->mem_start = mmio_start;
395 netdev->mem_end = mmio_start + mmio_len;
396 netdev->base_addr = adapter->hw.io_base;
398 adapter->bd_number = cards_found;
399 adapter->id_string = e1000_strings[ent->driver_data];
401 /* setup the private structure */
403 if(e1000_sw_init(adapter))
406 if(adapter->hw.mac_type >= e1000_82543) {
407 netdev->features = NETIF_F_SG |
411 NETIF_F_HW_VLAN_FILTER;
413 netdev->features = NETIF_F_SG;
417 netdev->features |= NETIF_F_HIGHDMA;
419 /* make sure the EEPROM is good */
421 if(e1000_validate_eeprom_checksum(&adapter->hw) < 0) {
422 printk(KERN_ERR "The EEPROM Checksum Is Not Valid\n");
426 /* copy the MAC address out of the EEPROM */
428 e1000_read_mac_addr(&adapter->hw);
429 memcpy(netdev->dev_addr, adapter->hw.mac_addr, netdev->addr_len);
431 if(!is_valid_ether_addr(netdev->dev_addr))
434 e1000_read_part_num(&adapter->hw, &(adapter->part_num));
436 e1000_get_bus_info(&adapter->hw);
438 if((adapter->hw.mac_type == e1000_82544) &&
439 (adapter->hw.bus_type == e1000_bus_type_pcix))
441 adapter->max_data_per_txd = 4096;
443 adapter->max_data_per_txd = MAX_JUMBO_FRAME_SIZE;
446 init_timer(&adapter->watchdog_timer);
447 adapter->watchdog_timer.function = &e1000_watchdog;
448 adapter->watchdog_timer.data = (unsigned long) adapter;
450 init_timer(&adapter->phy_info_timer);
451 adapter->phy_info_timer.function = &e1000_update_phy_info;
452 adapter->phy_info_timer.data = (unsigned long) adapter;
454 INIT_TQUEUE(&adapter->tx_timeout_task,
455 (void (*)(void *))e1000_tx_timeout_task, netdev);
457 register_netdev(netdev);
458 memcpy(adapter->ifname, netdev->name, IFNAMSIZ);
459 adapter->ifname[IFNAMSIZ-1] = 0;
461 /* we're going to reset, so assume we have no link for now */
463 netif_carrier_off(netdev);
464 netif_stop_queue(netdev);
466 printk(KERN_INFO "%s: %s\n", netdev->name, adapter->id_string);
467 e1000_check_options(adapter);
469 /* Initial Wake on LAN setting
470 * If APM wake is enabled in the EEPROM,
471 * enable the ACPI Magic Packet filter
474 e1000_read_eeprom(&adapter->hw, EEPROM_INIT_CONTROL2_REG, &eeprom_data);
475 if((adapter->hw.mac_type >= e1000_82544) &&
476 (eeprom_data & E1000_EEPROM_APME))
477 adapter->wol |= E1000_WUFC_MAG;
479 /* reset the hardware with the new settings */
481 e1000_reset(adapter);
488 iounmap(adapter->hw.hw_addr);
490 pci_release_regions(pdev);
497 * e1000_remove - Device Removal Routine
498 * @pdev: PCI device information struct
500 * e1000_remove is called by the PCI subsystem to alert the driver
501 * that it should release a PCI device. The could be caused by a
502 * Hot-Plug event, or because the driver is going to be removed from
506 static void __devexit
507 e1000_remove(struct pci_dev *pdev)
509 struct net_device *netdev = pci_get_drvdata(pdev);
510 struct e1000_adapter *adapter = netdev->priv;
513 if(adapter->hw.mac_type >= e1000_82540) {
514 manc = E1000_READ_REG(&adapter->hw, MANC);
515 if(manc & E1000_MANC_SMBUS_EN) {
516 manc |= E1000_MANC_ARP_EN;
517 E1000_WRITE_REG(&adapter->hw, MANC, manc);
521 unregister_netdev(netdev);
523 e1000_phy_hw_reset(&adapter->hw);
525 iounmap(adapter->hw.hw_addr);
526 pci_release_regions(pdev);
532 * e1000_sw_init - Initialize general software structures (struct e1000_adapter)
533 * @adapter: board private structure to initialize
535 * e1000_sw_init initializes the Adapter private data structure.
536 * Fields are initialized based on PCI device information and
537 * OS network device settings (MTU size).
541 e1000_sw_init(struct e1000_adapter *adapter)
543 struct e1000_hw *hw = &adapter->hw;
544 struct net_device *netdev = adapter->netdev;
545 struct pci_dev *pdev = adapter->pdev;
547 /* PCI config space info */
549 hw->vendor_id = pdev->vendor;
550 hw->device_id = pdev->device;
551 hw->subsystem_vendor_id = pdev->subsystem_vendor;
552 hw->subsystem_id = pdev->subsystem_device;
554 pci_read_config_byte(pdev, PCI_REVISION_ID, &hw->revision_id);
556 pci_read_config_word(pdev, PCI_COMMAND, &hw->pci_cmd_word);
558 adapter->rx_buffer_len = E1000_RXBUFFER_2048;
559 hw->max_frame_size = netdev->mtu +
560 ENET_HEADER_SIZE + ETHERNET_FCS_SIZE;
561 hw->min_frame_size = MINIMUM_ETHERNET_FRAME_SIZE;
563 /* identify the MAC */
565 if (e1000_set_mac_type(hw)) {
566 E1000_ERR("Unknown MAC Type\n");
570 /* flow control settings */
572 hw->fc_high_water = E1000_FC_HIGH_THRESH;
573 hw->fc_low_water = E1000_FC_LOW_THRESH;
574 hw->fc_pause_time = E1000_FC_PAUSE_TIME;
577 /* Media type - copper or fiber */
579 if(hw->mac_type >= e1000_82543) {
580 uint32_t status = E1000_READ_REG(hw, STATUS);
582 if(status & E1000_STATUS_TBIMODE)
583 hw->media_type = e1000_media_type_fiber;
585 hw->media_type = e1000_media_type_copper;
587 hw->media_type = e1000_media_type_fiber;
590 if(hw->mac_type < e1000_82543)
591 hw->report_tx_early = 0;
593 hw->report_tx_early = 1;
595 hw->wait_autoneg_complete = FALSE;
596 hw->tbi_compatibility_en = TRUE;
597 hw->adaptive_ifs = TRUE;
601 if(hw->media_type == e1000_media_type_copper) {
602 hw->mdix = AUTO_ALL_MODES;
603 hw->disable_polarity_correction = FALSE;
606 atomic_set(&adapter->irq_sem, 1);
607 spin_lock_init(&adapter->stats_lock);
613 * e1000_open - Called when a network interface is made active
614 * @netdev: network interface device structure
616 * Returns 0 on success, negative value on failure
618 * The open entry point is called when a network interface is made
619 * active by the system (IFF_UP). At this point all resources needed
620 * for transmit and receive operations are allocated, the interrupt
621 * handler is registered with the OS, the watchdog timer is started,
622 * and the stack is notified that the interface is ready.
626 e1000_open(struct net_device *netdev)
628 struct e1000_adapter *adapter = netdev->priv;
630 /* allocate transmit descriptors */
632 if(e1000_setup_tx_resources(adapter))
635 /* allocate receive descriptors */
637 if(e1000_setup_rx_resources(adapter))
640 if(e1000_up(adapter))
646 e1000_free_rx_resources(adapter);
648 e1000_free_tx_resources(adapter);
650 e1000_reset(adapter);
656 * e1000_close - Disables a network interface
657 * @netdev: network interface device structure
659 * Returns 0, this is not allowed to fail
661 * The close entry point is called when an interface is de-activated
662 * by the OS. The hardware is still under the drivers control, but
663 * needs to be disabled. A global MAC reset is issued to stop the
664 * hardware, and all transmit and receive resources are freed.
668 e1000_close(struct net_device *netdev)
670 struct e1000_adapter *adapter = netdev->priv;
674 e1000_free_tx_resources(adapter);
675 e1000_free_rx_resources(adapter);
681 * e1000_setup_tx_resources - allocate Tx resources (Descriptors)
682 * @adapter: board private structure
684 * Return 0 on success, negative on failure
688 e1000_setup_tx_resources(struct e1000_adapter *adapter)
690 struct e1000_desc_ring *txdr = &adapter->tx_ring;
691 struct pci_dev *pdev = adapter->pdev;
694 size = sizeof(struct e1000_buffer) * txdr->count;
695 txdr->buffer_info = kmalloc(size, GFP_KERNEL);
696 if(!txdr->buffer_info) {
699 memset(txdr->buffer_info, 0, size);
701 /* round up to nearest 4K */
703 txdr->size = txdr->count * sizeof(struct e1000_tx_desc);
704 E1000_ROUNDUP(txdr->size, 4096);
706 txdr->desc = pci_alloc_consistent(pdev, txdr->size, &txdr->dma);
708 kfree(txdr->buffer_info);
711 memset(txdr->desc, 0, txdr->size);
713 txdr->next_to_use = 0;
714 txdr->next_to_clean = 0;
720 * e1000_configure_tx - Configure 8254x Transmit Unit after Reset
721 * @adapter: board private structure
723 * Configure the Tx unit of the MAC after a reset.
727 e1000_configure_tx(struct e1000_adapter *adapter)
729 uint64_t tdba = adapter->tx_ring.dma;
730 uint32_t tdlen = adapter->tx_ring.count * sizeof(struct e1000_tx_desc);
733 E1000_WRITE_REG(&adapter->hw, TDBAL, (tdba & 0x00000000ffffffffULL));
734 E1000_WRITE_REG(&adapter->hw, TDBAH, (tdba >> 32));
736 E1000_WRITE_REG(&adapter->hw, TDLEN, tdlen);
738 /* Setup the HW Tx Head and Tail descriptor pointers */
740 E1000_WRITE_REG(&adapter->hw, TDH, 0);
741 E1000_WRITE_REG(&adapter->hw, TDT, 0);
743 /* Set the default values for the Tx Inter Packet Gap timer */
745 switch (adapter->hw.mac_type) {
746 case e1000_82542_rev2_0:
747 case e1000_82542_rev2_1:
748 tipg = DEFAULT_82542_TIPG_IPGT;
749 tipg |= DEFAULT_82542_TIPG_IPGR1 << E1000_TIPG_IPGR1_SHIFT;
750 tipg |= DEFAULT_82542_TIPG_IPGR2 << E1000_TIPG_IPGR2_SHIFT;
753 if(adapter->hw.media_type == e1000_media_type_fiber)
754 tipg = DEFAULT_82543_TIPG_IPGT_FIBER;
756 tipg = DEFAULT_82543_TIPG_IPGT_COPPER;
757 tipg |= DEFAULT_82543_TIPG_IPGR1 << E1000_TIPG_IPGR1_SHIFT;
758 tipg |= DEFAULT_82543_TIPG_IPGR2 << E1000_TIPG_IPGR2_SHIFT;
760 E1000_WRITE_REG(&adapter->hw, TIPG, tipg);
762 /* Set the Tx Interrupt Delay register */
764 E1000_WRITE_REG(&adapter->hw, TIDV, adapter->tx_int_delay);
765 if(adapter->hw.mac_type >= e1000_82540)
766 E1000_WRITE_REG(&adapter->hw, TADV, adapter->tx_abs_int_delay);
768 /* Program the Transmit Control Register */
770 tctl = E1000_READ_REG(&adapter->hw, TCTL);
772 tctl &= ~E1000_TCTL_CT;
773 tctl |= E1000_TCTL_EN | E1000_TCTL_PSP |
774 (E1000_COLLISION_THRESHOLD << E1000_CT_SHIFT);
776 E1000_WRITE_REG(&adapter->hw, TCTL, tctl);
778 e1000_config_collision_dist(&adapter->hw);
780 /* Setup Transmit Descriptor Settings for this adapter */
781 adapter->txd_cmd = E1000_TXD_CMD_IFCS | E1000_TXD_CMD_IDE;
783 if(adapter->hw.report_tx_early == 1)
784 adapter->txd_cmd |= E1000_TXD_CMD_RS;
786 adapter->txd_cmd |= E1000_TXD_CMD_RPS;
790 * e1000_setup_rx_resources - allocate Rx resources (Descriptors)
791 * @adapter: board private structure
793 * Returns 0 on success, negative on failure
797 e1000_setup_rx_resources(struct e1000_adapter *adapter)
799 struct e1000_desc_ring *rxdr = &adapter->rx_ring;
800 struct pci_dev *pdev = adapter->pdev;
803 size = sizeof(struct e1000_buffer) * rxdr->count;
804 rxdr->buffer_info = kmalloc(size, GFP_KERNEL);
805 if(!rxdr->buffer_info) {
808 memset(rxdr->buffer_info, 0, size);
810 /* Round up to nearest 4K */
812 rxdr->size = rxdr->count * sizeof(struct e1000_rx_desc);
813 E1000_ROUNDUP(rxdr->size, 4096);
815 rxdr->desc = pci_alloc_consistent(pdev, rxdr->size, &rxdr->dma);
818 kfree(rxdr->buffer_info);
821 memset(rxdr->desc, 0, rxdr->size);
823 rxdr->next_to_clean = 0;
824 rxdr->next_to_use = 0;
830 * e1000_setup_rctl - configure the receive control register
831 * @adapter: Board private structure
835 e1000_setup_rctl(struct e1000_adapter *adapter)
839 rctl = E1000_READ_REG(&adapter->hw, RCTL);
841 rctl &= ~(3 << E1000_RCTL_MO_SHIFT);
843 rctl |= E1000_RCTL_EN | E1000_RCTL_BAM |
844 E1000_RCTL_LBM_NO | E1000_RCTL_RDMTS_HALF |
845 (adapter->hw.mc_filter_type << E1000_RCTL_MO_SHIFT);
847 if(adapter->hw.tbi_compatibility_on == 1)
848 rctl |= E1000_RCTL_SBP;
850 rctl &= ~E1000_RCTL_SBP;
852 rctl &= ~(E1000_RCTL_SZ_4096);
853 switch (adapter->rx_buffer_len) {
854 case E1000_RXBUFFER_2048:
856 rctl |= E1000_RCTL_SZ_2048;
857 rctl &= ~(E1000_RCTL_BSEX | E1000_RCTL_LPE);
859 case E1000_RXBUFFER_4096:
860 rctl |= E1000_RCTL_SZ_4096 | E1000_RCTL_BSEX | E1000_RCTL_LPE;
862 case E1000_RXBUFFER_8192:
863 rctl |= E1000_RCTL_SZ_8192 | E1000_RCTL_BSEX | E1000_RCTL_LPE;
865 case E1000_RXBUFFER_16384:
866 rctl |= E1000_RCTL_SZ_16384 | E1000_RCTL_BSEX | E1000_RCTL_LPE;
870 E1000_WRITE_REG(&adapter->hw, RCTL, rctl);
874 * e1000_configure_rx - Configure 8254x Receive Unit after Reset
875 * @adapter: board private structure
877 * Configure the Rx unit of the MAC after a reset.
881 e1000_configure_rx(struct e1000_adapter *adapter)
883 uint64_t rdba = adapter->rx_ring.dma;
884 uint32_t rdlen = adapter->rx_ring.count * sizeof(struct e1000_rx_desc);
888 /* make sure receives are disabled while setting up the descriptors */
890 rctl = E1000_READ_REG(&adapter->hw, RCTL);
891 E1000_WRITE_REG(&adapter->hw, RCTL, rctl & ~E1000_RCTL_EN);
893 /* set the Receive Delay Timer Register */
895 E1000_WRITE_REG(&adapter->hw, RDTR, adapter->rx_int_delay);
897 if(adapter->hw.mac_type >= e1000_82540) {
898 E1000_WRITE_REG(&adapter->hw, RADV, adapter->rx_abs_int_delay);
900 /* Set the interrupt throttling rate. Value is calculated
901 * as DEFAULT_ITR = 1/(MAX_INTS_PER_SEC * 256ns) */
902 #define MAX_INTS_PER_SEC 8000
903 #define DEFAULT_ITR 1000000000/(MAX_INTS_PER_SEC * 256)
904 E1000_WRITE_REG(&adapter->hw, ITR, DEFAULT_ITR);
907 /* Setup the Base and Length of the Rx Descriptor Ring */
909 E1000_WRITE_REG(&adapter->hw, RDBAL, (rdba & 0x00000000ffffffffULL));
910 E1000_WRITE_REG(&adapter->hw, RDBAH, (rdba >> 32));
912 E1000_WRITE_REG(&adapter->hw, RDLEN, rdlen);
914 /* Setup the HW Rx Head and Tail Descriptor Pointers */
915 E1000_WRITE_REG(&adapter->hw, RDH, 0);
916 E1000_WRITE_REG(&adapter->hw, RDT, 0);
918 /* Enable 82543 Receive Checksum Offload for TCP and UDP */
919 if((adapter->hw.mac_type >= e1000_82543) &&
920 (adapter->rx_csum == TRUE)) {
921 rxcsum = E1000_READ_REG(&adapter->hw, RXCSUM);
922 rxcsum |= E1000_RXCSUM_TUOFL;
923 E1000_WRITE_REG(&adapter->hw, RXCSUM, rxcsum);
926 /* Enable Receives */
928 E1000_WRITE_REG(&adapter->hw, RCTL, rctl);
932 * e1000_free_tx_resources - Free Tx Resources
933 * @adapter: board private structure
935 * Free all transmit software resources
939 e1000_free_tx_resources(struct e1000_adapter *adapter)
941 struct pci_dev *pdev = adapter->pdev;
943 e1000_clean_tx_ring(adapter);
945 kfree(adapter->tx_ring.buffer_info);
946 adapter->tx_ring.buffer_info = NULL;
948 pci_free_consistent(pdev, adapter->tx_ring.size,
949 adapter->tx_ring.desc, adapter->tx_ring.dma);
951 adapter->tx_ring.desc = NULL;
955 * e1000_clean_tx_ring - Free Tx Buffers
956 * @adapter: board private structure
960 e1000_clean_tx_ring(struct e1000_adapter *adapter)
962 struct pci_dev *pdev = adapter->pdev;
966 /* Free all the Tx ring sk_buffs */
968 for(i = 0; i < adapter->tx_ring.count; i++) {
969 if(adapter->tx_ring.buffer_info[i].skb) {
972 adapter->tx_ring.buffer_info[i].dma,
973 adapter->tx_ring.buffer_info[i].length,
976 dev_kfree_skb(adapter->tx_ring.buffer_info[i].skb);
978 adapter->tx_ring.buffer_info[i].skb = NULL;
982 size = sizeof(struct e1000_buffer) * adapter->tx_ring.count;
983 memset(adapter->tx_ring.buffer_info, 0, size);
985 /* Zero out the descriptor ring */
987 memset(adapter->tx_ring.desc, 0, adapter->tx_ring.size);
989 adapter->tx_ring.next_to_use = 0;
990 adapter->tx_ring.next_to_clean = 0;
992 E1000_WRITE_REG(&adapter->hw, TDH, 0);
993 E1000_WRITE_REG(&adapter->hw, TDT, 0);
997 * e1000_free_rx_resources - Free Rx Resources
998 * @adapter: board private structure
1000 * Free all receive software resources
1004 e1000_free_rx_resources(struct e1000_adapter *adapter)
1006 struct pci_dev *pdev = adapter->pdev;
1008 e1000_clean_rx_ring(adapter);
1010 kfree(adapter->rx_ring.buffer_info);
1011 adapter->rx_ring.buffer_info = NULL;
1013 pci_free_consistent(pdev, adapter->rx_ring.size,
1014 adapter->rx_ring.desc, adapter->rx_ring.dma);
1016 adapter->rx_ring.desc = NULL;
1020 * e1000_clean_rx_ring - Free Rx Buffers
1021 * @adapter: board private structure
1025 e1000_clean_rx_ring(struct e1000_adapter *adapter)
1027 struct pci_dev *pdev = adapter->pdev;
1031 /* Free all the Rx ring sk_buffs */
1033 for(i = 0; i < adapter->rx_ring.count; i++) {
1034 if(adapter->rx_ring.buffer_info[i].skb) {
1036 pci_unmap_single(pdev,
1037 adapter->rx_ring.buffer_info[i].dma,
1038 adapter->rx_ring.buffer_info[i].length,
1039 PCI_DMA_FROMDEVICE);
1041 dev_kfree_skb(adapter->rx_ring.buffer_info[i].skb);
1043 adapter->rx_ring.buffer_info[i].skb = NULL;
1047 size = sizeof(struct e1000_buffer) * adapter->rx_ring.count;
1048 memset(adapter->rx_ring.buffer_info, 0, size);
1050 /* Zero out the descriptor ring */
1052 memset(adapter->rx_ring.desc, 0, adapter->rx_ring.size);
1054 adapter->rx_ring.next_to_clean = 0;
1055 adapter->rx_ring.next_to_use = 0;
1057 E1000_WRITE_REG(&adapter->hw, RDH, 0);
1058 E1000_WRITE_REG(&adapter->hw, RDT, 0);
1061 /* The 82542 2.0 (revision 2) needs to have the receive unit in reset
1062 * and memory write and invalidate disabled for certain operations
1065 e1000_enter_82542_rst(struct e1000_adapter *adapter)
1067 struct net_device *netdev = adapter->netdev;
1070 e1000_pci_clear_mwi(&adapter->hw);
1072 rctl = E1000_READ_REG(&adapter->hw, RCTL);
1073 rctl |= E1000_RCTL_RST;
1074 E1000_WRITE_REG(&adapter->hw, RCTL, rctl);
1075 E1000_WRITE_FLUSH(&adapter->hw);
1078 if(netif_running(netdev))
1079 e1000_clean_rx_ring(adapter);
1083 e1000_leave_82542_rst(struct e1000_adapter *adapter)
1085 struct net_device *netdev = adapter->netdev;
1088 rctl = E1000_READ_REG(&adapter->hw, RCTL);
1089 rctl &= ~E1000_RCTL_RST;
1090 E1000_WRITE_REG(&adapter->hw, RCTL, rctl);
1091 E1000_WRITE_FLUSH(&adapter->hw);
1094 if(adapter->hw.pci_cmd_word & PCI_COMMAND_INVALIDATE)
1095 e1000_pci_set_mwi(&adapter->hw);
1097 if(netif_running(netdev)) {
1098 e1000_configure_rx(adapter);
1099 e1000_alloc_rx_buffers(adapter);
1104 * e1000_set_mac - Change the Ethernet Address of the NIC
1105 * @netdev: network interface device structure
1106 * @p: pointer to an address structure
1108 * Returns 0 on success, negative on failure
1112 e1000_set_mac(struct net_device *netdev, void *p)
1114 struct e1000_adapter *adapter = netdev->priv;
1115 struct sockaddr *addr = p;
1117 if(!is_valid_ether_addr(addr->sa_data))
1118 return -EADDRNOTAVAIL;
1120 /* 82542 2.0 needs to be in reset to write receive address registers */
1122 if(adapter->hw.mac_type == e1000_82542_rev2_0)
1123 e1000_enter_82542_rst(adapter);
1125 memcpy(netdev->dev_addr, addr->sa_data, netdev->addr_len);
1126 memcpy(adapter->hw.mac_addr, addr->sa_data, netdev->addr_len);
1128 e1000_rar_set(&adapter->hw, adapter->hw.mac_addr, 0);
1130 if(adapter->hw.mac_type == e1000_82542_rev2_0)
1131 e1000_leave_82542_rst(adapter);
1137 * e1000_set_multi - Multicast and Promiscuous mode set
1138 * @netdev: network interface device structure
1140 * The set_multi entry point is called whenever the multicast address
1141 * list or the network interface flags are updated. This routine is
1142 * resposible for configuring the hardware for proper multicast,
1143 * promiscuous mode, and all-multi behavior.
1147 e1000_set_multi(struct net_device *netdev)
1149 struct e1000_adapter *adapter = netdev->priv;
1150 struct e1000_hw *hw = &adapter->hw;
1151 struct dev_mc_list *mc_ptr;
1153 uint32_t hash_value;
1156 /* Check for Promiscuous and All Multicast modes */
1158 rctl = E1000_READ_REG(hw, RCTL);
1160 if(netdev->flags & IFF_PROMISC) {
1161 rctl |= (E1000_RCTL_UPE | E1000_RCTL_MPE);
1162 } else if(netdev->flags & IFF_ALLMULTI) {
1163 rctl |= E1000_RCTL_MPE;
1164 rctl &= ~E1000_RCTL_UPE;
1166 rctl &= ~(E1000_RCTL_UPE | E1000_RCTL_MPE);
1169 E1000_WRITE_REG(hw, RCTL, rctl);
1171 /* 82542 2.0 needs to be in reset to write receive address registers */
1173 if(hw->mac_type == e1000_82542_rev2_0)
1174 e1000_enter_82542_rst(adapter);
1176 /* load the first 15 multicast address into the exact filters 1-15
1177 * RAR 0 is used for the station MAC adddress
1178 * if there are not 15 addresses, go ahead and clear the filters
1180 mc_ptr = netdev->mc_list;
1182 for(i = 1; i < E1000_RAR_ENTRIES; i++) {
1184 e1000_rar_set(hw, mc_ptr->dmi_addr, i);
1185 mc_ptr = mc_ptr->next;
1187 E1000_WRITE_REG_ARRAY(hw, RA, i << 1, 0);
1188 E1000_WRITE_REG_ARRAY(hw, RA, (i << 1) + 1, 0);
1192 /* clear the old settings from the multicast hash table */
1194 for(i = 0; i < E1000_NUM_MTA_REGISTERS; i++)
1195 E1000_WRITE_REG_ARRAY(hw, MTA, i, 0);
1197 /* load any remaining addresses into the hash table */
1199 for(; mc_ptr; mc_ptr = mc_ptr->next) {
1200 hash_value = e1000_hash_mc_addr(hw, mc_ptr->dmi_addr);
1201 e1000_mta_set(hw, hash_value);
1204 if(hw->mac_type == e1000_82542_rev2_0)
1205 e1000_leave_82542_rst(adapter);
1209 /* need to wait a few seconds after link up to get diagnostic information from the phy */
1212 e1000_update_phy_info(unsigned long data)
1214 struct e1000_adapter *adapter = (struct e1000_adapter *) data;
1215 e1000_phy_get_info(&adapter->hw, &adapter->phy_info);
1219 * e1000_watchdog - Timer Call-back
1220 * @data: pointer to netdev cast into an unsigned long
1224 e1000_watchdog(unsigned long data)
1226 struct e1000_adapter *adapter = (struct e1000_adapter *) data;
1227 struct net_device *netdev = adapter->netdev;
1228 struct e1000_desc_ring *txdr = &adapter->tx_ring;
1231 e1000_check_for_link(&adapter->hw);
1233 if(E1000_READ_REG(&adapter->hw, STATUS) & E1000_STATUS_LU) {
1234 if(!netif_carrier_ok(netdev)) {
1235 e1000_get_speed_and_duplex(&adapter->hw,
1236 &adapter->link_speed,
1237 &adapter->link_duplex);
1240 "e1000: %s NIC Link is Up %d Mbps %s\n",
1241 netdev->name, adapter->link_speed,
1242 adapter->link_duplex == FULL_DUPLEX ?
1243 "Full Duplex" : "Half Duplex");
1245 netif_carrier_on(netdev);
1246 netif_wake_queue(netdev);
1247 mod_timer(&adapter->phy_info_timer, jiffies + 2 * HZ);
1250 if(netif_carrier_ok(netdev)) {
1251 adapter->link_speed = 0;
1252 adapter->link_duplex = 0;
1254 "e1000: %s NIC Link is Down\n",
1256 netif_carrier_off(netdev);
1257 netif_stop_queue(netdev);
1258 mod_timer(&adapter->phy_info_timer, jiffies + 2 * HZ);
1262 e1000_update_stats(adapter);
1263 e1000_update_adaptive(&adapter->hw);
1266 /* Cause software interrupt to ensure rx ring is cleaned */
1267 E1000_WRITE_REG(&adapter->hw, ICS, E1000_ICS_RXDMT0);
1269 /* Early detection of hung controller */
1270 i = txdr->next_to_clean;
1271 if(txdr->buffer_info[i].dma &&
1272 time_after(jiffies, txdr->buffer_info[i].time_stamp + HZ) &&
1273 !(E1000_READ_REG(&adapter->hw, STATUS) & E1000_STATUS_TXOFF))
1274 netif_stop_queue(netdev);
1276 /* Reset the timer */
1277 mod_timer(&adapter->watchdog_timer, jiffies + 2 * HZ);
1280 #define E1000_TX_FLAGS_CSUM 0x00000001
1281 #define E1000_TX_FLAGS_VLAN 0x00000002
1282 #define E1000_TX_FLAGS_VLAN_MASK 0xffff0000
1283 #define E1000_TX_FLAGS_VLAN_SHIFT 16
1285 static inline boolean_t
1286 e1000_tx_csum(struct e1000_adapter *adapter, struct sk_buff *skb)
1288 struct e1000_context_desc *context_desc;
1292 if(skb->ip_summed == CHECKSUM_HW) {
1293 css = skb->h.raw - skb->data;
1294 cso = (skb->h.raw + skb->csum) - skb->data;
1296 i = adapter->tx_ring.next_to_use;
1297 context_desc = E1000_CONTEXT_DESC(adapter->tx_ring, i);
1299 context_desc->upper_setup.tcp_fields.tucss = css;
1300 context_desc->upper_setup.tcp_fields.tucso = cso;
1301 context_desc->upper_setup.tcp_fields.tucse = 0;
1302 context_desc->tcp_seg_setup.data = 0;
1303 context_desc->cmd_and_length =
1304 cpu_to_le32(adapter->txd_cmd | E1000_TXD_CMD_DEXT);
1306 i = (i + 1) % adapter->tx_ring.count;
1307 adapter->tx_ring.next_to_use = i;
1316 e1000_tx_map(struct e1000_adapter *adapter, struct sk_buff *skb)
1318 struct e1000_desc_ring *tx_ring = &adapter->tx_ring;
1319 int len, offset, size, count, i;
1322 len = skb->len - skb->data_len;
1323 i = (tx_ring->next_to_use + tx_ring->count - 1) % tx_ring->count;
1329 i = (i + 1) % tx_ring->count;
1330 size = min(len, adapter->max_data_per_txd);
1331 tx_ring->buffer_info[i].length = size;
1332 tx_ring->buffer_info[i].dma =
1333 pci_map_single(adapter->pdev,
1337 tx_ring->buffer_info[i].time_stamp = jiffies;
1344 for(f = 0; f < skb_shinfo(skb)->nr_frags; f++) {
1345 struct skb_frag_struct *frag;
1347 frag = &skb_shinfo(skb)->frags[f];
1352 i = (i + 1) % tx_ring->count;
1353 size = min(len, adapter->max_data_per_txd);
1354 tx_ring->buffer_info[i].length = size;
1355 tx_ring->buffer_info[i].dma =
1356 pci_map_page(adapter->pdev,
1358 frag->page_offset + offset,
1367 tx_ring->buffer_info[i].skb = skb;
1373 e1000_tx_queue(struct e1000_adapter *adapter, int count, int tx_flags)
1375 struct e1000_desc_ring *tx_ring = &adapter->tx_ring;
1376 struct e1000_tx_desc *tx_desc = NULL;
1377 uint32_t txd_upper, txd_lower;
1381 txd_lower = adapter->txd_cmd;
1383 if(tx_flags & E1000_TX_FLAGS_CSUM) {
1384 txd_lower |= E1000_TXD_CMD_DEXT | E1000_TXD_DTYP_D;
1385 txd_upper |= E1000_TXD_POPTS_TXSM << 8;
1388 if(tx_flags & E1000_TX_FLAGS_VLAN) {
1389 txd_lower |= E1000_TXD_CMD_VLE;
1390 txd_upper |= (tx_flags & E1000_TX_FLAGS_VLAN_MASK);
1393 i = tx_ring->next_to_use;
1396 tx_desc = E1000_TX_DESC(*tx_ring, i);
1397 tx_desc->buffer_addr = cpu_to_le64(tx_ring->buffer_info[i].dma);
1398 tx_desc->lower.data =
1399 cpu_to_le32(txd_lower | tx_ring->buffer_info[i].length);
1400 tx_desc->upper.data = cpu_to_le32(txd_upper);
1401 i = (i + 1) % tx_ring->count;
1404 tx_desc->lower.data |= cpu_to_le32(E1000_TXD_CMD_EOP);
1406 /* Force memory writes to complete before letting h/w
1407 * know there are new descriptors to fetch. (Only
1408 * applicable for weak-ordered memory model archs,
1409 * such as IA-64). */
1412 tx_ring->next_to_use = i;
1413 E1000_WRITE_REG(&adapter->hw, TDT, i);
1416 #define TXD_USE_COUNT(S, X) (((S) / (X)) + (((S) % (X)) ? 1 : 0))
1419 e1000_xmit_frame(struct sk_buff *skb, struct net_device *netdev)
1421 struct e1000_adapter *adapter = netdev->priv;
1422 int tx_flags = 0, count;
1425 count = TXD_USE_COUNT(skb->len - skb->data_len,
1426 adapter->max_data_per_txd);
1429 dev_kfree_skb_any(skb);
1433 for(f = 0; f < skb_shinfo(skb)->nr_frags; f++)
1434 count += TXD_USE_COUNT(skb_shinfo(skb)->frags[f].size,
1435 adapter->max_data_per_txd);
1437 if(skb->ip_summed == CHECKSUM_HW)
1440 if(E1000_DESC_UNUSED(&adapter->tx_ring) < count) {
1441 netif_stop_queue(netdev);
1445 if(e1000_tx_csum(adapter, skb))
1446 tx_flags |= E1000_TX_FLAGS_CSUM;
1448 if(adapter->vlgrp && vlan_tx_tag_present(skb)) {
1449 tx_flags |= E1000_TX_FLAGS_VLAN;
1450 tx_flags |= (vlan_tx_tag_get(skb) << E1000_TX_FLAGS_VLAN_SHIFT);
1453 count = e1000_tx_map(adapter, skb);
1455 e1000_tx_queue(adapter, count, tx_flags);
1457 netdev->trans_start = jiffies;
1463 * e1000_tx_timeout - Respond to a Tx Hang
1464 * @netdev: network interface device structure
1468 e1000_tx_timeout(struct net_device *netdev)
1470 struct e1000_adapter *adapter = netdev->priv;
1472 /* Do the reset outside of interrupt context */
1473 schedule_task(&adapter->tx_timeout_task);
1477 e1000_tx_timeout_task(struct net_device *netdev)
1479 struct e1000_adapter *adapter = netdev->priv;
1481 netif_device_detach(netdev);
1482 e1000_down(adapter);
1484 netif_device_attach(netdev);
1488 * e1000_get_stats - Get System Network Statistics
1489 * @netdev: network interface device structure
1491 * Returns the address of the device statistics structure.
1492 * The statistics are actually updated from the timer callback.
1495 static struct net_device_stats *
1496 e1000_get_stats(struct net_device *netdev)
1498 struct e1000_adapter *adapter = netdev->priv;
1500 return &adapter->net_stats;
1504 * e1000_change_mtu - Change the Maximum Transfer Unit
1505 * @netdev: network interface device structure
1506 * @new_mtu: new value for maximum frame size
1508 * Returns 0 on success, negative on failure
1512 e1000_change_mtu(struct net_device *netdev, int new_mtu)
1514 struct e1000_adapter *adapter = netdev->priv;
1515 int old_mtu = adapter->rx_buffer_len;
1516 int max_frame = new_mtu + ENET_HEADER_SIZE + ETHERNET_FCS_SIZE;
1518 if((max_frame < MINIMUM_ETHERNET_FRAME_SIZE) ||
1519 (max_frame > MAX_JUMBO_FRAME_SIZE)) {
1520 E1000_ERR("Invalid MTU setting\n");
1524 if(max_frame <= MAXIMUM_ETHERNET_FRAME_SIZE) {
1525 adapter->rx_buffer_len = E1000_RXBUFFER_2048;
1527 } else if(adapter->hw.mac_type < e1000_82543) {
1528 E1000_ERR("Jumbo Frames not supported on 82542\n");
1531 } else if(max_frame <= E1000_RXBUFFER_4096) {
1532 adapter->rx_buffer_len = E1000_RXBUFFER_4096;
1534 } else if(max_frame <= E1000_RXBUFFER_8192) {
1535 adapter->rx_buffer_len = E1000_RXBUFFER_8192;
1538 adapter->rx_buffer_len = E1000_RXBUFFER_16384;
1541 if(old_mtu != adapter->rx_buffer_len && netif_running(netdev)) {
1543 e1000_down(adapter);
1547 netdev->mtu = new_mtu;
1548 adapter->hw.max_frame_size = max_frame;
1554 * e1000_update_stats - Update the board statistics counters
1555 * @adapter: board private structure
1559 e1000_update_stats(struct e1000_adapter *adapter)
1561 struct e1000_hw *hw = &adapter->hw;
1562 unsigned long flags;
1565 #define PHY_IDLE_ERROR_COUNT_MASK 0x00FF
1567 spin_lock_irqsave(&adapter->stats_lock, flags);
1569 /* these counters are modified from e1000_adjust_tbi_stats,
1570 * called from the interrupt context, so they must only
1571 * be written while holding adapter->stats_lock
1574 adapter->stats.crcerrs += E1000_READ_REG(hw, CRCERRS);
1575 adapter->stats.gprc += E1000_READ_REG(hw, GPRC);
1576 adapter->stats.gorcl += E1000_READ_REG(hw, GORCL);
1577 adapter->stats.gorch += E1000_READ_REG(hw, GORCH);
1578 adapter->stats.bprc += E1000_READ_REG(hw, BPRC);
1579 adapter->stats.mprc += E1000_READ_REG(hw, MPRC);
1580 adapter->stats.roc += E1000_READ_REG(hw, ROC);
1581 adapter->stats.prc64 += E1000_READ_REG(hw, PRC64);
1582 adapter->stats.prc127 += E1000_READ_REG(hw, PRC127);
1583 adapter->stats.prc255 += E1000_READ_REG(hw, PRC255);
1584 adapter->stats.prc511 += E1000_READ_REG(hw, PRC511);
1585 adapter->stats.prc1023 += E1000_READ_REG(hw, PRC1023);
1586 adapter->stats.prc1522 += E1000_READ_REG(hw, PRC1522);
1588 spin_unlock_irqrestore(&adapter->stats_lock, flags);
1590 /* the rest of the counters are only modified here */
1592 adapter->stats.symerrs += E1000_READ_REG(hw, SYMERRS);
1593 adapter->stats.mpc += E1000_READ_REG(hw, MPC);
1594 adapter->stats.scc += E1000_READ_REG(hw, SCC);
1595 adapter->stats.ecol += E1000_READ_REG(hw, ECOL);
1596 adapter->stats.mcc += E1000_READ_REG(hw, MCC);
1597 adapter->stats.latecol += E1000_READ_REG(hw, LATECOL);
1598 adapter->stats.dc += E1000_READ_REG(hw, DC);
1599 adapter->stats.sec += E1000_READ_REG(hw, SEC);
1600 adapter->stats.rlec += E1000_READ_REG(hw, RLEC);
1601 adapter->stats.xonrxc += E1000_READ_REG(hw, XONRXC);
1602 adapter->stats.xontxc += E1000_READ_REG(hw, XONTXC);
1603 adapter->stats.xoffrxc += E1000_READ_REG(hw, XOFFRXC);
1604 adapter->stats.xofftxc += E1000_READ_REG(hw, XOFFTXC);
1605 adapter->stats.fcruc += E1000_READ_REG(hw, FCRUC);
1606 adapter->stats.gptc += E1000_READ_REG(hw, GPTC);
1607 adapter->stats.gotcl += E1000_READ_REG(hw, GOTCL);
1608 adapter->stats.gotch += E1000_READ_REG(hw, GOTCH);
1609 adapter->stats.rnbc += E1000_READ_REG(hw, RNBC);
1610 adapter->stats.ruc += E1000_READ_REG(hw, RUC);
1611 adapter->stats.rfc += E1000_READ_REG(hw, RFC);
1612 adapter->stats.rjc += E1000_READ_REG(hw, RJC);
1613 adapter->stats.torl += E1000_READ_REG(hw, TORL);
1614 adapter->stats.torh += E1000_READ_REG(hw, TORH);
1615 adapter->stats.totl += E1000_READ_REG(hw, TOTL);
1616 adapter->stats.toth += E1000_READ_REG(hw, TOTH);
1617 adapter->stats.tpr += E1000_READ_REG(hw, TPR);
1618 adapter->stats.ptc64 += E1000_READ_REG(hw, PTC64);
1619 adapter->stats.ptc127 += E1000_READ_REG(hw, PTC127);
1620 adapter->stats.ptc255 += E1000_READ_REG(hw, PTC255);
1621 adapter->stats.ptc511 += E1000_READ_REG(hw, PTC511);
1622 adapter->stats.ptc1023 += E1000_READ_REG(hw, PTC1023);
1623 adapter->stats.ptc1522 += E1000_READ_REG(hw, PTC1522);
1624 adapter->stats.mptc += E1000_READ_REG(hw, MPTC);
1625 adapter->stats.bptc += E1000_READ_REG(hw, BPTC);
1627 /* used for adaptive IFS */
1629 hw->tx_packet_delta = E1000_READ_REG(hw, TPT);
1630 adapter->stats.tpt += hw->tx_packet_delta;
1631 hw->collision_delta = E1000_READ_REG(hw, COLC);
1632 adapter->stats.colc += hw->collision_delta;
1634 if(hw->mac_type >= e1000_82543) {
1635 adapter->stats.algnerrc += E1000_READ_REG(hw, ALGNERRC);
1636 adapter->stats.rxerrc += E1000_READ_REG(hw, RXERRC);
1637 adapter->stats.tncrs += E1000_READ_REG(hw, TNCRS);
1638 adapter->stats.cexterr += E1000_READ_REG(hw, CEXTERR);
1639 adapter->stats.tsctc += E1000_READ_REG(hw, TSCTC);
1640 adapter->stats.tsctfc += E1000_READ_REG(hw, TSCTFC);
1643 /* Fill out the OS statistics structure */
1645 adapter->net_stats.rx_packets = adapter->stats.gprc;
1646 adapter->net_stats.tx_packets = adapter->stats.gptc;
1647 adapter->net_stats.rx_bytes = adapter->stats.gorcl;
1648 adapter->net_stats.tx_bytes = adapter->stats.gotcl;
1649 adapter->net_stats.multicast = adapter->stats.mprc;
1650 adapter->net_stats.collisions = adapter->stats.colc;
1654 adapter->net_stats.rx_errors = adapter->stats.rxerrc +
1655 adapter->stats.crcerrs + adapter->stats.algnerrc +
1656 adapter->stats.rlec + adapter->stats.rnbc +
1657 adapter->stats.mpc + adapter->stats.cexterr;
1658 adapter->net_stats.rx_dropped = adapter->stats.rnbc;
1659 adapter->net_stats.rx_length_errors = adapter->stats.rlec;
1660 adapter->net_stats.rx_crc_errors = adapter->stats.crcerrs;
1661 adapter->net_stats.rx_frame_errors = adapter->stats.algnerrc;
1662 adapter->net_stats.rx_fifo_errors = adapter->stats.mpc;
1663 adapter->net_stats.rx_missed_errors = adapter->stats.mpc;
1667 adapter->net_stats.tx_errors = adapter->stats.ecol +
1668 adapter->stats.latecol;
1669 adapter->net_stats.tx_aborted_errors = adapter->stats.ecol;
1670 adapter->net_stats.tx_window_errors = adapter->stats.latecol;
1671 adapter->net_stats.tx_carrier_errors = adapter->stats.tncrs;
1673 /* Tx Dropped needs to be maintained elsewhere */
1677 if(hw->media_type == e1000_media_type_copper) {
1678 if((adapter->link_speed == SPEED_1000) &&
1679 (!e1000_read_phy_reg(hw, PHY_1000T_STATUS, &phy_tmp))) {
1680 phy_tmp &= PHY_IDLE_ERROR_COUNT_MASK;
1681 adapter->phy_stats.idle_errors += phy_tmp;
1684 if((hw->mac_type <= e1000_82546) &&
1685 !e1000_read_phy_reg(hw, M88E1000_RX_ERR_CNTR, &phy_tmp))
1686 adapter->phy_stats.receive_errors += phy_tmp;
1691 * e1000_irq_disable - Mask off interrupt generation on the NIC
1692 * @adapter: board private structure
1696 e1000_irq_disable(struct e1000_adapter *adapter)
1698 atomic_inc(&adapter->irq_sem);
1699 E1000_WRITE_REG(&adapter->hw, IMC, ~0);
1700 E1000_WRITE_FLUSH(&adapter->hw);
1705 * e1000_irq_enable - Enable default interrupt generation settings
1706 * @adapter: board private structure
1710 e1000_irq_enable(struct e1000_adapter *adapter)
1712 if(atomic_dec_and_test(&adapter->irq_sem)) {
1713 E1000_WRITE_REG(&adapter->hw, IMS, IMS_ENABLE_MASK);
1714 E1000_WRITE_FLUSH(&adapter->hw);
1719 * e1000_intr - Interrupt Handler
1720 * @irq: interrupt number
1721 * @data: pointer to a network interface device structure
1722 * @pt_regs: CPU registers structure
1726 e1000_intr(int irq, void *data, struct pt_regs *regs)
1728 struct net_device *netdev = data;
1729 struct e1000_adapter *adapter = netdev->priv;
1731 int i = E1000_MAX_INTR;
1733 while(i && (icr = E1000_READ_REG(&adapter->hw, ICR))) {
1735 if(icr & (E1000_ICR_RXSEQ | E1000_ICR_LSC)) {
1736 adapter->hw.get_link_status = 1;
1737 mod_timer(&adapter->watchdog_timer, jiffies);
1740 e1000_clean_rx_irq(adapter);
1741 e1000_clean_tx_irq(adapter);
1748 * e1000_clean_tx_irq - Reclaim resources after transmit completes
1749 * @adapter: board private structure
1753 e1000_clean_tx_irq(struct e1000_adapter *adapter)
1755 struct e1000_desc_ring *tx_ring = &adapter->tx_ring;
1756 struct net_device *netdev = adapter->netdev;
1757 struct pci_dev *pdev = adapter->pdev;
1758 struct e1000_tx_desc *tx_desc;
1761 i = tx_ring->next_to_clean;
1762 tx_desc = E1000_TX_DESC(*tx_ring, i);
1764 while(tx_desc->upper.data & cpu_to_le32(E1000_TXD_STAT_DD)) {
1766 if(tx_ring->buffer_info[i].dma) {
1768 pci_unmap_page(pdev,
1769 tx_ring->buffer_info[i].dma,
1770 tx_ring->buffer_info[i].length,
1773 tx_ring->buffer_info[i].dma = 0;
1776 if(tx_ring->buffer_info[i].skb) {
1778 dev_kfree_skb_any(tx_ring->buffer_info[i].skb);
1780 tx_ring->buffer_info[i].skb = NULL;
1783 tx_desc->upper.data = 0;
1785 i = (i + 1) % tx_ring->count;
1786 tx_desc = E1000_TX_DESC(*tx_ring, i);
1789 tx_ring->next_to_clean = i;
1791 if(netif_queue_stopped(netdev) && netif_carrier_ok(netdev) &&
1792 (E1000_DESC_UNUSED(tx_ring) > E1000_TX_QUEUE_WAKE)) {
1794 netif_wake_queue(netdev);
1799 * e1000_clean_rx_irq - Send received data up the network stack,
1800 * @adapter: board private structure
1804 e1000_clean_rx_irq(struct e1000_adapter *adapter)
1806 struct e1000_desc_ring *rx_ring = &adapter->rx_ring;
1807 struct net_device *netdev = adapter->netdev;
1808 struct pci_dev *pdev = adapter->pdev;
1809 struct e1000_rx_desc *rx_desc;
1810 struct sk_buff *skb;
1811 unsigned long flags;
1816 i = rx_ring->next_to_clean;
1817 rx_desc = E1000_RX_DESC(*rx_ring, i);
1819 while(rx_desc->status & E1000_RXD_STAT_DD) {
1821 pci_unmap_single(pdev,
1822 rx_ring->buffer_info[i].dma,
1823 rx_ring->buffer_info[i].length,
1824 PCI_DMA_FROMDEVICE);
1826 skb = rx_ring->buffer_info[i].skb;
1827 length = le16_to_cpu(rx_desc->length);
1829 if(!(rx_desc->status & E1000_RXD_STAT_EOP)) {
1831 /* All receives must fit into a single buffer */
1833 E1000_DBG("Receive packet consumed multiple buffers\n");
1835 dev_kfree_skb_irq(skb);
1836 rx_desc->status = 0;
1837 rx_ring->buffer_info[i].skb = NULL;
1839 i = (i + 1) % rx_ring->count;
1841 rx_desc = E1000_RX_DESC(*rx_ring, i);
1845 if(rx_desc->errors & E1000_RXD_ERR_FRAME_ERR_MASK) {
1847 last_byte = *(skb->data + length - 1);
1849 if(TBI_ACCEPT(&adapter->hw, rx_desc->status,
1850 rx_desc->errors, length, last_byte)) {
1852 spin_lock_irqsave(&adapter->stats_lock, flags);
1854 e1000_tbi_adjust_stats(&adapter->hw,
1858 spin_unlock_irqrestore(&adapter->stats_lock,
1863 dev_kfree_skb_irq(skb);
1864 rx_desc->status = 0;
1865 rx_ring->buffer_info[i].skb = NULL;
1867 i = (i + 1) % rx_ring->count;
1869 rx_desc = E1000_RX_DESC(*rx_ring, i);
1875 skb_put(skb, length - ETHERNET_FCS_SIZE);
1877 /* Receive Checksum Offload */
1878 e1000_rx_checksum(adapter, rx_desc, skb);
1880 skb->protocol = eth_type_trans(skb, netdev);
1881 if(adapter->vlgrp && (rx_desc->status & E1000_RXD_STAT_VP)) {
1882 vlan_hwaccel_rx(skb, adapter->vlgrp,
1883 (rx_desc->special & E1000_RXD_SPC_VLAN_MASK));
1887 netdev->last_rx = jiffies;
1889 rx_desc->status = 0;
1890 rx_ring->buffer_info[i].skb = NULL;
1892 i = (i + 1) % rx_ring->count;
1894 rx_desc = E1000_RX_DESC(*rx_ring, i);
1897 rx_ring->next_to_clean = i;
1899 e1000_alloc_rx_buffers(adapter);
1903 * e1000_alloc_rx_buffers - Replace used receive buffers
1904 * @data: address of board private structure
1908 e1000_alloc_rx_buffers(struct e1000_adapter *adapter)
1910 struct e1000_desc_ring *rx_ring = &adapter->rx_ring;
1911 struct net_device *netdev = adapter->netdev;
1912 struct pci_dev *pdev = adapter->pdev;
1913 struct e1000_rx_desc *rx_desc;
1914 struct sk_buff *skb;
1920 i = rx_ring->next_to_use;
1922 while(!rx_ring->buffer_info[i].skb) {
1923 rx_desc = E1000_RX_DESC(*rx_ring, i);
1925 skb = dev_alloc_skb(adapter->rx_buffer_len + reserve_len);
1928 /* Better luck next round */
1932 /* Make buffer alignment 2 beyond a 16 byte boundary
1933 * this will result in a 16 byte aligned IP header after
1934 * the 14 byte MAC header is removed
1936 skb_reserve(skb, reserve_len);
1940 rx_ring->buffer_info[i].skb = skb;
1941 rx_ring->buffer_info[i].length = adapter->rx_buffer_len;
1942 rx_ring->buffer_info[i].dma =
1943 pci_map_single(pdev,
1945 adapter->rx_buffer_len,
1946 PCI_DMA_FROMDEVICE);
1948 rx_desc->buffer_addr = cpu_to_le64(rx_ring->buffer_info[i].dma);
1950 if(!(i % E1000_RX_BUFFER_WRITE)) {
1951 /* Force memory writes to complete before letting h/w
1952 * know there are new descriptors to fetch. (Only
1953 * applicable for weak-ordered memory model archs,
1954 * such as IA-64). */
1957 E1000_WRITE_REG(&adapter->hw, RDT, i);
1960 i = (i + 1) % rx_ring->count;
1963 rx_ring->next_to_use = i;
1974 e1000_ioctl(struct net_device *netdev, struct ifreq *ifr, int cmd)
1978 return e1000_ethtool_ioctl(netdev, ifr);
1985 * e1000_rx_checksum - Receive Checksum Offload for 82543
1986 * @adapter: board private structure
1987 * @rx_desc: receive descriptor
1988 * @sk_buff: socket buffer with received data
1992 e1000_rx_checksum(struct e1000_adapter *adapter,
1993 struct e1000_rx_desc *rx_desc,
1994 struct sk_buff *skb)
1996 /* 82543 or newer only */
1997 if((adapter->hw.mac_type < e1000_82543) ||
1998 /* Ignore Checksum bit is set */
1999 (rx_desc->status & E1000_RXD_STAT_IXSM) ||
2000 /* TCP Checksum has not been calculated */
2001 (!(rx_desc->status & E1000_RXD_STAT_TCPCS))) {
2002 skb->ip_summed = CHECKSUM_NONE;
2006 /* At this point we know the hardware did the TCP checksum */
2007 /* now look at the TCP checksum error bit */
2008 if(rx_desc->errors & E1000_RXD_ERR_TCPE) {
2009 /* let the stack verify checksum errors */
2010 skb->ip_summed = CHECKSUM_NONE;
2011 adapter->hw_csum_err++;
2013 /* TCP checksum is good */
2014 skb->ip_summed = CHECKSUM_UNNECESSARY;
2015 adapter->hw_csum_good++;
2020 e1000_pci_set_mwi(struct e1000_hw *hw)
2022 struct e1000_adapter *adapter = hw->back;
2024 pci_set_mwi(adapter->pdev);
2028 e1000_pci_clear_mwi(struct e1000_hw *hw)
2030 struct e1000_adapter *adapter = hw->back;
2032 pci_clear_mwi(adapter->pdev);
2036 e1000_read_pci_cfg(struct e1000_hw *hw, uint32_t reg, uint16_t *value)
2038 struct e1000_adapter *adapter = hw->back;
2040 pci_read_config_word(adapter->pdev, reg, value);
2044 e1000_write_pci_cfg(struct e1000_hw *hw, uint32_t reg, uint16_t *value)
2046 struct e1000_adapter *adapter = hw->back;
2048 pci_write_config_word(adapter->pdev, reg, *value);
2052 e1000_io_read(struct e1000_hw *hw, uint32_t port)
2058 e1000_io_write(struct e1000_hw *hw, uint32_t port, uint32_t value)
2064 e1000_vlan_rx_register(struct net_device *netdev, struct vlan_group *grp)
2066 struct e1000_adapter *adapter = netdev->priv;
2067 uint32_t ctrl, rctl;
2069 e1000_irq_disable(adapter);
2070 adapter->vlgrp = grp;
2073 /* enable VLAN tag insert/strip */
2075 E1000_WRITE_REG(&adapter->hw, VET, ETHERNET_IEEE_VLAN_TYPE);
2077 ctrl = E1000_READ_REG(&adapter->hw, CTRL);
2078 ctrl |= E1000_CTRL_VME;
2079 E1000_WRITE_REG(&adapter->hw, CTRL, ctrl);
2081 /* enable VLAN receive filtering */
2083 rctl = E1000_READ_REG(&adapter->hw, RCTL);
2084 rctl |= E1000_RCTL_VFE;
2085 rctl &= ~E1000_RCTL_CFIEN;
2086 E1000_WRITE_REG(&adapter->hw, RCTL, rctl);
2088 /* disable VLAN tag insert/strip */
2090 ctrl = E1000_READ_REG(&adapter->hw, CTRL);
2091 ctrl &= ~E1000_CTRL_VME;
2092 E1000_WRITE_REG(&adapter->hw, CTRL, ctrl);
2094 /* disable VLAN filtering */
2096 rctl = E1000_READ_REG(&adapter->hw, RCTL);
2097 rctl &= ~E1000_RCTL_VFE;
2098 E1000_WRITE_REG(&adapter->hw, RCTL, rctl);
2101 e1000_irq_enable(adapter);
2105 e1000_vlan_rx_add_vid(struct net_device *netdev, uint16_t vid)
2107 struct e1000_adapter *adapter = netdev->priv;
2108 uint32_t vfta, index;
2110 /* add VID to filter table */
2112 index = (vid >> 5) & 0x7F;
2113 vfta = E1000_READ_REG_ARRAY(&adapter->hw, VFTA, index);
2114 vfta |= (1 << (vid & 0x1F));
2115 e1000_write_vfta(&adapter->hw, index, vfta);
2119 e1000_vlan_rx_kill_vid(struct net_device *netdev, uint16_t vid)
2121 struct e1000_adapter *adapter = netdev->priv;
2122 uint32_t vfta, index;
2124 e1000_irq_disable(adapter);
2127 adapter->vlgrp->vlan_devices[vid] = NULL;
2129 e1000_irq_enable(adapter);
2131 /* remove VID from filter table*/
2133 index = (vid >> 5) & 0x7F;
2134 vfta = E1000_READ_REG_ARRAY(&adapter->hw, VFTA, index);
2135 vfta &= ~(1 << (vid & 0x1F));
2136 e1000_write_vfta(&adapter->hw, index, vfta);
2140 e1000_restore_vlan(struct e1000_adapter *adapter)
2142 e1000_vlan_rx_register(adapter->netdev, adapter->vlgrp);
2144 if(adapter->vlgrp) {
2146 for(vid = 0; vid < VLAN_GROUP_ARRAY_LEN; vid++) {
2147 if(!adapter->vlgrp->vlan_devices[vid])
2149 e1000_vlan_rx_add_vid(adapter->netdev, vid);
2155 e1000_notify_reboot(struct notifier_block *nb, unsigned long event, void *p)
2157 struct pci_dev *pdev = NULL;
2163 pci_for_each_dev(pdev) {
2164 if(pci_dev_driver(pdev) == &e1000_driver)
2165 e1000_suspend(pdev, 3);
2172 e1000_suspend(struct pci_dev *pdev, uint32_t state)
2174 struct net_device *netdev = pci_get_drvdata(pdev);
2175 struct e1000_adapter *adapter = netdev->priv;
2176 uint32_t ctrl, ctrl_ext, rctl, manc, status;
2177 uint32_t wufc = adapter->wol;
2179 netif_device_detach(netdev);
2181 if(netif_running(netdev))
2182 e1000_down(adapter);
2184 status = E1000_READ_REG(&adapter->hw, STATUS);
2185 if(status & E1000_STATUS_LU)
2186 wufc &= ~E1000_WUFC_LNKC;
2189 e1000_setup_rctl(adapter);
2190 e1000_set_multi(netdev);
2192 /* turn on all-multi mode if wake on multicast is enabled */
2193 if(adapter->wol & E1000_WUFC_MC) {
2194 rctl = E1000_READ_REG(&adapter->hw, RCTL);
2195 rctl |= E1000_RCTL_MPE;
2196 E1000_WRITE_REG(&adapter->hw, RCTL, rctl);
2199 if(adapter->hw.mac_type >= e1000_82540) {
2200 ctrl = E1000_READ_REG(&adapter->hw, CTRL);
2201 /* advertise wake from D3Cold */
2202 #define E1000_CTRL_ADVD3WUC 0x00100000
2203 /* phy power management enable */
2204 #define E1000_CTRL_EN_PHY_PWR_MGMT 0x00200000
2205 ctrl |= E1000_CTRL_ADVD3WUC |
2206 E1000_CTRL_EN_PHY_PWR_MGMT;
2207 E1000_WRITE_REG(&adapter->hw, CTRL, ctrl);
2210 if(adapter->hw.media_type == e1000_media_type_fiber) {
2211 /* keep the laser running in D3 */
2212 ctrl_ext = E1000_READ_REG(&adapter->hw, CTRL_EXT);
2213 ctrl_ext |= E1000_CTRL_EXT_SDP7_DATA;
2214 E1000_WRITE_REG(&adapter->hw, CTRL_EXT, ctrl_ext);
2217 E1000_WRITE_REG(&adapter->hw, WUC, E1000_WUC_PME_EN);
2218 E1000_WRITE_REG(&adapter->hw, WUFC, wufc);
2219 pci_enable_wake(pdev, 3, 1);
2220 pci_enable_wake(pdev, 4, 1); /* 4 == D3 cold */
2222 E1000_WRITE_REG(&adapter->hw, WUC, 0);
2223 E1000_WRITE_REG(&adapter->hw, WUFC, 0);
2224 pci_enable_wake(pdev, 3, 0);
2225 pci_enable_wake(pdev, 4, 0); /* 4 == D3 cold */
2228 pci_save_state(pdev, adapter->pci_state);
2230 if(adapter->hw.mac_type >= e1000_82540) {
2231 manc = E1000_READ_REG(&adapter->hw, MANC);
2232 if(manc & E1000_MANC_SMBUS_EN) {
2233 manc |= E1000_MANC_ARP_EN;
2234 E1000_WRITE_REG(&adapter->hw, MANC, manc);
2239 state = (state > 0) ? 3 : 0;
2240 pci_set_power_state(pdev, state);
2247 e1000_resume(struct pci_dev *pdev)
2249 struct net_device *netdev = pci_get_drvdata(pdev);
2250 struct e1000_adapter *adapter = netdev->priv;
2253 pci_set_power_state(pdev, 0);
2254 pci_restore_state(pdev, adapter->pci_state);
2256 pci_enable_wake(pdev, 3, 0);
2257 pci_enable_wake(pdev, 4, 0); /* 4 == D3 cold */
2259 e1000_reset(adapter);
2260 E1000_WRITE_REG(&adapter->hw, WUS, ~0);
2262 if(netif_running(netdev))
2265 netif_device_attach(netdev);
2267 if(adapter->hw.mac_type >= e1000_82540) {
2268 manc = E1000_READ_REG(&adapter->hw, MANC);
2269 manc &= ~(E1000_MANC_ARP_EN);
2270 E1000_WRITE_REG(&adapter->hw, MANC, manc);