Creating binary with Bootloader and application

cancel
Showing results for 
Show  only  | Search instead for 
Did you mean: 

Creating binary with Bootloader and application

Jump to solution
968 Views
pejo
Contributor I

Hi,

I'm developing a booloader for an LPC550X board. The bootloader should at a certain point in the code start the application. This application should be allocated in the flash memory at a fixed address. 

I'd like some help to create a binary, which we can flash to the board and which contains both binaries (bootloader and application).

 

Any ideas where to start?

Thank you!

Labels (1)
0 Kudos
Reply
1 Solution
926 Views
frank_m
Senior Contributor III

Yes, objcopy would work, too.
As a starter, here a link to a tutorial regarding this topic.
https://mcuoneclipse.com/2017/03/29/mcuxpresso-ide-s-record-intel-hex-and-binary-files/

> I've seen that with objcopy I can teoretically convert ELF to SRC Format but what I don't fully understand is how to tell to the resulting file that the BL should be in a given position in the FLASH and the Application in another position.

The S19 (SREC) and Intel HEX format contain both addresses and data.
These are basically human-readable text format files, that define both that target address and the data.
Since BL and application are in different sectors and thus different addresses, they don't interfere.
https://en.wikipedia.org/wiki/SREC_(file_format)

Although you might need to restrict yourself with the syntactically possible combinations of SREC/HEX files, because some flashing tools are poorly written in this regard.
While allowed by the SREC file format definition, I dealt with flashing tools that expected a fixed input line length, a fixed address size, and only ascending addresses.
The mentioned SRecord tool could deal with all this requirements.

View solution in original post

0 Kudos
Reply
7 Replies
933 Views
frank_m
Senior Contributor III

I would recommend using SREC/S19 or HEX files instead.

Since the BL and the application are in different sectors, both files would be easy to merge.
Occasionally I have even done so manually, i.e. copied the data contents of the BL into the SREC file of the application. Of course one need to consider structure and syntax of the S19 file format.

My company often used the "srec_cat" tool to join both in a post-build step.
This tool is part of the free "SRecord" package, which you will easily find with a search engine.

0 Kudos
Reply
928 Views
pejo
Contributor I

hi Frank,

thank you for your message. I'm unfortunately not very experienced with this platform. By default I'm creating ELF files after compilation from the console (or AXF from the MCUXpresso IDE). Is the SRC Format compatible with the ARM/Cortex M33 architecture? 

I've seen that with objcopy I can teoretically convert ELF to SRC Format but what I don't fully understand is how to tell to the resulting file that the BL should be in a given position in the FLASH and the Application in another position.

0 Kudos
Reply
927 Views
frank_m
Senior Contributor III

Yes, objcopy would work, too.
As a starter, here a link to a tutorial regarding this topic.
https://mcuoneclipse.com/2017/03/29/mcuxpresso-ide-s-record-intel-hex-and-binary-files/

> I've seen that with objcopy I can teoretically convert ELF to SRC Format but what I don't fully understand is how to tell to the resulting file that the BL should be in a given position in the FLASH and the Application in another position.

The S19 (SREC) and Intel HEX format contain both addresses and data.
These are basically human-readable text format files, that define both that target address and the data.
Since BL and application are in different sectors and thus different addresses, they don't interfere.
https://en.wikipedia.org/wiki/SREC_(file_format)

Although you might need to restrict yourself with the syntactically possible combinations of SREC/HEX files, because some flashing tools are poorly written in this regard.
While allowed by the SREC file format definition, I dealt with flashing tools that expected a fixed input line length, a fixed address size, and only ascending addresses.
The mentioned SRecord tool could deal with all this requirements.

0 Kudos
Reply
821 Views
pejo
Contributor I

Hi Frank,

I've tested it and flashed it to the board and it worked nicely. Thank you a lot !

Summary of operations:

* [srec_cat] Convert Application binary ->intel hex format with srec_cat

* [srec_cat] Convert intel hex Application to hex with offset 

* [objcopy] Create bootloader elf-> bootloader hex file

* [srec_cat] Merge hex files (Application hex file with offset + bootloader hex file)

* [srec_cat] Create final binary from merged intel hex file

0 Kudos
Reply
920 Views
pejo
Contributor I

hi Frank,

thank you a lot for the info. I'll try it next week and let you know what we find out and whether it worked. Have a nice WE.

0 Kudos
Reply
951 Views
Pavel_Hernandez
NXP TechSupport
NXP TechSupport

Hello, my name is Pavel and I will be supporting your case, maybe this tool is what are you looking for, with BLHOST you can send the command to write a certain region of the flash.

blhost -p COMxx write-memory 0x0 root.bin (for the bootloader)

blhost -p COMxx write-memory 0x6000 root.bin (for the image)

the command needs to modify the regions only for example.

To use the BLHOST I recommend install the SPSDK.

Installation Guide — SPSDK documentation

0 Kudos
Reply
930 Views
pejo
Contributor I

Thank you Pavel but what I'm trying to do is to create a binary containing both BL and Application which I can flash N times, not to flash BL and Application directly to the MCU (which is very useful indeed)

0 Kudos
Reply