-
Notifications
You must be signed in to change notification settings - Fork 13.3k
New issue
Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? # to your account
Avoid float-double-conversion #7559
Conversation
|
Converting floats to doubles is very expensive on esp8266, so prefer calculations or comparisons as float. This saves 10% (20 bytes) of the String::parseFloat() code size and probably quite a bit of runtime overhead.
@d-a-v thats just initialization, which seems to be handled fine by the compiler. anyway, fixed, thanks! |
Can you please build an example that uses these calls w/ and w/o this change so we can measure the code differences and report the full flash usage (i.e. the IROM/IRAM/BSS/DATA block at the end of build) |
so there are examples that use the code, but they're not run in the ci checks. no idea why :-( Here's what I did to reproduce: add a (nonsensical) usage: --- a/libraries/esp8266/examples/TestEspApi/TestEspApi.ino
+++ b/libraries/esp8266/examples/TestEspApi/TestEspApi.ino
@@ -242,6 +242,7 @@ void setup() {
// messages are also readable.
Serial.begin(74880);
+ Serial.parseFloat();
// Try pushing frequency to 160MHz.
system_update_cpu_freq(SYS_CPU_160MHZ); then build it: $ pio ci ./libraries/esp8266/examples/TestEspApi --board nodemcuv2
...
RAM: [=== ] 33.9% (used 27752 bytes from 81920 bytes)
Flash: [=== ] 25.5% (used 265836 bytes from 1044464 bytes)
.pio/build/nodemcuv2/firmware.elf :
section size addr
.data 1248 1073643520
.noinit 4 1073644768
.text 232 1074790400
.irom0.text 236132 1075843088
.text1 26656 1074790632
.rodata 1568 1073644784
.bss 24936 1073646352
.comment 5065 0 then I applied the patch to ~/.platformio/packages/framework-arduinoespressif8266/cores/esp8266/Stream.cpp $ pio ci ./libraries/esp8266/examples/TestEspApi --board nodemcuv2
...
RAM: [=== ] 33.9% (used 27752 bytes from 81920 bytes)
Flash: [=== ] 25.4% (used 265804 bytes from 1044464 bytes)
.pio/build/nodemcuv2/firmware.elf :
section size addr
.data 1248 1073643520
.noinit 4 1073644768
.text 232 1074790400
.irom0.text 236100 1075843088
.text1 26656 1074790632
.rodata 1568 1073644784
.bss 24936 1073646352
|
* master: (299 commits) Fix error message typo (esp8266#7581) Update certs-from-mozilla.py (esp8266#7578) Update DigestAuthorization.ino (Simple example update) (esp8266#7579) Fix gzip+signed OTA error (esp8266#7577) Properly replace toolchain in PlatformIO CI script (esp8266#7580) Update certs-from-mozilla.py (esp8266#7573) Fixup weird combination of oneline/multi line comments (esp8266#7566) Reduce codesize of setOutputPower (esp8266#7572) Fix typos in tests Force gcc inlining, use same style for getCycleCount as for getCpuFreqMHz. Even more concise #if form. Inline, fewer LOC, remove redundant definition in cpp. Netump Initial commit (esp8266#7527) Delete owner field (esp8266#7563) Avoid float-double-conversion (esp8266#7559) Use direct member initialization instead of ctr initialisation (esp8266#7556) Add CI test for eboot build (esp8266#7546) getCpuFreqMHz(): fix when F_CPU is not defined (esp8266#7554) emulation-on-host makefile update, allowing to pass more options (esp8266#7552) add sdk options to "generic esp8285 module" (esp8266#7550) ...
Converting floats to doubles is very expensive on esp8266, so prefer
calculations or comparisons as float. This saves 10% (20 bytes) of the
String::parseFloat() code size and probably quite a bit of runtime
overhead.