Lines Matching refs:adapter
71 static void netxen_schedule_work(struct netxen_adapter *adapter,
73 static void netxen_cancel_fw_work(struct netxen_adapter *adapter);
79 static void netxen_create_sysfs_entries(struct netxen_adapter *adapter);
80 static void netxen_remove_sysfs_entries(struct netxen_adapter *adapter);
81 static void netxen_create_diag_entries(struct netxen_adapter *adapter);
82 static void netxen_remove_diag_entries(struct netxen_adapter *adapter);
83 static int nx_dev_request_aer(struct netxen_adapter *adapter);
84 static int nx_decr_dev_ref_cnt(struct netxen_adapter *adapter);
85 static int netxen_can_start_firmware(struct netxen_adapter *adapter);
122 netxen_nic_update_cmd_producer(struct netxen_adapter *adapter, in netxen_nic_update_cmd_producer() argument
125 NXWRIO(adapter, tx_ring->crb_cmd_producer, tx_ring->producer); in netxen_nic_update_cmd_producer()
134 netxen_nic_update_cmd_consumer(struct netxen_adapter *adapter, in netxen_nic_update_cmd_consumer() argument
137 NXWRIO(adapter, tx_ring->crb_cmd_consumer, tx_ring->sw_consumer); in netxen_nic_update_cmd_consumer()
151 struct netxen_adapter *adapter = sds_ring->adapter; in netxen_nic_disable_int() local
153 NXWRIO(adapter, sds_ring->crb_intr_mask, 0); in netxen_nic_disable_int()
158 struct netxen_adapter *adapter = sds_ring->adapter; in netxen_nic_enable_int() local
160 NXWRIO(adapter, sds_ring->crb_intr_mask, 0x1); in netxen_nic_enable_int()
162 if (!NETXEN_IS_MSI_FAMILY(adapter)) in netxen_nic_enable_int()
163 NXWRIO(adapter, adapter->tgt_mask_reg, 0xfbff); in netxen_nic_enable_int()
184 netxen_napi_add(struct netxen_adapter *adapter, struct net_device *netdev) in netxen_napi_add() argument
188 struct netxen_recv_context *recv_ctx = &adapter->recv_ctx; in netxen_napi_add()
190 if (netxen_alloc_sds_rings(recv_ctx, adapter->max_sds_rings)) in netxen_napi_add()
193 for (ring = 0; ring < adapter->max_sds_rings; ring++) { in netxen_napi_add()
203 netxen_napi_del(struct netxen_adapter *adapter) in netxen_napi_del() argument
207 struct netxen_recv_context *recv_ctx = &adapter->recv_ctx; in netxen_napi_del()
209 for (ring = 0; ring < adapter->max_sds_rings; ring++) { in netxen_napi_del()
214 netxen_free_sds_rings(&adapter->recv_ctx); in netxen_napi_del()
218 netxen_napi_enable(struct netxen_adapter *adapter) in netxen_napi_enable() argument
222 struct netxen_recv_context *recv_ctx = &adapter->recv_ctx; in netxen_napi_enable()
224 for (ring = 0; ring < adapter->max_sds_rings; ring++) { in netxen_napi_enable()
232 netxen_napi_disable(struct netxen_adapter *adapter) in netxen_napi_disable() argument
236 struct netxen_recv_context *recv_ctx = &adapter->recv_ctx; in netxen_napi_disable()
238 for (ring = 0; ring < adapter->max_sds_rings; ring++) { in netxen_napi_disable()
246 static int nx_set_dma_mask(struct netxen_adapter *adapter) in nx_set_dma_mask() argument
248 struct pci_dev *pdev = adapter->pdev; in nx_set_dma_mask()
251 adapter->pci_using_dac = 0; in nx_set_dma_mask()
256 if (NX_IS_REVISION_P2(adapter->ahw.revision_id)) { in nx_set_dma_mask()
267 adapter->pci_using_dac = 1; in nx_set_dma_mask()
276 nx_update_dma_mask(struct netxen_adapter *adapter) in nx_update_dma_mask() argument
280 struct pci_dev *pdev = adapter->pdev; in nx_update_dma_mask()
284 shift = NXRD32(adapter, CRB_DMA_SHIFT); in nx_update_dma_mask()
288 if (NX_IS_REVISION_P3(adapter->ahw.revision_id) && (shift > 9)) in nx_update_dma_mask()
290 else if ((adapter->ahw.revision_id == NX_P2_C1) && (shift <= 4)) in nx_update_dma_mask()
303 if (NX_IS_REVISION_P3(adapter->ahw.revision_id)) { in nx_update_dma_mask()
321 netxen_check_hw_init(struct netxen_adapter *adapter, int first_boot) in netxen_check_hw_init() argument
327 NXWR32(adapter, NETXEN_CAM_RAM(0x1fc), NETXEN_BDINFO_MAGIC); in netxen_check_hw_init()
329 if (!NX_IS_REVISION_P2(adapter->ahw.revision_id)) in netxen_check_hw_init()
333 first_boot = NXRD32(adapter, NETXEN_PCIE_REG(0x4)); in netxen_check_hw_init()
336 NXWR32(adapter, NETXEN_PCIE_REG(0x4), first_boot); in netxen_check_hw_init()
337 NXRD32(adapter, NETXEN_PCIE_REG(0x4)); in netxen_check_hw_init()
341 first_boot = NXRD32(adapter, NETXEN_ROMUSB_GLB_SW_RESET); in netxen_check_hw_init()
344 NXWR32(adapter, NETXEN_CAM_RAM(0x1fc), 0); in netxen_check_hw_init()
349 val = NXRD32(adapter, NETXEN_ROMUSB_GLB_PEGTUNE_DONE); in netxen_check_hw_init()
350 NXWR32(adapter, NETXEN_ROMUSB_GLB_PEGTUNE_DONE, val | 0x1); in netxen_check_hw_init()
354 val = NXRD32(adapter, NETXEN_CAM_RAM(0x1fc)); in netxen_check_hw_init()
364 static void netxen_set_port_mode(struct netxen_adapter *adapter) in netxen_set_port_mode() argument
368 val = adapter->ahw.board_type; in netxen_set_port_mode()
373 NXWR32(adapter, NETXEN_PORT_MODE_ADDR, data); in netxen_set_port_mode()
376 NXWR32(adapter, NETXEN_PORT_MODE_ADDR, data); in netxen_set_port_mode()
379 NXWR32(adapter, NETXEN_PORT_MODE_ADDR, data); in netxen_set_port_mode()
382 NXWR32(adapter, NETXEN_PORT_MODE_ADDR, data); in netxen_set_port_mode()
385 NXWR32(adapter, NETXEN_PORT_MODE_ADDR, data); in netxen_set_port_mode()
394 NXWR32(adapter, NETXEN_WOL_PORT_MODE, wol_port_mode); in netxen_set_port_mode()
400 static void netxen_pcie_strap_init(struct netxen_adapter *adapter) in netxen_pcie_strap_init() argument
409 pdev = adapter->pdev; in netxen_pcie_strap_init()
411 chicken = NXRD32(adapter, NETXEN_PCIE_REG(PCIE_CHICKEN3)); in netxen_pcie_strap_init()
425 dev_info(&adapter->pdev->dev, "Gen2 strapping detected\n"); in netxen_pcie_strap_init()
430 dev_info(&adapter->pdev->dev, "Gen1 strapping detected\n"); in netxen_pcie_strap_init()
431 if (adapter->ahw.revision_id == NX_P3_B0) in netxen_pcie_strap_init()
437 NXWR32(adapter, NETXEN_PCIE_REG(PCIE_CHICKEN3), chicken); in netxen_pcie_strap_init()
469 static void netxen_init_msix_entries(struct netxen_adapter *adapter, int count) in netxen_init_msix_entries() argument
474 adapter->msix_entries[i].entry = i; in netxen_init_msix_entries()
478 netxen_read_mac_addr(struct netxen_adapter *adapter) in netxen_read_mac_addr() argument
483 struct net_device *netdev = adapter->netdev; in netxen_read_mac_addr()
484 struct pci_dev *pdev = adapter->pdev; in netxen_read_mac_addr()
486 if (NX_IS_REVISION_P3(adapter->ahw.revision_id)) { in netxen_read_mac_addr()
487 if (netxen_p3_get_mac_addr(adapter, &mac_addr) != 0) in netxen_read_mac_addr()
490 if (netxen_get_flash_mac_addr(adapter, &mac_addr) != 0) in netxen_read_mac_addr()
498 memcpy(adapter->mac_addr, netdev->dev_addr, netdev->addr_len); in netxen_read_mac_addr()
510 struct netxen_adapter *adapter = netdev_priv(netdev); in netxen_nic_set_mac() local
518 netxen_napi_disable(adapter); in netxen_nic_set_mac()
521 memcpy(adapter->mac_addr, addr->sa_data, netdev->addr_len); in netxen_nic_set_mac()
523 adapter->macaddr_set(adapter, addr->sa_data); in netxen_nic_set_mac()
527 netxen_napi_enable(adapter); in netxen_nic_set_mac()
534 struct netxen_adapter *adapter = netdev_priv(dev); in netxen_set_multicast_list() local
536 adapter->set_multi(dev); in netxen_set_multicast_list()
554 struct netxen_adapter *adapter = netdev_priv(dev); in netxen_set_features() local
563 if (netxen_config_hw_lro(adapter, hw_lro)) in netxen_set_features()
566 if (!(features & NETIF_F_LRO) && netxen_send_lro_cleanup(adapter)) in netxen_set_features()
594 static inline void netxen_set_interrupt_mode(struct netxen_adapter *adapter, in netxen_set_interrupt_mode() argument
597 NXWR32(adapter, NETXEN_INTR_MODE_REG, mode); in netxen_set_interrupt_mode()
600 static inline u32 netxen_get_interrupt_mode(struct netxen_adapter *adapter) in netxen_get_interrupt_mode() argument
602 return NXRD32(adapter, NETXEN_INTR_MODE_REG); in netxen_get_interrupt_mode()
606 netxen_initialize_interrupt_registers(struct netxen_adapter *adapter) in netxen_initialize_interrupt_registers() argument
611 if (adapter->ahw.revision_id >= NX_P3_B0) in netxen_initialize_interrupt_registers()
612 legacy_intrp = &legacy_intr[adapter->ahw.pci_func]; in netxen_initialize_interrupt_registers()
619 adapter->int_vec_bit = legacy_intrp->int_vec_bit; in netxen_initialize_interrupt_registers()
620 adapter->tgt_status_reg = netxen_get_ioaddr(adapter, tgt_status_reg); in netxen_initialize_interrupt_registers()
621 adapter->tgt_mask_reg = netxen_get_ioaddr(adapter, in netxen_initialize_interrupt_registers()
623 adapter->pci_int_reg = netxen_get_ioaddr(adapter, in netxen_initialize_interrupt_registers()
625 adapter->isr_int_vec = netxen_get_ioaddr(adapter, ISR_INT_VECTOR); in netxen_initialize_interrupt_registers()
627 if (adapter->ahw.revision_id >= NX_P3_B1) in netxen_initialize_interrupt_registers()
628 adapter->crb_int_state_reg = netxen_get_ioaddr(adapter, in netxen_initialize_interrupt_registers()
631 adapter->crb_int_state_reg = netxen_get_ioaddr(adapter, in netxen_initialize_interrupt_registers()
635 static int netxen_setup_msi_interrupts(struct netxen_adapter *adapter, in netxen_setup_msi_interrupts() argument
638 struct pci_dev *pdev = adapter->pdev; in netxen_setup_msi_interrupts()
642 if (adapter->msix_supported) { in netxen_setup_msi_interrupts()
643 netxen_init_msix_entries(adapter, num_msix); in netxen_setup_msi_interrupts()
644 err = pci_enable_msix_range(pdev, adapter->msix_entries, in netxen_setup_msi_interrupts()
647 adapter->flags |= NETXEN_NIC_MSIX_ENABLED; in netxen_setup_msi_interrupts()
650 if (adapter->rss_supported) in netxen_setup_msi_interrupts()
651 adapter->max_sds_rings = num_msix; in netxen_setup_msi_interrupts()
660 value = msi_tgt_status[adapter->ahw.pci_func]; in netxen_setup_msi_interrupts()
661 adapter->flags |= NETXEN_NIC_MSI_ENABLED; in netxen_setup_msi_interrupts()
662 adapter->tgt_status_reg = netxen_get_ioaddr(adapter, value); in netxen_setup_msi_interrupts()
663 adapter->msix_entries[0].vector = pdev->irq; in netxen_setup_msi_interrupts()
672 static int netxen_setup_intr(struct netxen_adapter *adapter) in netxen_setup_intr() argument
674 struct pci_dev *pdev = adapter->pdev; in netxen_setup_intr()
677 if (adapter->rss_supported) in netxen_setup_intr()
683 adapter->max_sds_rings = 1; in netxen_setup_intr()
684 adapter->flags &= ~(NETXEN_NIC_MSI_ENABLED | NETXEN_NIC_MSIX_ENABLED); in netxen_setup_intr()
686 netxen_initialize_interrupt_registers(adapter); in netxen_setup_intr()
690 if (!netxen_setup_msi_interrupts(adapter, num_msix)) in netxen_setup_intr()
691 netxen_set_interrupt_mode(adapter, NETXEN_MSI_MODE); in netxen_setup_intr()
693 netxen_set_interrupt_mode(adapter, NETXEN_INTX_MODE); in netxen_setup_intr()
695 if (netxen_get_interrupt_mode(adapter) == NETXEN_MSI_MODE && in netxen_setup_intr()
696 netxen_setup_msi_interrupts(adapter, num_msix)) { in netxen_setup_intr()
702 if (!NETXEN_IS_MSI_FAMILY(adapter)) { in netxen_setup_intr()
703 adapter->msix_entries[0].vector = pdev->irq; in netxen_setup_intr()
710 netxen_teardown_intr(struct netxen_adapter *adapter) in netxen_teardown_intr() argument
712 if (adapter->flags & NETXEN_NIC_MSIX_ENABLED) in netxen_teardown_intr()
713 pci_disable_msix(adapter->pdev); in netxen_teardown_intr()
714 if (adapter->flags & NETXEN_NIC_MSI_ENABLED) in netxen_teardown_intr()
715 pci_disable_msi(adapter->pdev); in netxen_teardown_intr()
719 netxen_cleanup_pci_map(struct netxen_adapter *adapter) in netxen_cleanup_pci_map() argument
721 if (adapter->ahw.db_base != NULL) in netxen_cleanup_pci_map()
722 iounmap(adapter->ahw.db_base); in netxen_cleanup_pci_map()
723 if (adapter->ahw.pci_base0 != NULL) in netxen_cleanup_pci_map()
724 iounmap(adapter->ahw.pci_base0); in netxen_cleanup_pci_map()
725 if (adapter->ahw.pci_base1 != NULL) in netxen_cleanup_pci_map()
726 iounmap(adapter->ahw.pci_base1); in netxen_cleanup_pci_map()
727 if (adapter->ahw.pci_base2 != NULL) in netxen_cleanup_pci_map()
728 iounmap(adapter->ahw.pci_base2); in netxen_cleanup_pci_map()
732 netxen_setup_pci_map(struct netxen_adapter *adapter) in netxen_setup_pci_map() argument
739 struct pci_dev *pdev = adapter->pdev; in netxen_setup_pci_map()
740 int pci_func = adapter->ahw.pci_func; in netxen_setup_pci_map()
741 struct netxen_hardware_context *ahw = &adapter->ahw; in netxen_setup_pci_map()
749 adapter->ahw.crb_win = -1; in netxen_setup_pci_map()
750 adapter->ahw.ocm_win = -1; in netxen_setup_pci_map()
796 netxen_setup_hwops(adapter); in netxen_setup_pci_map()
800 if (NX_IS_REVISION_P3P(adapter->ahw.revision_id)) { in netxen_setup_pci_map()
801 adapter->ahw.ocm_win_crb = netxen_get_ioaddr(adapter, in netxen_setup_pci_map()
804 } else if (NX_IS_REVISION_P3(adapter->ahw.revision_id)) { in netxen_setup_pci_map()
805 adapter->ahw.ocm_win_crb = netxen_get_ioaddr(adapter, in netxen_setup_pci_map()
809 if (NX_IS_REVISION_P3(adapter->ahw.revision_id)) in netxen_setup_pci_map()
831 adapter->ahw.db_base = db_ptr; in netxen_setup_pci_map()
832 adapter->ahw.db_len = db_len; in netxen_setup_pci_map()
836 netxen_cleanup_pci_map(adapter); in netxen_setup_pci_map()
841 netxen_check_options(struct netxen_adapter *adapter) in netxen_check_options() argument
848 struct pci_dev *pdev = adapter->pdev; in netxen_check_options()
850 adapter->driver_mismatch = 0; in netxen_check_options()
855 if (netxen_rom_fast_read(adapter, offset, &val) == -1) { in netxen_check_options()
857 adapter->driver_mismatch = 1; in netxen_check_options()
864 fw_major = NXRD32(adapter, NETXEN_FW_VERSION_MAJOR); in netxen_check_options()
865 fw_minor = NXRD32(adapter, NETXEN_FW_VERSION_MINOR); in netxen_check_options()
866 fw_build = NXRD32(adapter, NETXEN_FW_VERSION_SUB); in netxen_check_options()
867 prev_fw_version = adapter->fw_version; in netxen_check_options()
868 adapter->fw_version = NETXEN_VERSION_CODE(fw_major, fw_minor, fw_build); in netxen_check_options()
871 if (NX_IS_REVISION_P3(adapter->ahw.revision_id)) { in netxen_check_options()
872 if (adapter->mdump.md_template == NULL || in netxen_check_options()
873 adapter->fw_version > prev_fw_version) { in netxen_check_options()
874 kfree(adapter->mdump.md_template); in netxen_check_options()
875 adapter->mdump.md_template = NULL; in netxen_check_options()
876 err = netxen_setup_minidump(adapter); in netxen_check_options()
878 dev_err(&adapter->pdev->dev, in netxen_check_options()
883 if (adapter->portnum == 0) { in netxen_check_options()
884 if (netxen_nic_get_brd_name_by_type(adapter->ahw.board_type, in netxen_check_options()
890 brd_name, serial_num, adapter->ahw.revision_id); in netxen_check_options()
893 if (adapter->fw_version < NETXEN_VERSION_CODE(3, 4, 216)) { in netxen_check_options()
894 adapter->driver_mismatch = 1; in netxen_check_options()
900 if (NX_IS_REVISION_P3(adapter->ahw.revision_id)) { in netxen_check_options()
901 i = NXRD32(adapter, NETXEN_SRE_MISC); in netxen_check_options()
902 adapter->ahw.cut_through = (i & 0x8000) ? 1 : 0; in netxen_check_options()
907 adapter->ahw.cut_through ? "cut-through" : "legacy"); in netxen_check_options()
909 if (adapter->fw_version >= NETXEN_VERSION_CODE(4, 0, 222)) in netxen_check_options()
910 adapter->capabilities = NXRD32(adapter, CRB_FW_CAPABILITIES_1); in netxen_check_options()
912 if (adapter->ahw.port_type == NETXEN_NIC_XGBE) { in netxen_check_options()
913 adapter->num_rxd = DEFAULT_RCV_DESCRIPTORS_10G; in netxen_check_options()
914 adapter->num_jumbo_rxd = MAX_JUMBO_RCV_DESCRIPTORS_10G; in netxen_check_options()
915 } else if (adapter->ahw.port_type == NETXEN_NIC_GBE) { in netxen_check_options()
916 adapter->num_rxd = DEFAULT_RCV_DESCRIPTORS_1G; in netxen_check_options()
917 adapter->num_jumbo_rxd = MAX_JUMBO_RCV_DESCRIPTORS_1G; in netxen_check_options()
920 adapter->msix_supported = 0; in netxen_check_options()
921 if (NX_IS_REVISION_P3(adapter->ahw.revision_id)) { in netxen_check_options()
922 adapter->msix_supported = !!use_msi_x; in netxen_check_options()
923 adapter->rss_supported = !!use_msi_x; in netxen_check_options()
926 netxen_rom_fast_read(adapter, in netxen_check_options()
931 switch (adapter->ahw.board_type) { in netxen_check_options()
934 adapter->msix_supported = !!use_msi_x; in netxen_check_options()
935 adapter->rss_supported = !!use_msi_x; in netxen_check_options()
943 adapter->num_txd = MAX_CMD_DESCRIPTORS; in netxen_check_options()
945 if (NX_IS_REVISION_P2(adapter->ahw.revision_id)) { in netxen_check_options()
946 adapter->num_lro_rxd = MAX_LRO_RCV_DESCRIPTORS; in netxen_check_options()
947 adapter->max_rds_rings = 3; in netxen_check_options()
949 adapter->num_lro_rxd = 0; in netxen_check_options()
950 adapter->max_rds_rings = 2; in netxen_check_options()
955 netxen_start_firmware(struct netxen_adapter *adapter) in netxen_start_firmware() argument
958 struct pci_dev *pdev = adapter->pdev; in netxen_start_firmware()
961 err = nx_set_dma_mask(adapter); in netxen_start_firmware()
965 err = netxen_can_start_firmware(adapter); in netxen_start_firmware()
973 first_boot = NXRD32(adapter, NETXEN_CAM_RAM(0x1fc)); in netxen_start_firmware()
975 err = netxen_check_hw_init(adapter, first_boot); in netxen_start_firmware()
981 netxen_request_firmware(adapter); in netxen_start_firmware()
983 err = netxen_need_fw_reset(adapter); in netxen_start_firmware()
990 NXWR32(adapter, CRB_CMDPEG_STATE, 0); in netxen_start_firmware()
991 netxen_pinit_from_rom(adapter); in netxen_start_firmware()
995 NXWR32(adapter, CRB_DMA_SHIFT, 0x55555555); in netxen_start_firmware()
996 NXWR32(adapter, NETXEN_PEG_HALT_STATUS1, 0); in netxen_start_firmware()
997 NXWR32(adapter, NETXEN_PEG_HALT_STATUS2, 0); in netxen_start_firmware()
999 if (NX_IS_REVISION_P3(adapter->ahw.revision_id)) in netxen_start_firmware()
1000 netxen_set_port_mode(adapter); in netxen_start_firmware()
1002 err = netxen_load_firmware(adapter); in netxen_start_firmware()
1006 netxen_release_firmware(adapter); in netxen_start_firmware()
1008 if (NX_IS_REVISION_P2(adapter->ahw.revision_id)) { in netxen_start_firmware()
1012 if (adapter->ahw.port_type == NETXEN_NIC_XGBE) in netxen_start_firmware()
1014 NXWR32(adapter, NETXEN_MAC_ADDR_CNTL_REG, val); in netxen_start_firmware()
1018 err = netxen_init_dummy_dma(adapter); in netxen_start_firmware()
1028 NXWR32(adapter, CRB_DRIVER_VERSION, val); in netxen_start_firmware()
1031 if (NX_IS_REVISION_P3(adapter->ahw.revision_id)) in netxen_start_firmware()
1032 netxen_pcie_strap_init(adapter); in netxen_start_firmware()
1036 err = netxen_phantom_init(adapter, NETXEN_NIC_PEG_TUNE); in netxen_start_firmware()
1038 netxen_free_dummy_dma(adapter); in netxen_start_firmware()
1042 NXWR32(adapter, NX_CRB_DEV_STATE, NX_DEV_READY); in netxen_start_firmware()
1044 nx_update_dma_mask(adapter); in netxen_start_firmware()
1046 netxen_check_options(adapter); in netxen_start_firmware()
1048 adapter->need_fw_reset = 0; in netxen_start_firmware()
1053 netxen_release_firmware(adapter); in netxen_start_firmware()
1058 netxen_nic_request_irq(struct netxen_adapter *adapter) in netxen_nic_request_irq() argument
1065 struct net_device *netdev = adapter->netdev; in netxen_nic_request_irq()
1066 struct netxen_recv_context *recv_ctx = &adapter->recv_ctx; in netxen_nic_request_irq()
1068 if (adapter->flags & NETXEN_NIC_MSIX_ENABLED) in netxen_nic_request_irq()
1070 else if (adapter->flags & NETXEN_NIC_MSI_ENABLED) in netxen_nic_request_irq()
1076 adapter->irq = netdev->irq; in netxen_nic_request_irq()
1078 for (ring = 0; ring < adapter->max_sds_rings; ring++) { in netxen_nic_request_irq()
1091 netxen_nic_free_irq(struct netxen_adapter *adapter) in netxen_nic_free_irq() argument
1096 struct netxen_recv_context *recv_ctx = &adapter->recv_ctx; in netxen_nic_free_irq()
1098 for (ring = 0; ring < adapter->max_sds_rings; ring++) { in netxen_nic_free_irq()
1105 netxen_nic_init_coalesce_defaults(struct netxen_adapter *adapter) in netxen_nic_init_coalesce_defaults() argument
1107 adapter->coal.flags = NETXEN_NIC_INTR_DEFAULT; in netxen_nic_init_coalesce_defaults()
1108 adapter->coal.normal.data.rx_time_us = in netxen_nic_init_coalesce_defaults()
1110 adapter->coal.normal.data.rx_packets = in netxen_nic_init_coalesce_defaults()
1112 adapter->coal.normal.data.tx_time_us = in netxen_nic_init_coalesce_defaults()
1114 adapter->coal.normal.data.tx_packets = in netxen_nic_init_coalesce_defaults()
1120 __netxen_nic_up(struct netxen_adapter *adapter, struct net_device *netdev) in __netxen_nic_up() argument
1124 if (adapter->is_up != NETXEN_ADAPTER_UP_MAGIC) in __netxen_nic_up()
1127 err = adapter->init_port(adapter, adapter->physical_port); in __netxen_nic_up()
1130 netxen_nic_driver_name, adapter->portnum); in __netxen_nic_up()
1133 if (NX_IS_REVISION_P2(adapter->ahw.revision_id)) in __netxen_nic_up()
1134 adapter->macaddr_set(adapter, adapter->mac_addr); in __netxen_nic_up()
1136 adapter->set_multi(netdev); in __netxen_nic_up()
1137 adapter->set_mtu(adapter, netdev->mtu); in __netxen_nic_up()
1139 adapter->ahw.linkup = 0; in __netxen_nic_up()
1141 if (adapter->max_sds_rings > 1) in __netxen_nic_up()
1142 netxen_config_rss(adapter, 1); in __netxen_nic_up()
1144 if (NX_IS_REVISION_P3(adapter->ahw.revision_id)) in __netxen_nic_up()
1145 netxen_config_intr_coalesce(adapter); in __netxen_nic_up()
1148 netxen_config_hw_lro(adapter, NETXEN_NIC_LRO_ENABLED); in __netxen_nic_up()
1150 netxen_napi_enable(adapter); in __netxen_nic_up()
1152 if (adapter->capabilities & NX_FW_CAPABILITY_LINK_NOTIFICATION) in __netxen_nic_up()
1153 netxen_linkevent_request(adapter, 1); in __netxen_nic_up()
1155 netxen_nic_set_link_parameters(adapter); in __netxen_nic_up()
1157 set_bit(__NX_DEV_UP, &adapter->state); in __netxen_nic_up()
1164 netxen_nic_up(struct netxen_adapter *adapter, struct net_device *netdev) in netxen_nic_up() argument
1170 err = __netxen_nic_up(adapter, netdev); in netxen_nic_up()
1178 __netxen_nic_down(struct netxen_adapter *adapter, struct net_device *netdev) in __netxen_nic_down() argument
1180 if (adapter->is_up != NETXEN_ADAPTER_UP_MAGIC) in __netxen_nic_down()
1183 if (!test_and_clear_bit(__NX_DEV_UP, &adapter->state)) in __netxen_nic_down()
1190 if (adapter->capabilities & NX_FW_CAPABILITY_LINK_NOTIFICATION) in __netxen_nic_down()
1191 netxen_linkevent_request(adapter, 0); in __netxen_nic_down()
1193 if (adapter->stop_port) in __netxen_nic_down()
1194 adapter->stop_port(adapter); in __netxen_nic_down()
1196 if (NX_IS_REVISION_P3(adapter->ahw.revision_id)) in __netxen_nic_down()
1197 netxen_p3_free_mac_list(adapter); in __netxen_nic_down()
1199 adapter->set_promisc(adapter, NETXEN_NIU_NON_PROMISC_MODE); in __netxen_nic_down()
1201 netxen_napi_disable(adapter); in __netxen_nic_down()
1203 netxen_release_tx_buffers(adapter); in __netxen_nic_down()
1209 netxen_nic_down(struct netxen_adapter *adapter, struct net_device *netdev) in netxen_nic_down() argument
1213 __netxen_nic_down(adapter, netdev); in netxen_nic_down()
1219 netxen_nic_attach(struct netxen_adapter *adapter) in netxen_nic_attach() argument
1221 struct net_device *netdev = adapter->netdev; in netxen_nic_attach()
1222 struct pci_dev *pdev = adapter->pdev; in netxen_nic_attach()
1228 if (adapter->is_up == NETXEN_ADAPTER_UP_MAGIC) in netxen_nic_attach()
1231 err = netxen_init_firmware(adapter); in netxen_nic_attach()
1235 adapter->flags &= ~NETXEN_FW_MSS_CAP; in netxen_nic_attach()
1236 if (adapter->capabilities & NX_FW_CAPABILITY_MORE_CAPS) { in netxen_nic_attach()
1237 capab2 = NXRD32(adapter, CRB_FW_CAPABILITIES_2); in netxen_nic_attach()
1239 adapter->flags |= NETXEN_FW_MSS_CAP; in netxen_nic_attach()
1242 err = netxen_napi_add(adapter, netdev); in netxen_nic_attach()
1246 err = netxen_alloc_sw_resources(adapter); in netxen_nic_attach()
1253 err = netxen_alloc_hw_resources(adapter); in netxen_nic_attach()
1260 if (NX_IS_REVISION_P2(adapter->ahw.revision_id)) { in netxen_nic_attach()
1261 tx_ring = adapter->tx_ring; in netxen_nic_attach()
1262 tx_ring->crb_cmd_producer = netxen_get_ioaddr(adapter, in netxen_nic_attach()
1263 crb_cmd_producer[adapter->portnum]); in netxen_nic_attach()
1264 tx_ring->crb_cmd_consumer = netxen_get_ioaddr(adapter, in netxen_nic_attach()
1265 crb_cmd_consumer[adapter->portnum]); in netxen_nic_attach()
1270 netxen_nic_update_cmd_producer(adapter, tx_ring); in netxen_nic_attach()
1271 netxen_nic_update_cmd_consumer(adapter, tx_ring); in netxen_nic_attach()
1274 for (ring = 0; ring < adapter->max_rds_rings; ring++) { in netxen_nic_attach()
1275 rds_ring = &adapter->recv_ctx.rds_rings[ring]; in netxen_nic_attach()
1276 netxen_post_rx_buffers(adapter, ring, rds_ring); in netxen_nic_attach()
1279 err = netxen_nic_request_irq(adapter); in netxen_nic_attach()
1286 if (NX_IS_REVISION_P3(adapter->ahw.revision_id)) in netxen_nic_attach()
1287 netxen_nic_init_coalesce_defaults(adapter); in netxen_nic_attach()
1289 netxen_create_sysfs_entries(adapter); in netxen_nic_attach()
1291 adapter->is_up = NETXEN_ADAPTER_UP_MAGIC; in netxen_nic_attach()
1295 netxen_release_rx_buffers(adapter); in netxen_nic_attach()
1296 netxen_free_hw_resources(adapter); in netxen_nic_attach()
1298 netxen_free_sw_resources(adapter); in netxen_nic_attach()
1303 netxen_nic_detach(struct netxen_adapter *adapter) in netxen_nic_detach() argument
1305 if (adapter->is_up != NETXEN_ADAPTER_UP_MAGIC) in netxen_nic_detach()
1308 netxen_remove_sysfs_entries(adapter); in netxen_nic_detach()
1310 netxen_free_hw_resources(adapter); in netxen_nic_detach()
1311 netxen_release_rx_buffers(adapter); in netxen_nic_detach()
1312 netxen_nic_free_irq(adapter); in netxen_nic_detach()
1313 netxen_napi_del(adapter); in netxen_nic_detach()
1314 netxen_free_sw_resources(adapter); in netxen_nic_detach()
1316 adapter->is_up = 0; in netxen_nic_detach()
1320 netxen_nic_reset_context(struct netxen_adapter *adapter) in netxen_nic_reset_context() argument
1323 struct net_device *netdev = adapter->netdev; in netxen_nic_reset_context()
1325 if (test_and_set_bit(__NX_RESETTING, &adapter->state)) in netxen_nic_reset_context()
1328 if (adapter->is_up == NETXEN_ADAPTER_UP_MAGIC) { in netxen_nic_reset_context()
1333 __netxen_nic_down(adapter, netdev); in netxen_nic_reset_context()
1335 netxen_nic_detach(adapter); in netxen_nic_reset_context()
1338 err = netxen_nic_attach(adapter); in netxen_nic_reset_context()
1340 err = __netxen_nic_up(adapter, netdev); in netxen_nic_reset_context()
1350 clear_bit(__NX_RESETTING, &adapter->state); in netxen_nic_reset_context()
1355 netxen_setup_netdev(struct netxen_adapter *adapter, in netxen_setup_netdev() argument
1359 struct pci_dev *pdev = adapter->pdev; in netxen_setup_netdev()
1361 adapter->mc_enabled = 0; in netxen_setup_netdev()
1362 if (NX_IS_REVISION_P3(adapter->ahw.revision_id)) in netxen_setup_netdev()
1363 adapter->max_mc_count = 38; in netxen_setup_netdev()
1365 adapter->max_mc_count = 16; in netxen_setup_netdev()
1377 if (NX_IS_REVISION_P3(adapter->ahw.revision_id)) in netxen_setup_netdev()
1382 if (adapter->pci_using_dac) { in netxen_setup_netdev()
1387 if (adapter->capabilities & NX_FW_CAPABILITY_FVLANTX) in netxen_setup_netdev()
1390 if (adapter->capabilities & NX_FW_CAPABILITY_HW_LRO) in netxen_setup_netdev()
1395 netdev->irq = adapter->msix_entries[0].vector; in netxen_setup_netdev()
1397 INIT_WORK(&adapter->tx_timeout_task, netxen_tx_timeout_task); in netxen_setup_netdev()
1399 if (netxen_read_mac_addr(adapter)) in netxen_setup_netdev()
1416 static void netxen_read_ula_info(struct netxen_adapter *adapter) in netxen_read_ula_info() argument
1421 if (adapter->portnum != 0) in netxen_read_ula_info()
1424 temp = NXRD32(adapter, NETXEN_ULA_KEY); in netxen_read_ula_info()
1427 dev_info(&adapter->pdev->dev, "ULA adapter"); in netxen_read_ula_info()
1430 dev_info(&adapter->pdev->dev, "non ULA adapter"); in netxen_read_ula_info()
1440 static void netxen_mask_aer_correctable(struct netxen_adapter *adapter) in netxen_mask_aer_correctable() argument
1442 struct pci_dev *pdev = adapter->pdev; in netxen_mask_aer_correctable()
1450 if (adapter->ahw.board_type != NETXEN_BRDTYPE_P3_4_GB_MM && in netxen_mask_aer_correctable()
1451 adapter->ahw.board_type != NETXEN_BRDTYPE_P3_10G_TP) in netxen_mask_aer_correctable()
1469 struct netxen_adapter *adapter = NULL; in netxen_nic_probe() local
1505 adapter = netdev_priv(netdev); in netxen_nic_probe()
1506 adapter->netdev = netdev; in netxen_nic_probe()
1507 adapter->pdev = pdev; in netxen_nic_probe()
1508 adapter->ahw.pci_func = pci_func_id; in netxen_nic_probe()
1511 adapter->ahw.revision_id = revision_id; in netxen_nic_probe()
1513 rwlock_init(&adapter->ahw.crb_lock); in netxen_nic_probe()
1514 spin_lock_init(&adapter->ahw.mem_lock); in netxen_nic_probe()
1516 spin_lock_init(&adapter->tx_clean_lock); in netxen_nic_probe()
1517 INIT_LIST_HEAD(&adapter->mac_list); in netxen_nic_probe()
1518 INIT_LIST_HEAD(&adapter->ip_list); in netxen_nic_probe()
1520 err = netxen_setup_pci_map(adapter); in netxen_nic_probe()
1525 adapter->portnum = pci_func_id; in netxen_nic_probe()
1527 err = netxen_nic_get_board_info(adapter); in netxen_nic_probe()
1534 netxen_mask_aer_correctable(adapter); in netxen_nic_probe()
1538 switch (adapter->ahw.board_type) { in netxen_nic_probe()
1542 adapter->portnum = pci_func_id - 2; in netxen_nic_probe()
1548 err = netxen_check_flash_fw_compatibility(adapter); in netxen_nic_probe()
1552 if (adapter->portnum == 0) { in netxen_nic_probe()
1553 val = NXRD32(adapter, NX_CRB_DEV_REF_COUNT); in netxen_nic_probe()
1555 NXWR32(adapter, NX_CRB_DEV_REF_COUNT, 0); in netxen_nic_probe()
1556 adapter->need_fw_reset = 1; in netxen_nic_probe()
1560 err = netxen_start_firmware(adapter); in netxen_nic_probe()
1567 adapter->physical_port = adapter->portnum; in netxen_nic_probe()
1568 if (NX_IS_REVISION_P2(adapter->ahw.revision_id)) { in netxen_nic_probe()
1569 i = NXRD32(adapter, CRB_V2P(adapter->portnum)); in netxen_nic_probe()
1571 adapter->physical_port = i; in netxen_nic_probe()
1574 netxen_nic_clear_stats(adapter); in netxen_nic_probe()
1576 err = netxen_setup_intr(adapter); in netxen_nic_probe()
1579 dev_err(&adapter->pdev->dev, in netxen_nic_probe()
1584 netxen_read_ula_info(adapter); in netxen_nic_probe()
1586 err = netxen_setup_netdev(adapter, netdev); in netxen_nic_probe()
1590 pci_set_drvdata(pdev, adapter); in netxen_nic_probe()
1592 netxen_schedule_work(adapter, netxen_fw_poll_work, FW_POLL_DELAY); in netxen_nic_probe()
1594 switch (adapter->ahw.port_type) { in netxen_nic_probe()
1596 dev_info(&adapter->pdev->dev, "%s: GbE port initialized\n", in netxen_nic_probe()
1597 adapter->netdev->name); in netxen_nic_probe()
1600 dev_info(&adapter->pdev->dev, "%s: XGbE port initialized\n", in netxen_nic_probe()
1601 adapter->netdev->name); in netxen_nic_probe()
1605 netxen_create_diag_entries(adapter); in netxen_nic_probe()
1610 netxen_teardown_intr(adapter); in netxen_nic_probe()
1612 netxen_free_dummy_dma(adapter); in netxen_nic_probe()
1615 nx_decr_dev_ref_cnt(adapter); in netxen_nic_probe()
1618 netxen_cleanup_pci_map(adapter); in netxen_nic_probe()
1632 void netxen_cleanup_minidump(struct netxen_adapter *adapter) in netxen_cleanup_minidump() argument
1634 kfree(adapter->mdump.md_template); in netxen_cleanup_minidump()
1635 adapter->mdump.md_template = NULL; in netxen_cleanup_minidump()
1637 if (adapter->mdump.md_capture_buff) { in netxen_cleanup_minidump()
1638 vfree(adapter->mdump.md_capture_buff); in netxen_cleanup_minidump()
1639 adapter->mdump.md_capture_buff = NULL; in netxen_cleanup_minidump()
1645 struct netxen_adapter *adapter; in netxen_nic_remove() local
1648 adapter = pci_get_drvdata(pdev); in netxen_nic_remove()
1649 if (adapter == NULL) in netxen_nic_remove()
1652 netdev = adapter->netdev; in netxen_nic_remove()
1654 netxen_cancel_fw_work(adapter); in netxen_nic_remove()
1658 cancel_work_sync(&adapter->tx_timeout_task); in netxen_nic_remove()
1660 netxen_free_ip_list(adapter, false); in netxen_nic_remove()
1661 netxen_nic_detach(adapter); in netxen_nic_remove()
1663 nx_decr_dev_ref_cnt(adapter); in netxen_nic_remove()
1665 if (adapter->portnum == 0) in netxen_nic_remove()
1666 netxen_free_dummy_dma(adapter); in netxen_nic_remove()
1668 clear_bit(__NX_RESETTING, &adapter->state); in netxen_nic_remove()
1670 netxen_teardown_intr(adapter); in netxen_nic_remove()
1671 netxen_set_interrupt_mode(adapter, 0); in netxen_nic_remove()
1672 netxen_remove_diag_entries(adapter); in netxen_nic_remove()
1674 netxen_cleanup_pci_map(adapter); in netxen_nic_remove()
1676 netxen_release_firmware(adapter); in netxen_nic_remove()
1679 netxen_cleanup_minidump(adapter); in netxen_nic_remove()
1689 static void netxen_nic_detach_func(struct netxen_adapter *adapter) in netxen_nic_detach_func() argument
1691 struct net_device *netdev = adapter->netdev; in netxen_nic_detach_func()
1695 netxen_cancel_fw_work(adapter); in netxen_nic_detach_func()
1698 netxen_nic_down(adapter, netdev); in netxen_nic_detach_func()
1700 cancel_work_sync(&adapter->tx_timeout_task); in netxen_nic_detach_func()
1702 netxen_nic_detach(adapter); in netxen_nic_detach_func()
1704 if (adapter->portnum == 0) in netxen_nic_detach_func()
1705 netxen_free_dummy_dma(adapter); in netxen_nic_detach_func()
1707 nx_decr_dev_ref_cnt(adapter); in netxen_nic_detach_func()
1709 clear_bit(__NX_RESETTING, &adapter->state); in netxen_nic_detach_func()
1714 struct netxen_adapter *adapter = pci_get_drvdata(pdev); in netxen_nic_attach_func() local
1715 struct net_device *netdev = adapter->netdev; in netxen_nic_attach_func()
1726 adapter->ahw.crb_win = -1; in netxen_nic_attach_func()
1727 adapter->ahw.ocm_win = -1; in netxen_nic_attach_func()
1729 err = netxen_start_firmware(adapter); in netxen_nic_attach_func()
1736 err = netxen_nic_attach(adapter); in netxen_nic_attach_func()
1740 err = netxen_nic_up(adapter, netdev); in netxen_nic_attach_func()
1748 netxen_schedule_work(adapter, netxen_fw_poll_work, FW_POLL_DELAY); in netxen_nic_attach_func()
1752 netxen_nic_detach(adapter); in netxen_nic_attach_func()
1754 nx_decr_dev_ref_cnt(adapter); in netxen_nic_attach_func()
1761 struct netxen_adapter *adapter = pci_get_drvdata(pdev); in netxen_io_error_detected() local
1766 if (nx_dev_request_aer(adapter)) in netxen_io_error_detected()
1769 netxen_nic_detach_func(adapter); in netxen_io_error_detected()
1792 struct netxen_adapter *adapter = pci_get_drvdata(pdev); in netxen_nic_shutdown() local
1794 netxen_nic_detach_func(adapter); in netxen_nic_shutdown()
1799 if (netxen_nic_wol_supported(adapter)) { in netxen_nic_shutdown()
1811 struct netxen_adapter *adapter = pci_get_drvdata(pdev); in netxen_nic_suspend() local
1814 netxen_nic_detach_func(adapter); in netxen_nic_suspend()
1820 if (netxen_nic_wol_supported(adapter)) { in netxen_nic_suspend()
1840 struct netxen_adapter *adapter = netdev_priv(netdev); in netxen_nic_open() local
1843 if (adapter->driver_mismatch) in netxen_nic_open()
1846 err = netxen_nic_attach(adapter); in netxen_nic_open()
1850 err = __netxen_nic_up(adapter, netdev); in netxen_nic_open()
1859 netxen_nic_detach(adapter); in netxen_nic_open()
1868 struct netxen_adapter *adapter = netdev_priv(netdev); in netxen_nic_close() local
1870 __netxen_nic_down(adapter, netdev); in netxen_nic_close()
2057 struct netxen_adapter *adapter = netdev_priv(netdev); in netxen_nic_xmit_frame() local
2058 struct nx_host_tx_ring *tx_ring = adapter->tx_ring; in netxen_nic_xmit_frame()
2103 pdev = adapter->pdev; in netxen_nic_xmit_frame()
2115 netxen_set_tx_port(first_desc, adapter->portnum); in netxen_nic_xmit_frame()
2152 adapter->stats.txbytes += skb->len; in netxen_nic_xmit_frame()
2153 adapter->stats.xmitcalled++; in netxen_nic_xmit_frame()
2155 netxen_nic_update_cmd_producer(adapter, tx_ring); in netxen_nic_xmit_frame()
2160 adapter->stats.txdropped++; in netxen_nic_xmit_frame()
2165 static int netxen_nic_check_temp(struct netxen_adapter *adapter) in netxen_nic_check_temp() argument
2167 struct net_device *netdev = adapter->netdev; in netxen_nic_check_temp()
2171 temp = NXRD32(adapter, CRB_TEMP_STATE); in netxen_nic_check_temp()
2183 if (adapter->temp == NX_TEMP_NORMAL) { in netxen_nic_check_temp()
2191 if (adapter->temp == NX_TEMP_WARN) { in netxen_nic_check_temp()
2198 adapter->temp = temp_state; in netxen_nic_check_temp()
2202 void netxen_advert_link_change(struct netxen_adapter *adapter, int linkup) in netxen_advert_link_change() argument
2204 struct net_device *netdev = adapter->netdev; in netxen_advert_link_change()
2206 if (adapter->ahw.linkup && !linkup) { in netxen_advert_link_change()
2209 adapter->ahw.linkup = 0; in netxen_advert_link_change()
2214 adapter->link_changed = !adapter->has_link_events; in netxen_advert_link_change()
2215 } else if (!adapter->ahw.linkup && linkup) { in netxen_advert_link_change()
2218 adapter->ahw.linkup = 1; in netxen_advert_link_change()
2223 adapter->link_changed = !adapter->has_link_events; in netxen_advert_link_change()
2227 static void netxen_nic_handle_phy_intr(struct netxen_adapter *adapter) in netxen_nic_handle_phy_intr() argument
2231 port = adapter->physical_port; in netxen_nic_handle_phy_intr()
2233 if (NX_IS_REVISION_P3(adapter->ahw.revision_id)) { in netxen_nic_handle_phy_intr()
2234 val = NXRD32(adapter, CRB_XG_STATE_P3); in netxen_nic_handle_phy_intr()
2235 val = XG_LINK_STATE_P3(adapter->ahw.pci_func, val); in netxen_nic_handle_phy_intr()
2238 val = NXRD32(adapter, CRB_XG_STATE); in netxen_nic_handle_phy_intr()
2243 netxen_advert_link_change(adapter, linkup); in netxen_nic_handle_phy_intr()
2248 struct netxen_adapter *adapter = netdev_priv(netdev); in netxen_tx_timeout() local
2250 if (test_bit(__NX_RESETTING, &adapter->state)) in netxen_tx_timeout()
2254 schedule_work(&adapter->tx_timeout_task); in netxen_tx_timeout()
2259 struct netxen_adapter *adapter = in netxen_tx_timeout_task() local
2262 if (!netif_running(adapter->netdev)) in netxen_tx_timeout_task()
2265 if (test_and_set_bit(__NX_RESETTING, &adapter->state)) in netxen_tx_timeout_task()
2268 if (++adapter->tx_timeo_cnt >= NX_MAX_TX_TIMEOUTS) in netxen_tx_timeout_task()
2272 if (NX_IS_REVISION_P2(adapter->ahw.revision_id)) { in netxen_tx_timeout_task()
2274 netxen_napi_disable(adapter); in netxen_tx_timeout_task()
2276 netxen_napi_enable(adapter); in netxen_tx_timeout_task()
2278 netif_wake_queue(adapter->netdev); in netxen_tx_timeout_task()
2280 clear_bit(__NX_RESETTING, &adapter->state); in netxen_tx_timeout_task()
2282 clear_bit(__NX_RESETTING, &adapter->state); in netxen_tx_timeout_task()
2283 if (netxen_nic_reset_context(adapter)) { in netxen_tx_timeout_task()
2288 adapter->netdev->trans_start = jiffies; in netxen_tx_timeout_task()
2293 adapter->need_fw_reset = 1; in netxen_tx_timeout_task()
2294 clear_bit(__NX_RESETTING, &adapter->state); in netxen_tx_timeout_task()
2300 struct netxen_adapter *adapter = netdev_priv(netdev); in netxen_nic_get_stats() local
2302 stats->rx_packets = adapter->stats.rx_pkts + adapter->stats.lro_pkts; in netxen_nic_get_stats()
2303 stats->tx_packets = adapter->stats.xmitfinished; in netxen_nic_get_stats()
2304 stats->rx_bytes = adapter->stats.rxbytes; in netxen_nic_get_stats()
2305 stats->tx_bytes = adapter->stats.txbytes; in netxen_nic_get_stats()
2306 stats->rx_dropped = adapter->stats.rxdropped; in netxen_nic_get_stats()
2307 stats->tx_dropped = adapter->stats.txdropped; in netxen_nic_get_stats()
2315 struct netxen_adapter *adapter = sds_ring->adapter; in netxen_intr() local
2318 status = readl(adapter->isr_int_vec); in netxen_intr()
2320 if (!(status & adapter->int_vec_bit)) in netxen_intr()
2323 if (NX_IS_REVISION_P3(adapter->ahw.revision_id)) { in netxen_intr()
2325 status = readl(adapter->crb_int_state_reg); in netxen_intr()
2332 our_int = readl(adapter->crb_int_state_reg); in netxen_intr()
2335 if (!test_and_clear_bit((7 + adapter->portnum), &our_int)) in netxen_intr()
2339 writel((our_int & 0xffffffff), adapter->crb_int_state_reg); in netxen_intr()
2345 writel(0xffffffff, adapter->tgt_status_reg); in netxen_intr()
2347 readl(adapter->isr_int_vec); in netxen_intr()
2348 readl(adapter->isr_int_vec); in netxen_intr()
2358 struct netxen_adapter *adapter = sds_ring->adapter; in netxen_msi_intr() local
2361 writel(0xffffffff, adapter->tgt_status_reg); in netxen_msi_intr()
2380 struct netxen_adapter *adapter = sds_ring->adapter; in netxen_nic_poll() local
2385 tx_complete = netxen_process_cmd_ring(adapter); in netxen_nic_poll()
2394 if (test_bit(__NX_DEV_UP, &adapter->state)) in netxen_nic_poll()
2406 struct netxen_adapter *adapter = netdev_priv(netdev); in netxen_nic_poll_controller() local
2407 struct netxen_recv_context *recv_ctx = &adapter->recv_ctx; in netxen_nic_poll_controller()
2409 disable_irq(adapter->irq); in netxen_nic_poll_controller()
2410 for (ring = 0; ring < adapter->max_sds_rings; ring++) { in netxen_nic_poll_controller()
2412 netxen_intr(adapter->irq, sds_ring); in netxen_nic_poll_controller()
2414 enable_irq(adapter->irq); in netxen_nic_poll_controller()
2419 nx_incr_dev_ref_cnt(struct netxen_adapter *adapter) in nx_incr_dev_ref_cnt() argument
2422 if (netxen_api_lock(adapter)) in nx_incr_dev_ref_cnt()
2425 count = NXRD32(adapter, NX_CRB_DEV_REF_COUNT); in nx_incr_dev_ref_cnt()
2427 NXWR32(adapter, NX_CRB_DEV_REF_COUNT, ++count); in nx_incr_dev_ref_cnt()
2429 netxen_api_unlock(adapter); in nx_incr_dev_ref_cnt()
2434 nx_decr_dev_ref_cnt(struct netxen_adapter *adapter) in nx_decr_dev_ref_cnt() argument
2437 if (netxen_api_lock(adapter)) in nx_decr_dev_ref_cnt()
2440 count = NXRD32(adapter, NX_CRB_DEV_REF_COUNT); in nx_decr_dev_ref_cnt()
2443 NXWR32(adapter, NX_CRB_DEV_REF_COUNT, --count); in nx_decr_dev_ref_cnt()
2444 state = NXRD32(adapter, NX_CRB_DEV_STATE); in nx_decr_dev_ref_cnt()
2447 NXWR32(adapter, NX_CRB_DEV_STATE, NX_DEV_COLD); in nx_decr_dev_ref_cnt()
2449 netxen_api_unlock(adapter); in nx_decr_dev_ref_cnt()
2454 nx_dev_request_aer(struct netxen_adapter *adapter) in nx_dev_request_aer() argument
2459 if (netxen_api_lock(adapter)) in nx_dev_request_aer()
2462 state = NXRD32(adapter, NX_CRB_DEV_STATE); in nx_dev_request_aer()
2467 NXWR32(adapter, NX_CRB_DEV_STATE, NX_DEV_NEED_AER); in nx_dev_request_aer()
2471 netxen_api_unlock(adapter); in nx_dev_request_aer()
2476 nx_dev_request_reset(struct netxen_adapter *adapter) in nx_dev_request_reset() argument
2481 if (netxen_api_lock(adapter)) in nx_dev_request_reset()
2484 state = NXRD32(adapter, NX_CRB_DEV_STATE); in nx_dev_request_reset()
2489 NXWR32(adapter, NX_CRB_DEV_STATE, NX_DEV_NEED_RESET); in nx_dev_request_reset()
2490 adapter->flags |= NETXEN_FW_RESET_OWNER; in nx_dev_request_reset()
2494 netxen_api_unlock(adapter); in nx_dev_request_reset()
2500 netxen_can_start_firmware(struct netxen_adapter *adapter) in netxen_can_start_firmware() argument
2505 if (netxen_api_lock(adapter)) { in netxen_can_start_firmware()
2506 nx_incr_dev_ref_cnt(adapter); in netxen_can_start_firmware()
2510 count = NXRD32(adapter, NX_CRB_DEV_REF_COUNT); in netxen_can_start_firmware()
2517 NXWR32(adapter, NX_CRB_DEV_STATE, NX_DEV_INITALIZING); in netxen_can_start_firmware()
2520 NXWR32(adapter, NX_CRB_DEV_REF_COUNT, ++count); in netxen_can_start_firmware()
2522 netxen_api_unlock(adapter); in netxen_can_start_firmware()
2528 netxen_schedule_work(struct netxen_adapter *adapter, in netxen_schedule_work() argument
2531 INIT_DELAYED_WORK(&adapter->fw_work, func); in netxen_schedule_work()
2532 schedule_delayed_work(&adapter->fw_work, delay); in netxen_schedule_work()
2536 netxen_cancel_fw_work(struct netxen_adapter *adapter) in netxen_cancel_fw_work() argument
2538 while (test_and_set_bit(__NX_RESETTING, &adapter->state)) in netxen_cancel_fw_work()
2541 cancel_delayed_work_sync(&adapter->fw_work); in netxen_cancel_fw_work()
2547 struct netxen_adapter *adapter = container_of(work, in netxen_attach_work() local
2549 struct net_device *netdev = adapter->netdev; in netxen_attach_work()
2553 err = netxen_nic_attach(adapter); in netxen_attach_work()
2557 err = netxen_nic_up(adapter, netdev); in netxen_attach_work()
2559 netxen_nic_detach(adapter); in netxen_attach_work()
2569 adapter->fw_fail_cnt = 0; in netxen_attach_work()
2570 clear_bit(__NX_RESETTING, &adapter->state); in netxen_attach_work()
2571 netxen_schedule_work(adapter, netxen_fw_poll_work, FW_POLL_DELAY); in netxen_attach_work()
2577 struct netxen_adapter *adapter = container_of(work, in netxen_fwinit_work() local
2581 dev_state = NXRD32(adapter, NX_CRB_DEV_STATE); in netxen_fwinit_work()
2582 if (adapter->flags & NETXEN_FW_RESET_OWNER) { in netxen_fwinit_work()
2583 count = NXRD32(adapter, NX_CRB_DEV_REF_COUNT); in netxen_fwinit_work()
2586 if (adapter->mdump.md_enabled) { in netxen_fwinit_work()
2588 netxen_dump_fw(adapter); in netxen_fwinit_work()
2591 adapter->flags &= ~NETXEN_FW_RESET_OWNER; in netxen_fwinit_work()
2592 if (netxen_api_lock(adapter)) { in netxen_fwinit_work()
2593 clear_bit(__NX_RESETTING, &adapter->state); in netxen_fwinit_work()
2594 NXWR32(adapter, NX_CRB_DEV_STATE, in netxen_fwinit_work()
2598 count = NXRD32(adapter, NX_CRB_DEV_REF_COUNT); in netxen_fwinit_work()
2599 NXWR32(adapter, NX_CRB_DEV_REF_COUNT, --count); in netxen_fwinit_work()
2600 NXWR32(adapter, NX_CRB_DEV_STATE, NX_DEV_COLD); in netxen_fwinit_work()
2602 netxen_api_unlock(adapter); in netxen_fwinit_work()
2609 if (!netxen_start_firmware(adapter)) { in netxen_fwinit_work()
2610 netxen_schedule_work(adapter, netxen_attach_work, 0); in netxen_fwinit_work()
2617 netxen_schedule_work(adapter, in netxen_fwinit_work()
2623 nx_incr_dev_ref_cnt(adapter); in netxen_fwinit_work()
2627 if (netxen_api_lock(adapter)) { in netxen_fwinit_work()
2628 clear_bit(__NX_RESETTING, &adapter->state); in netxen_fwinit_work()
2631 NXWR32(adapter, NX_CRB_DEV_STATE, NX_DEV_FAILED); in netxen_fwinit_work()
2632 netxen_api_unlock(adapter); in netxen_fwinit_work()
2633 dev_err(&adapter->pdev->dev, "%s: Device initialization Failed\n", in netxen_fwinit_work()
2634 adapter->netdev->name); in netxen_fwinit_work()
2636 clear_bit(__NX_RESETTING, &adapter->state); in netxen_fwinit_work()
2642 struct netxen_adapter *adapter = container_of(work, in netxen_detach_work() local
2644 struct net_device *netdev = adapter->netdev; in netxen_detach_work()
2650 netxen_nic_down(adapter, netdev); in netxen_detach_work()
2653 netxen_nic_detach(adapter); in netxen_detach_work()
2656 status = NXRD32(adapter, NETXEN_PEG_HALT_STATUS1); in netxen_detach_work()
2661 if (adapter->temp == NX_TEMP_PANIC) in netxen_detach_work()
2664 if (!(adapter->flags & NETXEN_FW_RESET_OWNER)) in netxen_detach_work()
2665 ref_cnt = nx_decr_dev_ref_cnt(adapter); in netxen_detach_work()
2672 adapter->fw_wait_cnt = 0; in netxen_detach_work()
2673 netxen_schedule_work(adapter, netxen_fwinit_work, delay); in netxen_detach_work()
2678 clear_bit(__NX_RESETTING, &adapter->state); in netxen_detach_work()
2682 netxen_check_health(struct netxen_adapter *adapter) in netxen_check_health() argument
2686 struct net_device *netdev = adapter->netdev; in netxen_check_health()
2688 state = NXRD32(adapter, NX_CRB_DEV_STATE); in netxen_check_health()
2692 if (netxen_nic_check_temp(adapter)) in netxen_check_health()
2695 if (adapter->need_fw_reset) { in netxen_check_health()
2696 if (nx_dev_request_reset(adapter)) in netxen_check_health()
2707 adapter->need_fw_reset = 1; in netxen_check_health()
2708 if (NX_IS_REVISION_P2(adapter->ahw.revision_id)) in netxen_check_health()
2712 if (NX_IS_REVISION_P2(adapter->ahw.revision_id)) in netxen_check_health()
2715 heartbit = NXRD32(adapter, NETXEN_PEG_ALIVE_COUNTER); in netxen_check_health()
2716 if (heartbit != adapter->heartbit) { in netxen_check_health()
2717 adapter->heartbit = heartbit; in netxen_check_health()
2718 adapter->fw_fail_cnt = 0; in netxen_check_health()
2719 if (adapter->need_fw_reset) in netxen_check_health()
2724 if (++adapter->fw_fail_cnt < FW_FAIL_THRESH) in netxen_check_health()
2727 if (nx_dev_request_reset(adapter)) in netxen_check_health()
2730 clear_bit(__NX_FW_ATTACHED, &adapter->state); in netxen_check_health()
2733 peg_status = NXRD32(adapter, NETXEN_PEG_HALT_STATUS1); in netxen_check_health()
2734 dev_err(&adapter->pdev->dev, "Dumping hw/fw registers\n" in netxen_check_health()
2740 NXRD32(adapter, NETXEN_PEG_HALT_STATUS2), in netxen_check_health()
2741 NXRD32(adapter, NETXEN_CRB_PEG_NET_0 + 0x3c), in netxen_check_health()
2742 NXRD32(adapter, NETXEN_CRB_PEG_NET_1 + 0x3c), in netxen_check_health()
2743 NXRD32(adapter, NETXEN_CRB_PEG_NET_2 + 0x3c), in netxen_check_health()
2744 NXRD32(adapter, NETXEN_CRB_PEG_NET_3 + 0x3c), in netxen_check_health()
2745 NXRD32(adapter, NETXEN_CRB_PEG_NET_4 + 0x3c)); in netxen_check_health()
2747 dev_err(&adapter->pdev->dev, in netxen_check_health()
2752 !test_and_set_bit(__NX_RESETTING, &adapter->state)) in netxen_check_health()
2753 netxen_schedule_work(adapter, netxen_detach_work, 0); in netxen_check_health()
2760 struct netxen_adapter *adapter = container_of(work, in netxen_fw_poll_work() local
2763 if (test_bit(__NX_RESETTING, &adapter->state)) in netxen_fw_poll_work()
2766 if (test_bit(__NX_DEV_UP, &adapter->state) && in netxen_fw_poll_work()
2767 !(adapter->capabilities & NX_FW_CAPABILITY_LINK_NOTIFICATION)) { in netxen_fw_poll_work()
2768 if (!adapter->has_link_events) { in netxen_fw_poll_work()
2770 netxen_nic_handle_phy_intr(adapter); in netxen_fw_poll_work()
2772 if (adapter->link_changed) in netxen_fw_poll_work()
2773 netxen_nic_set_link_parameters(adapter); in netxen_fw_poll_work()
2777 if (netxen_check_health(adapter)) in netxen_fw_poll_work()
2781 netxen_schedule_work(adapter, netxen_fw_poll_work, FW_POLL_DELAY); in netxen_fw_poll_work()
2789 struct netxen_adapter *adapter = netdev_priv(net); in netxen_store_bridged_mode() local
2793 if (!(adapter->capabilities & NX_FW_CAPABILITY_BDG)) in netxen_store_bridged_mode()
2796 if (adapter->is_up != NETXEN_ADAPTER_UP_MAGIC) in netxen_store_bridged_mode()
2802 if (!netxen_config_bridged_mode(adapter, !!new)) in netxen_store_bridged_mode()
2814 struct netxen_adapter *adapter; in netxen_show_bridged_mode() local
2817 adapter = netdev_priv(net); in netxen_show_bridged_mode()
2819 if (adapter->capabilities & NX_FW_CAPABILITY_BDG) in netxen_show_bridged_mode()
2820 bridged_mode = !!(adapter->flags & NETXEN_NIC_BRIDGE_ENABLED); in netxen_show_bridged_mode()
2835 struct netxen_adapter *adapter = dev_get_drvdata(dev); in netxen_store_diag_mode() local
2841 if (!!new != !!(adapter->flags & NETXEN_NIC_DIAG_ENABLED)) in netxen_store_diag_mode()
2842 adapter->flags ^= NETXEN_NIC_DIAG_ENABLED; in netxen_store_diag_mode()
2851 struct netxen_adapter *adapter = dev_get_drvdata(dev); in netxen_show_diag_mode() local
2854 !!(adapter->flags & NETXEN_NIC_DIAG_ENABLED)); in netxen_show_diag_mode()
2864 netxen_sysfs_validate_crb(struct netxen_adapter *adapter, in netxen_sysfs_validate_crb() argument
2869 if (!(adapter->flags & NETXEN_NIC_DIAG_ENABLED)) in netxen_sysfs_validate_crb()
2873 if (NX_IS_REVISION_P2(adapter->ahw.revision_id)) in netxen_sysfs_validate_crb()
2895 struct netxen_adapter *adapter = dev_get_drvdata(dev); in netxen_sysfs_read_crb() local
2900 ret = netxen_sysfs_validate_crb(adapter, offset, size); in netxen_sysfs_read_crb()
2904 if (NX_IS_REVISION_P3(adapter->ahw.revision_id) && in netxen_sysfs_read_crb()
2907 netxen_pci_camqm_read_2M(adapter, offset, &qmdata); in netxen_sysfs_read_crb()
2910 data = NXRD32(adapter, offset); in netxen_sysfs_read_crb()
2923 struct netxen_adapter *adapter = dev_get_drvdata(dev); in netxen_sysfs_write_crb() local
2928 ret = netxen_sysfs_validate_crb(adapter, offset, size); in netxen_sysfs_write_crb()
2932 if (NX_IS_REVISION_P3(adapter->ahw.revision_id) && in netxen_sysfs_write_crb()
2936 netxen_pci_camqm_write_2M(adapter, offset, qmdata); in netxen_sysfs_write_crb()
2939 NXWR32(adapter, offset, data); in netxen_sysfs_write_crb()
2946 netxen_sysfs_validate_mem(struct netxen_adapter *adapter, in netxen_sysfs_validate_mem() argument
2949 if (!(adapter->flags & NETXEN_NIC_DIAG_ENABLED)) in netxen_sysfs_validate_mem()
2964 struct netxen_adapter *adapter = dev_get_drvdata(dev); in netxen_sysfs_read_mem() local
2968 ret = netxen_sysfs_validate_mem(adapter, offset, size); in netxen_sysfs_read_mem()
2972 if (adapter->pci_mem_read(adapter, offset, &data)) in netxen_sysfs_read_mem()
2985 struct netxen_adapter *adapter = dev_get_drvdata(dev); in netxen_sysfs_write_mem() local
2989 ret = netxen_sysfs_validate_mem(adapter, offset, size); in netxen_sysfs_write_mem()
2995 if (adapter->pci_mem_write(adapter, offset, data)) in netxen_sysfs_write_mem()
3022 struct netxen_adapter *adapter = dev_get_drvdata(dev); in netxen_sysfs_read_dimm() local
3023 struct net_device *netdev = adapter->netdev; in netxen_sysfs_read_dimm()
3034 val = NXRD32(adapter, NETXEN_DIMM_CAPABILITY); in netxen_sysfs_read_dimm()
3146 netxen_create_sysfs_entries(struct netxen_adapter *adapter) in netxen_create_sysfs_entries() argument
3148 struct device *dev = &adapter->pdev->dev; in netxen_create_sysfs_entries()
3150 if (adapter->capabilities & NX_FW_CAPABILITY_BDG) { in netxen_create_sysfs_entries()
3160 netxen_remove_sysfs_entries(struct netxen_adapter *adapter) in netxen_remove_sysfs_entries() argument
3162 struct device *dev = &adapter->pdev->dev; in netxen_remove_sysfs_entries()
3164 if (adapter->capabilities & NX_FW_CAPABILITY_BDG) in netxen_remove_sysfs_entries()
3169 netxen_create_diag_entries(struct netxen_adapter *adapter) in netxen_create_diag_entries() argument
3171 struct pci_dev *pdev = adapter->pdev; in netxen_create_diag_entries()
3187 netxen_remove_diag_entries(struct netxen_adapter *adapter) in netxen_remove_diag_entries() argument
3189 struct pci_dev *pdev = adapter->pdev; in netxen_remove_diag_entries()
3203 netxen_destip_supported(struct netxen_adapter *adapter) in netxen_destip_supported() argument
3205 if (NX_IS_REVISION_P2(adapter->ahw.revision_id)) in netxen_destip_supported()
3208 if (adapter->ahw.cut_through) in netxen_destip_supported()
3215 netxen_free_ip_list(struct netxen_adapter *adapter, bool master) in netxen_free_ip_list() argument
3219 list_for_each_entry_safe(cur, tmp_cur, &adapter->ip_list, list) { in netxen_free_ip_list()
3222 netxen_config_ipaddr(adapter, cur->ip_addr, in netxen_free_ip_list()
3228 netxen_config_ipaddr(adapter, cur->ip_addr, NX_IP_DOWN); in netxen_free_ip_list()
3236 netxen_list_config_ip(struct netxen_adapter *adapter, in netxen_list_config_ip() argument
3251 list_for_each(head, &adapter->ip_list) { in netxen_list_config_ip()
3265 list_add_tail(&cur->list, &adapter->ip_list); in netxen_list_config_ip()
3266 netxen_config_ipaddr(adapter, ifa->ifa_address, NX_IP_UP); in netxen_list_config_ip()
3271 &adapter->ip_list, list) { in netxen_list_config_ip()
3275 netxen_config_ipaddr(adapter, ifa->ifa_address, in netxen_list_config_ip()
3287 netxen_config_indev_addr(struct netxen_adapter *adapter, in netxen_config_indev_addr() argument
3292 if (!netxen_destip_supported(adapter)) in netxen_config_indev_addr()
3302 netxen_list_config_ip(adapter, ifa, NX_IP_UP); in netxen_config_indev_addr()
3305 netxen_list_config_ip(adapter, ifa, NX_IP_DOWN); in netxen_config_indev_addr()
3319 struct netxen_adapter *adapter = netdev_priv(netdev); in netxen_restore_indev_addr() local
3324 netxen_config_indev_addr(adapter, netdev, event); in netxen_restore_indev_addr()
3326 list_for_each_entry_safe(pos, tmp_pos, &adapter->ip_list, list) { in netxen_restore_indev_addr()
3327 netxen_config_ipaddr(adapter, pos->ip_addr, ip_event); in netxen_restore_indev_addr()
3334 struct netxen_adapter *adapter; in netxen_config_checkdev() local
3338 adapter = netdev_priv(dev); in netxen_config_checkdev()
3339 if (!adapter) in netxen_config_checkdev()
3341 if (!netxen_destip_supported(adapter)) in netxen_config_checkdev()
3343 if (adapter->is_up != NETXEN_ADAPTER_UP_MAGIC) in netxen_config_checkdev()
3357 struct netxen_adapter *adapter = netdev_priv(dev); in netxen_config_master() local
3369 netxen_config_indev_addr(adapter, master, event); in netxen_config_master()
3373 netxen_config_indev_addr(adapter, slave, event); in netxen_config_master()
3382 netxen_free_ip_list(adapter, true); in netxen_config_master()
3388 struct netxen_adapter *adapter; in netxen_netdev_event() local
3408 adapter = netdev_priv(slave); in netxen_netdev_event()
3409 netxen_config_indev_addr(adapter, in netxen_netdev_event()
3416 adapter = netdev_priv(dev); in netxen_netdev_event()
3420 netxen_config_indev_addr(adapter, orig_dev, event); in netxen_netdev_event()
3431 struct netxen_adapter *adapter; in netxen_inetaddr_event() local
3453 adapter = netdev_priv(slave); in netxen_inetaddr_event()
3454 netxen_list_config_ip(adapter, ifa, ip_event); in netxen_inetaddr_event()
3460 adapter = netdev_priv(dev); in netxen_inetaddr_event()
3461 netxen_list_config_ip(adapter, ifa, ip_event); in netxen_inetaddr_event()
3480 netxen_free_ip_list(struct netxen_adapter *adapter, bool master) in netxen_free_ip_list() argument