This thread has been locked.
If you have a related question, please click the "Ask a related question" button in the top right corner. The newly created question will be automatically linked to this question.
A too important number of CC2530 devices fail in the field - the system locks up for some reason. I can't use the usual flow.
After checking all options, it all boils down to generating the code with "Debug information for C-SPY" or not.
I tried disabling optimizations, etc. Strangely enough that option really does the trick.
I checked this by reading the flash contents from a failing device to a hex file which is then reload into the device before each partial flash update where NV memory and internals are protected from being overwritten (flash pages 120 and up (122 and up would in theory suffice)).
As soon as the "Debug information for C-SPY" is enabled, the misbehavior is gone.
At the same time it's a chicken and egg problem - I can't debug in detail when C-SPY is disabled, and the problem is gone when enabling C-SPY. It looks like a Heisenberg principle for embedded software.
Anyway, I would like to continue to automate HEX file generation.
I tried the "Extra Output" tab as well where the tickbox can be checked, but no '...a51' file is generated (the project name has been blanked out). That can not be selected when "With runtime control modules" is enabled, but as the screenshot shows, it still says "Secondary output: (None for the selected format). So it's probably an IDE corner case where the "Extra Output" can be configured even though it isn't really applicable.
The only alternative I see at this time is to program a device interactively, then read back the contents to a hex file, clean up that hex file and use it for programming other devices. That requires several manual interventions: program using the IAR IDE, read back using the Flash Programmer, and pd manually clean up (/eventually create a script for that).
Any other suggestion is welcome.
Extra Output setting:
Hi Mario,
I'm glad to hear that you've managed to resolve your issue. I do not have any insight to offer regarding how "Debug information for C-SPY" changes behavior or the ability to generate hex images with the d51 file. I recommend that you contact IAR for further insight to their Linker and avaialable options.
Regards,
Ryan
It seems that the last workspace settings were not saved an the a51 file is generated at the same time as the d51 file now.
I now need to validate that this hex file is ok with the NV flash contents ;-)..