How to create a HEX file for LPC43 for internal flash memory that can be used with FlashMagic?
The standard hex file that's created starts at address 0x00000000 therefore when downloaded into the chip does not make a working program.
The common solution when needing download files with checksums is to add a post-build step in the project. Then write a tiny program that computes the checksum.
Either read the hex file, modify it with a checksum and save.
Or potentially use Keil's tool to convert your data to binary if you find it easier to work with raw binary data.
Keil's linker can't know if a specific boot loader for a specific platform might have special needs besides the actual binary data that forms the program. Especially since lost of customers writes their own boot loaders with totally own requirements. So the checksum might use CRC-32, CRC-64, MD5, SHA-1, Adler-32, ... And there are many ways a checksum can be stored. Should it be first in the file. Or last in the file. Just after the end of the actual code. Or in the last bytes of the internal flash of a chip. Stored big-endian? Little-endian? In binary form? In hex form? uu-encoded? And maybe that little checksum record is also expected to store a magic number to signify the intended platform, so firmware for hardware revision 1 can't be accidentally downloaded into hardware revision 2. And there might be a need to store a firmware version and potentially a build date in that meta-information record.
So in the end - customer-supplied build-steps are a great route to fulfill special bootloader needs.
Wow - first time in a long time I get text-based Captcha. So Keil staff has - in my view incorrectly - assumed that text-based captcha will solve the spam issues. Captcha is a great way to waste our time. But not a good solution to avoid spam. Why should we users have to suffer, because Keil can't invest the time and use real accounts?
The solution is first to run this $K\ARM\BIN\ELFDWT.EXE !L BASEADDRESS(0x1A000000) Which is needed anyway.
Then this $K\ARM\ARMCC\bin\fromelf --i32 --output=name1.hex name2.axf
That fixed the problem.
Of course the automatic HEX generation needs to be disabled.
BTW, I think LP43 is a great micro that deserves much better documentation. It's really hard to start working with it.