Merge branch 'DPAA-Ethernet-fixes'

Madalin Bucur says:

====================
DPAA Ethernet fixes

This patch set is addressing several issues in the DPAA Ethernet
driver suite:

 - module unload crash caused by wrong reference to device being left
   in the cleanup code after the DSA related changes
 - scheduling wile atomic bug in QMan code revealed during dpaa_eth
   module unload
 - a couple of error counter fixes, a duplicated init in dpaa_eth.
====================

Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
David S. Miller 2018-03-14 13:16:23 -04:00
commit 16c2e4db83
2 changed files with 9 additions and 27 deletions

View File

@ -2008,7 +2008,6 @@ static inline int dpaa_xmit(struct dpaa_priv *priv,
} }
if (unlikely(err < 0)) { if (unlikely(err < 0)) {
percpu_stats->tx_errors++;
percpu_stats->tx_fifo_errors++; percpu_stats->tx_fifo_errors++;
return err; return err;
} }
@ -2278,7 +2277,6 @@ static enum qman_cb_dqrr_result rx_default_dqrr(struct qman_portal *portal,
vaddr = phys_to_virt(addr); vaddr = phys_to_virt(addr);
prefetch(vaddr + qm_fd_get_offset(fd)); prefetch(vaddr + qm_fd_get_offset(fd));
fd_format = qm_fd_get_format(fd);
/* The only FD types that we may receive are contig and S/G */ /* The only FD types that we may receive are contig and S/G */
WARN_ON((fd_format != qm_fd_contig) && (fd_format != qm_fd_sg)); WARN_ON((fd_format != qm_fd_contig) && (fd_format != qm_fd_sg));
@ -2311,8 +2309,10 @@ static enum qman_cb_dqrr_result rx_default_dqrr(struct qman_portal *portal,
skb_len = skb->len; skb_len = skb->len;
if (unlikely(netif_receive_skb(skb) == NET_RX_DROP)) if (unlikely(netif_receive_skb(skb) == NET_RX_DROP)) {
percpu_stats->rx_dropped++;
return qman_cb_dqrr_consume; return qman_cb_dqrr_consume;
}
percpu_stats->rx_packets++; percpu_stats->rx_packets++;
percpu_stats->rx_bytes += skb_len; percpu_stats->rx_bytes += skb_len;
@ -2860,7 +2860,7 @@ static int dpaa_remove(struct platform_device *pdev)
struct device *dev; struct device *dev;
int err; int err;
dev = &pdev->dev; dev = pdev->dev.parent;
net_dev = dev_get_drvdata(dev); net_dev = dev_get_drvdata(dev);
priv = netdev_priv(net_dev); priv = netdev_priv(net_dev);

View File

@ -2443,39 +2443,21 @@ struct cgr_comp {
struct completion completion; struct completion completion;
}; };
static int qman_delete_cgr_thread(void *p) static void qman_delete_cgr_smp_call(void *p)
{ {
struct cgr_comp *cgr_comp = (struct cgr_comp *)p; qman_delete_cgr((struct qman_cgr *)p);
int ret;
ret = qman_delete_cgr(cgr_comp->cgr);
complete(&cgr_comp->completion);
return ret;
} }
void qman_delete_cgr_safe(struct qman_cgr *cgr) void qman_delete_cgr_safe(struct qman_cgr *cgr)
{ {
struct task_struct *thread;
struct cgr_comp cgr_comp;
preempt_disable(); preempt_disable();
if (qman_cgr_cpus[cgr->cgrid] != smp_processor_id()) { if (qman_cgr_cpus[cgr->cgrid] != smp_processor_id()) {
init_completion(&cgr_comp.completion); smp_call_function_single(qman_cgr_cpus[cgr->cgrid],
cgr_comp.cgr = cgr; qman_delete_cgr_smp_call, cgr, true);
thread = kthread_create(qman_delete_cgr_thread, &cgr_comp,
"cgr_del");
if (IS_ERR(thread))
goto out;
kthread_bind(thread, qman_cgr_cpus[cgr->cgrid]);
wake_up_process(thread);
wait_for_completion(&cgr_comp.completion);
preempt_enable(); preempt_enable();
return; return;
} }
out:
qman_delete_cgr(cgr); qman_delete_cgr(cgr);
preempt_enable(); preempt_enable();
} }