[PATCH v4 2/2] dma: Add Xilinx zynqmp dma engine driver support
punnaiah choudary kalluri
punnaia at xilinx.com
Wed Aug 19 23:31:27 PDT 2015
On Thu, Aug 20, 2015 at 11:43 AM, Vinod Koul <vinod.koul at intel.com> wrote:
> On Thu, Aug 06, 2015 at 08:49:33AM +0530, Punnaiah Choudary Kalluri wrote:
>
>> + list_for_each_entry_safe(desc, next, &chan->done_list, node) {
>> + dma_async_tx_callback callback;
>> + void *callback_param;
>> +
>> + list_del(&desc->node);
>> +
>> + callback = desc->async_tx.callback;
>> + callback_param = desc->async_tx.callback_param;
>> + if (callback) {
>> + if (in_interrupt())
>> + spin_unlock_bh(&chan->lock);
>> + else
>> + spin_unlock(&chan->lock);
>
> This looks bad!
> Why would callback be called from different context. It should only be
> invoked from your tasklet
During the terminate call, driver need to clean up the existing BDs so that time
this function will be called from the thread or process context in
addition to the
tasklet context.
DO you have any suggestion here ?
>
>> +static int zynqmp_dma_device_terminate_all(struct dma_chan *dchan)
>> +{
>> + struct zynqmp_dma_chan *chan = to_chan(dchan);
>> +
>> + spin_lock_bh(&chan->lock);
>> + zynqmp_dma_reset(chan);
>> + spin_unlock_bh(&chan->lock);
>
> No descriptor cleanup
zynqmp_dma_reset will do the descriptor cleanup.
>
>> +static void zynqmp_dma_chan_remove(struct zynqmp_dma_chan *chan)
>> +{
>> + if (!chan)
>> + return;
>> +
>> + devm_free_irq(chan->zdev->dev, chan->irq, chan);
>> + tasklet_kill(&chan->tasklet);
>> + list_del(&chan->common.device_node);
>
> not deregistering with dmaengine?
This i am doing it in zynqmp_dma_remove function. Each channel will be
a standalone dma device for ZynqMP DMA case
>
>> + zdev->chan = chan;
>> + tasklet_init(&chan->tasklet, zynqmp_dma_do_tasklet, (ulong)chan);
>> + spin_lock_init(&chan->lock);
>> + INIT_LIST_HEAD(&chan->active_list);
>> + INIT_LIST_HEAD(&chan->pending_list);
>> + INIT_LIST_HEAD(&chan->done_list);
>> + INIT_LIST_HEAD(&chan->free_list);
>
> You can simmplify this by using vchan framework!
I got your point . but i have already said my reasons why i am
reluctant to use vchan framework in v3 review.
>
>> +MODULE_AUTHOR("Xilinx, Inc.");
>> +MODULE_DESCRIPTION("Xilinx ZynqMP DMA driver");
>> +MODULE_LICENSE("GPL");
> No alias, how did it get loaded?
I will fix this. thanks.
Regards,
Punnaiah
>
> --
> ~Vinod
>
More information about the linux-arm-kernel
mailing list