aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/netxen/netxen_nic.h
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/netxen/netxen_nic.h')
-rw-r--r--drivers/net/netxen/netxen_nic.h165
1 files changed, 153 insertions, 12 deletions
diff --git a/drivers/net/netxen/netxen_nic.h b/drivers/net/netxen/netxen_nic.h
index 0458db45e700..1bee560d7d0a 100644
--- a/drivers/net/netxen/netxen_nic.h
+++ b/drivers/net/netxen/netxen_nic.h
@@ -63,12 +63,12 @@
63 63
64#include "netxen_nic_hw.h" 64#include "netxen_nic_hw.h"
65 65
66#define NETXEN_NIC_BUILD_NO "232" 66#define NETXEN_NIC_BUILD_NO "5"
67#define _NETXEN_NIC_LINUX_MAJOR 2 67#define _NETXEN_NIC_LINUX_MAJOR 2
68#define _NETXEN_NIC_LINUX_MINOR 3 68#define _NETXEN_NIC_LINUX_MINOR 3
69#define _NETXEN_NIC_LINUX_SUBVERSION 57 69#define _NETXEN_NIC_LINUX_SUBVERSION 59
70#define NETXEN_NIC_LINUX_VERSIONID "2.3.57" 70#define NETXEN_NIC_LINUX_VERSIONID "2.3.59" "-" NETXEN_NIC_BUILD_NO
71#define NETXEN_NIC_FW_VERSIONID "2.3.57" 71#define NETXEN_NIC_FW_VERSIONID "2.3.59"
72 72
73#define RCV_DESC_RINGSIZE \ 73#define RCV_DESC_RINGSIZE \
74 (sizeof(struct rcv_desc) * adapter->max_rx_desc_count) 74 (sizeof(struct rcv_desc) * adapter->max_rx_desc_count)
@@ -89,9 +89,24 @@
89 * normalize a 64MB crb address to 32MB PCI window 89 * normalize a 64MB crb address to 32MB PCI window
90 * To use NETXEN_CRB_NORMALIZE, window _must_ be set to 1 90 * To use NETXEN_CRB_NORMALIZE, window _must_ be set to 1
91 */ 91 */
92#define NETXEN_CRB_NORMAL(reg) \
93 (reg) - NETXEN_CRB_PCIX_HOST2 + NETXEN_CRB_PCIX_HOST
94
92#define NETXEN_CRB_NORMALIZE(adapter, reg) \ 95#define NETXEN_CRB_NORMALIZE(adapter, reg) \
93 ((adapter)->ahw.pci_base + (reg) \ 96 pci_base_offset(adapter, NETXEN_CRB_NORMAL(reg))
94 - NETXEN_CRB_PCIX_HOST2 + NETXEN_CRB_PCIX_HOST) 97
98#define FIRST_PAGE_GROUP_START 0
99#define FIRST_PAGE_GROUP_END 0x400000
100
101#define SECOND_PAGE_GROUP_START 0x4000000
102#define SECOND_PAGE_GROUP_END 0x66BC000
103
104#define THIRD_PAGE_GROUP_START 0x70E4000
105#define THIRD_PAGE_GROUP_END 0x8000000
106
107#define FIRST_PAGE_GROUP_SIZE FIRST_PAGE_GROUP_END - FIRST_PAGE_GROUP_START
108#define SECOND_PAGE_GROUP_SIZE SECOND_PAGE_GROUP_END - SECOND_PAGE_GROUP_START
109#define THIRD_PAGE_GROUP_SIZE THIRD_PAGE_GROUP_END - THIRD_PAGE_GROUP_START
95 110
96#define MAX_RX_BUFFER_LENGTH 2000 111#define MAX_RX_BUFFER_LENGTH 2000
97#define MAX_RX_JUMBO_BUFFER_LENGTH 9046 112#define MAX_RX_JUMBO_BUFFER_LENGTH 9046
@@ -328,6 +343,7 @@ typedef enum {
328 NETXEN_BRDTYPE_P2_SB31_10G_HMEZ = 0x000e, 343 NETXEN_BRDTYPE_P2_SB31_10G_HMEZ = 0x000e,
329 NETXEN_BRDTYPE_P2_SB31_10G_CX4 = 0x000f 344 NETXEN_BRDTYPE_P2_SB31_10G_CX4 = 0x000f
330} netxen_brdtype_t; 345} netxen_brdtype_t;
346#define NUM_SUPPORTED_BOARDS (sizeof(netxen_boards)/sizeof(netxen_brdinfo_t))
331 347
332typedef enum { 348typedef enum {
333 NETXEN_BRDMFG_INVENTEC = 1 349 NETXEN_BRDMFG_INVENTEC = 1
@@ -615,15 +631,23 @@ struct netxen_rx_buffer {
615 */ 631 */
616struct netxen_hardware_context { 632struct netxen_hardware_context {
617 struct pci_dev *pdev; 633 struct pci_dev *pdev;
618 void __iomem *pci_base; /* base of mapped phantom memory */ 634 void __iomem *pci_base0;
635 void __iomem *pci_base1;
636 void __iomem *pci_base2;
637
619 u8 revision_id; 638 u8 revision_id;
620 u16 board_type; 639 u16 board_type;
621 u16 max_ports; 640 u16 max_ports;
622 struct netxen_board_info boardcfg; 641 struct netxen_board_info boardcfg;
623 u32 xg_linkup; 642 u32 xg_linkup;
643 u32 qg_linksup;
624 /* Address of cmd ring in Phantom */ 644 /* Address of cmd ring in Phantom */
625 struct cmd_desc_type0 *cmd_desc_head; 645 struct cmd_desc_type0 *cmd_desc_head;
646 char *pauseaddr;
647 struct pci_dev *cmd_desc_pdev;
626 dma_addr_t cmd_desc_phys_addr; 648 dma_addr_t cmd_desc_phys_addr;
649 dma_addr_t pause_physaddr;
650 struct pci_dev *pause_pdev;
627 struct netxen_adapter *adapter; 651 struct netxen_adapter *adapter;
628}; 652};
629 653
@@ -654,6 +678,7 @@ struct netxen_rcv_desc_ctx {
654 u32 rcv_pending; /* Num of bufs posted in phantom */ 678 u32 rcv_pending; /* Num of bufs posted in phantom */
655 u32 rcv_free; /* Num of bufs in free list */ 679 u32 rcv_free; /* Num of bufs in free list */
656 dma_addr_t phys_addr; 680 dma_addr_t phys_addr;
681 struct pci_dev *phys_pdev;
657 struct rcv_desc *desc_head; /* address of rx ring in Phantom */ 682 struct rcv_desc *desc_head; /* address of rx ring in Phantom */
658 u32 max_rx_desc_count; 683 u32 max_rx_desc_count;
659 u32 dma_size; 684 u32 dma_size;
@@ -673,6 +698,7 @@ struct netxen_recv_context {
673 u32 status_rx_producer; 698 u32 status_rx_producer;
674 u32 status_rx_consumer; 699 u32 status_rx_consumer;
675 dma_addr_t rcv_status_desc_phys_addr; 700 dma_addr_t rcv_status_desc_phys_addr;
701 struct pci_dev *rcv_status_desc_pdev;
676 struct status_desc *rcv_status_desc_head; 702 struct status_desc *rcv_status_desc_head;
677}; 703};
678 704
@@ -708,6 +734,7 @@ struct netxen_adapter {
708 u32 flags; 734 u32 flags;
709 u32 irq; 735 u32 irq;
710 int driver_mismatch; 736 int driver_mismatch;
737 u32 temp;
711 738
712 struct netxen_adapter_stats stats; 739 struct netxen_adapter_stats stats;
713 740
@@ -766,6 +793,43 @@ struct netxen_port {
766 struct netxen_port_stats stats; 793 struct netxen_port_stats stats;
767}; 794};
768 795
796#define PCI_OFFSET_FIRST_RANGE(adapter, off) \
797 ((adapter)->ahw.pci_base0 + (off))
798#define PCI_OFFSET_SECOND_RANGE(adapter, off) \
799 ((adapter)->ahw.pci_base1 + (off) - SECOND_PAGE_GROUP_START)
800#define PCI_OFFSET_THIRD_RANGE(adapter, off) \
801 ((adapter)->ahw.pci_base2 + (off) - THIRD_PAGE_GROUP_START)
802
803static inline void __iomem *pci_base_offset(struct netxen_adapter *adapter,
804 unsigned long off)
805{
806 if ((off < FIRST_PAGE_GROUP_END) && (off >= FIRST_PAGE_GROUP_START)) {
807 return (adapter->ahw.pci_base0 + off);
808 } else if ((off < SECOND_PAGE_GROUP_END) &&
809 (off >= SECOND_PAGE_GROUP_START)) {
810 return (adapter->ahw.pci_base1 + off - SECOND_PAGE_GROUP_START);
811 } else if ((off < THIRD_PAGE_GROUP_END) &&
812 (off >= THIRD_PAGE_GROUP_START)) {
813 return (adapter->ahw.pci_base2 + off - THIRD_PAGE_GROUP_START);
814 }
815 return NULL;
816}
817
818static inline void __iomem *pci_base(struct netxen_adapter *adapter,
819 unsigned long off)
820{
821 if ((off < FIRST_PAGE_GROUP_END) && (off >= FIRST_PAGE_GROUP_START)) {
822 return adapter->ahw.pci_base0;
823 } else if ((off < SECOND_PAGE_GROUP_END) &&
824 (off >= SECOND_PAGE_GROUP_START)) {
825 return adapter->ahw.pci_base1;
826 } else if ((off < THIRD_PAGE_GROUP_END) &&
827 (off >= THIRD_PAGE_GROUP_START)) {
828 return adapter->ahw.pci_base2;
829 }
830 return NULL;
831}
832
769struct netxen_drvops { 833struct netxen_drvops {
770 int (*enable_phy_interrupts) (struct netxen_adapter *, int); 834 int (*enable_phy_interrupts) (struct netxen_adapter *, int);
771 int (*disable_phy_interrupts) (struct netxen_adapter *, int); 835 int (*disable_phy_interrupts) (struct netxen_adapter *, int);
@@ -809,7 +873,6 @@ int netxen_niu_gbe_phy_write(struct netxen_adapter *adapter, long phy,
809 long reg, __le32 val); 873 long reg, __le32 val);
810 874
811/* Functions available from netxen_nic_hw.c */ 875/* Functions available from netxen_nic_hw.c */
812int netxen_niu_xginit(struct netxen_adapter *);
813int netxen_nic_set_mtu_xgb(struct netxen_port *port, int new_mtu); 876int netxen_nic_set_mtu_xgb(struct netxen_port *port, int new_mtu);
814int netxen_nic_set_mtu_gb(struct netxen_port *port, int new_mtu); 877int netxen_nic_set_mtu_gb(struct netxen_port *port, int new_mtu);
815void netxen_nic_init_niu_gb(struct netxen_adapter *adapter); 878void netxen_nic_init_niu_gb(struct netxen_adapter *adapter);
@@ -828,10 +891,13 @@ void netxen_crb_writelit_adapter(struct netxen_adapter *adapter,
828 unsigned long off, int data); 891 unsigned long off, int data);
829 892
830/* Functions from netxen_nic_init.c */ 893/* Functions from netxen_nic_init.c */
831void netxen_phantom_init(struct netxen_adapter *adapter); 894void netxen_phantom_init(struct netxen_adapter *adapter, int pegtune_val);
832void netxen_load_firmware(struct netxen_adapter *adapter); 895void netxen_load_firmware(struct netxen_adapter *adapter);
833int netxen_pinit_from_rom(struct netxen_adapter *adapter, int verbose); 896int netxen_pinit_from_rom(struct netxen_adapter *adapter, int verbose);
834int netxen_rom_fast_read(struct netxen_adapter *adapter, int addr, int *valp); 897int netxen_rom_fast_read(struct netxen_adapter *adapter, int addr, int *valp);
898int netxen_rom_fast_write(struct netxen_adapter *adapter, int addr, int data);
899int netxen_rom_se(struct netxen_adapter *adapter, int addr);
900int netxen_do_rom_se(struct netxen_adapter *adapter, int addr);
835 901
836/* Functions from netxen_nic_isr.c */ 902/* Functions from netxen_nic_isr.c */
837void netxen_nic_isr_other(struct netxen_adapter *adapter); 903void netxen_nic_isr_other(struct netxen_adapter *adapter);
@@ -842,6 +908,8 @@ void netxen_handle_port_int(struct netxen_adapter *adapter, u32 port,
842void netxen_nic_stop_all_ports(struct netxen_adapter *adapter); 908void netxen_nic_stop_all_ports(struct netxen_adapter *adapter);
843void netxen_initialize_adapter_sw(struct netxen_adapter *adapter); 909void netxen_initialize_adapter_sw(struct netxen_adapter *adapter);
844void netxen_initialize_adapter_hw(struct netxen_adapter *adapter); 910void netxen_initialize_adapter_hw(struct netxen_adapter *adapter);
911void *netxen_alloc(struct pci_dev *pdev, size_t sz, dma_addr_t * ptr,
912 struct pci_dev **used_dev);
845void netxen_initialize_adapter_ops(struct netxen_adapter *adapter); 913void netxen_initialize_adapter_ops(struct netxen_adapter *adapter);
846int netxen_init_firmware(struct netxen_adapter *adapter); 914int netxen_init_firmware(struct netxen_adapter *adapter);
847void netxen_free_hw_resources(struct netxen_adapter *adapter); 915void netxen_free_hw_resources(struct netxen_adapter *adapter);
@@ -869,7 +937,10 @@ static inline void netxen_nic_disable_int(struct netxen_adapter *adapter)
869 /* 937 /*
870 * ISR_INT_MASK: Can be read from window 0 or 1. 938 * ISR_INT_MASK: Can be read from window 0 or 1.
871 */ 939 */
872 writel(0x7ff, (void __iomem *)(adapter->ahw.pci_base + ISR_INT_MASK)); 940 writel(0x7ff,
941 (void __iomem
942 *)(PCI_OFFSET_SECOND_RANGE(adapter, ISR_INT_MASK)));
943
873} 944}
874 945
875static inline void netxen_nic_enable_int(struct netxen_adapter *adapter) 946static inline void netxen_nic_enable_int(struct netxen_adapter *adapter)
@@ -888,13 +959,83 @@ static inline void netxen_nic_enable_int(struct netxen_adapter *adapter)
888 break; 959 break;
889 } 960 }
890 961
891 writel(mask, (void __iomem *)(adapter->ahw.pci_base + ISR_INT_MASK)); 962 writel(mask,
963 (void __iomem
964 *)(PCI_OFFSET_SECOND_RANGE(adapter, ISR_INT_MASK)));
892 965
893 if (!(adapter->flags & NETXEN_NIC_MSI_ENABLED)) { 966 if (!(adapter->flags & NETXEN_NIC_MSI_ENABLED)) {
894 mask = 0xbff; 967 mask = 0xbff;
895 writel(mask, (void __iomem *) 968 writel(mask, (void __iomem *)
896 (adapter->ahw.pci_base + ISR_INT_TARGET_MASK)); 969 (PCI_OFFSET_SECOND_RANGE(adapter, ISR_INT_TARGET_MASK)));
970 }
971}
972
973/*
974 * NetXen Board information
975 */
976
977#define NETXEN_MAX_SHORT_NAME 16
978typedef struct {
979 netxen_brdtype_t brdtype; /* type of board */
980 long ports; /* max no of physical ports */
981 char short_name[NETXEN_MAX_SHORT_NAME];
982} netxen_brdinfo_t;
983
984static const netxen_brdinfo_t netxen_boards[] = {
985 {NETXEN_BRDTYPE_P2_SB31_10G_CX4, 1, "XGb CX4"},
986 {NETXEN_BRDTYPE_P2_SB31_10G_HMEZ, 1, "XGb HMEZ"},
987 {NETXEN_BRDTYPE_P2_SB31_10G_IMEZ, 2, "XGb IMEZ"},
988 {NETXEN_BRDTYPE_P2_SB31_10G, 1, "XGb XFP"},
989 {NETXEN_BRDTYPE_P2_SB35_4G, 4, "Quad Gb"},
990 {NETXEN_BRDTYPE_P2_SB31_2G, 2, "Dual Gb"},
991};
992
993#define NUM_SUPPORTED_BOARDS (sizeof(netxen_boards)/sizeof(netxen_brdinfo_t))
994
995static inline void get_brd_ports_name_by_type(u32 type, int *ports, char *name)
996{
997 int i, found = 0;
998 for (i = 0; i < NUM_SUPPORTED_BOARDS; ++i) {
999 if (netxen_boards[i].brdtype == type) {
1000 *ports = netxen_boards[i].ports;
1001 strcpy(name, netxen_boards[i].short_name);
1002 found = 1;
1003 break;
1004 }
1005 }
1006 if (!found) {
1007 *ports = 0;
1008 name = "Unknown";
1009 }
1010}
1011
1012static inline void get_brd_port_by_type(u32 type, int *ports)
1013{
1014 int i, found = 0;
1015 for (i = 0; i < NUM_SUPPORTED_BOARDS; ++i) {
1016 if (netxen_boards[i].brdtype == type) {
1017 *ports = netxen_boards[i].ports;
1018 found = 1;
1019 break;
1020 }
1021 }
1022 if (!found)
1023 *ports = 0;
1024}
1025
1026static inline void get_brd_name_by_type(u32 type, char *name)
1027{
1028 int i, found = 0;
1029 for (i = 0; i < NUM_SUPPORTED_BOARDS; ++i) {
1030 if (netxen_boards[i].brdtype == type) {
1031 strcpy(name, netxen_boards[i].short_name);
1032 found = 1;
1033 break;
1034 }
1035
897 } 1036 }
1037 if (!found)
1038 name = "Unknown";
898} 1039}
899 1040
900int netxen_is_flash_supported(struct netxen_adapter *adapter); 1041int netxen_is_flash_supported(struct netxen_adapter *adapter);