S
sx107
So, I am making a USB MSC firmware updater bootloader for STM32H750. The problem is that this microcontroller can only erase it's flash memory entirely to rewrite it later, so the bootloader and all currently running code will be erased.
My idea to solve this problem is to put everything into RAM from flash and run the code from there. So, I've succesfully copied all code from FLASH to RAM, modified the vector table, and ran the code from RAM. The problem then was that all functions were actually running from flash, because the jump addresses weren't modified.
I've recompiled the code then as position-independent (-fPIC flag). Functions then started running from the RAM, but global variables don't work now - every usage of them puts me in HardFault. I think it happens because of the memory offset between flash and RAM: the code tries to use the same offset while the code is in ram, putting all global variables outside the memory space.
I am using stm32cubeide.
My idea to solve this problem is to put everything into RAM from flash and run the code from there. So, I've succesfully copied all code from FLASH to RAM, modified the vector table, and ran the code from RAM. The problem then was that all functions were actually running from flash, because the jump addresses weren't modified.
I've recompiled the code then as position-independent (-fPIC flag). Functions then started running from the RAM, but global variables don't work now - every usage of them puts me in HardFault. I think it happens because of the memory offset between flash and RAM: the code tries to use the same offset while the code is in ram, putting all global variables outside the memory space.
- Am I right in my assumption of what happens?
- If I am - how do I make jump addresses position independent, but variable addresses - still absolute?
- Perhaps, an easier solution is to make all functions "RAM Functions" - they work exactly as I need - stored initially in FLASH, then copied to RAM and afterwards they run from there. But how do I make everything .RamFunc without putting proper attribute in front of every single function manually?
I am using stm32cubeide.