Просмотр исходного кода

bmips: check NAPI context when refilling rx SKB

Check if we're in NAPI context when refilling rx. Normally we're almost
always running in NAPI context. Dispatch to napi_alloc_frag() directly
instead of relying on netdev_alloc_frag() which does the same but with
the overhead of local_bh_disable/enable.

Signed-off-by: Sieng Piaw Liew <[email protected]>
[improve code format]
Signed-off-by: Álvaro Fernández Rojas <[email protected]>
Sieng Piaw Liew 3 лет назад
Родитель
Сommit
a332b8cc9c
1 измененных файлов с 10 добавлено и 6 удалено
  1. 10 6
      target/linux/bmips/files/drivers/net/ethernet/broadcom/bcm6368-enetsw.c

+ 10 - 6
target/linux/bmips/files/drivers/net/ethernet/broadcom/bcm6368-enetsw.c

@@ -256,7 +256,7 @@ static inline void dmas_writel(struct bcm6368_enetsw *priv, u32 val,
 /*
 /*
  * refill rx queue
  * refill rx queue
  */
  */
-static int bcm6368_enetsw_refill_rx(struct net_device *dev)
+static int bcm6368_enetsw_refill_rx(struct net_device *dev, bool napi_mode)
 {
 {
 	struct bcm6368_enetsw *priv = netdev_priv(dev);
 	struct bcm6368_enetsw *priv = netdev_priv(dev);
 
 
@@ -269,8 +269,12 @@ static int bcm6368_enetsw_refill_rx(struct net_device *dev)
 		desc = &priv->rx_desc_cpu[desc_idx];
 		desc = &priv->rx_desc_cpu[desc_idx];
 
 
 		if (!priv->rx_buf[desc_idx]) {
 		if (!priv->rx_buf[desc_idx]) {
-			unsigned char *buf =
-				netdev_alloc_frag(priv->rx_frag_size);
+			unsigned char *buf;
+
+			if (likely(napi_mode))
+				buf = napi_alloc_frag(priv->rx_frag_size);
+			else
+				buf = netdev_alloc_frag(priv->rx_frag_size);
 
 
 			if (unlikely(!buf))
 			if (unlikely(!buf))
 				break;
 				break;
@@ -319,7 +323,7 @@ static void bcm6368_enetsw_refill_rx_timer(struct timer_list *t)
 	struct net_device *dev = priv->net_dev;
 	struct net_device *dev = priv->net_dev;
 
 
 	spin_lock(&priv->rx_lock);
 	spin_lock(&priv->rx_lock);
-	bcm6368_enetsw_refill_rx(dev);
+	bcm6368_enetsw_refill_rx(dev, false);
 	spin_unlock(&priv->rx_lock);
 	spin_unlock(&priv->rx_lock);
 }
 }
 
 
@@ -419,7 +423,7 @@ static int bcm6368_enetsw_receive_queue(struct net_device *dev, int budget)
 	} while (--budget > 0);
 	} while (--budget > 0);
 
 
 	if (processed || !priv->rx_desc_count) {
 	if (processed || !priv->rx_desc_count) {
-		bcm6368_enetsw_refill_rx(dev);
+		bcm6368_enetsw_refill_rx(dev, true);
 
 
 		/* kick rx dma */
 		/* kick rx dma */
 		dmac_writel(priv, priv->dma_chan_en_mask,
 		dmac_writel(priv, priv->dma_chan_en_mask,
@@ -725,7 +729,7 @@ static int bcm6368_enetsw_open(struct net_device *dev)
 	dma_writel(priv, DMA_BUFALLOC_FORCE_MASK | 0,
 	dma_writel(priv, DMA_BUFALLOC_FORCE_MASK | 0,
 		   DMA_BUFALLOC_REG(priv->rx_chan));
 		   DMA_BUFALLOC_REG(priv->rx_chan));
 
 
-	if (bcm6368_enetsw_refill_rx(dev)) {
+	if (bcm6368_enetsw_refill_rx(dev, false)) {
 		dev_err(kdev, "cannot allocate rx buffer queue\n");
 		dev_err(kdev, "cannot allocate rx buffer queue\n");
 		ret = -ENOMEM;
 		ret = -ENOMEM;
 		goto out;
 		goto out;