icache problems in I.MX RT1021

キャンセル
次の結果を表示 
表示  限定  | 次の代わりに検索 
もしかして: 

icache problems in I.MX RT1021

ソリューションへジャンプ
1,489件の閲覧回数
nda
Contributor III

Hello. I've never used MPU and cache before, so i dont know how to solve problem. 

I'am working with LPSPI and receiving data form external flash: 

base->TCR |= LPSPI_TCR_TXMSK(isTxMask); // start transmission

while (!(base->SR & LPSPI_SR_FCF_MASK)) {}; // waiting for frame transfer has completed
this code doesnot work properly. Some times it works and some time it doesnot. It hangs and i cant even stop the debugger. If i disable icache before waiting it works, but delays are significant. 

This works:

base->TCR |= LPSPI_TCR_TXMSK(isTxMask);

if (SCB_CCR_IC_Msk == (SCB_CCR_IC_Msk & SCB->CCR)){SCB_DisableICache();}
while (!(base->SR & LPSPI_SR_FCF_MASK)) {};
SCB_EnableICache();

Does anybody can explain me, what i am doing wrong?

ラベル(1)
0 件の賞賛
返信
1 解決策
1,474件の閲覧回数
nda
Contributor III

Thank you Crist for your answer.

Your advice does not help.  

I dont know why simple while loop does not work somtimes. Looking for another flag helped me:

while (!(base->SR & LPSPI_SR_RDF_MASK)) {};

 

元の投稿で解決策を見る

0 件の賞賛
返信
2 返答(返信)
1,476件の閲覧回数
crist_xu
NXP Employee
NXP Employee

Hi, 

    I saw that you said: "If i disable icache before waiting it works, but delays are significant."  Does this mean if you add a delay loop,

also can fix your issue? if that, i think that you can test __DSB() __ISB() instead, without the SCB_DisableIcache();

 

Regards,

       Crist

0 件の賞賛
返信
1,475件の閲覧回数
nda
Contributor III

Thank you Crist for your answer.

Your advice does not help.  

I dont know why simple while loop does not work somtimes. Looking for another flag helped me:

while (!(base->SR & LPSPI_SR_RDF_MASK)) {};

 

0 件の賞賛
返信