Reputation: 12653
I'm have an Arduino Uno R3. I'm making logical objects for each of my sensors using C++. The Arduino has very limited on-board memory 32KB*, and, on average, my compiled objects are coming out around 6KB*.
I am already using the smallest possible data types required, in an attempt to minimize my memory footprint. Is there a compiler flag to minimize the size of the binary, or do I need to use shorter variable and function names, less functions, etc. to minimize my code base?
Also, any other tips or words of advice for minimizing binary size would be appreciated.
*It may not be measured in KB (as I don't have it sitting in front of me), but 1 object is approximately 1/5 of my total memory size, which is prompting my concern.
Upvotes: 22
Views: 32291
Reputation: 5341
For debug where you want fast builds and good error messages, use -Og -g3 -fsanitize=address -fno-omit-frame-pointer -Wall -Werror
For production where you want the smallest fastest binaries:
-Os -fwrapv -fomit-frame-pointer -ffunction-sections -fdata-sections -fno-asynchronous-unwind-tables
, which are very safe. Separately add -Wl,--gc-sections -fwhole-program -s -Wl,--build-id=none
_only_ to the very last gcc step which links everything together. (If you added that to intermediary steps, things would fall apart and not work.)grep -rnwe throw -e catch
shows you use no exceptions, add -fno-exceptions
grep -rnwe dynamic_cast -e virtual
shows you use no virtual methods or dynamic_cast, add -fno-rtti
grep -rnwe errno -e virtual
shows you don't use errno, add -fno-math-errno
grep -rnwe std:
shows you don't use dynamic standard library methods (macro-like std such as std::max
are fine to use), add -nodefaultlibs -lc -lgcc_s
You should now have the smallest binary you can get for-free/minimal-effort.
Upvotes: 1
Reputation: 199
If your code does not contain c++-exception-handling you can save a lot of space (up to 30k after all optimize steps mentioned by Tuxdude).
Therefore you have to provide the following flag:
-fno-exceptions
But even if you don't use exceptions, the exception handling can be included! Check the following steps:
no usage of new, delete
. If you really need it replace them by malloc/free wrappers. For an example search for "tinynew.cpp"
provide function for pure virtual call, e.g.extern "C" void __cxa_pure_virtual() { while(1); }
Cheers Flo
Upvotes: 20
Reputation: 49583
There are lots of techniques to reduce binary size in addition to what us2012
and others mentioned in the comments, summing them up with some points of my own:
-Os
to make gcc/g++ optimize for size.-ffunction-sections -fdata-sections
to separate each function or data into distinct sections within the translation unit. Combine it with the linker option -Wl,--gc-sections
to get rid of any unreferenced sections.strip
with at least the following options: -s -R .comment -R .gnu.version
. It can be combined with --strip-unneeded
to remove all symbols that are not necessary for relocation processing.Upvotes: 50