提交 1b055409 编写于 作者: D David S. Miller

Merge branch 'hns3-next'

Barry Song says:

====================
net: hns3: a bundle of minor cleanup and fixes

some minor changes to either improve the readability or make the code align
with linux APIs better.
====================
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
...@@ -8,6 +8,7 @@ ...@@ -8,6 +8,7 @@
#include <linux/cpu_rmap.h> #include <linux/cpu_rmap.h>
#endif #endif
#include <linux/if_vlan.h> #include <linux/if_vlan.h>
#include <linux/irq.h>
#include <linux/ip.h> #include <linux/ip.h>
#include <linux/ipv6.h> #include <linux/ipv6.h>
#include <linux/module.h> #include <linux/module.h>
...@@ -154,6 +155,7 @@ static int hns3_nic_init_irq(struct hns3_nic_priv *priv) ...@@ -154,6 +155,7 @@ static int hns3_nic_init_irq(struct hns3_nic_priv *priv)
tqp_vectors->name[HNAE3_INT_NAME_LEN - 1] = '\0'; tqp_vectors->name[HNAE3_INT_NAME_LEN - 1] = '\0';
irq_set_status_flags(tqp_vectors->vector_irq, IRQ_NOAUTOEN);
ret = request_irq(tqp_vectors->vector_irq, hns3_irq_handle, 0, ret = request_irq(tqp_vectors->vector_irq, hns3_irq_handle, 0,
tqp_vectors->name, tqp_vectors); tqp_vectors->name, tqp_vectors);
if (ret) { if (ret) {
...@@ -163,8 +165,6 @@ static int hns3_nic_init_irq(struct hns3_nic_priv *priv) ...@@ -163,8 +165,6 @@ static int hns3_nic_init_irq(struct hns3_nic_priv *priv)
return ret; return ret;
} }
disable_irq(tqp_vectors->vector_irq);
irq_set_affinity_hint(tqp_vectors->vector_irq, irq_set_affinity_hint(tqp_vectors->vector_irq,
&tqp_vectors->affinity_mask); &tqp_vectors->affinity_mask);
...@@ -2097,10 +2097,8 @@ static int hns3_probe(struct pci_dev *pdev, const struct pci_device_id *ent) ...@@ -2097,10 +2097,8 @@ static int hns3_probe(struct pci_dev *pdev, const struct pci_device_id *ent)
pci_set_drvdata(pdev, ae_dev); pci_set_drvdata(pdev, ae_dev);
ret = hnae3_register_ae_dev(ae_dev); ret = hnae3_register_ae_dev(ae_dev);
if (ret) { if (ret)
devm_kfree(&pdev->dev, ae_dev);
pci_set_drvdata(pdev, NULL); pci_set_drvdata(pdev, NULL);
}
return ret; return ret;
} }
...@@ -2157,7 +2155,6 @@ static void hns3_shutdown(struct pci_dev *pdev) ...@@ -2157,7 +2155,6 @@ static void hns3_shutdown(struct pci_dev *pdev)
struct hnae3_ae_dev *ae_dev = pci_get_drvdata(pdev); struct hnae3_ae_dev *ae_dev = pci_get_drvdata(pdev);
hnae3_unregister_ae_dev(ae_dev); hnae3_unregister_ae_dev(ae_dev);
devm_kfree(&pdev->dev, ae_dev);
pci_set_drvdata(pdev, NULL); pci_set_drvdata(pdev, NULL);
if (system_state == SYSTEM_POWER_OFF) if (system_state == SYSTEM_POWER_OFF)
...@@ -2408,7 +2405,7 @@ static int hns3_alloc_desc(struct hns3_enet_ring *ring) ...@@ -2408,7 +2405,7 @@ static int hns3_alloc_desc(struct hns3_enet_ring *ring)
return 0; return 0;
} }
static int hns3_reserve_buffer_map(struct hns3_enet_ring *ring, static int hns3_alloc_and_map_buffer(struct hns3_enet_ring *ring,
struct hns3_desc_cb *cb) struct hns3_desc_cb *cb)
{ {
int ret; int ret;
...@@ -2429,9 +2426,9 @@ static int hns3_reserve_buffer_map(struct hns3_enet_ring *ring, ...@@ -2429,9 +2426,9 @@ static int hns3_reserve_buffer_map(struct hns3_enet_ring *ring,
return ret; return ret;
} }
static int hns3_alloc_buffer_attach(struct hns3_enet_ring *ring, int i) static int hns3_alloc_and_attach_buffer(struct hns3_enet_ring *ring, int i)
{ {
int ret = hns3_reserve_buffer_map(ring, &ring->desc_cb[i]); int ret = hns3_alloc_and_map_buffer(ring, &ring->desc_cb[i]);
if (ret) if (ret)
return ret; return ret;
...@@ -2447,7 +2444,7 @@ static int hns3_alloc_ring_buffers(struct hns3_enet_ring *ring) ...@@ -2447,7 +2444,7 @@ static int hns3_alloc_ring_buffers(struct hns3_enet_ring *ring)
int i, j, ret; int i, j, ret;
for (i = 0; i < ring->desc_num; i++) { for (i = 0; i < ring->desc_num; i++) {
ret = hns3_alloc_buffer_attach(ring, i); ret = hns3_alloc_and_attach_buffer(ring, i);
if (ret) if (ret)
goto out_buffer_fail; goto out_buffer_fail;
} }
...@@ -2476,6 +2473,11 @@ static void hns3_reuse_buffer(struct hns3_enet_ring *ring, int i) ...@@ -2476,6 +2473,11 @@ static void hns3_reuse_buffer(struct hns3_enet_ring *ring, int i)
ring->desc[i].addr = cpu_to_le64(ring->desc_cb[i].dma + ring->desc[i].addr = cpu_to_le64(ring->desc_cb[i].dma +
ring->desc_cb[i].page_offset); ring->desc_cb[i].page_offset);
ring->desc[i].rx.bd_base_info = 0; ring->desc[i].rx.bd_base_info = 0;
dma_sync_single_for_device(ring_to_dev(ring),
ring->desc_cb[i].dma + ring->desc_cb[i].page_offset,
hns3_buf_size(ring),
DMA_FROM_DEVICE);
} }
static void hns3_nic_reclaim_desc(struct hns3_enet_ring *ring, int head, static void hns3_nic_reclaim_desc(struct hns3_enet_ring *ring, int head,
...@@ -2593,7 +2595,7 @@ static void hns3_nic_alloc_rx_buffers(struct hns3_enet_ring *ring, ...@@ -2593,7 +2595,7 @@ static void hns3_nic_alloc_rx_buffers(struct hns3_enet_ring *ring,
hns3_reuse_buffer(ring, ring->next_to_use); hns3_reuse_buffer(ring, ring->next_to_use);
} else { } else {
ret = hns3_reserve_buffer_map(ring, &res_cbs); ret = hns3_alloc_and_map_buffer(ring, &res_cbs);
if (ret) { if (ret) {
u64_stats_update_begin(&ring->syncp); u64_stats_update_begin(&ring->syncp);
ring->stats.sw_err_cnt++; ring->stats.sw_err_cnt++;
...@@ -2921,6 +2923,11 @@ static int hns3_add_frag(struct hns3_enet_ring *ring) ...@@ -2921,6 +2923,11 @@ static int hns3_add_frag(struct hns3_enet_ring *ring)
skb = ring->tail_skb; skb = ring->tail_skb;
} }
dma_sync_single_for_cpu(ring_to_dev(ring),
desc_cb->dma + desc_cb->page_offset,
hns3_buf_size(ring),
DMA_FROM_DEVICE);
hns3_nic_reuse_page(skb, ring->frag_num++, ring, 0, desc_cb); hns3_nic_reuse_page(skb, ring->frag_num++, ring, 0, desc_cb);
trace_hns3_rx_desc(ring); trace_hns3_rx_desc(ring);
ring_ptr_move_fw(ring, next_to_clean); ring_ptr_move_fw(ring, next_to_clean);
...@@ -3072,8 +3079,14 @@ static int hns3_handle_rx_bd(struct hns3_enet_ring *ring) ...@@ -3072,8 +3079,14 @@ static int hns3_handle_rx_bd(struct hns3_enet_ring *ring)
if (unlikely(!(bd_base_info & BIT(HNS3_RXD_VLD_B)))) if (unlikely(!(bd_base_info & BIT(HNS3_RXD_VLD_B))))
return -ENXIO; return -ENXIO;
if (!skb) if (!skb) {
ring->va = (unsigned char *)desc_cb->buf + desc_cb->page_offset; ring->va = desc_cb->buf + desc_cb->page_offset;
dma_sync_single_for_cpu(ring_to_dev(ring),
desc_cb->dma + desc_cb->page_offset,
hns3_buf_size(ring),
DMA_FROM_DEVICE);
}
/* Prefetch first cache line of first page /* Prefetch first cache line of first page
* Idea is to cache few bytes of the header of the packet. Our L1 Cache * Idea is to cache few bytes of the header of the packet. Our L1 Cache
...@@ -4187,7 +4200,7 @@ static int hns3_clear_rx_ring(struct hns3_enet_ring *ring) ...@@ -4187,7 +4200,7 @@ static int hns3_clear_rx_ring(struct hns3_enet_ring *ring)
* stack, so we need to replace the buffer here. * stack, so we need to replace the buffer here.
*/ */
if (!ring->desc_cb[ring->next_to_use].reuse_flag) { if (!ring->desc_cb[ring->next_to_use].reuse_flag) {
ret = hns3_reserve_buffer_map(ring, &res_cbs); ret = hns3_alloc_and_map_buffer(ring, &res_cbs);
if (ret) { if (ret) {
u64_stats_update_begin(&ring->syncp); u64_stats_update_begin(&ring->syncp);
ring->stats.sw_err_cnt++; ring->stats.sw_err_cnt++;
......
...@@ -407,7 +407,7 @@ struct hns3_enet_ring { ...@@ -407,7 +407,7 @@ struct hns3_enet_ring {
u32 pull_len; /* head length for current packet */ u32 pull_len; /* head length for current packet */
u32 frag_num; u32 frag_num;
unsigned char *va; /* first buffer address for current packet */ void *va; /* first buffer address for current packet */
u32 flag; /* ring attribute */ u32 flag; /* ring attribute */
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册