aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net')
-rw-r--r--drivers/net/s2io.c321
-rw-r--r--drivers/net/s2io.h5
2 files changed, 165 insertions, 161 deletions
diff --git a/drivers/net/s2io.c b/drivers/net/s2io.c
index 1d13f60a9f52..3138df5773ee 100644
--- a/drivers/net/s2io.c
+++ b/drivers/net/s2io.c
@@ -652,9 +652,9 @@ static int init_shared_mem(struct s2io_nic *nic)
652 size += tx_cfg->fifo_len; 652 size += tx_cfg->fifo_len;
653 } 653 }
654 if (size > MAX_AVAILABLE_TXDS) { 654 if (size > MAX_AVAILABLE_TXDS) {
655 DBG_PRINT(ERR_DBG, "s2io: Requested TxDs too high, "); 655 DBG_PRINT(ERR_DBG,
656 DBG_PRINT(ERR_DBG, "Requested: %d, max supported: 8192\n", 656 "Too many TxDs requested: %d, max supported: %d\n",
657 size); 657 size, MAX_AVAILABLE_TXDS);
658 return -EINVAL; 658 return -EINVAL;
659 } 659 }
660 660
@@ -667,10 +667,9 @@ static int init_shared_mem(struct s2io_nic *nic)
667 * Legal values are from 2 to 8192 667 * Legal values are from 2 to 8192
668 */ 668 */
669 if (size < 2) { 669 if (size < 2) {
670 DBG_PRINT(ERR_DBG, "s2io: Invalid fifo len (%d)", size); 670 DBG_PRINT(ERR_DBG, "Fifo %d: Invalid length (%d) - "
671 DBG_PRINT(ERR_DBG, "for fifo %d\n", i); 671 "Valid lengths are 2 through 8192\n",
672 DBG_PRINT(ERR_DBG, "s2io: Legal values for fifo len" 672 i, size);
673 "are 2 to 8192\n");
674 return -EINVAL; 673 return -EINVAL;
675 } 674 }
676 } 675 }
@@ -713,8 +712,8 @@ static int init_shared_mem(struct s2io_nic *nic)
713 tmp_v = pci_alloc_consistent(nic->pdev, 712 tmp_v = pci_alloc_consistent(nic->pdev,
714 PAGE_SIZE, &tmp_p); 713 PAGE_SIZE, &tmp_p);
715 if (!tmp_v) { 714 if (!tmp_v) {
716 DBG_PRINT(INFO_DBG, "pci_alloc_consistent "); 715 DBG_PRINT(INFO_DBG,
717 DBG_PRINT(INFO_DBG, "failed for TxDL\n"); 716 "pci_alloc_consistent failed for TxDL\n");
718 return -ENOMEM; 717 return -ENOMEM;
719 } 718 }
720 /* If we got a zero DMA address(can happen on 719 /* If we got a zero DMA address(can happen on
@@ -725,17 +724,14 @@ static int init_shared_mem(struct s2io_nic *nic)
725 if (!tmp_p) { 724 if (!tmp_p) {
726 mac_control->zerodma_virt_addr = tmp_v; 725 mac_control->zerodma_virt_addr = tmp_v;
727 DBG_PRINT(INIT_DBG, 726 DBG_PRINT(INIT_DBG,
728 "%s: Zero DMA address for TxDL. ", 727 "%s: Zero DMA address for TxDL. "
729 dev->name); 728 "Virtual address %p\n",
730 DBG_PRINT(INIT_DBG, 729 dev->name, tmp_v);
731 "Virtual address %p\n", tmp_v);
732 tmp_v = pci_alloc_consistent(nic->pdev, 730 tmp_v = pci_alloc_consistent(nic->pdev,
733 PAGE_SIZE, &tmp_p); 731 PAGE_SIZE, &tmp_p);
734 if (!tmp_v) { 732 if (!tmp_v) {
735 DBG_PRINT(INFO_DBG, 733 DBG_PRINT(INFO_DBG,
736 "pci_alloc_consistent "); 734 "pci_alloc_consistent failed for TxDL\n");
737 DBG_PRINT(INFO_DBG,
738 "failed for TxDL\n");
739 return -ENOMEM; 735 return -ENOMEM;
740 } 736 }
741 mem_allocated += PAGE_SIZE; 737 mem_allocated += PAGE_SIZE;
@@ -771,9 +767,9 @@ static int init_shared_mem(struct s2io_nic *nic)
771 struct ring_info *ring = &mac_control->rings[i]; 767 struct ring_info *ring = &mac_control->rings[i];
772 768
773 if (rx_cfg->num_rxd % (rxd_count[nic->rxd_mode] + 1)) { 769 if (rx_cfg->num_rxd % (rxd_count[nic->rxd_mode] + 1)) {
774 DBG_PRINT(ERR_DBG, "%s: RxD count of ", dev->name); 770 DBG_PRINT(ERR_DBG, "%s: Ring%d RxD count is not a "
775 DBG_PRINT(ERR_DBG, "Ring%d is not a multiple of ", i); 771 "multiple of RxDs per Block\n",
776 DBG_PRINT(ERR_DBG, "RxDs per Block"); 772 dev->name, i);
777 return FAILURE; 773 return FAILURE;
778 } 774 }
779 size += rx_cfg->num_rxd; 775 size += rx_cfg->num_rxd;
@@ -927,7 +923,7 @@ static int init_shared_mem(struct s2io_nic *nic)
927 tmp_v_addr = mac_control->stats_mem; 923 tmp_v_addr = mac_control->stats_mem;
928 mac_control->stats_info = (struct stat_block *)tmp_v_addr; 924 mac_control->stats_info = (struct stat_block *)tmp_v_addr;
929 memset(tmp_v_addr, 0, size); 925 memset(tmp_v_addr, 0, size);
930 DBG_PRINT(INIT_DBG, "%s:Ring Mem PHY: 0x%llx\n", dev->name, 926 DBG_PRINT(INIT_DBG, "%s: Ring Mem PHY: 0x%llx\n", dev->name,
931 (unsigned long long)tmp_p_addr); 927 (unsigned long long)tmp_p_addr);
932 mac_control->stats_info->sw_stat.mem_allocated += mem_allocated; 928 mac_control->stats_info->sw_stat.mem_allocated += mem_allocated;
933 return SUCCESS; 929 return SUCCESS;
@@ -994,10 +990,9 @@ static void free_shared_mem(struct s2io_nic *nic)
994 mac_control->zerodma_virt_addr, 990 mac_control->zerodma_virt_addr,
995 (dma_addr_t)0); 991 (dma_addr_t)0);
996 DBG_PRINT(INIT_DBG, 992 DBG_PRINT(INIT_DBG,
997 "%s: Freeing TxDL with zero DMA addr. ", 993 "%s: Freeing TxDL with zero DMA address. "
998 dev->name); 994 "Virtual address %p\n",
999 DBG_PRINT(INIT_DBG, "Virtual address %p\n", 995 dev->name, mac_control->zerodma_virt_addr);
1000 mac_control->zerodma_virt_addr);
1001 swstats->mem_freed += PAGE_SIZE; 996 swstats->mem_freed += PAGE_SIZE;
1002 } 997 }
1003 kfree(fifo->list_info); 998 kfree(fifo->list_info);
@@ -1120,6 +1115,7 @@ static int s2io_print_pci_mode(struct s2io_nic *nic)
1120 register u64 val64 = 0; 1115 register u64 val64 = 0;
1121 int mode; 1116 int mode;
1122 struct config_param *config = &nic->config; 1117 struct config_param *config = &nic->config;
1118 const char *pcimode;
1123 1119
1124 val64 = readq(&bar0->pci_mode); 1120 val64 = readq(&bar0->pci_mode);
1125 mode = (u8)GET_PCI_MODE(val64); 1121 mode = (u8)GET_PCI_MODE(val64);
@@ -1135,38 +1131,39 @@ static int s2io_print_pci_mode(struct s2io_nic *nic)
1135 return mode; 1131 return mode;
1136 } 1132 }
1137 1133
1138 DBG_PRINT(ERR_DBG, "%s: Device is on %d bit ",
1139 nic->dev->name, val64 & PCI_MODE_32_BITS ? 32 : 64);
1140
1141 switch (mode) { 1134 switch (mode) {
1142 case PCI_MODE_PCI_33: 1135 case PCI_MODE_PCI_33:
1143 DBG_PRINT(ERR_DBG, "33MHz PCI bus\n"); 1136 pcimode = "33MHz PCI bus";
1144 break; 1137 break;
1145 case PCI_MODE_PCI_66: 1138 case PCI_MODE_PCI_66:
1146 DBG_PRINT(ERR_DBG, "66MHz PCI bus\n"); 1139 pcimode = "66MHz PCI bus";
1147 break; 1140 break;
1148 case PCI_MODE_PCIX_M1_66: 1141 case PCI_MODE_PCIX_M1_66:
1149 DBG_PRINT(ERR_DBG, "66MHz PCIX(M1) bus\n"); 1142 pcimode = "66MHz PCIX(M1) bus";
1150 break; 1143 break;
1151 case PCI_MODE_PCIX_M1_100: 1144 case PCI_MODE_PCIX_M1_100:
1152 DBG_PRINT(ERR_DBG, "100MHz PCIX(M1) bus\n"); 1145 pcimode = "100MHz PCIX(M1) bus";
1153 break; 1146 break;
1154 case PCI_MODE_PCIX_M1_133: 1147 case PCI_MODE_PCIX_M1_133:
1155 DBG_PRINT(ERR_DBG, "133MHz PCIX(M1) bus\n"); 1148 pcimode = "133MHz PCIX(M1) bus";
1156 break; 1149 break;
1157 case PCI_MODE_PCIX_M2_66: 1150 case PCI_MODE_PCIX_M2_66:
1158 DBG_PRINT(ERR_DBG, "133MHz PCIX(M2) bus\n"); 1151 pcimode = "133MHz PCIX(M2) bus";
1159 break; 1152 break;
1160 case PCI_MODE_PCIX_M2_100: 1153 case PCI_MODE_PCIX_M2_100:
1161 DBG_PRINT(ERR_DBG, "200MHz PCIX(M2) bus\n"); 1154 pcimode = "200MHz PCIX(M2) bus";
1162 break; 1155 break;
1163 case PCI_MODE_PCIX_M2_133: 1156 case PCI_MODE_PCIX_M2_133:
1164 DBG_PRINT(ERR_DBG, "266MHz PCIX(M2) bus\n"); 1157 pcimode = "266MHz PCIX(M2) bus";
1165 break; 1158 break;
1166 default: 1159 default:
1167 return -1; /* Unsupported bus speed */ 1160 pcimode = "unsupported bus!";
1161 mode = -1;
1168 } 1162 }
1169 1163
1164 DBG_PRINT(ERR_DBG, "%s: Device is on %d bit %s\n",
1165 nic->dev->name, val64 & PCI_MODE_32_BITS ? 32 : 64, pcimode);
1166
1170 return mode; 1167 return mode;
1171} 1168}
1172 1169
@@ -1704,9 +1701,9 @@ static int init_nic(struct s2io_nic *nic)
1704 /* Disable differentiated services steering logic */ 1701 /* Disable differentiated services steering logic */
1705 for (i = 0; i < 64; i++) { 1702 for (i = 0; i < 64; i++) {
1706 if (rts_ds_steer(nic, i, 0) == FAILURE) { 1703 if (rts_ds_steer(nic, i, 0) == FAILURE) {
1707 DBG_PRINT(ERR_DBG, "%s: failed rts ds steering", 1704 DBG_PRINT(ERR_DBG,
1708 dev->name); 1705 "%s: rts_ds_steer failed on codepoint %d\n",
1709 DBG_PRINT(ERR_DBG, "set on codepoint %d\n", i); 1706 dev->name, i);
1710 return -ENODEV; 1707 return -ENODEV;
1711 } 1708 }
1712 } 1709 }
@@ -1783,7 +1780,7 @@ static int init_nic(struct s2io_nic *nic)
1783 break; 1780 break;
1784 1781
1785 if (time > 10) { 1782 if (time > 10) {
1786 DBG_PRINT(ERR_DBG, "%s: RTI init Failed\n", 1783 DBG_PRINT(ERR_DBG, "%s: RTI init failed\n",
1787 dev->name); 1784 dev->name);
1788 return -ENODEV; 1785 return -ENODEV;
1789 } 1786 }
@@ -2189,35 +2186,35 @@ static int verify_xena_quiescence(struct s2io_nic *sp)
2189 mode = s2io_verify_pci_mode(sp); 2186 mode = s2io_verify_pci_mode(sp);
2190 2187
2191 if (!(val64 & ADAPTER_STATUS_TDMA_READY)) { 2188 if (!(val64 & ADAPTER_STATUS_TDMA_READY)) {
2192 DBG_PRINT(ERR_DBG, "%s", "TDMA is not ready!"); 2189 DBG_PRINT(ERR_DBG, "TDMA is not ready!\n");
2193 return 0; 2190 return 0;
2194 } 2191 }
2195 if (!(val64 & ADAPTER_STATUS_RDMA_READY)) { 2192 if (!(val64 & ADAPTER_STATUS_RDMA_READY)) {
2196 DBG_PRINT(ERR_DBG, "%s", "RDMA is not ready!"); 2193 DBG_PRINT(ERR_DBG, "RDMA is not ready!\n");
2197 return 0; 2194 return 0;
2198 } 2195 }
2199 if (!(val64 & ADAPTER_STATUS_PFC_READY)) { 2196 if (!(val64 & ADAPTER_STATUS_PFC_READY)) {
2200 DBG_PRINT(ERR_DBG, "%s", "PFC is not ready!"); 2197 DBG_PRINT(ERR_DBG, "PFC is not ready!\n");
2201 return 0; 2198 return 0;
2202 } 2199 }
2203 if (!(val64 & ADAPTER_STATUS_TMAC_BUF_EMPTY)) { 2200 if (!(val64 & ADAPTER_STATUS_TMAC_BUF_EMPTY)) {
2204 DBG_PRINT(ERR_DBG, "%s", "TMAC BUF is not empty!"); 2201 DBG_PRINT(ERR_DBG, "TMAC BUF is not empty!\n");
2205 return 0; 2202 return 0;
2206 } 2203 }
2207 if (!(val64 & ADAPTER_STATUS_PIC_QUIESCENT)) { 2204 if (!(val64 & ADAPTER_STATUS_PIC_QUIESCENT)) {
2208 DBG_PRINT(ERR_DBG, "%s", "PIC is not QUIESCENT!"); 2205 DBG_PRINT(ERR_DBG, "PIC is not QUIESCENT!\n");
2209 return 0; 2206 return 0;
2210 } 2207 }
2211 if (!(val64 & ADAPTER_STATUS_MC_DRAM_READY)) { 2208 if (!(val64 & ADAPTER_STATUS_MC_DRAM_READY)) {
2212 DBG_PRINT(ERR_DBG, "%s", "MC_DRAM is not ready!"); 2209 DBG_PRINT(ERR_DBG, "MC_DRAM is not ready!\n");
2213 return 0; 2210 return 0;
2214 } 2211 }
2215 if (!(val64 & ADAPTER_STATUS_MC_QUEUES_READY)) { 2212 if (!(val64 & ADAPTER_STATUS_MC_QUEUES_READY)) {
2216 DBG_PRINT(ERR_DBG, "%s", "MC_QUEUES is not ready!"); 2213 DBG_PRINT(ERR_DBG, "MC_QUEUES is not ready!\n");
2217 return 0; 2214 return 0;
2218 } 2215 }
2219 if (!(val64 & ADAPTER_STATUS_M_PLL_LOCK)) { 2216 if (!(val64 & ADAPTER_STATUS_M_PLL_LOCK)) {
2220 DBG_PRINT(ERR_DBG, "%s", "M_PLL is not locked!"); 2217 DBG_PRINT(ERR_DBG, "M_PLL is not locked!\n");
2221 return 0; 2218 return 0;
2222 } 2219 }
2223 2220
@@ -2229,12 +2226,12 @@ static int verify_xena_quiescence(struct s2io_nic *sp)
2229 if (!(val64 & ADAPTER_STATUS_P_PLL_LOCK) && 2226 if (!(val64 & ADAPTER_STATUS_P_PLL_LOCK) &&
2230 sp->device_type == XFRAME_II_DEVICE && 2227 sp->device_type == XFRAME_II_DEVICE &&
2231 mode != PCI_MODE_PCI_33) { 2228 mode != PCI_MODE_PCI_33) {
2232 DBG_PRINT(ERR_DBG, "%s", "P_PLL is not locked!"); 2229 DBG_PRINT(ERR_DBG, "P_PLL is not locked!\n");
2233 return 0; 2230 return 0;
2234 } 2231 }
2235 if (!((val64 & ADAPTER_STATUS_RC_PRC_QUIESCENT) == 2232 if (!((val64 & ADAPTER_STATUS_RC_PRC_QUIESCENT) ==
2236 ADAPTER_STATUS_RC_PRC_QUIESCENT)) { 2233 ADAPTER_STATUS_RC_PRC_QUIESCENT)) {
2237 DBG_PRINT(ERR_DBG, "%s", "RC_PRC is not QUIESCENT!"); 2234 DBG_PRINT(ERR_DBG, "RC_PRC is not QUIESCENT!\n");
2238 return 0; 2235 return 0;
2239 } 2236 }
2240 return 1; 2237 return 1;
@@ -2339,9 +2336,9 @@ static int start_nic(struct s2io_nic *nic)
2339 */ 2336 */
2340 val64 = readq(&bar0->adapter_status); 2337 val64 = readq(&bar0->adapter_status);
2341 if (!verify_xena_quiescence(nic)) { 2338 if (!verify_xena_quiescence(nic)) {
2342 DBG_PRINT(ERR_DBG, "%s: device is not ready, ", dev->name); 2339 DBG_PRINT(ERR_DBG, "%s: device is not ready, "
2343 DBG_PRINT(ERR_DBG, "Adapter status reads: 0x%llx\n", 2340 "Adapter status reads: 0x%llx\n",
2344 (unsigned long long)val64); 2341 dev->name, (unsigned long long)val64);
2345 return FAILURE; 2342 return FAILURE;
2346 } 2343 }
2347 2344
@@ -2455,7 +2452,7 @@ static void free_tx_buffers(struct s2io_nic *nic)
2455 } 2452 }
2456 } 2453 }
2457 DBG_PRINT(INTR_DBG, 2454 DBG_PRINT(INTR_DBG,
2458 "%s:forcibly freeing %d skbs on FIFO%d\n", 2455 "%s: forcibly freeing %d skbs on FIFO%d\n",
2459 dev->name, cnt, i); 2456 dev->name, cnt, i);
2460 fifo->tx_curr_get_info.offset = 0; 2457 fifo->tx_curr_get_info.offset = 0;
2461 fifo->tx_curr_put_info.offset = 0; 2458 fifo->tx_curr_put_info.offset = 0;
@@ -2547,8 +2544,8 @@ static int fill_rx_buffers(struct s2io_nic *nic, struct ring_info *ring,
2547 if ((block_no == block_no1) && 2544 if ((block_no == block_no1) &&
2548 (off == ring->rx_curr_get_info.offset) && 2545 (off == ring->rx_curr_get_info.offset) &&
2549 (rxdp->Host_Control)) { 2546 (rxdp->Host_Control)) {
2550 DBG_PRINT(INTR_DBG, "%s: Get and Put", ring->dev->name); 2547 DBG_PRINT(INTR_DBG, "%s: Get and Put info equated\n",
2551 DBG_PRINT(INTR_DBG, " info equated\n"); 2548 ring->dev->name);
2552 goto end; 2549 goto end;
2553 } 2550 }
2554 if (off && (off == ring->rxd_count)) { 2551 if (off && (off == ring->rxd_count)) {
@@ -2583,8 +2580,8 @@ static int fill_rx_buffers(struct s2io_nic *nic, struct ring_info *ring,
2583 /* allocate skb */ 2580 /* allocate skb */
2584 skb = dev_alloc_skb(size); 2581 skb = dev_alloc_skb(size);
2585 if (!skb) { 2582 if (!skb) {
2586 DBG_PRINT(INFO_DBG, "%s: Out of ", ring->dev->name); 2583 DBG_PRINT(INFO_DBG, "%s: Could not allocate skb\n",
2587 DBG_PRINT(INFO_DBG, "memory to allocate SKBs\n"); 2584 ring->dev->name);
2588 if (first_rxdp) { 2585 if (first_rxdp) {
2589 wmb(); 2586 wmb();
2590 first_rxdp->Control_1 |= RXD_OWN_XENA; 2587 first_rxdp->Control_1 |= RXD_OWN_XENA;
@@ -2806,7 +2803,7 @@ static void free_rx_buffers(struct s2io_nic *sp)
2806 ring->rx_curr_put_info.offset = 0; 2803 ring->rx_curr_put_info.offset = 0;
2807 ring->rx_curr_get_info.offset = 0; 2804 ring->rx_curr_get_info.offset = 0;
2808 ring->rx_bufs_left = 0; 2805 ring->rx_bufs_left = 0;
2809 DBG_PRINT(INIT_DBG, "%s:Freed 0x%x Rx Buffers on ring%d\n", 2806 DBG_PRINT(INIT_DBG, "%s: Freed 0x%x Rx Buffers on ring%d\n",
2810 dev->name, buf_cnt, i); 2807 dev->name, buf_cnt, i);
2811 } 2808 }
2812} 2809}
@@ -2814,8 +2811,8 @@ static void free_rx_buffers(struct s2io_nic *sp)
2814static int s2io_chk_rx_buffers(struct s2io_nic *nic, struct ring_info *ring) 2811static int s2io_chk_rx_buffers(struct s2io_nic *nic, struct ring_info *ring)
2815{ 2812{
2816 if (fill_rx_buffers(nic, ring, 0) == -ENOMEM) { 2813 if (fill_rx_buffers(nic, ring, 0) == -ENOMEM) {
2817 DBG_PRINT(INFO_DBG, "%s:Out of memory", ring->dev->name); 2814 DBG_PRINT(INFO_DBG, "%s: Out of memory in Rx Intr!!\n",
2818 DBG_PRINT(INFO_DBG, " in Rx Intr!!\n"); 2815 ring->dev->name);
2819 } 2816 }
2820 return 0; 2817 return 0;
2821} 2818}
@@ -2938,8 +2935,9 @@ static void s2io_netpoll(struct net_device *dev)
2938 struct ring_info *ring = &mac_control->rings[i]; 2935 struct ring_info *ring = &mac_control->rings[i];
2939 2936
2940 if (fill_rx_buffers(nic, ring, 0) == -ENOMEM) { 2937 if (fill_rx_buffers(nic, ring, 0) == -ENOMEM) {
2941 DBG_PRINT(INFO_DBG, "%s:Out of memory", dev->name); 2938 DBG_PRINT(INFO_DBG,
2942 DBG_PRINT(INFO_DBG, " in Rx Netpoll!!\n"); 2939 "%s: Out of memory in Rx Netpoll!!\n",
2940 dev->name);
2943 break; 2941 break;
2944 } 2942 }
2945 } 2943 }
@@ -2991,9 +2989,8 @@ static int rx_intr_handler(struct ring_info *ring_data, int budget)
2991 } 2989 }
2992 skb = (struct sk_buff *)((unsigned long)rxdp->Host_Control); 2990 skb = (struct sk_buff *)((unsigned long)rxdp->Host_Control);
2993 if (skb == NULL) { 2991 if (skb == NULL) {
2994 DBG_PRINT(ERR_DBG, "%s: The skb is ", 2992 DBG_PRINT(ERR_DBG, "%s: NULL skb in Rx Intr\n",
2995 ring_data->dev->name); 2993 ring_data->dev->name);
2996 DBG_PRINT(ERR_DBG, "Null in Rx Intr\n");
2997 return 0; 2994 return 0;
2998 } 2995 }
2999 if (ring_data->rxd_mode == RXD_MODE_1) { 2996 if (ring_data->rxd_mode == RXD_MODE_1) {
@@ -3126,8 +3123,8 @@ static void tx_intr_handler(struct fifo_info *fifo_data)
3126 skb = s2io_txdl_getskb(fifo_data, txdlp, get_info.offset); 3123 skb = s2io_txdl_getskb(fifo_data, txdlp, get_info.offset);
3127 if (skb == NULL) { 3124 if (skb == NULL) {
3128 spin_unlock_irqrestore(&fifo_data->tx_lock, flags); 3125 spin_unlock_irqrestore(&fifo_data->tx_lock, flags);
3129 DBG_PRINT(ERR_DBG, "%s: Null skb ", __func__); 3126 DBG_PRINT(ERR_DBG, "%s: NULL skb in Tx Free Intr\n",
3130 DBG_PRINT(ERR_DBG, "in Tx Free Intr\n"); 3127 __func__);
3131 return; 3128 return;
3132 } 3129 }
3133 pkt_cnt++; 3130 pkt_cnt++;
@@ -3266,22 +3263,22 @@ static void s2io_chk_xpak_counter(u64 *counter, u64 * regs_stat, u32 index,
3266 if (val64 == 3) { 3263 if (val64 == 3) {
3267 switch (type) { 3264 switch (type) {
3268 case 1: 3265 case 1:
3269 DBG_PRINT(ERR_DBG, "Take Xframe NIC out of " 3266 DBG_PRINT(ERR_DBG,
3270 "service. Excessive temperatures may " 3267 "Take Xframe NIC out of service.\n");
3271 "result in premature transceiver " 3268 DBG_PRINT(ERR_DBG,
3272 "failure \n"); 3269"Excessive temperatures may result in premature transceiver failure.\n");
3273 break; 3270 break;
3274 case 2: 3271 case 2:
3275 DBG_PRINT(ERR_DBG, "Take Xframe NIC out of " 3272 DBG_PRINT(ERR_DBG,
3276 "service Excessive bias currents may " 3273 "Take Xframe NIC out of service.\n");
3277 "indicate imminent laser diode " 3274 DBG_PRINT(ERR_DBG,
3278 "failure \n"); 3275"Excessive bias currents may indicate imminent laser diode failure.\n");
3279 break; 3276 break;
3280 case 3: 3277 case 3:
3281 DBG_PRINT(ERR_DBG, "Take Xframe NIC out of " 3278 DBG_PRINT(ERR_DBG,
3282 "service Excessive laser output " 3279 "Take Xframe NIC out of service.\n");
3283 "power may saturate far-end " 3280 DBG_PRINT(ERR_DBG,
3284 "receiver\n"); 3281"Excessive laser output power may saturate far-end receiver.\n");
3285 break; 3282 break;
3286 default: 3283 default:
3287 DBG_PRINT(ERR_DBG, 3284 DBG_PRINT(ERR_DBG,
@@ -3321,15 +3318,16 @@ static void s2io_updt_xpak_counter(struct net_device *dev)
3321 val64 = 0x0; 3318 val64 = 0x0;
3322 val64 = s2io_mdio_read(MDIO_MMD_PMAPMD, addr, dev); 3319 val64 = s2io_mdio_read(MDIO_MMD_PMAPMD, addr, dev);
3323 if ((val64 == 0xFFFF) || (val64 == 0x0000)) { 3320 if ((val64 == 0xFFFF) || (val64 == 0x0000)) {
3324 DBG_PRINT(ERR_DBG, "ERR: MDIO slave access failed - " 3321 DBG_PRINT(ERR_DBG,
3325 "Returned %llx\n", (unsigned long long)val64); 3322 "ERR: MDIO slave access failed - Returned %llx\n",
3323 (unsigned long long)val64);
3326 return; 3324 return;
3327 } 3325 }
3328 3326
3329 /* Check for the expected value of control reg 1 */ 3327 /* Check for the expected value of control reg 1 */
3330 if (val64 != MDIO_CTRL1_SPEED10G) { 3328 if (val64 != MDIO_CTRL1_SPEED10G) {
3331 DBG_PRINT(ERR_DBG, "Incorrect value at PMA address 0x0000 - "); 3329 DBG_PRINT(ERR_DBG, "Incorrect value at PMA address 0x0000 - "
3332 DBG_PRINT(ERR_DBG, "Returned: %llx- Expected: 0x%x\n", 3330 "Returned: %llx- Expected: 0x%x\n",
3333 (unsigned long long)val64, MDIO_CTRL1_SPEED10G); 3331 (unsigned long long)val64, MDIO_CTRL1_SPEED10G);
3334 return; 3332 return;
3335 } 3333 }
@@ -3481,7 +3479,7 @@ static void s2io_reset(struct s2io_nic *sp)
3481 struct stat_block *stats; 3479 struct stat_block *stats;
3482 struct swStat *swstats; 3480 struct swStat *swstats;
3483 3481
3484 DBG_PRINT(INIT_DBG, "%s - Resetting XFrame card %s\n", 3482 DBG_PRINT(INIT_DBG, "%s: Resetting XFrame card %s\n",
3485 __func__, sp->dev->name); 3483 __func__, sp->dev->name);
3486 3484
3487 /* Back up the PCI-X CMD reg, dont want to lose MMRBC, OST settings */ 3485 /* Back up the PCI-X CMD reg, dont want to lose MMRBC, OST settings */
@@ -3618,10 +3616,9 @@ static int s2io_set_swapper(struct s2io_nic *sp)
3618 i++; 3616 i++;
3619 } 3617 }
3620 if (i == 4) { 3618 if (i == 4) {
3621 DBG_PRINT(ERR_DBG, "%s: Endian settings are wrong, ", 3619 DBG_PRINT(ERR_DBG, "%s: Endian settings are wrong, "
3622 dev->name); 3620 "feedback read %llx\n",
3623 DBG_PRINT(ERR_DBG, "feedback read %llx\n", 3621 dev->name, (unsigned long long)val64);
3624 (unsigned long long)val64);
3625 return FAILURE; 3622 return FAILURE;
3626 } 3623 }
3627 valr = value[i]; 3624 valr = value[i];
@@ -3650,8 +3647,8 @@ static int s2io_set_swapper(struct s2io_nic *sp)
3650 } 3647 }
3651 if (i == 4) { 3648 if (i == 4) {
3652 unsigned long long x = val64; 3649 unsigned long long x = val64;
3653 DBG_PRINT(ERR_DBG, "Write failed, Xmsi_addr "); 3650 DBG_PRINT(ERR_DBG,
3654 DBG_PRINT(ERR_DBG, "reads:0x%llx\n", x); 3651 "Write failed, Xmsi_addr reads:0x%llx\n", x);
3655 return FAILURE; 3652 return FAILURE;
3656 } 3653 }
3657 } 3654 }
@@ -3711,10 +3708,9 @@ static int s2io_set_swapper(struct s2io_nic *sp)
3711 val64 = readq(&bar0->pif_rd_swapper_fb); 3708 val64 = readq(&bar0->pif_rd_swapper_fb);
3712 if (val64 != 0x0123456789ABCDEFULL) { 3709 if (val64 != 0x0123456789ABCDEFULL) {
3713 /* Endian settings are incorrect, calls for another dekko. */ 3710 /* Endian settings are incorrect, calls for another dekko. */
3714 DBG_PRINT(ERR_DBG, "%s: Endian settings are wrong, ", 3711 DBG_PRINT(ERR_DBG,
3715 dev->name); 3712 "%s: Endian settings are wrong, feedback read %llx\n",
3716 DBG_PRINT(ERR_DBG, "feedback read %llx\n", 3713 dev->name, (unsigned long long)val64);
3717 (unsigned long long)val64);
3718 return FAILURE; 3714 return FAILURE;
3719 } 3715 }
3720 3716
@@ -3758,7 +3754,8 @@ static void restore_xmsi_data(struct s2io_nic *nic)
3758 val64 = (s2BIT(7) | s2BIT(15) | vBIT(msix_index, 26, 6)); 3754 val64 = (s2BIT(7) | s2BIT(15) | vBIT(msix_index, 26, 6));
3759 writeq(val64, &bar0->xmsi_access); 3755 writeq(val64, &bar0->xmsi_access);
3760 if (wait_for_msix_trans(nic, msix_index)) { 3756 if (wait_for_msix_trans(nic, msix_index)) {
3761 DBG_PRINT(ERR_DBG, "failed in %s\n", __func__); 3757 DBG_PRINT(ERR_DBG, "%s: index: %d failed\n",
3758 __func__, msix_index);
3762 continue; 3759 continue;
3763 } 3760 }
3764 } 3761 }
@@ -3779,7 +3776,8 @@ static void store_xmsi_data(struct s2io_nic *nic)
3779 val64 = (s2BIT(15) | vBIT(msix_index, 26, 6)); 3776 val64 = (s2BIT(15) | vBIT(msix_index, 26, 6));
3780 writeq(val64, &bar0->xmsi_access); 3777 writeq(val64, &bar0->xmsi_access);
3781 if (wait_for_msix_trans(nic, msix_index)) { 3778 if (wait_for_msix_trans(nic, msix_index)) {
3782 DBG_PRINT(ERR_DBG, "failed in %s\n", __func__); 3779 DBG_PRINT(ERR_DBG, "%s: index: %d failed\n",
3780 __func__, msix_index);
3783 continue; 3781 continue;
3784 } 3782 }
3785 addr = readq(&bar0->xmsi_address); 3783 addr = readq(&bar0->xmsi_address);
@@ -3851,7 +3849,7 @@ static int s2io_enable_msi_x(struct s2io_nic *nic)
3851 ret = pci_enable_msix(nic->pdev, nic->entries, nic->num_entries); 3849 ret = pci_enable_msix(nic->pdev, nic->entries, nic->num_entries);
3852 /* We fail init if error or we get less vectors than min required */ 3850 /* We fail init if error or we get less vectors than min required */
3853 if (ret) { 3851 if (ret) {
3854 DBG_PRINT(ERR_DBG, "s2io: Enabling MSI-X failed\n"); 3852 DBG_PRINT(ERR_DBG, "Enabling MSI-X failed\n");
3855 kfree(nic->entries); 3853 kfree(nic->entries);
3856 swstats->mem_freed += nic->num_entries * 3854 swstats->mem_freed += nic->num_entries *
3857 sizeof(struct msix_entry); 3855 sizeof(struct msix_entry);
@@ -3915,8 +3913,8 @@ static int s2io_test_msi(struct s2io_nic *sp)
3915 if (!sp->msi_detected) { 3913 if (!sp->msi_detected) {
3916 /* MSI(X) test failed, go back to INTx mode */ 3914 /* MSI(X) test failed, go back to INTx mode */
3917 DBG_PRINT(ERR_DBG, "%s: PCI %s: No interrupt was generated " 3915 DBG_PRINT(ERR_DBG, "%s: PCI %s: No interrupt was generated "
3918 "using MSI(X) during test\n", sp->dev->name, 3916 "using MSI(X) during test\n",
3919 pci_name(pdev)); 3917 sp->dev->name, pci_name(pdev));
3920 3918
3921 err = -EOPNOTSUPP; 3919 err = -EOPNOTSUPP;
3922 } 3920 }
@@ -4095,7 +4093,7 @@ static int s2io_xmit(struct sk_buff *skb, struct net_device *dev)
4095 DBG_PRINT(TX_DBG, "%s: In Neterion Tx routine\n", dev->name); 4093 DBG_PRINT(TX_DBG, "%s: In Neterion Tx routine\n", dev->name);
4096 4094
4097 if (unlikely(skb->len <= 0)) { 4095 if (unlikely(skb->len <= 0)) {
4098 DBG_PRINT(TX_DBG, "%s:Buffer has no data..\n", dev->name); 4096 DBG_PRINT(TX_DBG, "%s: Buffer has no data..\n", dev->name);
4099 dev_kfree_skb_any(skb); 4097 dev_kfree_skb_any(skb);
4100 return NETDEV_TX_OK; 4098 return NETDEV_TX_OK;
4101 } 4099 }
@@ -5052,18 +5050,17 @@ static void s2io_set_multicast(struct net_device *dev)
5052 5050
5053 val64 = readq(&bar0->mac_cfg); 5051 val64 = readq(&bar0->mac_cfg);
5054 sp->promisc_flg = 0; 5052 sp->promisc_flg = 0;
5055 DBG_PRINT(INFO_DBG, "%s: left promiscuous mode\n", 5053 DBG_PRINT(INFO_DBG, "%s: left promiscuous mode\n", dev->name);
5056 dev->name);
5057 } 5054 }
5058 5055
5059 /* Update individual M_CAST address list */ 5056 /* Update individual M_CAST address list */
5060 if ((!sp->m_cast_flg) && dev->mc_count) { 5057 if ((!sp->m_cast_flg) && dev->mc_count) {
5061 if (dev->mc_count > 5058 if (dev->mc_count >
5062 (config->max_mc_addr - config->max_mac_addr)) { 5059 (config->max_mc_addr - config->max_mac_addr)) {
5063 DBG_PRINT(ERR_DBG, "%s: No more Rx filters ", 5060 DBG_PRINT(ERR_DBG,
5061 "%s: No more Rx filters can be added - "
5062 "please enable ALL_MULTI instead\n",
5064 dev->name); 5063 dev->name);
5065 DBG_PRINT(ERR_DBG, "can be added, please enable ");
5066 DBG_PRINT(ERR_DBG, "ALL_MULTI instead\n");
5067 return; 5064 return;
5068 } 5065 }
5069 5066
@@ -5086,8 +5083,9 @@ static void s2io_set_multicast(struct net_device *dev)
5086 if (wait_for_cmd_complete(&bar0->rmac_addr_cmd_mem, 5083 if (wait_for_cmd_complete(&bar0->rmac_addr_cmd_mem,
5087 RMAC_ADDR_CMD_MEM_STROBE_CMD_EXECUTING, 5084 RMAC_ADDR_CMD_MEM_STROBE_CMD_EXECUTING,
5088 S2IO_BIT_RESET)) { 5085 S2IO_BIT_RESET)) {
5089 DBG_PRINT(ERR_DBG, "%s: Adding ", dev->name); 5086 DBG_PRINT(ERR_DBG,
5090 DBG_PRINT(ERR_DBG, "Multicasts failed\n"); 5087 "%s: Adding Multicasts failed\n",
5088 dev->name);
5091 return; 5089 return;
5092 } 5090 }
5093 } 5091 }
@@ -5117,8 +5115,9 @@ static void s2io_set_multicast(struct net_device *dev)
5117 if (wait_for_cmd_complete(&bar0->rmac_addr_cmd_mem, 5115 if (wait_for_cmd_complete(&bar0->rmac_addr_cmd_mem,
5118 RMAC_ADDR_CMD_MEM_STROBE_CMD_EXECUTING, 5116 RMAC_ADDR_CMD_MEM_STROBE_CMD_EXECUTING,
5119 S2IO_BIT_RESET)) { 5117 S2IO_BIT_RESET)) {
5120 DBG_PRINT(ERR_DBG, "%s: Adding ", dev->name); 5118 DBG_PRINT(ERR_DBG,
5121 DBG_PRINT(ERR_DBG, "Multicasts failed\n"); 5119 "%s: Adding Multicasts failed\n",
5120 dev->name);
5122 return; 5121 return;
5123 } 5122 }
5124 } 5123 }
@@ -5552,7 +5551,7 @@ static void s2io_ethtool_gringparam(struct net_device *dev,
5552 for (i = 0 ; i < sp->config.tx_fifo_num ; i++) 5551 for (i = 0 ; i < sp->config.tx_fifo_num ; i++)
5553 tx_desc_count += sp->config.tx_cfg[i].fifo_len; 5552 tx_desc_count += sp->config.tx_cfg[i].fifo_len;
5554 5553
5555 DBG_PRINT(INFO_DBG, "\nmax txds : %d\n", sp->config.max_txds); 5554 DBG_PRINT(INFO_DBG, "max txds: %d\n", sp->config.max_txds);
5556 ering->tx_pending = tx_desc_count; 5555 ering->tx_pending = tx_desc_count;
5557 rx_desc_count = 0; 5556 rx_desc_count = 0;
5558 for (i = 0 ; i < sp->config.rx_ring_num ; i++) 5557 for (i = 0 ; i < sp->config.rx_ring_num ; i++)
@@ -5886,8 +5885,10 @@ static int s2io_ethtool_seeprom(struct net_device *dev,
5886 5885
5887 if (eeprom->magic != (sp->pdev->vendor | (sp->pdev->device << 16))) { 5886 if (eeprom->magic != (sp->pdev->vendor | (sp->pdev->device << 16))) {
5888 DBG_PRINT(ERR_DBG, 5887 DBG_PRINT(ERR_DBG,
5889 "ETHTOOL_WRITE_EEPROM Err: Magic value "); 5888 "ETHTOOL_WRITE_EEPROM Err: "
5890 DBG_PRINT(ERR_DBG, "is wrong, Its not 0x%x\n", eeprom->magic); 5889 "Magic value is wrong, it is 0x%x should be 0x%x\n",
5890 (sp->pdev->vendor | (sp->pdev->device << 16)),
5891 eeprom->magic);
5891 return -EFAULT; 5892 return -EFAULT;
5892 } 5893 }
5893 5894
@@ -5900,9 +5901,8 @@ static int s2io_ethtool_seeprom(struct net_device *dev,
5900 5901
5901 if (write_eeprom(sp, (eeprom->offset + cnt), valid, 0)) { 5902 if (write_eeprom(sp, (eeprom->offset + cnt), valid, 0)) {
5902 DBG_PRINT(ERR_DBG, 5903 DBG_PRINT(ERR_DBG,
5903 "ETHTOOL_WRITE_EEPROM Err: Cannot "); 5904 "ETHTOOL_WRITE_EEPROM Err: "
5904 DBG_PRINT(ERR_DBG, 5905 "Cannot write into the specified offset\n");
5905 "write into the specified offset\n");
5906 return -EFAULT; 5906 return -EFAULT;
5907 } 5907 }
5908 cnt++; 5908 cnt++;
@@ -5934,13 +5934,13 @@ static int s2io_register_test(struct s2io_nic *sp, uint64_t *data)
5934 val64 = readq(&bar0->pif_rd_swapper_fb); 5934 val64 = readq(&bar0->pif_rd_swapper_fb);
5935 if (val64 != 0x123456789abcdefULL) { 5935 if (val64 != 0x123456789abcdefULL) {
5936 fail = 1; 5936 fail = 1;
5937 DBG_PRINT(INFO_DBG, "Read Test level 1 fails\n"); 5937 DBG_PRINT(INFO_DBG, "Read Test level %d fails\n", 1);
5938 } 5938 }
5939 5939
5940 val64 = readq(&bar0->rmac_pause_cfg); 5940 val64 = readq(&bar0->rmac_pause_cfg);
5941 if (val64 != 0xc000ffff00000000ULL) { 5941 if (val64 != 0xc000ffff00000000ULL) {
5942 fail = 1; 5942 fail = 1;
5943 DBG_PRINT(INFO_DBG, "Read Test level 2 fails\n"); 5943 DBG_PRINT(INFO_DBG, "Read Test level %d fails\n", 2);
5944 } 5944 }
5945 5945
5946 val64 = readq(&bar0->rx_queue_cfg); 5946 val64 = readq(&bar0->rx_queue_cfg);
@@ -5950,13 +5950,13 @@ static int s2io_register_test(struct s2io_nic *sp, uint64_t *data)
5950 exp_val = 0x0808080808080808ULL; 5950 exp_val = 0x0808080808080808ULL;
5951 if (val64 != exp_val) { 5951 if (val64 != exp_val) {
5952 fail = 1; 5952 fail = 1;
5953 DBG_PRINT(INFO_DBG, "Read Test level 3 fails\n"); 5953 DBG_PRINT(INFO_DBG, "Read Test level %d fails\n", 3);
5954 } 5954 }
5955 5955
5956 val64 = readq(&bar0->xgxs_efifo_cfg); 5956 val64 = readq(&bar0->xgxs_efifo_cfg);
5957 if (val64 != 0x000000001923141EULL) { 5957 if (val64 != 0x000000001923141EULL) {
5958 fail = 1; 5958 fail = 1;
5959 DBG_PRINT(INFO_DBG, "Read Test level 4 fails\n"); 5959 DBG_PRINT(INFO_DBG, "Read Test level %d fails\n", 4);
5960 } 5960 }
5961 5961
5962 val64 = 0x5A5A5A5A5A5A5A5AULL; 5962 val64 = 0x5A5A5A5A5A5A5A5AULL;
@@ -5964,7 +5964,7 @@ static int s2io_register_test(struct s2io_nic *sp, uint64_t *data)
5964 val64 = readq(&bar0->xmsi_data); 5964 val64 = readq(&bar0->xmsi_data);
5965 if (val64 != 0x5A5A5A5A5A5A5A5AULL) { 5965 if (val64 != 0x5A5A5A5A5A5A5A5AULL) {
5966 fail = 1; 5966 fail = 1;
5967 DBG_PRINT(ERR_DBG, "Write Test level 1 fails\n"); 5967 DBG_PRINT(ERR_DBG, "Write Test level %d fails\n", 1);
5968 } 5968 }
5969 5969
5970 val64 = 0xA5A5A5A5A5A5A5A5ULL; 5970 val64 = 0xA5A5A5A5A5A5A5A5ULL;
@@ -5972,7 +5972,7 @@ static int s2io_register_test(struct s2io_nic *sp, uint64_t *data)
5972 val64 = readq(&bar0->xmsi_data); 5972 val64 = readq(&bar0->xmsi_data);
5973 if (val64 != 0xA5A5A5A5A5A5A5A5ULL) { 5973 if (val64 != 0xA5A5A5A5A5A5A5A5ULL) {
5974 fail = 1; 5974 fail = 1;
5975 DBG_PRINT(ERR_DBG, "Write Test level 2 fails\n"); 5975 DBG_PRINT(ERR_DBG, "Write Test level %d fails\n", 2);
5976 } 5976 }
5977 5977
5978 *data = fail; 5978 *data = fail;
@@ -6825,8 +6825,9 @@ static void s2io_set_link(struct work_struct *work)
6825 } 6825 }
6826 nic->device_enabled_once = true; 6826 nic->device_enabled_once = true;
6827 } else { 6827 } else {
6828 DBG_PRINT(ERR_DBG, "%s: Error: ", dev->name); 6828 DBG_PRINT(ERR_DBG,
6829 DBG_PRINT(ERR_DBG, "device is not Quiescent\n"); 6829 "%s: Error: device is not Quiescent\n",
6830 dev->name);
6830 s2io_stop_all_tx_queue(nic); 6831 s2io_stop_all_tx_queue(nic);
6831 } 6832 }
6832 } 6833 }
@@ -6876,9 +6877,9 @@ static int set_rxd_buffer_pointer(struct s2io_nic *sp, struct RxD_t *rxdp,
6876 } else { 6877 } else {
6877 *skb = dev_alloc_skb(size); 6878 *skb = dev_alloc_skb(size);
6878 if (!(*skb)) { 6879 if (!(*skb)) {
6879 DBG_PRINT(INFO_DBG, "%s: Out of ", dev->name); 6880 DBG_PRINT(INFO_DBG,
6880 DBG_PRINT(INFO_DBG, "memory to allocate "); 6881 "%s: Out of memory to allocate %s\n",
6881 DBG_PRINT(INFO_DBG, "1 buf mode SKBs\n"); 6882 dev->name, "1 buf mode SKBs");
6882 stats->mem_alloc_fail_cnt++; 6883 stats->mem_alloc_fail_cnt++;
6883 return -ENOMEM ; 6884 return -ENOMEM ;
6884 } 6885 }
@@ -6905,9 +6906,10 @@ static int set_rxd_buffer_pointer(struct s2io_nic *sp, struct RxD_t *rxdp,
6905 } else { 6906 } else {
6906 *skb = dev_alloc_skb(size); 6907 *skb = dev_alloc_skb(size);
6907 if (!(*skb)) { 6908 if (!(*skb)) {
6908 DBG_PRINT(INFO_DBG, "%s: Out of ", dev->name); 6909 DBG_PRINT(INFO_DBG,
6909 DBG_PRINT(INFO_DBG, "memory to allocate "); 6910 "%s: Out of memory to allocate %s\n",
6910 DBG_PRINT(INFO_DBG, "2 buf mode SKBs\n"); 6911 dev->name,
6912 "2 buf mode SKBs");
6911 stats->mem_alloc_fail_cnt++; 6913 stats->mem_alloc_fail_cnt++;
6912 return -ENOMEM; 6914 return -ENOMEM;
6913 } 6915 }
@@ -7095,8 +7097,8 @@ static int s2io_add_isr(struct s2io_nic *sp)
7095 } 7097 }
7096 if (!err) { 7098 if (!err) {
7097 pr_info("MSI-X-RX %d entries enabled\n", --msix_rx_cnt); 7099 pr_info("MSI-X-RX %d entries enabled\n", --msix_rx_cnt);
7098 DBG_PRINT(INFO_DBG, "MSI-X-TX entries enabled" 7100 DBG_PRINT(INFO_DBG,
7099 " through alarm vector\n"); 7101 "MSI-X-TX entries enabled through alarm vector\n");
7100 } 7102 }
7101 } 7103 }
7102 if (sp->config.intr_type == INTA) { 7104 if (sp->config.intr_type == INTA) {
@@ -7176,8 +7178,8 @@ static void do_s2io_card_down(struct s2io_nic *sp, int do_io)
7176 msleep(50); 7178 msleep(50);
7177 cnt++; 7179 cnt++;
7178 if (cnt == 10) { 7180 if (cnt == 10) {
7179 DBG_PRINT(ERR_DBG, "s2io_close:Device not Quiescent "); 7181 DBG_PRINT(ERR_DBG, "Device not Quiescent - "
7180 DBG_PRINT(ERR_DBG, "adaper status reads 0x%llx\n", 7182 "adapter status reads 0x%llx\n",
7181 (unsigned long long)val64); 7183 (unsigned long long)val64);
7182 break; 7184 break;
7183 } 7185 }
@@ -7628,7 +7630,7 @@ static int s2io_verify_parm(struct pci_dev *pdev, u8 *dev_intr_type,
7628 u8 *dev_multiq) 7630 u8 *dev_multiq)
7629{ 7631{
7630 if ((tx_fifo_num > MAX_TX_FIFOS) || (tx_fifo_num < 1)) { 7632 if ((tx_fifo_num > MAX_TX_FIFOS) || (tx_fifo_num < 1)) {
7631 DBG_PRINT(ERR_DBG, "s2io: Requested number of tx fifos " 7633 DBG_PRINT(ERR_DBG, "Requested number of tx fifos "
7632 "(%d) not supported\n", tx_fifo_num); 7634 "(%d) not supported\n", tx_fifo_num);
7633 7635
7634 if (tx_fifo_num < 1) 7636 if (tx_fifo_num < 1)
@@ -7636,8 +7638,7 @@ static int s2io_verify_parm(struct pci_dev *pdev, u8 *dev_intr_type,
7636 else 7638 else
7637 tx_fifo_num = MAX_TX_FIFOS; 7639 tx_fifo_num = MAX_TX_FIFOS;
7638 7640
7639 DBG_PRINT(ERR_DBG, "s2io: Default to %d ", tx_fifo_num); 7641 DBG_PRINT(ERR_DBG, "Default to %d tx fifos\n", tx_fifo_num);
7640 DBG_PRINT(ERR_DBG, "tx fifos\n");
7641 } 7642 }
7642 7643
7643 if (multiq) 7644 if (multiq)
@@ -7646,7 +7647,7 @@ static int s2io_verify_parm(struct pci_dev *pdev, u8 *dev_intr_type,
7646 if (tx_steering_type && (1 == tx_fifo_num)) { 7647 if (tx_steering_type && (1 == tx_fifo_num)) {
7647 if (tx_steering_type != TX_DEFAULT_STEERING) 7648 if (tx_steering_type != TX_DEFAULT_STEERING)
7648 DBG_PRINT(ERR_DBG, 7649 DBG_PRINT(ERR_DBG,
7649 "s2io: Tx steering is not supported with " 7650 "Tx steering is not supported with "
7650 "one fifo. Disabling Tx steering.\n"); 7651 "one fifo. Disabling Tx steering.\n");
7651 tx_steering_type = NO_STEERING; 7652 tx_steering_type = NO_STEERING;
7652 } 7653 }
@@ -7654,21 +7655,21 @@ static int s2io_verify_parm(struct pci_dev *pdev, u8 *dev_intr_type,
7654 if ((tx_steering_type < NO_STEERING) || 7655 if ((tx_steering_type < NO_STEERING) ||
7655 (tx_steering_type > TX_DEFAULT_STEERING)) { 7656 (tx_steering_type > TX_DEFAULT_STEERING)) {
7656 DBG_PRINT(ERR_DBG, 7657 DBG_PRINT(ERR_DBG,
7657 "s2io: Requested transmit steering not supported\n"); 7658 "Requested transmit steering not supported\n");
7658 DBG_PRINT(ERR_DBG, "s2io: Disabling transmit steering\n"); 7659 DBG_PRINT(ERR_DBG, "Disabling transmit steering\n");
7659 tx_steering_type = NO_STEERING; 7660 tx_steering_type = NO_STEERING;
7660 } 7661 }
7661 7662
7662 if (rx_ring_num > MAX_RX_RINGS) { 7663 if (rx_ring_num > MAX_RX_RINGS) {
7663 DBG_PRINT(ERR_DBG, 7664 DBG_PRINT(ERR_DBG,
7664 "s2io: Requested number of rx rings not supported\n"); 7665 "Requested number of rx rings not supported\n");
7665 DBG_PRINT(ERR_DBG, "s2io: Default to %d rx rings\n", 7666 DBG_PRINT(ERR_DBG, "Default to %d rx rings\n",
7666 MAX_RX_RINGS); 7667 MAX_RX_RINGS);
7667 rx_ring_num = MAX_RX_RINGS; 7668 rx_ring_num = MAX_RX_RINGS;
7668 } 7669 }
7669 7670
7670 if ((*dev_intr_type != INTA) && (*dev_intr_type != MSI_X)) { 7671 if ((*dev_intr_type != INTA) && (*dev_intr_type != MSI_X)) {
7671 DBG_PRINT(ERR_DBG, "s2io: Wrong intr_type requested. " 7672 DBG_PRINT(ERR_DBG, "Wrong intr_type requested. "
7672 "Defaulting to INTA\n"); 7673 "Defaulting to INTA\n");
7673 *dev_intr_type = INTA; 7674 *dev_intr_type = INTA;
7674 } 7675 }
@@ -7676,14 +7677,14 @@ static int s2io_verify_parm(struct pci_dev *pdev, u8 *dev_intr_type,
7676 if ((*dev_intr_type == MSI_X) && 7677 if ((*dev_intr_type == MSI_X) &&
7677 ((pdev->device != PCI_DEVICE_ID_HERC_WIN) && 7678 ((pdev->device != PCI_DEVICE_ID_HERC_WIN) &&
7678 (pdev->device != PCI_DEVICE_ID_HERC_UNI))) { 7679 (pdev->device != PCI_DEVICE_ID_HERC_UNI))) {
7679 DBG_PRINT(ERR_DBG, "s2io: Xframe I does not support MSI_X. " 7680 DBG_PRINT(ERR_DBG, "Xframe I does not support MSI_X. "
7680 "Defaulting to INTA\n"); 7681 "Defaulting to INTA\n");
7681 *dev_intr_type = INTA; 7682 *dev_intr_type = INTA;
7682 } 7683 }
7683 7684
7684 if ((rx_ring_mode != 1) && (rx_ring_mode != 2)) { 7685 if ((rx_ring_mode != 1) && (rx_ring_mode != 2)) {
7685 DBG_PRINT(ERR_DBG, "s2io: Requested ring mode not supported\n"); 7686 DBG_PRINT(ERR_DBG, "Requested ring mode not supported\n");
7686 DBG_PRINT(ERR_DBG, "s2io: Defaulting to 1-buffer mode\n"); 7687 DBG_PRINT(ERR_DBG, "Defaulting to 1-buffer mode\n");
7687 rx_ring_mode = 1; 7688 rx_ring_mode = 1;
7688 } 7689 }
7689 return SUCCESS; 7690 return SUCCESS;
@@ -7776,12 +7777,12 @@ s2io_init_nic(struct pci_dev *pdev, const struct pci_device_id *pre)
7776 ret = pci_enable_device(pdev); 7777 ret = pci_enable_device(pdev);
7777 if (ret) { 7778 if (ret) {
7778 DBG_PRINT(ERR_DBG, 7779 DBG_PRINT(ERR_DBG,
7779 "s2io_init_nic: pci_enable_device failed\n"); 7780 "%s: pci_enable_device failed\n", __func__);
7780 return ret; 7781 return ret;
7781 } 7782 }
7782 7783
7783 if (!pci_set_dma_mask(pdev, DMA_BIT_MASK(64))) { 7784 if (!pci_set_dma_mask(pdev, DMA_BIT_MASK(64))) {
7784 DBG_PRINT(INIT_DBG, "s2io_init_nic: Using 64bit DMA\n"); 7785 DBG_PRINT(INIT_DBG, "%s: Using 64bit DMA\n", __func__);
7785 dma_flag = true; 7786 dma_flag = true;
7786 if (pci_set_consistent_dma_mask(pdev, DMA_BIT_MASK(64))) { 7787 if (pci_set_consistent_dma_mask(pdev, DMA_BIT_MASK(64))) {
7787 DBG_PRINT(ERR_DBG, 7788 DBG_PRINT(ERR_DBG,
@@ -7791,14 +7792,14 @@ s2io_init_nic(struct pci_dev *pdev, const struct pci_device_id *pre)
7791 return -ENOMEM; 7792 return -ENOMEM;
7792 } 7793 }
7793 } else if (!pci_set_dma_mask(pdev, DMA_BIT_MASK(32))) { 7794 } else if (!pci_set_dma_mask(pdev, DMA_BIT_MASK(32))) {
7794 DBG_PRINT(INIT_DBG, "s2io_init_nic: Using 32bit DMA\n"); 7795 DBG_PRINT(INIT_DBG, "%s: Using 32bit DMA\n", __func__);
7795 } else { 7796 } else {
7796 pci_disable_device(pdev); 7797 pci_disable_device(pdev);
7797 return -ENOMEM; 7798 return -ENOMEM;
7798 } 7799 }
7799 ret = pci_request_regions(pdev, s2io_driver_name); 7800 ret = pci_request_regions(pdev, s2io_driver_name);
7800 if (ret) { 7801 if (ret) {
7801 DBG_PRINT(ERR_DBG, "%s: Request Regions failed - %x \n", 7802 DBG_PRINT(ERR_DBG, "%s: Request Regions failed - %x\n",
7802 __func__, ret); 7803 __func__, ret);
7803 pci_disable_device(pdev); 7804 pci_disable_device(pdev);
7804 return -ENODEV; 7805 return -ENODEV;
@@ -7992,7 +7993,7 @@ s2io_init_nic(struct pci_dev *pdev, const struct pci_device_id *pre)
7992 7993
7993 /* Setting swapper control on the NIC, for proper reset operation */ 7994 /* Setting swapper control on the NIC, for proper reset operation */
7994 if (s2io_set_swapper(sp)) { 7995 if (s2io_set_swapper(sp)) {
7995 DBG_PRINT(ERR_DBG, "%s:swapper settings are wrong\n", 7996 DBG_PRINT(ERR_DBG, "%s: swapper settings are wrong\n",
7996 dev->name); 7997 dev->name);
7997 ret = -EAGAIN; 7998 ret = -EAGAIN;
7998 goto set_swap_failed; 7999 goto set_swap_failed;
@@ -8002,8 +8003,8 @@ s2io_init_nic(struct pci_dev *pdev, const struct pci_device_id *pre)
8002 if (sp->device_type & XFRAME_II_DEVICE) { 8003 if (sp->device_type & XFRAME_II_DEVICE) {
8003 mode = s2io_verify_pci_mode(sp); 8004 mode = s2io_verify_pci_mode(sp);
8004 if (mode < 0) { 8005 if (mode < 0) {
8005 DBG_PRINT(ERR_DBG, "%s: ", __func__); 8006 DBG_PRINT(ERR_DBG, "%s: Unsupported PCI bus mode\n",
8006 DBG_PRINT(ERR_DBG, " Unsupported PCI bus mode\n"); 8007 __func__);
8007 ret = -EBADSLT; 8008 ret = -EBADSLT;
8008 goto set_swap_failed; 8009 goto set_swap_failed;
8009 } 8010 }
@@ -8021,7 +8022,7 @@ s2io_init_nic(struct pci_dev *pdev, const struct pci_device_id *pre)
8021 if (ret) { 8022 if (ret) {
8022 8023
8023 DBG_PRINT(ERR_DBG, 8024 DBG_PRINT(ERR_DBG,
8024 "s2io: MSI-X requested but failed to enable\n"); 8025 "MSI-X requested but failed to enable\n");
8025 sp->config.intr_type = INTA; 8026 sp->config.intr_type = INTA;
8026 } 8027 }
8027 } 8028 }
@@ -8137,12 +8138,11 @@ s2io_init_nic(struct pci_dev *pdev, const struct pci_device_id *pre)
8137 sp->product_name, pdev->revision); 8138 sp->product_name, pdev->revision);
8138 DBG_PRINT(ERR_DBG, "%s: Driver version %s\n", dev->name, 8139 DBG_PRINT(ERR_DBG, "%s: Driver version %s\n", dev->name,
8139 s2io_driver_version); 8140 s2io_driver_version);
8140 DBG_PRINT(ERR_DBG, "%s: MAC ADDR: %pM\n", dev->name, dev->dev_addr); 8141 DBG_PRINT(ERR_DBG, "%s: MAC Address: %pM\n", dev->name, dev->dev_addr);
8141 DBG_PRINT(ERR_DBG, "SERIAL NUMBER: %s\n", sp->serial_num); 8142 DBG_PRINT(ERR_DBG, "Serial number: %s\n", sp->serial_num);
8142 if (sp->device_type & XFRAME_II_DEVICE) { 8143 if (sp->device_type & XFRAME_II_DEVICE) {
8143 mode = s2io_print_pci_mode(sp); 8144 mode = s2io_print_pci_mode(sp);
8144 if (mode < 0) { 8145 if (mode < 0) {
8145 DBG_PRINT(ERR_DBG, " Unsupported PCI bus mode\n");
8146 ret = -EBADSLT; 8146 ret = -EBADSLT;
8147 unregister_netdev(dev); 8147 unregister_netdev(dev);
8148 goto set_swap_failed; 8148 goto set_swap_failed;
@@ -8532,8 +8532,9 @@ static int s2io_club_tcp_session(struct ring_info *ring_data, u8 *buffer,
8532 *lro = l_lro; 8532 *lro = l_lro;
8533 8533
8534 if ((*lro)->tcp_next_seq != ntohl(tcph->seq)) { 8534 if ((*lro)->tcp_next_seq != ntohl(tcph->seq)) {
8535 DBG_PRINT(INFO_DBG, "%s:Out of order. expected " 8535 DBG_PRINT(INFO_DBG, "%s: Out of sequence. "
8536 "0x%x, actual 0x%x\n", __func__, 8536 "expected 0x%x, actual 0x%x\n",
8537 __func__,
8537 (*lro)->tcp_next_seq, 8538 (*lro)->tcp_next_seq,
8538 ntohl(tcph->seq)); 8539 ntohl(tcph->seq));
8539 8540
@@ -8571,7 +8572,7 @@ static int s2io_club_tcp_session(struct ring_info *ring_data, u8 *buffer,
8571 } 8572 }
8572 8573
8573 if (ret == 0) { /* sessions exceeded */ 8574 if (ret == 0) { /* sessions exceeded */
8574 DBG_PRINT(INFO_DBG, "%s:All LRO sessions already in use\n", 8575 DBG_PRINT(INFO_DBG, "%s: All LRO sessions already in use\n",
8575 __func__); 8576 __func__);
8576 *lro = NULL; 8577 *lro = NULL;
8577 return ret; 8578 return ret;
@@ -8593,7 +8594,7 @@ static int s2io_club_tcp_session(struct ring_info *ring_data, u8 *buffer,
8593 } 8594 }
8594 break; 8595 break;
8595 default: 8596 default:
8596 DBG_PRINT(ERR_DBG, "%s:Dont know, can't say!!\n", __func__); 8597 DBG_PRINT(ERR_DBG, "%s: Don't know, can't say!!\n", __func__);
8597 break; 8598 break;
8598 } 8599 }
8599 8600
diff --git a/drivers/net/s2io.h b/drivers/net/s2io.h
index d5c5be6c07b9..47c36e0994f5 100644
--- a/drivers/net/s2io.h
+++ b/drivers/net/s2io.h
@@ -64,7 +64,10 @@ enum {
64static int debug_level = ERR_DBG; 64static int debug_level = ERR_DBG;
65 65
66/* DEBUG message print. */ 66/* DEBUG message print. */
67#define DBG_PRINT(dbg_level, args...) if(!(debug_level<dbg_level)) printk(args) 67#define DBG_PRINT(dbg_level, fmt, args...) do { \
68 if (dbg_level >= debug_level) \
69 pr_info(fmt, ##args); \
70 } while (0)
68 71
69/* Protocol assist features of the NIC */ 72/* Protocol assist features of the NIC */
70#define L3_CKSUM_OK 0xFFFF 73#define L3_CKSUM_OK 0xFFFF