Commit 776482cd authored by Christophe Jaillet's avatar Christophe Jaillet Committed by David S. Miller

wan/fsl_ucc_hdlc: Fix size used in dma_free_coherent()

Size used with 'dma_alloc_coherent()' and 'dma_free_coherent()' should be
consistent.
Here, the size of a pointer is used in dma_alloc... and the size of the
pointed structure is used in dma_free...

This has been spotted with coccinelle, using the following script:
////////////////////
@r@
expression x0, x1, y0, y1, z0, z1, t0, t1, ret;
@@

*   ret = dma_alloc_coherent(x0, y0, z0, t0);
    ...
*   dma_free_coherent(x1, y1, ret, t1);

@script:python@
y0 << r.y0;
y1 << r.y1;

@@
if y1.find(y0) == -1:
 print "WARNING: sizes look different:  '%s'   vs   '%s'" % (y0, y1)
////////////////////
Signed-off-by: default avatarChristophe JAILLET <christophe.jaillet@wanadoo.fr>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent fa6114d4
...@@ -295,11 +295,11 @@ static int uhdlc_init(struct ucc_hdlc_private *priv) ...@@ -295,11 +295,11 @@ static int uhdlc_init(struct ucc_hdlc_private *priv)
qe_muram_free(priv->ucc_pram_offset); qe_muram_free(priv->ucc_pram_offset);
free_tx_bd: free_tx_bd:
dma_free_coherent(priv->dev, dma_free_coherent(priv->dev,
TX_BD_RING_LEN * sizeof(struct qe_bd), TX_BD_RING_LEN * sizeof(struct qe_bd *),
priv->tx_bd_base, priv->dma_tx_bd); priv->tx_bd_base, priv->dma_tx_bd);
free_rx_bd: free_rx_bd:
dma_free_coherent(priv->dev, dma_free_coherent(priv->dev,
RX_BD_RING_LEN * sizeof(struct qe_bd), RX_BD_RING_LEN * sizeof(struct qe_bd *),
priv->rx_bd_base, priv->dma_rx_bd); priv->rx_bd_base, priv->dma_rx_bd);
free_uccf: free_uccf:
ucc_fast_free(priv->uccf); ucc_fast_free(priv->uccf);
...@@ -688,7 +688,7 @@ static void uhdlc_memclean(struct ucc_hdlc_private *priv) ...@@ -688,7 +688,7 @@ static void uhdlc_memclean(struct ucc_hdlc_private *priv)
if (priv->rx_bd_base) { if (priv->rx_bd_base) {
dma_free_coherent(priv->dev, dma_free_coherent(priv->dev,
RX_BD_RING_LEN * sizeof(struct qe_bd), RX_BD_RING_LEN * sizeof(struct qe_bd *),
priv->rx_bd_base, priv->dma_rx_bd); priv->rx_bd_base, priv->dma_rx_bd);
priv->rx_bd_base = NULL; priv->rx_bd_base = NULL;
...@@ -697,7 +697,7 @@ static void uhdlc_memclean(struct ucc_hdlc_private *priv) ...@@ -697,7 +697,7 @@ static void uhdlc_memclean(struct ucc_hdlc_private *priv)
if (priv->tx_bd_base) { if (priv->tx_bd_base) {
dma_free_coherent(priv->dev, dma_free_coherent(priv->dev,
TX_BD_RING_LEN * sizeof(struct qe_bd), TX_BD_RING_LEN * sizeof(struct qe_bd *),
priv->tx_bd_base, priv->dma_tx_bd); priv->tx_bd_base, priv->dma_tx_bd);
priv->tx_bd_base = NULL; priv->tx_bd_base = NULL;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment