Hello,
one years ago i wrote my own bootloader for Nucleo-L432KC and everything works OK. Now I am changing the board to Bluepill with 128 kB flash and i trying modify the bootloader for this board, but without success:
(I am using the online compiler )
In bootloader I have this settings:
target device is Nucleo-F103RB (it was recommended in forum, because the same flash size as on Bluepill)
in main code I changed only seqence of writing to flash (because F103 has 4 bytes page, L432 has 8 bytes page)
POST_APPLICATION_ADDR will be 0x08009000 here I have got the error message from compiler, that POST_APPLICATION_ADDR is not defined
→ I have enable the the bootloader in targets.json by parameter “bootloader_supported”: true and the error message disappeared
when the bootloader is finished i call the main program mbed_start_application(POST_APPLICATION_ADDR);
the bootloader starts and works without problem - I am able to upload main program into flash, but the main program will not start
when I checked the flash memory by ST-LINK it looks OK - the bootloader is from 0x08000000 to 0x00007A90, then few FF
the main program is uploaded from 0x00009000
I also compare the bin files with memory and it is uploaded without error
Have you any idea, what I am doing wrong?? How to solve it?
My feeling is that maybe - mbed_start_application(POST_APPLICATION_ADDR) don’t jump to the main program, but why?
or the main program isn’t compiled with mbed_app_start parameter (because when I upload the same main program compiled with same parameter “target.mbed_app_start”: “0x08009000” into flash memory from address 0x08000000 it works fine )
When building the bootloader .bin file, are you sure that POST_APPLICATION_ADDR = 0x08009000 and that that address is passed on when making call to the mbed_start_application function?
when I checked the flash memory by ST-LINK it looks OK - the bootloader is from 0x08000000 to 0x00007A90, then few FF
the main program is uploaded from 0x00009000
I assume that 0x00007A90 and 0x00009000 are typos (should be 0x08007A90 and 0x08009000).
I would recommend to follow the bootloader documentation for Creating the main program which suggests the following:
To create an application using a bootloader, you must first have created the bootloader binary and added it to the current project. You must then specify the bootloader image in mbed_app.json in the target_overrides section:
When a build occurs, the application builds for the address immediately after the bootloader. The build system does this automatically by defining the symbols MBED_APP_START and MBED_APP_SIZEin the linker script ( .sct , .ld or .icf ).
At the end of building, the build image is automatically combined with the bootloader to create the final image. Note: When building offline, the original uncombined image is in the same directory <project-name>_application.bin .
It defines the symbols APPLICATION_ADDR , APPLICATION_SIZE , BOOTLOADER_ADDR and BOOTLOADER_SIZE .
Dear Zoltan,
thank you very much for your feedback.
Yes you are right, there are typos in my text. The bootloader is uploaded from 0x08000000 to 0x08007A90 , then few FF and the main program is from 0x08009000.
I have checked the bootloader documentation. I don’t need the " path to padded bootloader binary" because I don’t generate the one file which including the bootloader and the main app. I am generating two separate bin files: bootloader and mainapp. The reason is that we have few versions of main app - our bootloader is uploaded on every board as a standard and the main application is uploaded by this bootloader later - based on the customer’s request.
I have two question, which can help me maybe…
regarding my change in targets.json
when the “bootloader_supported”: false than compiler don’t give me the POST_APPLICATION_ADDR to my bootloader despite in json_app is define ```
target.restrict_size": "0x00009000
when the “bootloader_supported”: true it is without error message (and I have also tested to define it directly in bootloader #define POST_APPLICATION_ADDR 0x8009000, but with the same result)
when the main application is compiled with mbed_app.json parameter target.mbed_app_start": "0x08009000 I am expecting that the vector will be moved and it can run only if is uploaded in flash from 0x08009000. Is it normal that this bin file runs correctly if I cleared flash and uploaded it by ST-link directly from addr 0x08000000 ?
when the “bootloader_supported”: true it is without error message (and I have also tested to define it directly in bootloader #define POST_APPLICATION_ADDR 0x8009000, but with the same result)
I think you should set “bootloader_supported”: true. My guess is that the bootloader is trying to start the application but because it is not built correctly it fails.
Is it normal that this bin file runs correctly if I cleared flash and uploaded it by ST-link directly from addr 0x08000000 ?
No, that is not normal. It indicates that the linker built the application program assuming that it will be loaded at the 0x08000000 address.
I don’t need the " path to padded bootloader binary" because I don’t generate the one file which including the bootloader and the main app. I am generating two separate bin files: bootloader and mainapp.
I think your bootloader binary is correct. But to build the second binary file (the application program binary) correctly you should follow the bootloader documentation as explained above. Then two binaries will be created. One binary will contain the bootloader plus the application program (you dont need this file). But the other one will contain only the application program linked in a way that it will run correctly when loaded at the 0x08009000 address (however, it won’t run correctly when loaded at 0x08000000).
It seems that the mbed-os/targets/TARGET_STM/TARGET_STM32F1/TARGET_NUCLEO_F103RB/device/TOOLCHAIN_GCC_ARM/STM32F103XB.ld linker file (or the mbed-os/targets/TARGET_STM/TARGET_STM32F1/TARGET_NUCLEO_F103RB/device/TOOLCHAIN_ARM/stm32f103xb.sct in case you the ARM toolchain rather that the GCC ARM) is not adapted for bootloader builds (the MBED_APP_START and MBED_APP_SIZE symbols are not used). To fix that for the GCC ARM toolchaing modify the STM32F103XB.ld as follows:
Dear Zoltan,
thank you very much. I have made few tests and I was sure that the problem isn’t in my code, but somewhere in setting. I will test your recommendation during the weekend and I will inform you…
Thank you once again for you excellent support and help.