[PATCH] dmaengine: qcom_hidma: release the descriptor before the callback

okaya at codeaurora.org okaya at codeaurora.org
Fri Aug 19 04:13:43 PDT 2016


On 2016-08-19 01:52, Vinod Koul wrote:
> On Thu, Aug 18, 2016 at 11:48:52PM -0400, Sinan Kaya wrote:
>> On 8/18/2016 11:42 PM, Vinod Koul wrote:
>> > On Thu, Aug 18, 2016 at 11:26:28PM -0400, Sinan Kaya wrote:
>> >> On 8/18/2016 10:48 PM, Vinod Koul wrote:
>> >>>> Keep a size limited list with error cookies and flush them in terminate all?
>> >>> I think so, terminate_all anyway cleans up the channel. Btw what is the
>> >>> behaviour on error? Do you terminate or somthing else?
>> >>>
>> >>
>> >> On error, I flush all outstanding transactions with an error code and I reset
>> >> the channel. After the reset, the DMA channel is functional again. The client
>> >> doesn't need to shutdown anything.
>> >
>> > You mean from the client context or driver?
>> >
>> 
>> The client doesn't need to call device_free_chan_resources and 
>> device_terminate_all
>> to be specific. Client can certainly call these if it needs to but it 
>> is not
>> required to recover the channel.
> 
> You didn't answer my question!
> 
> On error you said you flush, so who does that?

This is done by the driver in interrupt context when an error interrupt 
is received. All transactions are posted and hw is reset.

> 
>> After the reset in error condition, the client can continue issuing 
>> new requests
>> with tx_submit and device_issue_pending as usual.



More information about the linux-arm-kernel mailing list