diff options
-rw-r--r-- | drivers/net/netxen/netxen_nic.h | 19 | ||||
-rw-r--r-- | drivers/net/netxen/netxen_nic_ethtool.c | 5 | ||||
-rw-r--r-- | drivers/net/netxen/netxen_nic_hw.c | 270 | ||||
-rw-r--r-- | drivers/net/netxen/netxen_nic_init.c | 88 | ||||
-rw-r--r-- | drivers/net/netxen/netxen_nic_main.c | 74 | ||||
-rw-r--r-- | drivers/net/netxen/netxen_nic_phan_reg.h | 17 |
6 files changed, 113 insertions, 360 deletions
diff --git a/drivers/net/netxen/netxen_nic.h b/drivers/net/netxen/netxen_nic.h index da4c4fb97064..149bb60b0c46 100644 --- a/drivers/net/netxen/netxen_nic.h +++ b/drivers/net/netxen/netxen_nic.h | |||
@@ -132,7 +132,6 @@ | |||
132 | #define RX_JUMBO_DMA_MAP_LEN \ | 132 | #define RX_JUMBO_DMA_MAP_LEN \ |
133 | (MAX_RX_JUMBO_BUFFER_LENGTH - 2) | 133 | (MAX_RX_JUMBO_BUFFER_LENGTH - 2) |
134 | #define RX_LRO_DMA_MAP_LEN (MAX_RX_LRO_BUFFER_LENGTH - 2) | 134 | #define RX_LRO_DMA_MAP_LEN (MAX_RX_LRO_BUFFER_LENGTH - 2) |
135 | #define NETXEN_ROM_ROUNDUP 0x80000000ULL | ||
136 | 135 | ||
137 | /* | 136 | /* |
138 | * Maximum number of ring contexts | 137 | * Maximum number of ring contexts |
@@ -219,8 +218,6 @@ enum { | |||
219 | #define MPORT_MULTI_FUNCTION_MODE 0x2222 | 218 | #define MPORT_MULTI_FUNCTION_MODE 0x2222 |
220 | 219 | ||
221 | #include "netxen_nic_phan_reg.h" | 220 | #include "netxen_nic_phan_reg.h" |
222 | extern unsigned long long netxen_dma_mask; | ||
223 | extern unsigned long last_schedule_time; | ||
224 | 221 | ||
225 | /* | 222 | /* |
226 | * NetXen host-peg signal message structure | 223 | * NetXen host-peg signal message structure |
@@ -765,7 +762,6 @@ struct netxen_rx_buffer { | |||
765 | * contains interrupt info as well shared hardware info. | 762 | * contains interrupt info as well shared hardware info. |
766 | */ | 763 | */ |
767 | struct netxen_hardware_context { | 764 | struct netxen_hardware_context { |
768 | struct pci_dev *pdev; | ||
769 | void __iomem *pci_base0; | 765 | void __iomem *pci_base0; |
770 | void __iomem *pci_base1; | 766 | void __iomem *pci_base1; |
771 | void __iomem *pci_base2; | 767 | void __iomem *pci_base2; |
@@ -781,7 +777,6 @@ struct netxen_hardware_context { | |||
781 | u32 qg_linksup; | 777 | u32 qg_linksup; |
782 | /* Address of cmd ring in Phantom */ | 778 | /* Address of cmd ring in Phantom */ |
783 | struct cmd_desc_type0 *cmd_desc_head; | 779 | struct cmd_desc_type0 *cmd_desc_head; |
784 | struct pci_dev *cmd_desc_pdev; | ||
785 | dma_addr_t cmd_desc_phys_addr; | 780 | dma_addr_t cmd_desc_phys_addr; |
786 | struct netxen_adapter *adapter; | 781 | struct netxen_adapter *adapter; |
787 | int pci_func; | 782 | int pci_func; |
@@ -816,9 +811,8 @@ struct netxen_adapter_stats { | |||
816 | struct netxen_rcv_desc_ctx { | 811 | struct netxen_rcv_desc_ctx { |
817 | u32 flags; | 812 | u32 flags; |
818 | u32 producer; | 813 | u32 producer; |
819 | u32 rcv_pending; /* Num of bufs posted in phantom */ | ||
820 | dma_addr_t phys_addr; | 814 | dma_addr_t phys_addr; |
821 | struct pci_dev *phys_pdev; | 815 | u32 crb_rcv_producer; /* reg offset */ |
822 | struct rcv_desc *desc_head; /* address of rx ring in Phantom */ | 816 | struct rcv_desc *desc_head; /* address of rx ring in Phantom */ |
823 | u32 max_rx_desc_count; | 817 | u32 max_rx_desc_count; |
824 | u32 dma_size; | 818 | u32 dma_size; |
@@ -835,10 +829,9 @@ struct netxen_rcv_desc_ctx { | |||
835 | */ | 829 | */ |
836 | struct netxen_recv_context { | 830 | struct netxen_recv_context { |
837 | struct netxen_rcv_desc_ctx rcv_desc[NUM_RCV_DESC_RINGS]; | 831 | struct netxen_rcv_desc_ctx rcv_desc[NUM_RCV_DESC_RINGS]; |
838 | u32 status_rx_producer; | ||
839 | u32 status_rx_consumer; | 832 | u32 status_rx_consumer; |
833 | u32 crb_sts_consumer; /* reg offset */ | ||
840 | dma_addr_t rcv_status_desc_phys_addr; | 834 | dma_addr_t rcv_status_desc_phys_addr; |
841 | struct pci_dev *rcv_status_desc_pdev; | ||
842 | struct status_desc *rcv_status_desc_head; | 835 | struct status_desc *rcv_status_desc_head; |
843 | }; | 836 | }; |
844 | 837 | ||
@@ -854,7 +847,6 @@ struct netxen_dummy_dma { | |||
854 | struct netxen_adapter { | 847 | struct netxen_adapter { |
855 | struct netxen_hardware_context ahw; | 848 | struct netxen_hardware_context ahw; |
856 | 849 | ||
857 | struct netxen_adapter *master; | ||
858 | struct net_device *netdev; | 850 | struct net_device *netdev; |
859 | struct pci_dev *pdev; | 851 | struct pci_dev *pdev; |
860 | struct napi_struct napi; | 852 | struct napi_struct napi; |
@@ -873,6 +865,8 @@ struct netxen_adapter { | |||
873 | u32 cmd_producer; | 865 | u32 cmd_producer; |
874 | __le32 *cmd_consumer; | 866 | __le32 *cmd_consumer; |
875 | u32 last_cmd_consumer; | 867 | u32 last_cmd_consumer; |
868 | u32 crb_addr_cmd_producer; | ||
869 | u32 crb_addr_cmd_consumer; | ||
876 | 870 | ||
877 | u32 max_tx_desc_count; | 871 | u32 max_tx_desc_count; |
878 | u32 max_rx_desc_count; | 872 | u32 max_rx_desc_count; |
@@ -886,14 +880,12 @@ struct netxen_adapter { | |||
886 | 880 | ||
887 | struct netxen_adapter_stats stats; | 881 | struct netxen_adapter_stats stats; |
888 | 882 | ||
889 | u16 portno; | ||
890 | u16 link_speed; | 883 | u16 link_speed; |
891 | u16 link_duplex; | 884 | u16 link_duplex; |
892 | u16 state; | 885 | u16 state; |
893 | u16 link_autoneg; | 886 | u16 link_autoneg; |
894 | int rx_csum; | 887 | int rx_csum; |
895 | int status; | 888 | int status; |
896 | spinlock_t stats_lock; | ||
897 | 889 | ||
898 | struct netxen_cmd_buffer *cmd_buf_arr; /* Command buffers for xmit */ | 890 | struct netxen_cmd_buffer *cmd_buf_arr; /* Command buffers for xmit */ |
899 | 891 | ||
@@ -908,7 +900,6 @@ struct netxen_adapter { | |||
908 | 900 | ||
909 | /* Context interface shared between card and host */ | 901 | /* Context interface shared between card and host */ |
910 | struct netxen_ring_ctx *ctx_desc; | 902 | struct netxen_ring_ctx *ctx_desc; |
911 | struct pci_dev *ctx_desc_pdev; | ||
912 | dma_addr_t ctx_desc_phys_addr; | 903 | dma_addr_t ctx_desc_phys_addr; |
913 | int intr_scheme; | 904 | int intr_scheme; |
914 | int msi_mode; | 905 | int msi_mode; |
@@ -1034,8 +1025,6 @@ int netxen_rom_se(struct netxen_adapter *adapter, int addr); | |||
1034 | 1025 | ||
1035 | /* Functions from netxen_nic_isr.c */ | 1026 | /* Functions from netxen_nic_isr.c */ |
1036 | void netxen_initialize_adapter_sw(struct netxen_adapter *adapter); | 1027 | void netxen_initialize_adapter_sw(struct netxen_adapter *adapter); |
1037 | void *netxen_alloc(struct pci_dev *pdev, size_t sz, dma_addr_t * ptr, | ||
1038 | struct pci_dev **used_dev); | ||
1039 | void netxen_initialize_adapter_ops(struct netxen_adapter *adapter); | 1028 | void netxen_initialize_adapter_ops(struct netxen_adapter *adapter); |
1040 | int netxen_init_firmware(struct netxen_adapter *adapter); | 1029 | int netxen_init_firmware(struct netxen_adapter *adapter); |
1041 | void netxen_free_hw_resources(struct netxen_adapter *adapter); | 1030 | void netxen_free_hw_resources(struct netxen_adapter *adapter); |
diff --git a/drivers/net/netxen/netxen_nic_ethtool.c b/drivers/net/netxen/netxen_nic_ethtool.c index 723487bf200c..99071c253766 100644 --- a/drivers/net/netxen/netxen_nic_ethtool.c +++ b/drivers/net/netxen/netxen_nic_ethtool.c | |||
@@ -427,6 +427,7 @@ netxen_nic_get_eeprom(struct net_device *dev, struct ethtool_eeprom *eeprom, | |||
427 | return 0; | 427 | return 0; |
428 | } | 428 | } |
429 | 429 | ||
430 | #if 0 | ||
430 | static int | 431 | static int |
431 | netxen_nic_set_eeprom(struct net_device *dev, struct ethtool_eeprom *eeprom, | 432 | netxen_nic_set_eeprom(struct net_device *dev, struct ethtool_eeprom *eeprom, |
432 | u8 * bytes) | 433 | u8 * bytes) |
@@ -447,7 +448,6 @@ netxen_nic_set_eeprom(struct net_device *dev, struct ethtool_eeprom *eeprom, | |||
447 | } | 448 | } |
448 | printk(KERN_INFO "%s: flash unlocked. \n", | 449 | printk(KERN_INFO "%s: flash unlocked. \n", |
449 | netxen_nic_driver_name); | 450 | netxen_nic_driver_name); |
450 | last_schedule_time = jiffies; | ||
451 | ret = netxen_flash_erase_secondary(adapter); | 451 | ret = netxen_flash_erase_secondary(adapter); |
452 | if (ret != FLASH_SUCCESS) { | 452 | if (ret != FLASH_SUCCESS) { |
453 | printk(KERN_ERR "%s: Flash erase failed.\n", | 453 | printk(KERN_ERR "%s: Flash erase failed.\n", |
@@ -497,6 +497,7 @@ netxen_nic_set_eeprom(struct net_device *dev, struct ethtool_eeprom *eeprom, | |||
497 | 497 | ||
498 | return netxen_rom_fast_write_words(adapter, offset, bytes, eeprom->len); | 498 | return netxen_rom_fast_write_words(adapter, offset, bytes, eeprom->len); |
499 | } | 499 | } |
500 | #endif /* 0 */ | ||
500 | 501 | ||
501 | static void | 502 | static void |
502 | netxen_nic_get_ringparam(struct net_device *dev, struct ethtool_ringparam *ring) | 503 | netxen_nic_get_ringparam(struct net_device *dev, struct ethtool_ringparam *ring) |
@@ -745,7 +746,9 @@ struct ethtool_ops netxen_nic_ethtool_ops = { | |||
745 | .get_link = ethtool_op_get_link, | 746 | .get_link = ethtool_op_get_link, |
746 | .get_eeprom_len = netxen_nic_get_eeprom_len, | 747 | .get_eeprom_len = netxen_nic_get_eeprom_len, |
747 | .get_eeprom = netxen_nic_get_eeprom, | 748 | .get_eeprom = netxen_nic_get_eeprom, |
749 | #if 0 | ||
748 | .set_eeprom = netxen_nic_set_eeprom, | 750 | .set_eeprom = netxen_nic_set_eeprom, |
751 | #endif | ||
749 | .get_ringparam = netxen_nic_get_ringparam, | 752 | .get_ringparam = netxen_nic_get_ringparam, |
750 | .get_pauseparam = netxen_nic_get_pauseparam, | 753 | .get_pauseparam = netxen_nic_get_pauseparam, |
751 | .set_pauseparam = netxen_nic_set_pauseparam, | 754 | .set_pauseparam = netxen_nic_set_pauseparam, |
diff --git a/drivers/net/netxen/netxen_nic_hw.c b/drivers/net/netxen/netxen_nic_hw.c index c43d06b8de9b..fa6d034c242c 100644 --- a/drivers/net/netxen/netxen_nic_hw.c +++ b/drivers/net/netxen/netxen_nic_hw.c | |||
@@ -43,203 +43,61 @@ struct netxen_recv_crb recv_crb_registers[] = { | |||
43 | * Instance 0. | 43 | * Instance 0. |
44 | */ | 44 | */ |
45 | { | 45 | { |
46 | /* rcv_desc_crb: */ | 46 | /* crb_rcv_producer: */ |
47 | { | 47 | { |
48 | { | 48 | NETXEN_NIC_REG(0x100), |
49 | /* crb_rcv_producer_offset: */ | 49 | /* Jumbo frames */ |
50 | NETXEN_NIC_REG(0x100), | 50 | NETXEN_NIC_REG(0x110), |
51 | /* crb_rcv_consumer_offset: */ | 51 | /* LRO */ |
52 | NETXEN_NIC_REG(0x104), | 52 | NETXEN_NIC_REG(0x120) |
53 | /* crb_gloablrcv_ring: */ | 53 | }, |
54 | NETXEN_NIC_REG(0x108), | 54 | /* crb_sts_consumer: */ |
55 | /* crb_rcv_ring_size */ | 55 | NETXEN_NIC_REG(0x138), |
56 | NETXEN_NIC_REG(0x10c), | 56 | }, |
57 | |||
58 | }, | ||
59 | /* Jumbo frames */ | ||
60 | { | ||
61 | /* crb_rcv_producer_offset: */ | ||
62 | NETXEN_NIC_REG(0x110), | ||
63 | /* crb_rcv_consumer_offset: */ | ||
64 | NETXEN_NIC_REG(0x114), | ||
65 | /* crb_gloablrcv_ring: */ | ||
66 | NETXEN_NIC_REG(0x118), | ||
67 | /* crb_rcv_ring_size */ | ||
68 | NETXEN_NIC_REG(0x11c), | ||
69 | }, | ||
70 | /* LRO */ | ||
71 | { | ||
72 | /* crb_rcv_producer_offset: */ | ||
73 | NETXEN_NIC_REG(0x120), | ||
74 | /* crb_rcv_consumer_offset: */ | ||
75 | NETXEN_NIC_REG(0x124), | ||
76 | /* crb_gloablrcv_ring: */ | ||
77 | NETXEN_NIC_REG(0x128), | ||
78 | /* crb_rcv_ring_size */ | ||
79 | NETXEN_NIC_REG(0x12c), | ||
80 | } | ||
81 | }, | ||
82 | /* crb_rcvstatus_ring: */ | ||
83 | NETXEN_NIC_REG(0x130), | ||
84 | /* crb_rcv_status_producer: */ | ||
85 | NETXEN_NIC_REG(0x134), | ||
86 | /* crb_rcv_status_consumer: */ | ||
87 | NETXEN_NIC_REG(0x138), | ||
88 | /* crb_rcvpeg_state: */ | ||
89 | NETXEN_NIC_REG(0x13c), | ||
90 | /* crb_status_ring_size */ | ||
91 | NETXEN_NIC_REG(0x140), | ||
92 | |||
93 | }, | ||
94 | /* | 57 | /* |
95 | * Instance 1, | 58 | * Instance 1, |
96 | */ | 59 | */ |
97 | { | 60 | { |
98 | /* rcv_desc_crb: */ | 61 | /* crb_rcv_producer: */ |
99 | { | 62 | { |
100 | { | 63 | NETXEN_NIC_REG(0x144), |
101 | /* crb_rcv_producer_offset: */ | 64 | /* Jumbo frames */ |
102 | NETXEN_NIC_REG(0x144), | 65 | NETXEN_NIC_REG(0x154), |
103 | /* crb_rcv_consumer_offset: */ | 66 | /* LRO */ |
104 | NETXEN_NIC_REG(0x148), | 67 | NETXEN_NIC_REG(0x164) |
105 | /* crb_globalrcv_ring: */ | 68 | }, |
106 | NETXEN_NIC_REG(0x14c), | 69 | /* crb_sts_consumer: */ |
107 | /* crb_rcv_ring_size */ | 70 | NETXEN_NIC_REG(0x17c), |
108 | NETXEN_NIC_REG(0x150), | 71 | }, |
109 | |||
110 | }, | ||
111 | /* Jumbo frames */ | ||
112 | { | ||
113 | /* crb_rcv_producer_offset: */ | ||
114 | NETXEN_NIC_REG(0x154), | ||
115 | /* crb_rcv_consumer_offset: */ | ||
116 | NETXEN_NIC_REG(0x158), | ||
117 | /* crb_globalrcv_ring: */ | ||
118 | NETXEN_NIC_REG(0x15c), | ||
119 | /* crb_rcv_ring_size */ | ||
120 | NETXEN_NIC_REG(0x160), | ||
121 | }, | ||
122 | /* LRO */ | ||
123 | { | ||
124 | /* crb_rcv_producer_offset: */ | ||
125 | NETXEN_NIC_REG(0x164), | ||
126 | /* crb_rcv_consumer_offset: */ | ||
127 | NETXEN_NIC_REG(0x168), | ||
128 | /* crb_globalrcv_ring: */ | ||
129 | NETXEN_NIC_REG(0x16c), | ||
130 | /* crb_rcv_ring_size */ | ||
131 | NETXEN_NIC_REG(0x170), | ||
132 | } | ||
133 | |||
134 | }, | ||
135 | /* crb_rcvstatus_ring: */ | ||
136 | NETXEN_NIC_REG(0x174), | ||
137 | /* crb_rcv_status_producer: */ | ||
138 | NETXEN_NIC_REG(0x178), | ||
139 | /* crb_rcv_status_consumer: */ | ||
140 | NETXEN_NIC_REG(0x17c), | ||
141 | /* crb_rcvpeg_state: */ | ||
142 | NETXEN_NIC_REG(0x180), | ||
143 | /* crb_status_ring_size */ | ||
144 | NETXEN_NIC_REG(0x184), | ||
145 | }, | ||
146 | /* | 72 | /* |
147 | * Instance 2, | 73 | * Instance 2, |
148 | */ | 74 | */ |
149 | { | 75 | { |
150 | { | 76 | /* crb_rcv_producer: */ |
151 | { | 77 | { |
152 | /* crb_rcv_producer_offset: */ | 78 | NETXEN_NIC_REG(0x1d8), |
153 | NETXEN_NIC_REG(0x1d8), | 79 | /* Jumbo frames */ |
154 | /* crb_rcv_consumer_offset: */ | 80 | NETXEN_NIC_REG(0x1f8), |
155 | NETXEN_NIC_REG(0x1dc), | 81 | /* LRO */ |
156 | /* crb_gloablrcv_ring: */ | 82 | NETXEN_NIC_REG(0x208) |
157 | NETXEN_NIC_REG(0x1f0), | 83 | }, |
158 | /* crb_rcv_ring_size */ | 84 | /* crb_sts_consumer: */ |
159 | NETXEN_NIC_REG(0x1f4), | 85 | NETXEN_NIC_REG(0x220), |
160 | }, | ||
161 | /* Jumbo frames */ | ||
162 | { | ||
163 | /* crb_rcv_producer_offset: */ | ||
164 | NETXEN_NIC_REG(0x1f8), | ||
165 | /* crb_rcv_consumer_offset: */ | ||
166 | NETXEN_NIC_REG(0x1fc), | ||
167 | /* crb_gloablrcv_ring: */ | ||
168 | NETXEN_NIC_REG(0x200), | ||
169 | /* crb_rcv_ring_size */ | ||
170 | NETXEN_NIC_REG(0x204), | ||
171 | }, | ||
172 | /* LRO */ | ||
173 | { | ||
174 | /* crb_rcv_producer_offset: */ | ||
175 | NETXEN_NIC_REG(0x208), | ||
176 | /* crb_rcv_consumer_offset: */ | ||
177 | NETXEN_NIC_REG(0x20c), | ||
178 | /* crb_gloablrcv_ring: */ | ||
179 | NETXEN_NIC_REG(0x210), | ||
180 | /* crb_rcv_ring_size */ | ||
181 | NETXEN_NIC_REG(0x214), | ||
182 | } | ||
183 | }, | ||
184 | /* crb_rcvstatus_ring: */ | ||
185 | NETXEN_NIC_REG(0x218), | ||
186 | /* crb_rcv_status_producer: */ | ||
187 | NETXEN_NIC_REG(0x21c), | ||
188 | /* crb_rcv_status_consumer: */ | ||
189 | NETXEN_NIC_REG(0x220), | ||
190 | /* crb_rcvpeg_state: */ | ||
191 | NETXEN_NIC_REG(0x224), | ||
192 | /* crb_status_ring_size */ | ||
193 | NETXEN_NIC_REG(0x228), | ||
194 | }, | 86 | }, |
195 | /* | 87 | /* |
196 | * Instance 3, | 88 | * Instance 3, |
197 | */ | 89 | */ |
198 | { | 90 | { |
199 | { | 91 | /* crb_rcv_producer: */ |
200 | { | 92 | { |
201 | /* crb_rcv_producer_offset: */ | 93 | NETXEN_NIC_REG(0x22c), |
202 | NETXEN_NIC_REG(0x22c), | 94 | /* Jumbo frames */ |
203 | /* crb_rcv_consumer_offset: */ | 95 | NETXEN_NIC_REG(0x23c), |
204 | NETXEN_NIC_REG(0x230), | 96 | /* LRO */ |
205 | /* crb_gloablrcv_ring: */ | 97 | NETXEN_NIC_REG(0x24c) |
206 | NETXEN_NIC_REG(0x234), | 98 | }, |
207 | /* crb_rcv_ring_size */ | 99 | /* crb_sts_consumer: */ |
208 | NETXEN_NIC_REG(0x238), | 100 | NETXEN_NIC_REG(0x264), |
209 | }, | ||
210 | /* Jumbo frames */ | ||
211 | { | ||
212 | /* crb_rcv_producer_offset: */ | ||
213 | NETXEN_NIC_REG(0x23c), | ||
214 | /* crb_rcv_consumer_offset: */ | ||
215 | NETXEN_NIC_REG(0x240), | ||
216 | /* crb_gloablrcv_ring: */ | ||
217 | NETXEN_NIC_REG(0x244), | ||
218 | /* crb_rcv_ring_size */ | ||
219 | NETXEN_NIC_REG(0x248), | ||
220 | }, | ||
221 | /* LRO */ | ||
222 | { | ||
223 | /* crb_rcv_producer_offset: */ | ||
224 | NETXEN_NIC_REG(0x24c), | ||
225 | /* crb_rcv_consumer_offset: */ | ||
226 | NETXEN_NIC_REG(0x250), | ||
227 | /* crb_gloablrcv_ring: */ | ||
228 | NETXEN_NIC_REG(0x254), | ||
229 | /* crb_rcv_ring_size */ | ||
230 | NETXEN_NIC_REG(0x258), | ||
231 | } | ||
232 | }, | ||
233 | /* crb_rcvstatus_ring: */ | ||
234 | NETXEN_NIC_REG(0x25c), | ||
235 | /* crb_rcv_status_producer: */ | ||
236 | NETXEN_NIC_REG(0x260), | ||
237 | /* crb_rcv_status_consumer: */ | ||
238 | NETXEN_NIC_REG(0x264), | ||
239 | /* crb_rcvpeg_state: */ | ||
240 | NETXEN_NIC_REG(0x268), | ||
241 | /* crb_status_ring_size */ | ||
242 | NETXEN_NIC_REG(0x26c), | ||
243 | }, | 101 | }, |
244 | }; | 102 | }; |
245 | 103 | ||
@@ -375,16 +233,12 @@ int netxen_nic_hw_resources(struct netxen_adapter *adapter) | |||
375 | loops = 0; | 233 | loops = 0; |
376 | state = 0; | 234 | state = 0; |
377 | /* Window 1 call */ | 235 | /* Window 1 call */ |
378 | state = readl(NETXEN_CRB_NORMALIZE(adapter, | 236 | state = readl(NETXEN_CRB_NORMALIZE(adapter, CRB_RCVPEG_STATE)); |
379 | recv_crb_registers[ctx]. | ||
380 | crb_rcvpeg_state)); | ||
381 | while (state != PHAN_PEG_RCV_INITIALIZED && loops < 20) { | 237 | while (state != PHAN_PEG_RCV_INITIALIZED && loops < 20) { |
382 | msleep(1); | 238 | msleep(1); |
383 | /* Window 1 call */ | 239 | /* Window 1 call */ |
384 | state = readl(NETXEN_CRB_NORMALIZE(adapter, | 240 | state = readl(NETXEN_CRB_NORMALIZE(adapter, |
385 | recv_crb_registers | 241 | CRB_RCVPEG_STATE)); |
386 | [ctx]. | ||
387 | crb_rcvpeg_state)); | ||
388 | loops++; | 242 | loops++; |
389 | } | 243 | } |
390 | if (loops >= 20) { | 244 | if (loops >= 20) { |
@@ -399,11 +253,9 @@ int netxen_nic_hw_resources(struct netxen_adapter *adapter) | |||
399 | adapter->msi_mode = readl( | 253 | adapter->msi_mode = readl( |
400 | NETXEN_CRB_NORMALIZE(adapter, CRB_NIC_MSI_MODE_FW)); | 254 | NETXEN_CRB_NORMALIZE(adapter, CRB_NIC_MSI_MODE_FW)); |
401 | 255 | ||
402 | addr = netxen_alloc(adapter->ahw.pdev, | 256 | addr = pci_alloc_consistent(adapter->pdev, |
403 | sizeof(struct netxen_ring_ctx) + | 257 | sizeof(struct netxen_ring_ctx) + sizeof(uint32_t), |
404 | sizeof(uint32_t), | 258 | &adapter->ctx_desc_phys_addr); |
405 | (dma_addr_t *) & adapter->ctx_desc_phys_addr, | ||
406 | &adapter->ctx_desc_pdev); | ||
407 | 259 | ||
408 | if (addr == NULL) { | 260 | if (addr == NULL) { |
409 | DPRINTK(ERR, "bad return from pci_alloc_consistent\n"); | 261 | DPRINTK(ERR, "bad return from pci_alloc_consistent\n"); |
@@ -419,11 +271,10 @@ int netxen_nic_hw_resources(struct netxen_adapter *adapter) | |||
419 | adapter->cmd_consumer = (__le32 *) (((char *)addr) + | 271 | adapter->cmd_consumer = (__le32 *) (((char *)addr) + |
420 | sizeof(struct netxen_ring_ctx)); | 272 | sizeof(struct netxen_ring_ctx)); |
421 | 273 | ||
422 | addr = netxen_alloc(adapter->ahw.pdev, | 274 | addr = pci_alloc_consistent(adapter->pdev, |
423 | sizeof(struct cmd_desc_type0) * | 275 | sizeof(struct cmd_desc_type0) * |
424 | adapter->max_tx_desc_count, | 276 | adapter->max_tx_desc_count, |
425 | (dma_addr_t *) & hw->cmd_desc_phys_addr, | 277 | &hw->cmd_desc_phys_addr); |
426 | &adapter->ahw.cmd_desc_pdev); | ||
427 | 278 | ||
428 | if (addr == NULL) { | 279 | if (addr == NULL) { |
429 | DPRINTK(ERR, "bad return from pci_alloc_consistent\n"); | 280 | DPRINTK(ERR, "bad return from pci_alloc_consistent\n"); |
@@ -443,10 +294,9 @@ int netxen_nic_hw_resources(struct netxen_adapter *adapter) | |||
443 | 294 | ||
444 | for (ring = 0; ring < NUM_RCV_DESC_RINGS; ring++) { | 295 | for (ring = 0; ring < NUM_RCV_DESC_RINGS; ring++) { |
445 | rcv_desc = &recv_ctx->rcv_desc[ring]; | 296 | rcv_desc = &recv_ctx->rcv_desc[ring]; |
446 | addr = netxen_alloc(adapter->ahw.pdev, | 297 | addr = pci_alloc_consistent(adapter->pdev, |
447 | RCV_DESC_RINGSIZE, | 298 | RCV_DESC_RINGSIZE, |
448 | &rcv_desc->phys_addr, | 299 | &rcv_desc->phys_addr); |
449 | &rcv_desc->phys_pdev); | ||
450 | if (addr == NULL) { | 300 | if (addr == NULL) { |
451 | DPRINTK(ERR, "bad return from " | 301 | DPRINTK(ERR, "bad return from " |
452 | "pci_alloc_consistent\n"); | 302 | "pci_alloc_consistent\n"); |
@@ -459,11 +309,13 @@ int netxen_nic_hw_resources(struct netxen_adapter *adapter) | |||
459 | cpu_to_le64(rcv_desc->phys_addr); | 309 | cpu_to_le64(rcv_desc->phys_addr); |
460 | adapter->ctx_desc->rcv_ctx[ring].rcv_ring_size = | 310 | adapter->ctx_desc->rcv_ctx[ring].rcv_ring_size = |
461 | cpu_to_le32(rcv_desc->max_rx_desc_count); | 311 | cpu_to_le32(rcv_desc->max_rx_desc_count); |
312 | rcv_desc->crb_rcv_producer = | ||
313 | recv_crb_registers[adapter->portnum]. | ||
314 | crb_rcv_producer[ring]; | ||
462 | } | 315 | } |
463 | 316 | ||
464 | addr = netxen_alloc(adapter->ahw.pdev, STATUS_DESC_RINGSIZE, | 317 | addr = pci_alloc_consistent(adapter->pdev, STATUS_DESC_RINGSIZE, |
465 | &recv_ctx->rcv_status_desc_phys_addr, | 318 | &recv_ctx->rcv_status_desc_phys_addr); |
466 | &recv_ctx->rcv_status_desc_pdev); | ||
467 | if (addr == NULL) { | 319 | if (addr == NULL) { |
468 | DPRINTK(ERR, "bad return from" | 320 | DPRINTK(ERR, "bad return from" |
469 | " pci_alloc_consistent\n"); | 321 | " pci_alloc_consistent\n"); |
@@ -476,6 +328,8 @@ int netxen_nic_hw_resources(struct netxen_adapter *adapter) | |||
476 | cpu_to_le64(recv_ctx->rcv_status_desc_phys_addr); | 328 | cpu_to_le64(recv_ctx->rcv_status_desc_phys_addr); |
477 | adapter->ctx_desc->sts_ring_size = | 329 | adapter->ctx_desc->sts_ring_size = |
478 | cpu_to_le32(adapter->max_rx_desc_count); | 330 | cpu_to_le32(adapter->max_rx_desc_count); |
331 | recv_ctx->crb_sts_consumer = | ||
332 | recv_crb_registers[adapter->portnum].crb_sts_consumer; | ||
479 | 333 | ||
480 | } | 334 | } |
481 | /* Window = 1 */ | 335 | /* Window = 1 */ |
@@ -496,7 +350,7 @@ void netxen_free_hw_resources(struct netxen_adapter *adapter) | |||
496 | int ctx, ring; | 350 | int ctx, ring; |
497 | 351 | ||
498 | if (adapter->ctx_desc != NULL) { | 352 | if (adapter->ctx_desc != NULL) { |
499 | pci_free_consistent(adapter->ctx_desc_pdev, | 353 | pci_free_consistent(adapter->pdev, |
500 | sizeof(struct netxen_ring_ctx) + | 354 | sizeof(struct netxen_ring_ctx) + |
501 | sizeof(uint32_t), | 355 | sizeof(uint32_t), |
502 | adapter->ctx_desc, | 356 | adapter->ctx_desc, |
@@ -505,7 +359,7 @@ void netxen_free_hw_resources(struct netxen_adapter *adapter) | |||
505 | } | 359 | } |
506 | 360 | ||
507 | if (adapter->ahw.cmd_desc_head != NULL) { | 361 | if (adapter->ahw.cmd_desc_head != NULL) { |
508 | pci_free_consistent(adapter->ahw.cmd_desc_pdev, | 362 | pci_free_consistent(adapter->pdev, |
509 | sizeof(struct cmd_desc_type0) * | 363 | sizeof(struct cmd_desc_type0) * |
510 | adapter->max_tx_desc_count, | 364 | adapter->max_tx_desc_count, |
511 | adapter->ahw.cmd_desc_head, | 365 | adapter->ahw.cmd_desc_head, |
@@ -519,7 +373,7 @@ void netxen_free_hw_resources(struct netxen_adapter *adapter) | |||
519 | rcv_desc = &recv_ctx->rcv_desc[ring]; | 373 | rcv_desc = &recv_ctx->rcv_desc[ring]; |
520 | 374 | ||
521 | if (rcv_desc->desc_head != NULL) { | 375 | if (rcv_desc->desc_head != NULL) { |
522 | pci_free_consistent(rcv_desc->phys_pdev, | 376 | pci_free_consistent(adapter->pdev, |
523 | RCV_DESC_RINGSIZE, | 377 | RCV_DESC_RINGSIZE, |
524 | rcv_desc->desc_head, | 378 | rcv_desc->desc_head, |
525 | rcv_desc->phys_addr); | 379 | rcv_desc->phys_addr); |
@@ -528,7 +382,7 @@ void netxen_free_hw_resources(struct netxen_adapter *adapter) | |||
528 | } | 382 | } |
529 | 383 | ||
530 | if (recv_ctx->rcv_status_desc_head != NULL) { | 384 | if (recv_ctx->rcv_status_desc_head != NULL) { |
531 | pci_free_consistent(recv_ctx->rcv_status_desc_pdev, | 385 | pci_free_consistent(adapter->pdev, |
532 | STATUS_DESC_RINGSIZE, | 386 | STATUS_DESC_RINGSIZE, |
533 | recv_ctx->rcv_status_desc_head, | 387 | recv_ctx->rcv_status_desc_head, |
534 | recv_ctx-> | 388 | recv_ctx-> |
diff --git a/drivers/net/netxen/netxen_nic_init.c b/drivers/net/netxen/netxen_nic_init.c index 70d1b22ced22..37fd6bc93eb9 100644 --- a/drivers/net/netxen/netxen_nic_init.c +++ b/drivers/net/netxen/netxen_nic_init.c | |||
@@ -42,8 +42,6 @@ struct crb_addr_pair { | |||
42 | u32 data; | 42 | u32 data; |
43 | }; | 43 | }; |
44 | 44 | ||
45 | unsigned long last_schedule_time; | ||
46 | |||
47 | #define NETXEN_MAX_CRB_XFORM 60 | 45 | #define NETXEN_MAX_CRB_XFORM 60 |
48 | static unsigned int crb_addr_xform[NETXEN_MAX_CRB_XFORM]; | 46 | static unsigned int crb_addr_xform[NETXEN_MAX_CRB_XFORM]; |
49 | #define NETXEN_ADDR_ERROR (0xffffffff) | 47 | #define NETXEN_ADDR_ERROR (0xffffffff) |
@@ -155,24 +153,6 @@ int netxen_init_firmware(struct netxen_adapter *adapter) | |||
155 | return err; | 153 | return err; |
156 | } | 154 | } |
157 | 155 | ||
158 | #define NETXEN_ADDR_LIMIT 0xffffffffULL | ||
159 | |||
160 | void *netxen_alloc(struct pci_dev *pdev, size_t sz, dma_addr_t * ptr, | ||
161 | struct pci_dev **used_dev) | ||
162 | { | ||
163 | void *addr; | ||
164 | |||
165 | addr = pci_alloc_consistent(pdev, sz, ptr); | ||
166 | if ((unsigned long long)(*ptr) < NETXEN_ADDR_LIMIT) { | ||
167 | *used_dev = pdev; | ||
168 | return addr; | ||
169 | } | ||
170 | pci_free_consistent(pdev, sz, addr, *ptr); | ||
171 | addr = pci_alloc_consistent(NULL, sz, ptr); | ||
172 | *used_dev = NULL; | ||
173 | return addr; | ||
174 | } | ||
175 | |||
176 | void netxen_initialize_adapter_sw(struct netxen_adapter *adapter) | 156 | void netxen_initialize_adapter_sw(struct netxen_adapter *adapter) |
177 | { | 157 | { |
178 | int ctxid, ring; | 158 | int ctxid, ring; |
@@ -270,7 +250,9 @@ static u32 netxen_decode_crb_addr(u32 addr) | |||
270 | 250 | ||
271 | static long rom_max_timeout = 100; | 251 | static long rom_max_timeout = 100; |
272 | static long rom_lock_timeout = 10000; | 252 | static long rom_lock_timeout = 10000; |
253 | #if 0 | ||
273 | static long rom_write_timeout = 700; | 254 | static long rom_write_timeout = 700; |
255 | #endif | ||
274 | 256 | ||
275 | static int rom_lock(struct netxen_adapter *adapter) | 257 | static int rom_lock(struct netxen_adapter *adapter) |
276 | { | 258 | { |
@@ -319,6 +301,7 @@ static int netxen_wait_rom_done(struct netxen_adapter *adapter) | |||
319 | return 0; | 301 | return 0; |
320 | } | 302 | } |
321 | 303 | ||
304 | #if 0 | ||
322 | static int netxen_rom_wren(struct netxen_adapter *adapter) | 305 | static int netxen_rom_wren(struct netxen_adapter *adapter) |
323 | { | 306 | { |
324 | /* Set write enable latch in ROM status register */ | 307 | /* Set write enable latch in ROM status register */ |
@@ -348,6 +331,7 @@ static int netxen_do_rom_rdsr(struct netxen_adapter *adapter) | |||
348 | } | 331 | } |
349 | return netxen_rdcrbreg(adapter, NETXEN_ROMUSB_ROM_RDATA); | 332 | return netxen_rdcrbreg(adapter, NETXEN_ROMUSB_ROM_RDATA); |
350 | } | 333 | } |
334 | #endif | ||
351 | 335 | ||
352 | static void netxen_rom_unlock(struct netxen_adapter *adapter) | 336 | static void netxen_rom_unlock(struct netxen_adapter *adapter) |
353 | { | 337 | { |
@@ -358,6 +342,7 @@ static void netxen_rom_unlock(struct netxen_adapter *adapter) | |||
358 | 342 | ||
359 | } | 343 | } |
360 | 344 | ||
345 | #if 0 | ||
361 | static int netxen_rom_wip_poll(struct netxen_adapter *adapter) | 346 | static int netxen_rom_wip_poll(struct netxen_adapter *adapter) |
362 | { | 347 | { |
363 | long timeout = 0; | 348 | long timeout = 0; |
@@ -393,6 +378,7 @@ static int do_rom_fast_write(struct netxen_adapter *adapter, int addr, | |||
393 | 378 | ||
394 | return netxen_rom_wip_poll(adapter); | 379 | return netxen_rom_wip_poll(adapter); |
395 | } | 380 | } |
381 | #endif | ||
396 | 382 | ||
397 | static int do_rom_fast_read(struct netxen_adapter *adapter, | 383 | static int do_rom_fast_read(struct netxen_adapter *adapter, |
398 | int addr, int *valp) | 384 | int addr, int *valp) |
@@ -475,7 +461,6 @@ int netxen_rom_fast_write(struct netxen_adapter *adapter, int addr, int data) | |||
475 | netxen_rom_unlock(adapter); | 461 | netxen_rom_unlock(adapter); |
476 | return ret; | 462 | return ret; |
477 | } | 463 | } |
478 | #endif /* 0 */ | ||
479 | 464 | ||
480 | static int do_rom_fast_write_words(struct netxen_adapter *adapter, | 465 | static int do_rom_fast_write_words(struct netxen_adapter *adapter, |
481 | int addr, u8 *bytes, size_t size) | 466 | int addr, u8 *bytes, size_t size) |
@@ -740,13 +725,12 @@ int netxen_flash_unlock(struct netxen_adapter *adapter) | |||
740 | 725 | ||
741 | return ret; | 726 | return ret; |
742 | } | 727 | } |
728 | #endif /* 0 */ | ||
743 | 729 | ||
744 | #define NETXEN_BOARDTYPE 0x4008 | 730 | #define NETXEN_BOARDTYPE 0x4008 |
745 | #define NETXEN_BOARDNUM 0x400c | 731 | #define NETXEN_BOARDNUM 0x400c |
746 | #define NETXEN_CHIPNUM 0x4010 | 732 | #define NETXEN_CHIPNUM 0x4010 |
747 | #define NETXEN_ROMBUS_RESET 0xFFFFFFFF | 733 | #define NETXEN_ROMBUS_RESET 0xFFFFFFFF |
748 | #define NETXEN_ROM_FIRST_BARRIER 0x800000000ULL | ||
749 | #define NETXEN_ROM_FOUND_INIT 0x400 | ||
750 | 734 | ||
751 | int netxen_pinit_from_rom(struct netxen_adapter *adapter, int verbose) | 735 | int netxen_pinit_from_rom(struct netxen_adapter *adapter, int verbose) |
752 | { | 736 | { |
@@ -776,10 +760,9 @@ int netxen_pinit_from_rom(struct netxen_adapter *adapter, int verbose) | |||
776 | printk("Could not read chip number\n"); | 760 | printk("Could not read chip number\n"); |
777 | } | 761 | } |
778 | 762 | ||
779 | if (netxen_rom_fast_read(adapter, 0, &n) == 0 | 763 | if (netxen_rom_fast_read(adapter, 0, &n) == 0 && (n & 0x80000000)) { |
780 | && (n & NETXEN_ROM_FIRST_BARRIER)) { | 764 | n &= ~0x80000000; |
781 | n &= ~NETXEN_ROM_ROUNDUP; | 765 | if (n < 0x400) { |
782 | if (n < NETXEN_ROM_FOUND_INIT) { | ||
783 | if (verbose) | 766 | if (verbose) |
784 | printk("%s: %d CRB init values found" | 767 | printk("%s: %d CRB init values found" |
785 | " in ROM.\n", netxen_nic_driver_name, n); | 768 | " in ROM.\n", netxen_nic_driver_name, n); |
@@ -829,16 +812,8 @@ int netxen_pinit_from_rom(struct netxen_adapter *adapter, int verbose) | |||
829 | buf[i].data = NETXEN_NIC_XDMA_RESET; | 812 | buf[i].data = NETXEN_NIC_XDMA_RESET; |
830 | } | 813 | } |
831 | 814 | ||
832 | if (ADDR_IN_WINDOW1(off)) { | 815 | netxen_nic_hw_write_wx(adapter, off, &buf[i].data, 4); |
833 | writel(buf[i].data, | ||
834 | NETXEN_CRB_NORMALIZE(adapter, off)); | ||
835 | } else { | ||
836 | netxen_nic_pci_change_crbwindow(adapter, 0); | ||
837 | writel(buf[i].data, | ||
838 | pci_base_offset(adapter, off)); | ||
839 | 816 | ||
840 | netxen_nic_pci_change_crbwindow(adapter, 1); | ||
841 | } | ||
842 | if (init_delay == 1) { | 817 | if (init_delay == 1) { |
843 | msleep(1000); | 818 | msleep(1000); |
844 | init_delay = 0; | 819 | init_delay = 0; |
@@ -897,7 +872,7 @@ int netxen_initialize_adapter_offload(struct netxen_adapter *adapter) | |||
897 | uint32_t lo; | 872 | uint32_t lo; |
898 | 873 | ||
899 | adapter->dummy_dma.addr = | 874 | adapter->dummy_dma.addr = |
900 | pci_alloc_consistent(adapter->ahw.pdev, | 875 | pci_alloc_consistent(adapter->pdev, |
901 | NETXEN_HOST_DUMMY_DMA_SIZE, | 876 | NETXEN_HOST_DUMMY_DMA_SIZE, |
902 | &adapter->dummy_dma.phys_addr); | 877 | &adapter->dummy_dma.phys_addr); |
903 | if (adapter->dummy_dma.addr == NULL) { | 878 | if (adapter->dummy_dma.addr == NULL) { |
@@ -931,7 +906,7 @@ void netxen_free_adapter_offload(struct netxen_adapter *adapter) | |||
931 | } while (--i); | 906 | } while (--i); |
932 | 907 | ||
933 | if (i) { | 908 | if (i) { |
934 | pci_free_consistent(adapter->ahw.pdev, | 909 | pci_free_consistent(adapter->pdev, |
935 | NETXEN_HOST_DUMMY_DMA_SIZE, | 910 | NETXEN_HOST_DUMMY_DMA_SIZE, |
936 | adapter->dummy_dma.addr, | 911 | adapter->dummy_dma.addr, |
937 | adapter->dummy_dma.phys_addr); | 912 | adapter->dummy_dma.phys_addr); |
@@ -1104,8 +1079,6 @@ static void netxen_process_rcv(struct netxen_adapter *adapter, int ctxid, | |||
1104 | ret = netif_receive_skb(skb); | 1079 | ret = netif_receive_skb(skb); |
1105 | netdev->last_rx = jiffies; | 1080 | netdev->last_rx = jiffies; |
1106 | 1081 | ||
1107 | rcv_desc->rcv_pending--; | ||
1108 | |||
1109 | /* | 1082 | /* |
1110 | * We just consumed one buffer so post a buffer. | 1083 | * We just consumed one buffer so post a buffer. |
1111 | */ | 1084 | */ |
@@ -1125,7 +1098,6 @@ u32 netxen_process_rcv_ring(struct netxen_adapter *adapter, int ctxid, int max) | |||
1125 | struct status_desc *desc_head = recv_ctx->rcv_status_desc_head; | 1098 | struct status_desc *desc_head = recv_ctx->rcv_status_desc_head; |
1126 | struct status_desc *desc; /* used to read status desc here */ | 1099 | struct status_desc *desc; /* used to read status desc here */ |
1127 | u32 consumer = recv_ctx->status_rx_consumer; | 1100 | u32 consumer = recv_ctx->status_rx_consumer; |
1128 | u32 producer = 0; | ||
1129 | int count = 0, ring; | 1101 | int count = 0, ring; |
1130 | 1102 | ||
1131 | while (count < max) { | 1103 | while (count < max) { |
@@ -1146,13 +1118,10 @@ u32 netxen_process_rcv_ring(struct netxen_adapter *adapter, int ctxid, int max) | |||
1146 | /* update the consumer index in phantom */ | 1118 | /* update the consumer index in phantom */ |
1147 | if (count) { | 1119 | if (count) { |
1148 | recv_ctx->status_rx_consumer = consumer; | 1120 | recv_ctx->status_rx_consumer = consumer; |
1149 | recv_ctx->status_rx_producer = producer; | ||
1150 | 1121 | ||
1151 | /* Window = 1 */ | 1122 | /* Window = 1 */ |
1152 | writel(consumer, | 1123 | writel(consumer, NETXEN_CRB_NORMALIZE(adapter, |
1153 | NETXEN_CRB_NORMALIZE(adapter, | 1124 | recv_ctx->crb_sts_consumer)); |
1154 | recv_crb_registers[adapter->portnum]. | ||
1155 | crb_rcv_status_consumer)); | ||
1156 | } | 1125 | } |
1157 | 1126 | ||
1158 | return count; | 1127 | return count; |
@@ -1231,7 +1200,7 @@ int netxen_process_cmd_ring(struct netxen_adapter *adapter) | |||
1231 | */ | 1200 | */ |
1232 | void netxen_post_rx_buffers(struct netxen_adapter *adapter, u32 ctx, u32 ringid) | 1201 | void netxen_post_rx_buffers(struct netxen_adapter *adapter, u32 ctx, u32 ringid) |
1233 | { | 1202 | { |
1234 | struct pci_dev *pdev = adapter->ahw.pdev; | 1203 | struct pci_dev *pdev = adapter->pdev; |
1235 | struct sk_buff *skb; | 1204 | struct sk_buff *skb; |
1236 | struct netxen_recv_context *recv_ctx = &(adapter->recv_ctx[ctx]); | 1205 | struct netxen_recv_context *recv_ctx = &(adapter->recv_ctx[ctx]); |
1237 | struct netxen_rcv_desc_ctx *rcv_desc = NULL; | 1206 | struct netxen_rcv_desc_ctx *rcv_desc = NULL; |
@@ -1294,16 +1263,11 @@ void netxen_post_rx_buffers(struct netxen_adapter *adapter, u32 ctx, u32 ringid) | |||
1294 | /* if we did allocate buffers, then write the count to Phantom */ | 1263 | /* if we did allocate buffers, then write the count to Phantom */ |
1295 | if (count) { | 1264 | if (count) { |
1296 | rcv_desc->begin_alloc = index; | 1265 | rcv_desc->begin_alloc = index; |
1297 | rcv_desc->rcv_pending += count; | ||
1298 | rcv_desc->producer = producer; | 1266 | rcv_desc->producer = producer; |
1299 | /* Window = 1 */ | 1267 | /* Window = 1 */ |
1300 | writel((producer - 1) & | 1268 | writel((producer - 1) & (rcv_desc->max_rx_desc_count - 1), |
1301 | (rcv_desc->max_rx_desc_count - 1), | 1269 | NETXEN_CRB_NORMALIZE(adapter, |
1302 | NETXEN_CRB_NORMALIZE(adapter, | 1270 | rcv_desc->crb_rcv_producer)); |
1303 | recv_crb_registers[ | ||
1304 | adapter->portnum]. | ||
1305 | rcv_desc_crb[ringid]. | ||
1306 | crb_rcv_producer_offset)); | ||
1307 | /* | 1271 | /* |
1308 | * Write a doorbell msg to tell phanmon of change in | 1272 | * Write a doorbell msg to tell phanmon of change in |
1309 | * receive ring producer | 1273 | * receive ring producer |
@@ -1325,7 +1289,7 @@ void netxen_post_rx_buffers(struct netxen_adapter *adapter, u32 ctx, u32 ringid) | |||
1325 | static void netxen_post_rx_buffers_nodb(struct netxen_adapter *adapter, | 1289 | static void netxen_post_rx_buffers_nodb(struct netxen_adapter *adapter, |
1326 | uint32_t ctx, uint32_t ringid) | 1290 | uint32_t ctx, uint32_t ringid) |
1327 | { | 1291 | { |
1328 | struct pci_dev *pdev = adapter->ahw.pdev; | 1292 | struct pci_dev *pdev = adapter->pdev; |
1329 | struct sk_buff *skb; | 1293 | struct sk_buff *skb; |
1330 | struct netxen_recv_context *recv_ctx = &(adapter->recv_ctx[ctx]); | 1294 | struct netxen_recv_context *recv_ctx = &(adapter->recv_ctx[ctx]); |
1331 | struct netxen_rcv_desc_ctx *rcv_desc = NULL; | 1295 | struct netxen_rcv_desc_ctx *rcv_desc = NULL; |
@@ -1370,7 +1334,6 @@ static void netxen_post_rx_buffers_nodb(struct netxen_adapter *adapter, | |||
1370 | pdesc->reference_handle = cpu_to_le16(buffer->ref_handle); | 1334 | pdesc->reference_handle = cpu_to_le16(buffer->ref_handle); |
1371 | pdesc->buffer_length = cpu_to_le32(rcv_desc->dma_size); | 1335 | pdesc->buffer_length = cpu_to_le32(rcv_desc->dma_size); |
1372 | pdesc->addr_buffer = cpu_to_le64(buffer->dma); | 1336 | pdesc->addr_buffer = cpu_to_le64(buffer->dma); |
1373 | DPRINTK(INFO, "done writing descripter\n"); | ||
1374 | producer = | 1337 | producer = |
1375 | get_next_index(producer, rcv_desc->max_rx_desc_count); | 1338 | get_next_index(producer, rcv_desc->max_rx_desc_count); |
1376 | index = get_next_index(index, rcv_desc->max_rx_desc_count); | 1339 | index = get_next_index(index, rcv_desc->max_rx_desc_count); |
@@ -1380,16 +1343,11 @@ static void netxen_post_rx_buffers_nodb(struct netxen_adapter *adapter, | |||
1380 | /* if we did allocate buffers, then write the count to Phantom */ | 1343 | /* if we did allocate buffers, then write the count to Phantom */ |
1381 | if (count) { | 1344 | if (count) { |
1382 | rcv_desc->begin_alloc = index; | 1345 | rcv_desc->begin_alloc = index; |
1383 | rcv_desc->rcv_pending += count; | ||
1384 | rcv_desc->producer = producer; | 1346 | rcv_desc->producer = producer; |
1385 | /* Window = 1 */ | 1347 | /* Window = 1 */ |
1386 | writel((producer - 1) & | 1348 | writel((producer - 1) & (rcv_desc->max_rx_desc_count - 1), |
1387 | (rcv_desc->max_rx_desc_count - 1), | 1349 | NETXEN_CRB_NORMALIZE(adapter, |
1388 | NETXEN_CRB_NORMALIZE(adapter, | 1350 | rcv_desc->crb_rcv_producer)); |
1389 | recv_crb_registers[ | ||
1390 | adapter->portnum]. | ||
1391 | rcv_desc_crb[ringid]. | ||
1392 | crb_rcv_producer_offset)); | ||
1393 | wmb(); | 1351 | wmb(); |
1394 | } | 1352 | } |
1395 | } | 1353 | } |
diff --git a/drivers/net/netxen/netxen_nic_main.c b/drivers/net/netxen/netxen_nic_main.c index 63cd67b931e7..91b02ebc9a10 100644 --- a/drivers/net/netxen/netxen_nic_main.c +++ b/drivers/net/netxen/netxen_nic_main.c | |||
@@ -108,66 +108,30 @@ static struct workqueue_struct *netxen_workq; | |||
108 | 108 | ||
109 | static void netxen_watchdog(unsigned long); | 109 | static void netxen_watchdog(unsigned long); |
110 | 110 | ||
111 | static uint32_t crb_cmd_producer[4] = { | ||
112 | CRB_CMD_PRODUCER_OFFSET, CRB_CMD_PRODUCER_OFFSET_1, | ||
113 | CRB_CMD_PRODUCER_OFFSET_2, CRB_CMD_PRODUCER_OFFSET_3 | ||
114 | }; | ||
115 | |||
111 | static void netxen_nic_update_cmd_producer(struct netxen_adapter *adapter, | 116 | static void netxen_nic_update_cmd_producer(struct netxen_adapter *adapter, |
112 | uint32_t crb_producer) | 117 | uint32_t crb_producer) |
113 | { | 118 | { |
114 | switch (adapter->portnum) { | 119 | writel(crb_producer, NETXEN_CRB_NORMALIZE(adapter, |
115 | case 0: | 120 | adapter->crb_addr_cmd_producer)); |
116 | writel(crb_producer, NETXEN_CRB_NORMALIZE | ||
117 | (adapter, CRB_CMD_PRODUCER_OFFSET)); | ||
118 | return; | ||
119 | case 1: | ||
120 | writel(crb_producer, NETXEN_CRB_NORMALIZE | ||
121 | (adapter, CRB_CMD_PRODUCER_OFFSET_1)); | ||
122 | return; | ||
123 | case 2: | ||
124 | writel(crb_producer, NETXEN_CRB_NORMALIZE | ||
125 | (adapter, CRB_CMD_PRODUCER_OFFSET_2)); | ||
126 | return; | ||
127 | case 3: | ||
128 | writel(crb_producer, NETXEN_CRB_NORMALIZE | ||
129 | (adapter, CRB_CMD_PRODUCER_OFFSET_3)); | ||
130 | return; | ||
131 | default: | ||
132 | printk(KERN_WARNING "We tried to update " | ||
133 | "CRB_CMD_PRODUCER_OFFSET for invalid " | ||
134 | "PCI function id %d\n", | ||
135 | adapter->portnum); | ||
136 | return; | ||
137 | } | ||
138 | } | 121 | } |
139 | 122 | ||
123 | static uint32_t crb_cmd_consumer[4] = { | ||
124 | CRB_CMD_CONSUMER_OFFSET, CRB_CMD_CONSUMER_OFFSET_1, | ||
125 | CRB_CMD_CONSUMER_OFFSET_2, CRB_CMD_CONSUMER_OFFSET_3 | ||
126 | }; | ||
127 | |||
140 | static void netxen_nic_update_cmd_consumer(struct netxen_adapter *adapter, | 128 | static void netxen_nic_update_cmd_consumer(struct netxen_adapter *adapter, |
141 | u32 crb_consumer) | 129 | u32 crb_consumer) |
142 | { | 130 | { |
143 | switch (adapter->portnum) { | 131 | writel(crb_consumer, NETXEN_CRB_NORMALIZE(adapter, |
144 | case 0: | 132 | adapter->crb_addr_cmd_consumer)); |
145 | writel(crb_consumer, NETXEN_CRB_NORMALIZE | ||
146 | (adapter, CRB_CMD_CONSUMER_OFFSET)); | ||
147 | return; | ||
148 | case 1: | ||
149 | writel(crb_consumer, NETXEN_CRB_NORMALIZE | ||
150 | (adapter, CRB_CMD_CONSUMER_OFFSET_1)); | ||
151 | return; | ||
152 | case 2: | ||
153 | writel(crb_consumer, NETXEN_CRB_NORMALIZE | ||
154 | (adapter, CRB_CMD_CONSUMER_OFFSET_2)); | ||
155 | return; | ||
156 | case 3: | ||
157 | writel(crb_consumer, NETXEN_CRB_NORMALIZE | ||
158 | (adapter, CRB_CMD_CONSUMER_OFFSET_3)); | ||
159 | return; | ||
160 | default: | ||
161 | printk(KERN_WARNING "We tried to update " | ||
162 | "CRB_CMD_PRODUCER_OFFSET for invalid " | ||
163 | "PCI function id %d\n", | ||
164 | adapter->portnum); | ||
165 | return; | ||
166 | } | ||
167 | } | 133 | } |
168 | 134 | ||
169 | #define ADAPTER_LIST_SIZE 12 | ||
170 | |||
171 | static uint32_t msi_tgt_status[4] = { | 135 | static uint32_t msi_tgt_status[4] = { |
172 | ISR_INT_TARGET_STATUS, ISR_INT_TARGET_STATUS_F1, | 136 | ISR_INT_TARGET_STATUS, ISR_INT_TARGET_STATUS_F1, |
173 | ISR_INT_TARGET_STATUS_F2, ISR_INT_TARGET_STATUS_F3 | 137 | ISR_INT_TARGET_STATUS_F2, ISR_INT_TARGET_STATUS_F3 |
@@ -334,7 +298,6 @@ netxen_nic_probe(struct pci_dev *pdev, const struct pci_device_id *ent) | |||
334 | 298 | ||
335 | adapter = netdev->priv; | 299 | adapter = netdev->priv; |
336 | 300 | ||
337 | adapter->ahw.pdev = pdev; | ||
338 | adapter->ahw.pci_func = pci_func_id; | 301 | adapter->ahw.pci_func = pci_func_id; |
339 | 302 | ||
340 | /* remap phys address */ | 303 | /* remap phys address */ |
@@ -552,12 +515,13 @@ netxen_nic_probe(struct pci_dev *pdev, const struct pci_device_id *ent) | |||
552 | adapter->watchdog_timer.function = &netxen_watchdog; | 515 | adapter->watchdog_timer.function = &netxen_watchdog; |
553 | adapter->watchdog_timer.data = (unsigned long)adapter; | 516 | adapter->watchdog_timer.data = (unsigned long)adapter; |
554 | INIT_WORK(&adapter->watchdog_task, netxen_watchdog_task); | 517 | INIT_WORK(&adapter->watchdog_task, netxen_watchdog_task); |
555 | adapter->ahw.pdev = pdev; | ||
556 | adapter->ahw.revision_id = pdev->revision; | 518 | adapter->ahw.revision_id = pdev->revision; |
557 | 519 | ||
558 | /* make sure Window == 1 */ | 520 | /* make sure Window == 1 */ |
559 | netxen_nic_pci_change_crbwindow(adapter, 1); | 521 | netxen_nic_pci_change_crbwindow(adapter, 1); |
560 | 522 | ||
523 | adapter->crb_addr_cmd_producer = crb_cmd_producer[adapter->portnum]; | ||
524 | adapter->crb_addr_cmd_consumer = crb_cmd_consumer[adapter->portnum]; | ||
561 | netxen_nic_update_cmd_producer(adapter, 0); | 525 | netxen_nic_update_cmd_producer(adapter, 0); |
562 | netxen_nic_update_cmd_consumer(adapter, 0); | 526 | netxen_nic_update_cmd_consumer(adapter, 0); |
563 | writel(0, NETXEN_CRB_NORMALIZE(adapter, CRB_HOST_CMD_ADDR_LO)); | 527 | writel(0, NETXEN_CRB_NORMALIZE(adapter, CRB_HOST_CMD_ADDR_LO)); |
@@ -816,7 +780,7 @@ static int netxen_nic_open(struct net_device *netdev) | |||
816 | for (ring = 0; ring < NUM_RCV_DESC_RINGS; ring++) | 780 | for (ring = 0; ring < NUM_RCV_DESC_RINGS; ring++) |
817 | netxen_post_rx_buffers(adapter, ctx, ring); | 781 | netxen_post_rx_buffers(adapter, ctx, ring); |
818 | } | 782 | } |
819 | adapter->irq = adapter->ahw.pdev->irq; | 783 | adapter->irq = adapter->pdev->irq; |
820 | if (adapter->flags & NETXEN_NIC_MSI_ENABLED) | 784 | if (adapter->flags & NETXEN_NIC_MSI_ENABLED) |
821 | handler = netxen_msi_intr; | 785 | handler = netxen_msi_intr; |
822 | else { | 786 | else { |
@@ -1220,10 +1184,6 @@ module_init(netxen_init_module); | |||
1220 | 1184 | ||
1221 | static void __exit netxen_exit_module(void) | 1185 | static void __exit netxen_exit_module(void) |
1222 | { | 1186 | { |
1223 | /* | ||
1224 | * Wait for some time to allow the dma to drain, if any. | ||
1225 | */ | ||
1226 | msleep(100); | ||
1227 | pci_unregister_driver(&netxen_driver); | 1187 | pci_unregister_driver(&netxen_driver); |
1228 | destroy_workqueue(netxen_workq); | 1188 | destroy_workqueue(netxen_workq); |
1229 | } | 1189 | } |
diff --git a/drivers/net/netxen/netxen_nic_phan_reg.h b/drivers/net/netxen/netxen_nic_phan_reg.h index a566b50f36f5..db2202aeb0d7 100644 --- a/drivers/net/netxen/netxen_nic_phan_reg.h +++ b/drivers/net/netxen/netxen_nic_phan_reg.h | |||
@@ -98,6 +98,7 @@ | |||
98 | #define CRB_JUMBO_BUFFER_PROD NETXEN_NIC_REG(0xf4) | 98 | #define CRB_JUMBO_BUFFER_PROD NETXEN_NIC_REG(0xf4) |
99 | #define CRB_JUMBO_BUFFER_CONS NETXEN_NIC_REG(0xf8) | 99 | #define CRB_JUMBO_BUFFER_CONS NETXEN_NIC_REG(0xf8) |
100 | 100 | ||
101 | #define CRB_RCVPEG_STATE NETXEN_NIC_REG(0x13c) | ||
101 | #define CRB_CMD_PRODUCER_OFFSET_1 NETXEN_NIC_REG(0x1ac) | 102 | #define CRB_CMD_PRODUCER_OFFSET_1 NETXEN_NIC_REG(0x1ac) |
102 | #define CRB_CMD_CONSUMER_OFFSET_1 NETXEN_NIC_REG(0x1b0) | 103 | #define CRB_CMD_CONSUMER_OFFSET_1 NETXEN_NIC_REG(0x1b0) |
103 | #define CRB_CMD_PRODUCER_OFFSET_2 NETXEN_NIC_REG(0x1b8) | 104 | #define CRB_CMD_PRODUCER_OFFSET_2 NETXEN_NIC_REG(0x1b8) |
@@ -147,25 +148,13 @@ | |||
147 | #define nx_get_temp_state(x) ((x) & 0xffff) | 148 | #define nx_get_temp_state(x) ((x) & 0xffff) |
148 | #define nx_encode_temp(val, state) (((val) << 16) | (state)) | 149 | #define nx_encode_temp(val, state) (((val) << 16) | (state)) |
149 | 150 | ||
150 | /* CRB registers per Rcv Descriptor ring */ | ||
151 | struct netxen_rcv_desc_crb { | ||
152 | u32 crb_rcv_producer_offset __attribute__ ((aligned(512))); | ||
153 | u32 crb_rcv_consumer_offset; | ||
154 | u32 crb_globalrcv_ring; | ||
155 | u32 crb_rcv_ring_size; | ||
156 | }; | ||
157 | |||
158 | /* | 151 | /* |
159 | * CRB registers used by the receive peg logic. | 152 | * CRB registers used by the receive peg logic. |
160 | */ | 153 | */ |
161 | 154 | ||
162 | struct netxen_recv_crb { | 155 | struct netxen_recv_crb { |
163 | struct netxen_rcv_desc_crb rcv_desc_crb[NUM_RCV_DESC_RINGS]; | 156 | u32 crb_rcv_producer[NUM_RCV_DESC_RINGS]; |
164 | u32 crb_rcvstatus_ring; | 157 | u32 crb_sts_consumer; |
165 | u32 crb_rcv_status_producer; | ||
166 | u32 crb_rcv_status_consumer; | ||
167 | u32 crb_rcvpeg_state; | ||
168 | u32 crb_status_ring_size; | ||
169 | }; | 158 | }; |
170 | 159 | ||
171 | extern struct netxen_recv_crb recv_crb_registers[]; | 160 | extern struct netxen_recv_crb recv_crb_registers[]; |