Hello,
I am trying to reconfigure my project to have global data placement in the SDRAM, I am using mx rt 1020 board. I define XIP_BOOT_HEADER_DCD_ENABLE = 1 and SKIP_SYSCLK_INIT and the project compiles just fine and I can see that global variables are placed in the SDRAM. I also configure the MCU settings as in the picture below:
And my configurations for the linker script page:
I am able to begin running the program. The problem is that the program halts when I lpi2c_rtos_init is called within BOARD_InitPeripherals. Specifically, when it tries to generate mutex / allocate memory. The program gets stuck in the xTaskResumeAll function since the function call doesn't match the previous call to vTaskSuspendAll. I am obviously missing something in my configurations, but am having a hard time figuring out exactly what that could be.
I have tried following other forum posts such as this one
and this one
But neither of these posts have helped solve my specific issue.
I have been able to successfully initialize the lpi2c rtos interface by reconfiguring the heap and stack placement to SRAM_ITC or to SRAM_DTC, however this causes task creation to fail later in the program. I am assuming that the memory configurations for freeRTOS are expecting something different than what I am giving them.
Another thing that I've thought could be the problem is defining SKIP_SYSCLK_INIT, since the peripherals use the system PLL along with semc, but I find this unlikely.
I was hoping someone could give me some direction on where to begin looking, or what could possibly be causing the issue. I'm very new to this sort of programming and appreciate any help.
已解决! 转到解答。
Hi @tbtbtbt ,
This problem may caused by SDRAM cache feature. You'd better put heap in noncacheable area. You can assign part of SDRAM space to be noncacheable in BOARD_ConfigMPU().
Regards,
Jing
Hi @tbtbtbt ,
This problem may caused by SDRAM cache feature. You'd better put heap in noncacheable area. You can assign part of SDRAM space to be noncacheable in BOARD_ConfigMPU().
Regards,
Jing
