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.
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.