[PATCH 1/5] dmaengine: mxs-dma: add dma support for i.MX23/28

Sascha Hauer s.hauer at pengutronix.de
Wed Feb 9 03:34:00 EST 2011


Shawn,

On Wed, Feb 09, 2011 at 07:28:34AM +0800, Shawn Guo wrote:
> > > +
> > > +     if (direction == DMA_NONE) {
> > > +             ccw = &mxs_chan->ccw[0];
> > > +             pio = (u32 *) sgl;
> > > +
> > > +             for (j = 0; j < sg_len;)
> > > +                     ccw->pio_words[j++] = *pio++;
> > > +
> > > +             ccw->next = 0;
> > > +             ccw->bits.chain = 0;
> > > +             ccw->bits.irq = 1;
> > > +             ccw->bits.dec_sem = 1;
> > > +             ccw->bits.wait4end = flags;
> > > +             ccw->bits.halt_on_terminate = 1;
> > > +             ccw->bits.terminate_flush = 1;
> > > +             ccw->bits.pio_num = sg_len;
> > > +             ccw->bits.command = MXS_DMA_NO_XFER;
> > 
> > Does this have a valid usecase? I would just return some error code
> > here. pio_num and pio_words are unused in the driver and I don't think
> > a dmaengine driver should have some kind of PIO fallback.
> > 
> If you happen to have a look at mxs-mmc patch set, you could find it.

As Russell already pointed out, the (mmc-) driver should handle this.

> > > +
> > > +     /*
> > > +      * dmaengine clients have to use dma_device.dev_id to filter
> > > +      * dma device between apbh and apbx, so need to ensure it is
> > > +      * identical to mxs_dma_engine.dev_id.
> > > +      */
> > > +     if (mxs_dma->dma_device.dev_id != mxs_dma->dev_id) {
> > > +             dev_err(&pdev->dev, "dev_id of dma_device %d differs from mxs_dma_engine %d\n",
> > > +                             mxs_dma->dma_device.dev_id, mxs_dma->dev_id);
> > > +             goto err_init;
> > > +     }
> > 
> > I think it makes more sense to match against device names (apbh vs.
> > apbx) in the client's filter function than to rely on exact numbering.
> > 
> I agree, if there is already a member like dev_name in dma_device.
> There is dev_id but no dev_name.  Suggestion on how to use device
> name for matching?

Have a look at the implementation of imx_dma_is_general_purpose() and
imx_dma_is_ipu().

Sascha


-- 
Pengutronix e.K.                           |                             |
Industrial Linux Solutions                 | http://www.pengutronix.de/  |
Peiner Str. 6-8, 31137 Hildesheim, Germany | Phone: +49-5121-206917-0    |
Amtsgericht Hildesheim, HRA 2686           | Fax:   +49-5121-206917-5555 |



More information about the linux-arm-kernel mailing list