[PATCH v5 4/5] dma: mmp_pdma: add support for residue reporting

Vinod Koul vinod.koul at intel.com
Fri Sep 13 00:51:35 EDT 2013


On Tue, Sep 10, 2013 at 05:46:19PM +0200, Daniel Mack wrote:
> Hi Vinod,
> 
> Sorry for the late response, I've been on vacations.
> 
> On 25.08.2013 18:33, Vinod Koul wrote:
> > On Wed, Aug 21, 2013 at 02:08:57PM +0200, Daniel Mack wrote:
> >> In order to report the channel's residue, we walk the list of running
> >> descriptors, look for those which match the cookie, and then try to find
> >> the descriptor which defines upper and lower boundaries that embrace the
> >> current transport pointer.
> > 
> >>
> >> +		/*
> >> +		 * 'passed' will be latched once we found the descriptor which
> >> +		 * lies inside the boundaries of the curr pointer. All
> >> +		 * descriptors that occur in the list _after_ we found that
> >> +		 * partially handled descriptor are still to be processed and
> >> +		 * are hence added to the residual bytes counter.
> >> +		 */
> > do you have multiple descriptors for one transaction? Should be No.
> 
> Sure, that can be the case. One transaction could span across multiple
> descriptors, especially if its overall length exceeds the maximum length
> of one descriptor.
Yes and these addiional descriptor for a transacation should be child
descriptors. 
The child descriptors should have ->parent point to parent descriptor and ->next
to next in the chain of children.

> > The cookie is assigned to a transaction when it is submitted. so when you see
> > descriptor cookie is less than completed one, then it already completed and
> > should not be in pending list.
> 
> Hmm, what about an integer overrun?
The cookie needs to wrapped to 1. If you use virtual dma code then it would be
done. Since the variable is 32bit, i dont think you will have so many eonding
trasaction so i havent seen any concerns on that.

~Vinod

-- 



More information about the linux-arm-kernel mailing list