Hi,all
If the RAM resource of S32K312 running autosar is not enough and the program dies, Is there any good way to solve the problem?
There are ways we can think of
1. Directly define functions and variables to TCM for execution. This involves modifying the startup file and remapping variables and functions to the specified address
2, it is best to directly turn TCM into RAM. We read about it in the S32K3 Memories Guide, but that chapter is for dual-core. I don't know if the single core S32K312 can also be set to RAM, is there anything to pay attention to?
已解决! 转到解答。
Hi,
Yes, TCM can be used as system RAM. In case of S32K312 no configuration is necessary. Mentioned section says something different:
It makes accessible TCM of disabled core. S32K312 is single core device which is running all the time, so this section does not apply here.
There’s no mechanism which would force variables to another section while current section is full. This is up to user. You need to force selected objects to new section explicitly.
Regards,
Lukas
Hi,
Yes, TCM can be used as system RAM. In case of S32K312 no configuration is necessary. Mentioned section says something different:
It makes accessible TCM of disabled core. S32K312 is single core device which is running all the time, so this section does not apply here.
There’s no mechanism which would force variables to another section while current section is full. This is up to user. You need to force selected objects to new section explicitly.
Regards,
Lukas
In case of Autosar, please create new ticket here:
https://support.nxp.com/s/?language=en_US
Maybe there's better way but I'm not sure, this is out of my scope.
Regards,
Lukas
Hi,
I was posting a similar question.
I also checkout this post:
https://community.nxp.com/t5/S32K/Would-you-share-the-s32k3-RTOS-sample-code-for-refer/m-p/1457368#M...
And download the code, but it is not helping.
I need to configure the TCM as system RAM, as according to the Reference Manual.
I tried some configuration but with no luck...in the AN13388 is contained some code. Particularly:
// Example 5. TCM Configured as System RAM
/********************************** START TCM_Configured as System RAM *****************************/
MC_ME->PRTN2_COFB1_CLKEN |= MC_ME_PRTN2_COFB1_CLKEN_REQ62(1); /* PRTN2_COFB1_CLKEN_[REQ62] = 1 */
/* Enable clock for TCM for CM7_0 */
MC_ME->PRTN2_COFB1_CLKEN |= MC_ME_PRTN2_COFB1_CLKEN_REQ63(1); /* PRTN2_COFB1_CLKEN_[REQ63] = 1 */
/* Enable clock for TCM for CM7_1 */
DCM_GPR->DCMRWF4 |= DCM_GPR_DCMRWF4_cm7_0_cpuwait(1); /* DCMRWF4[CM7_0_CPUWAIT] = 1 */
/* Wait Mode for CM7_0 */
DCM_GPR->DCMRWF4 |= DCM_GPR_DCMRWF4_cm7_1_cpuwait(1); /* DCMRWF4[CM7_1_CPUWAIT] = 1 */
/* Wait Mode for CM7_1 */
MC_ME->PRTN0_CORE0_PCONF |= MC_ME_PRTN0_CORE0_PCONF_CCE(1); /* PRTN0_CORE0_PCONF[CCE] = 1 */
/* Enable Clock for CM7_0 */
MC_ME->PRTN0_CORE1_PCONF |= MC_ME_PRTN0_CORE1_PCONF_CCE(1); /* PRTN0_CORE1_PCONF[CCE] = 1 */
/* Enable Clock for CM7_1 */
/********************************** END TCM_Configured as System RAM *******************************/
But this is not for a S32K31x. My question:
1. Is it possible to configure TCM as system RAM with a monocore micro?
2. Is there a demo or a tutorial for that? The Reference manual provide a general description for it.
Hi, ValTek
Thank you very much for sharing, I have a very bad guess
1. Using TCM as system RAM only allows DMA, EMAC, HSE and other masters to access. (otherwise Kernel-specific access only)
2, As we imagine the way: TCM as extended RAM, when the compiler allocated RAM resources insufficient, automatically allocate part of the data to the TCM address. This method is impossible to implement. If this idea can be realized, can you provide some information?
3. When RAM resources run low, we can only manually add __attribute__ ((section(") "). .dtcm0_code") Load some resources into TCM? Or is there a better way?
Hi Xian,
we are discussing same topics this days. Same bad guess...
My comments regarding your list:
1. My idea is to use HSE in TCM, since I'm close to sys ram limit now (so it could be ok);
2. Totally agree with you: this method is impossible to implement, no idea how this could work. What about the stack also? Is at the end of sys ram. We need clarification from NXP;
3. Same as my doubt. If I need to add the section attributes for all the code, it will be a nightmare...
I'm looking for a demo code that could provide TCM capability examples