iMX RT1021 TCM and OCRAM allocation and issue

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

iMX RT1021 TCM and OCRAM allocation and issue

ソリューションへジャンプ
1,605件の閲覧回数
harikrishnan_ch
Contributor II

Scenario:

  • We have design, where firmware utilizes only IRAM.
  • Our usage was within 128Kb utilizing 2 TCM banks (64K each).
  • We have expanded the design and RAM usage increased above 128Kb.
  • We had enabled OCRAM (128Kb)  in scatter loader file.
  • .map file looks normal and memory is allotted.
  • We are using standard MPU configuration given in example. ( is cached has play here? )

Issue:

Application starts misbehaving when large memory buffer is allocated with new scatter loader file.

Some of the functionalities partially fail, like File system, network etc.

 

I have attached  map file generated with and without large buffer allocated in the program.

Like to have suggestion on, what I am missing here and root cause for the issue.

Thanks.

ラベル(1)
0 件の賞賛
返信
1 解決策
1,312件の閲覧回数
diego_charles
NXP TechSupport
NXP TechSupport

Hi @harikrishnan_ch 

My apologies for the delayed response and thank you for providing additional information. 

By looking at your scatter file it seems that you are using LWIp stack, but what I do not know how is the large buffer related to the stack or how interacts with your application, so I could not reproduce your issue. Could you replicate this on a much simpler environment? 

Let me know if you found something else that we could consider during this time. 

Best regards, 

Diego

元の投稿で解決策を見る

0 件の賞賛
返信
6 返答(返信)
1,575件の閲覧回数
diego_charles
NXP TechSupport
NXP TechSupport

Hi @harikrishnan_ch 

I understood, that you where first using the ITCM and DTMC ( 64 KB each) for your application. But then you also required the OCRAM ( 128 KB), so you started to use this memory.

I have the i.MX RT1020 to work and SDK examples. Are you able to point me how I could replicate your issue with using an  SDK example as an starting point? 

Are you using KEIL or IAR? What is your current SDK version?

Cache could sometimes have an implication on system, application performance. 

Best regards, 

Diego

 

0 件の賞賛
返信
1,407件の閲覧回数
harikrishnan_ch
Contributor II

Hello Deigo, 

Do you have any update on recreation of issue? 

thanks 

haric

0 件の賞賛
返信
1,571件の閲覧回数
harikrishnan_ch
Contributor II

Hello Deigo, 

But , after reading a bit of data sheet  and memory related application note. 

I disabled only Data Cache in code. 

/* Enable I cache and D cache */
//SCB_EnableDCache();
SCB_EnableICache();

Now the system functions properly. I do not see and un usual behaviour of program.

Still, I like to knwo the root cause and why controller memory access behaves in such manner.

thanks and regards

haric

1,313件の閲覧回数
diego_charles
NXP TechSupport
NXP TechSupport

Hi @harikrishnan_ch 

My apologies for the delayed response and thank you for providing additional information. 

By looking at your scatter file it seems that you are using LWIp stack, but what I do not know how is the large buffer related to the stack or how interacts with your application, so I could not reproduce your issue. Could you replicate this on a much simpler environment? 

Let me know if you found something else that we could consider during this time. 

Best regards, 

Diego

0 件の賞賛
返信
981件の閲覧回数
harikrishnan_ch
Contributor II

I bellevue we have found solution. 

Let us close this case. Currently system is stable andmemory allocation is fine with fix i had made. 

Further memory allocations are carefully monitored.

1,573件の閲覧回数
harikrishnan_ch
Contributor II

Hello Diego,

I use Keil and SDK version in reference with Keil is MIMXRT1021_DFP 12.1.0. 

SDK is older version 

I had attached .map file, there you could find typical use case where memory usage can be seen. 

based on that you could create a test scenario.

harikrishnan_ch_0-1714725485435.png

harikrishnan_ch_1-1714726069479.png

 

thanks and regards

haric

0 件の賞賛
返信