Hi all
Here is a problem about the using of TCM.
I put two functions(they are just the same) of time-delay in the ITCM and the normal RAM, using the scatter file, and execute them one after another.
But at the end of func in ITCM, there is a PREFTECH abort(May it didn't execute fully at all).
During my boot.s, only ITCM bank0 was initialized:
MOV r9, #0x0
MCR p15, 0, r0, c9, c2, 0
LDR r0, =BASE_ITCM_BANK0 ;0xc20000
ORR r0, r0, #0x0D
MCR p15, 0, r0, c9, c1, 1
Here are the points that confused me:
1 why this prefetch abort happened ?
2 I wonder whether initialization of the ITCM_BANK0 is enough.
Sorry about my poor english T T, and thanks for your apply.
Hi Mr Harris:
Thanks for your reply.
What I have done about the TCM is just to check whether my ITCM works.
But I can not find another way to check it(there is no OS right now).
What's your suggestion?
Thanks a lot.
Ervin
Remap your TCM over a dead spot in your physical address map. If the code runs then the TCM is working.