Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[CI] Make SystemCommands take a StringBuilderBase to avoid extra stack usage #17984

Conversation

carol-apple
Copy link
Contributor

Problem

The SystemCommands::CreateCommonCommandArgs was taking a char buffer as an argument, creating a StringBuilder with the same buffer size, and then after forming the command, copying the string builder buffer to the input argument. This is inefficient and wastes stack space.

Change overview

  • Make SystemCommands::CreateCommonCommandArgs take a StringBuilderBase which is already initialized with the char buffer from the caller
  • This helps avoid the extra copy and char buffer

Testing

Verified that CI tests continue to pass

@github-actions
Copy link

github-actions bot commented May 3, 2022

PR #17984: Size comparison from 4d50b10 to e21cec2

Decreases (1 build for linux)
platform target config section 4d50b10 e21cec2 change % change
linux chip-tool-no-interactive-ipv6only arm64 (read only) 8818612 8818436 -176 -0.0
.text 6928564 6928388 -176 -0.0
Full report (25 builds for cc13x2_26x2, cyw30739, efr32, esp32, k32w, linux, mbed, nrfconnect, p6, telink)
platform target config section 4d50b10 e21cec2 change % change
cc13x2_26x2 all-clusters-app LP_CC2652R7 (read only) 688911 688911 0 0.0
(read/write) 163344 163344 0 0.0
.bss 75236 75236 0 0.0
.data 3400 3400 0 0.0
.rodata 102303 102303 0 0.0
.text 586124 586124 0 0.0
lock-ftd LP_CC2652R7 (read only) 676775 676775 0 0.0
(read/write) 166736 166736 0 0.0
.bss 73548 73548 0 0.0
.data 3224 3224 0 0.0
.rodata 94359 94359 0 0.0
.text 581936 581936 0 0.0
lock-mtd LP_CC2652R7 (read only) 625527 625527 0 0.0
(read/write) 146352 146352 0 0.0
.bss 69268 69268 0 0.0
.data 3224 3224 0 0.0
.rodata 94247 94247 0 0.0
.text 530792 530792 0 0.0
pump-app LP_CC2652R7 (read only) 661275 661275 0 0.0
(read/write) 183476 183476 0 0.0
.bss 73764 73764 0 0.0
.data 3256 3256 0 0.0
.rodata 80387 80387 0 0.0
.text 580404 580404 0 0.0
pump-controller-app LP_CC2652R7 (read only) 654171 654171 0 0.0
(read/write) 190380 190380 0 0.0
.bss 73820 73820 0 0.0
.data 3220 3220 0 0.0
.rodata 83323 83323 0 0.0
.text 570364 570364 0 0.0
cyw30739 light cyw930739m2evb_01 (read/write) 626370 626370 0 0.0
.app_xip_area 528904 528904 0 0.0
.bss 80116 80116 0 0.0
.data 696 696 0 0.0
.rodata 0 0 0 0.0
.text 0 0 0 0.0
lock cyw930739m2evb_01 (read/write) 625082 625082 0 0.0
.app_xip_area 529080 529080 0 0.0
.bss 78692 78692 0 0.0
.data 660 660 0 0.0
.rodata 0 0 0 0.0
.text 0 0 0 0.0
ota-requestor-no-progress-logging cyw930739m2evb_01 (read/write) 574218 574218 0 0.0
.app_xip_area 468596 468596 0 0.0
.bss 88016 88016 0 0.0
.data 572 572 0 0.0
.rodata 0 0 0 0.0
.text 112 112 0 0.0
efr32 lighting-app BRD4161A (read only) 908184 908184 0 0.0
(read/write) 134528 134528 0 0.0
.bss 132472 132472 0 0.0
.data 2052 2052 0 0.0
.text 908176 908176 0 0.0
BRD4161A+rpc (read only) 942544 942544 0 0.0
(read/write) 151208 151208 0 0.0
.bss 148952 148952 0 0.0
.data 2256 2256 0 0.0
.text 942536 942536 0 0.0
BRD4161A+rs911x (read only) 746564 746564 0 0.0
(read/write) 128752 128752 0 0.0
.bss 126772 126772 0 0.0
.data 1980 1980 0 0.0
.text 746556 746556 0 0.0
lock-app BRD4161A+wf200 (read only) 916560 916560 0 0.0
(read/write) 127540 127540 0 0.0
.bss 125604 125604 0 0.0
.data 1936 1936 0 0.0
.text 916552 916552 0 0.0
window-app BRD4161A (read only) 845432 845432 0 0.0
(read/write) 132616 132616 0 0.0
.bss 130648 130648 0 0.0
.data 1964 1964 0 0.0
.text 845424 845424 0 0.0
esp32 all-clusters-app c3devkit (read only) 999696 999696 0 0.0
(read/write) 1474506 1474506 0 0.0
.dram0.bss 68376 68376 0 0.0
.dram0.data 14428 14428 0 0.0
.flash.rodata 207248 207248 0 0.0
.flash.text 999696 999696 0 0.0
.iram0.text 62020 62020 0 0.0
m5stack (read only) 1054823 1054823 0 0.0
(read/write) 476936 476936 0 0.0
.dram0.bss 73896 73896 0 0.0
.dram0.data 34176 34176 0 0.0
.flash.rodata 237028 237028 0 0.0
.flash.text 1049439 1049439 0 0.0
.iram0.text 123107 123107 0 0.0
k32w light k32w061+release (read/write) 684236 684236 0 0.0
.bss 81320 81320 0 0.0
.data 2008 2008 0 0.0
.text 599204 599204 0 0.0
lock k32w061+release (read/write) 729052 729052 0 0.0
.bss 81744 81744 0 0.0
.data 1968 1968 0 0.0
.text 643636 643636 0 0.0
linux chip-tool-no-interactive-ipv6only arm64 (read only) 8818612 8818436 -176 -0.0
(read/write) 642641 642641 0 0.0
.bss 40913 40913 0 0.0
.data 1192 1192 0 0.0
.data.rel.ro 581752 581752 0 0.0
.dynamic 560 560 0 0.0
.got 14960 14960 0 0.0
.init 24 24 0 0.0
.init_array 184 184 0 0.0
.rodata 431540 431540 0 0.0
.text 6928564 6928388 -176 -0.0
thermostat-no-ble arm64 (read only) 2360964 2360964 0 0.0
(read/write) 174593 174593 0 0.0
.bss 86273 86273 0 0.0
.data 1496 1496 0 0.0
.data.rel.ro 79048 79048 0 0.0
.dynamic 560 560 0 0.0
.got 4736 4736 0 0.0
.init 24 24 0 0.0
.init_array 376 376 0 0.0
.rodata 145828 145828 0 0.0
.text 1985984 1985984 0 0.0
mbed lock-app CY8CPROTO_062_4343W+release (read only) 6224 6224 0 0.0
(read/write) 2418124 2418124 0 0.0
.bss 205884 205884 0 0.0
.data 5856 5856 0 0.0
.text 1380724 1380724 0 0.0
nrfconnect all-clusters-app nrf52840dk_nrf52840 (read/write) 1177707 1177707 0 0.0
bss 139600 139600 0 0.0
rodata 150804 150804 0 0.0
text 808644 808644 0 0.0
p6 all-clusters-app default (read/write) 2528592 2528592 0 0.0
.bss 139256 139256 0 0.0
.data 2792 2792 0 0.0
.text 1486856 1486856 0 0.0
light-app default (read/write) 2419192 2419192 0 0.0
.bss 132720 132720 0 0.0
.data 2592 2592 0 0.0
.text 1377456 1377456 0 0.0
lock-app default (read/write) 2428480 2428480 0 0.0
.bss 132544 132544 0 0.0
.data 2552 2552 0 0.0
.text 1386744 1386744 0 0.0
telink lighting-app tlsr9518adk80d (read/write) 804448 804448 0 0.0
bss 72232 72232 0 0.0
noinit 40416 40416 0 0.0
text 571272 571272 0 0.0

@bzbarsky-apple bzbarsky-apple merged commit 3131c14 into project-chip:master May 3, 2022
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants