We are planning to build a ROM mask + flash environment. That is the lower 32K code space will be mapping to ROM-mask and the upper 32K to flash. The lower 32K will check a function table in the upper 32k (flash). We we put drivers and basic APIs in the ROM-mask which serve as a library (and can't be changed after first release) By updating the flash (upper 32k), we can have different application.
we are planning to build several projects that share the same 32K ROM-mask source code (which is grouped by userclass) and have different application code. But the lower 32k are different.
Is there any solution??
For high-temperature solutions, ROM is still king. Flash memory retention times drops drastically with high temperature.
If all you need is low power consumption, then it would probably be easier to just look for a different processor. There are a lot of processors that will run very efficiently from a small button cell.
I'm normally using the Keil ARM tools, so you will have to look for help by someone else about how to set up a project. Just note that the linker must know that the fixed part is really fixed. If you just add the common code to the individual projects and compile, then the linker will assume that it may perform optimizations etc for all parts of the code. It is important that the linker knows that the 32kB are locked and that all it has access to is the call addresses. I think this was last discussed in a C51 thread within the last couple of weeks.