I have following question about code banking. There's some small tests, that uses one big library. So, how can I put this library to different code banks? Ofc, I can include this tests right in library project, but are there any other solutions?
"Which is exactly why it's a bad idea to fight the linker over where the best place for each object module is."
Assuming that the linker knows the precise details of every relevant detail of the hardware configuration.
The linker makes decisions based upon information it has available to it and the rules it has been programmed to use. If detail is missing, then the result may not be the optimum.
Sometimes, little hints about placement can help - Especially with an architecture like the '51.
As always, the key is understanding of the hardware and tools.
Indeed - and code banking is always a fight against the fundamental limitations of the architecture.
The fight might have been worth it years ago when there was little alternative - but, nowadays, why not just use an architecture which doesn't impose these restrictions in the first place??!
Surely that depends upon the intra-bank call overhead and the hardware logic used for bank selection?
Only in just how bad, exactly, the effect is.
Calling a (library) function contained within the same bank does not require that overhead and could therefore have a significant speed advantage.
Which is exactly why it's a bad idea to fight the linker over where the best place for each object module is.
"There's nothing to be gained from forcing its code into a particular bank."
Your question is based on rather complete misunderstanding of what a library is for. There's nothing to be gained from forcing its code into a particular bank.
For example, create 3 libraries for 3 differents banks, just like .h00, .h01 etc. But I don't know is it possible in keil
View all questions in Keil forum