This discussion has been locked.
You can no longer post new replies to this discussion. If you have a question you can start a new discussion

Cache maintenance and DMA

Greetings ARM community,

I have been tasked with cache maintenance.  The necessity popped up because of DMA issues on USB.

As a quick (not perm solution) I used the invalidate all routine.  While obviously not nominal in anyway

it does allow me to continue with USB tasks.

This is the assy for that. Pretty common example from the Cortex R4 and ARM ARM.

                MRC p15, 0, r0, c1, c0, 0 ; Read System Control Register configuration data

                DSB 0x0f

                MCR p15, 0, r0, c15, c5, 0 ; Invalidate entire data cache

                ISB 0x0f

                BX lr

                ENDFUNC

Moving forward I am trying to implement the invalidation by MVA to PoC and having no luck. This is my first go at this so it more than likely my misunderstanding which command to use.

If I can ask; which invalidate by MVA should I be using?  Is their a paper or section of the document arm arm to point it out?

The memory is configured as write-through.

I am going to experiment more with the other MVA to UoC but I want to gain a better understanding of this.

  • It'll depend on exactly what you're doing.  Given that you're interacting with a DMA, I would expect you use one of the operations to PoC (Point of Coherency).  That would be DCCMVAC (clean), DCIMVAC (invalidate) or DCCIMVAC (clean & invalidate).

    Getting the correct barriers in place for cache maintenance routines can be tricky.  If it's something your unfamiliar with I'd recommend reading the Barrier Litmus Tests appendix of the ARM Architecture Reference Manual.

  • Thanks for the recommendation Martin, I will do that. 

  • After reading the litmus tests I thought I had a better understanding but still no progress.

    I can get DCIMVAC to work "sometimes" which indicates, to me, a timing issue. 

    Sometimes meaning after a couple retries commands go but it still causes a stall.

    I have a feeling that I do not understand the address that is passed to me and how it relates to DCIMVAC.

    I receive an address and a size, I have a loop that does operations adding linesize to line on every iteration.

    Also, I have seen references that use DSB and some as in the documentation even in the litmus test for DMA operations it says

    DCIMVAC

    DMB

    So for now I am stuck.