aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/arm/ks8695net.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/arm/ks8695net.c')
-rw-r--r--drivers/net/arm/ks8695net.c67
1 files changed, 55 insertions, 12 deletions
diff --git a/drivers/net/arm/ks8695net.c b/drivers/net/arm/ks8695net.c
index ed0b0f3b7122..0073d198715b 100644
--- a/drivers/net/arm/ks8695net.c
+++ b/drivers/net/arm/ks8695net.c
@@ -41,8 +41,7 @@
41#include "ks8695net.h" 41#include "ks8695net.h"
42 42
43#define MODULENAME "ks8695_ether" 43#define MODULENAME "ks8695_ether"
44#define MODULEVERSION "1.01" 44#define MODULEVERSION "1.02"
45
46 45
47/* 46/*
48 * Transmit and device reset timeout, default 5 seconds. 47 * Transmit and device reset timeout, default 5 seconds.
@@ -98,6 +97,9 @@ struct ks8695_skbuff {
98#define MAX_RX_DESC 16 97#define MAX_RX_DESC 16
99#define MAX_RX_DESC_MASK 0xf 98#define MAX_RX_DESC_MASK 0xf
100 99
100/*napi_weight have better more than rx DMA buffers*/
101#define NAPI_WEIGHT 64
102
101#define MAX_RXBUF_SIZE 0x700 103#define MAX_RXBUF_SIZE 0x700
102 104
103#define TX_RING_DMA_SIZE (sizeof(struct tx_ring_desc) * MAX_TX_DESC) 105#define TX_RING_DMA_SIZE (sizeof(struct tx_ring_desc) * MAX_TX_DESC)
@@ -123,6 +125,7 @@ enum ks8695_dtype {
123 * @dev: The platform device object for this interface 125 * @dev: The platform device object for this interface
124 * @dtype: The type of this device 126 * @dtype: The type of this device
125 * @io_regs: The ioremapped registers for this interface 127 * @io_regs: The ioremapped registers for this interface
128 * @napi : Add support NAPI for Rx
126 * @rx_irq_name: The textual name of the RX IRQ from the platform data 129 * @rx_irq_name: The textual name of the RX IRQ from the platform data
127 * @tx_irq_name: The textual name of the TX IRQ from the platform data 130 * @tx_irq_name: The textual name of the TX IRQ from the platform data
128 * @link_irq_name: The textual name of the link IRQ from the 131 * @link_irq_name: The textual name of the link IRQ from the
@@ -146,6 +149,7 @@ enum ks8695_dtype {
146 * @rx_ring_dma: The DMA mapped equivalent of rx_ring 149 * @rx_ring_dma: The DMA mapped equivalent of rx_ring
147 * @rx_buffers: The sk_buff mappings for the RX ring 150 * @rx_buffers: The sk_buff mappings for the RX ring
148 * @next_rx_desc_read: The next RX descriptor to read from on IRQ 151 * @next_rx_desc_read: The next RX descriptor to read from on IRQ
152 * @rx_lock: A lock to protect Rx irq function
149 * @msg_enable: The flags for which messages to emit 153 * @msg_enable: The flags for which messages to emit
150 */ 154 */
151struct ks8695_priv { 155struct ks8695_priv {
@@ -398,11 +402,30 @@ ks8695_tx_irq(int irq, void *dev_id)
398} 402}
399 403
400/** 404/**
405 * ks8695_get_rx_enable_bit - Get rx interrupt enable/status bit
406 * @ksp: Private data for the KS8695 Ethernet
407 *
408 * For KS8695 document:
409 * Interrupt Enable Register (offset 0xE204)
410 * Bit29 : WAN MAC Receive Interrupt Enable
411 * Bit16 : LAN MAC Receive Interrupt Enable
412 * Interrupt Status Register (Offset 0xF208)
413 * Bit29: WAN MAC Receive Status
414 * Bit16: LAN MAC Receive Status
415 * So, this Rx interrrupt enable/status bit number is equal
416 * as Rx IRQ number.
417 */
418static inline u32 ks8695_get_rx_enable_bit(struct ks8695_priv *ksp)
419{
420 return ksp->rx_irq;
421}
422
423/**
401 * ks8695_rx_irq - Receive IRQ handler 424 * ks8695_rx_irq - Receive IRQ handler
402 * @irq: The IRQ which went off (ignored) 425 * @irq: The IRQ which went off (ignored)
403 * @dev_id: The net_device for the interrupt 426 * @dev_id: The net_device for the interrupt
404 * 427 *
405 * Use NAPI to receive packets. 428 * Inform NAPI that packet reception needs to be scheduled
406 */ 429 */
407 430
408static irqreturn_t 431static irqreturn_t
@@ -412,7 +435,7 @@ ks8695_rx_irq(int irq, void *dev_id)
412 struct ks8695_priv *ksp = netdev_priv(ndev); 435 struct ks8695_priv *ksp = netdev_priv(ndev);
413 unsigned long status; 436 unsigned long status;
414 437
415 unsigned long mask_bit = 1 << ksp->rx_irq; 438 unsigned long mask_bit = 1 << ks8695_get_rx_enable_bit(ksp);
416 439
417 spin_lock(&ksp->rx_lock); 440 spin_lock(&ksp->rx_lock);
418 441
@@ -434,9 +457,15 @@ ks8695_rx_irq(int irq, void *dev_id)
434 return IRQ_HANDLED; 457 return IRQ_HANDLED;
435} 458}
436 459
437static int ks8695_rx(struct net_device *ndev, int budget) 460/**
461 * ks8695_rx - Receive packets called by NAPI poll method
462 * @ksp: Private data for the KS8695 Ethernet
463 * @budget: The max packets would be receive
464 */
465
466static int ks8695_rx(struct ks8695_priv *ksp, int budget)
438{ 467{
439 struct ks8695_priv *ksp = netdev_priv(ndev); 468 struct net_device *ndev = ksp->ndev;
440 struct sk_buff *skb; 469 struct sk_buff *skb;
441 int buff_n; 470 int buff_n;
442 u32 flags; 471 u32 flags;
@@ -526,20 +555,32 @@ rx_finished:
526 555
527 /* And refill the buffers */ 556 /* And refill the buffers */
528 ks8695_refill_rxbuffers(ksp); 557 ks8695_refill_rxbuffers(ksp);
558
559 /* Kick the RX DMA engine, in case it became
560 * suspended */
561 ks8695_writereg(ksp, KS8695_DRSC, 0);
529 } 562 }
530 return received; 563 return received;
531} 564}
532 565
566
567/**
568 * ks8695_poll - Receive packet by NAPI poll method
569 * @ksp: Private data for the KS8695 Ethernet
570 * @budget: The remaining number packets for network subsystem
571 *
572 * Invoked by the network core when it requests for new
573 * packets from the driver
574 */
533static int ks8695_poll(struct napi_struct *napi, int budget) 575static int ks8695_poll(struct napi_struct *napi, int budget)
534{ 576{
535 struct ks8695_priv *ksp = container_of(napi, struct ks8695_priv, napi); 577 struct ks8695_priv *ksp = container_of(napi, struct ks8695_priv, napi);
536 struct net_device *dev = ksp->ndev; 578 unsigned long work_done;
537 unsigned long mask_bit = 1 << ksp->rx_irq;
538 unsigned long isr = readl(KS8695_IRQ_VA + KS8695_INTEN);
539 579
540 unsigned long work_done ; 580 unsigned long isr = readl(KS8695_IRQ_VA + KS8695_INTEN);
581 unsigned long mask_bit = 1 << ks8695_get_rx_enable_bit(ksp);
541 582
542 work_done = ks8695_rx(dev, budget); 583 work_done = ks8695_rx(ksp, budget);
543 584
544 if (work_done < budget) { 585 if (work_done < budget) {
545 unsigned long flags; 586 unsigned long flags;
@@ -1302,6 +1343,7 @@ ks8695_stop(struct net_device *ndev)
1302 struct ks8695_priv *ksp = netdev_priv(ndev); 1343 struct ks8695_priv *ksp = netdev_priv(ndev);
1303 1344
1304 netif_stop_queue(ndev); 1345 netif_stop_queue(ndev);
1346 napi_disable(&ksp->napi);
1305 netif_carrier_off(ndev); 1347 netif_carrier_off(ndev);
1306 1348
1307 ks8695_shutdown(ksp); 1349 ks8695_shutdown(ksp);
@@ -1336,6 +1378,7 @@ ks8695_open(struct net_device *ndev)
1336 return ret; 1378 return ret;
1337 } 1379 }
1338 1380
1381 napi_enable(&ksp->napi);
1339 netif_start_queue(ndev); 1382 netif_start_queue(ndev);
1340 1383
1341 return 0; 1384 return 0;
@@ -1521,7 +1564,7 @@ ks8695_probe(struct platform_device *pdev)
1521 SET_ETHTOOL_OPS(ndev, &ks8695_ethtool_ops); 1564 SET_ETHTOOL_OPS(ndev, &ks8695_ethtool_ops);
1522 ndev->watchdog_timeo = msecs_to_jiffies(watchdog); 1565 ndev->watchdog_timeo = msecs_to_jiffies(watchdog);
1523 1566
1524 netif_napi_add(ndev, &ksp->napi, ks8695_poll, 64); 1567 netif_napi_add(ndev, &ksp->napi, ks8695_poll, NAPI_WEIGHT);
1525 1568
1526 /* Retrieve the default MAC addr from the chip. */ 1569 /* Retrieve the default MAC addr from the chip. */
1527 /* The bootloader should have left it in there for us. */ 1570 /* The bootloader should have left it in there for us. */