[PATCH 01/12] dma: mmp_pdma: add protect when alloc/free phy channels
Ezequiel Garcia
ezequiel.garcia at free-electrons.com
Wed Aug 7 08:40:12 EDT 2013
Daniel,
It's good to see this effort is moving forward!
I just have a minor nitpick.
On Wed, Aug 07, 2013 at 12:19:19PM +0200, Daniel Mack wrote:
>
> #define tx_to_mmp_pdma_desc(tx) container_of(tx, struct mmp_pdma_desc_sw, async_tx)
> @@ -219,6 +220,7 @@ static struct mmp_pdma_phy *lookup_phy(struct mmp_pdma_chan *pchan)
> int prio, i;
> struct mmp_pdma_device *pdev = to_mmp_pdma_dev(pchan->chan.device);
> struct mmp_pdma_phy *phy;
> + unsigned long flags;
>
> /*
> * dma channel priorities
> @@ -227,6 +229,8 @@ static struct mmp_pdma_phy *lookup_phy(struct mmp_pdma_chan *pchan)
> * ch 8 - 11, 24 - 27 <--> (2)
> * ch 12 - 15, 28 - 31 <--> (3)
> */
> +
> + spin_lock_irqsave(&pdev->phy_lock, flags);
> for (prio = 0; prio <= (((pdev->dma_channels - 1) & 0xf) >> 2); prio++) {
> for (i = 0; i < pdev->dma_channels; i++) {
> if (prio != ((i & 0xf) >> 2))
> @@ -234,14 +238,30 @@ static struct mmp_pdma_phy *lookup_phy(struct mmp_pdma_chan *pchan)
> phy = &pdev->phy[i];
> if (!phy->vchan) {
> phy->vchan = pchan;
> + spin_unlock_irqrestore(&pdev->phy_lock, flags);
Isn't it better to goto ...
> return phy;
> }
> }
> }
>
... here?
I think it's generally cleaner and less error-prone.
> + spin_unlock_irqrestore(&pdev->phy_lock, flags);
> return NULL;
> }
>
--
Ezequiel García, Free Electrons
Embedded Linux, Kernel and Android Engineering
http://free-electrons.com
More information about the linux-arm-kernel
mailing list