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

[BDX][Darwin] Add basic BDX protocol supports for Matter.framework #21161

Merged
merged 3 commits into from
Jul 25, 2022

Conversation

vivien-apple
Copy link
Contributor

Problem

This PR add an early BDX protocol support to Matter.framework.

It can be validated, with the pre condition that chip-ota-requestor-app has been commissioned onto the darwin-framework-tool fabric:

# Shell 1
./out/debug/standalone/chip-ota-requestor-app --discriminator 3840 --secured-device-port 5560 --KVS /tmp/chip_kvs_requestor --otaDownloadPath /tmp/test.bin
#Shell 2
# Creates an OTA image file
echo "Test" > /tmp/my-fw.bin # Or any other biffer content that will fit onto multiple queries...
./src/app/ota_image_tool.py create -v 0xFFF1 -p 0x8001 -vn 10 -vs "1.0.0" -da sha256 "/tmp/my-fw.bin" "/tmp/my-fw.ota"

# Creates a json file listing all the available OTA image files
echo '{
    "deviceSoftwareVersionModel": [
        {
            "vendorId": 65521,
            "productId": 32769,
            "softwareVersion": 10,
            "softwareVersionString": "1.0.0",
            "cDVersionNumber": 18,
            "softwareVersionValid": true,
            "minApplicableSoftwareVersion": 0,
            "maxApplicableSoftwareVersion": 100,
            "otaURL": "/tmp/my-fw.ota"
        }
    ]
}' > /tmp/updates.json
 

$ ./out/debug/standalone/darwin-framework-tool interactive start
# Once in interactive mode
otasoftwareupdateapp candidate-file-path /tmp/updates.json
otasoftwareupdateapp set-consent-status granted
otasoftwareupdaterequestor announce-ota-provider 0x54FDA4CA5275DB40 0 0 0 0x12344321 0

Most of the BDX work is handle internally into the framework while only some methods to let the application returns the OTA image file, and the OTA image block are exposed.

/**
 * Notify the delegate when a BDX Session starts
 *
 */
- (void)handleBDXTransferSessionBegin:(NSString * _Nonnull)fileDesignator
                               offset:(NSNumber * _Nonnull)offset
                    completionHandler:(void (^)(NSError * error))completionHandler;

/**
 * Notify the delegate when a BDX Session ends
 *
 */
- (void)handleBDXTransferSessionEnd:(NSError * _Nullable)error;

/**
 * Notify the delegate when a BDX Query message has been received
 *
 */
- (void)handleBDXQuery:(NSNumber * _Nonnull)blockSize
            blockIndex:(NSNumber * _Nonnull)blockIndex
           bytesToSkip:(NSNumber * _Nonnull)bytesToSkip
     completionHandler:(void (^)(NSData * _Nullable data, BOOL isEOF))completionHandler;

There is still more work to do, such as handling MaxLength, exposing some bdx configuration properties to the delegate, enhance the mechanism used to select if bdx protocol should be used or not, ...

Change overview

  • Register an handler for the BDX protocol for the Matter.framework
  • Add some delegate methods for this BDX protocol handler.
  • Fix some documentation typos

Testing

See description.

@github-actions
Copy link

github-actions bot commented Jul 25, 2022

PR #21161: Size comparison from 2557f51 to 42ccf5e

Increases (4 builds for cc13x2_26x2, esp32, telink)
platform target config section 2557f51 42ccf5e change % change
cc13x2_26x2 all-clusters-minimal-app LP_CC2652R7 (read only) 634055 634063 8 0.0
.text 556140 556148 8 0.0
lock-ftd LP_CC2652R7 (read/write) 169916 169924 8 0.0
esp32 all-clusters-app c3devkit (read only) 1022010 1022012 2 0.0
.flash.text 1022010 1022012 2 0.0
telink light-switch-app tlsr9518adk80d text 567212 567214 2 0.0
Decreases (2 builds for cc13x2_26x2, nrfconnect)
platform target config section 2557f51 42ccf5e change % change
cc13x2_26x2 lock-ftd LP_CC2652R7 (read only) 671603 671595 -8 -0.0
.text 594672 594664 -8 -0.0
nrfconnect all-clusters-minimal-app nrf52840dk_nrf52840 text 801968 801964 -4 -0.0
Full report (32 builds for bl602, cc13x2_26x2, cyw30739, efr32, esp32, k32w, linux, mbed, nrfconnect, p6, telink)
platform target config section 2557f51 42ccf5e change % change
bl602 lighting-app bl602 (read/write) 1380786 1380786 0 0.0
.bss 117474 117474 0 0.0
.data 4480 4480 0 0.0
.text 1050916 1050916 0 0.0
bl602+rpc (read/write) 1426194 1426194 0 0.0
.bss 124922 124922 0 0.0
.data 4600 4600 0 0.0
.text 1082572 1082572 0 0.0
cc13x2_26x2 all-clusters-app LP_CC2652R7 (read only) 668463 668463 0 0.0
(read/write) 182880 182880 0 0.0
.bss 74236 74236 0 0.0
.data 3356 3356 0 0.0
.rodata 88367 88367 0 0.0
.text 579780 579780 0 0.0
all-clusters-minimal-app LP_CC2652R7 (read only) 634055 634063 8 0.0
(read/write) 157804 157804 0 0.0
.bss 73532 73532 0 0.0
.data 3356 3356 0 0.0
.rodata 77591 77591 0 0.0
.text 556140 556148 8 0.0
lock-ftd LP_CC2652R7 (read only) 671603 671595 -8 -0.0
(read/write) 169916 169924 8 0.0
.bss 71300 71300 0 0.0
.data 3280 3280 0 0.0
.rodata 76451 76451 0 0.0
.text 594672 594664 -8 -0.0
lock-mtd LP_CC2652R7 (read only) 653847 653847 0 0.0
(read/write) 183360 183360 0 0.0
.bss 66988 66988 0 0.0
.data 3280 3280 0 0.0
.rodata 101167 101167 0 0.0
.text 552200 552200 0 0.0
pump-app LP_CC2652R7 (read only) 681295 681295 0 0.0
(read/write) 161080 161080 0 0.0
.bss 71388 71388 0 0.0
.data 3280 3280 0 0.0
.rodata 89207 89207 0 0.0
.text 591604 591604 0 0.0
pump-controller-app LP_CC2652R7 (read only) 667039 667039 0 0.0
(read/write) 175456 175456 0 0.0
.bss 71508 71508 0 0.0
.data 3276 3276 0 0.0
.rodata 85039 85039 0 0.0
.text 581520 581520 0 0.0
shell LP_CC2652R7 (read only) 660954 660954 0 0.0
(read/write) 185892 185892 0 0.0
.bss 76540 76540 0 0.0
.data 3360 3360 0 0.0
.rodata 85146 85146 0 0.0
.text 575492 575492 0 0.0
cyw30739 light cyw930739m2evb_01 (read/write) 582042 582042 0 0.0
.app_xip_area 460432 460432 0 0.0
.bss 64404 64404 0 0.0
.data 716 716 0 0.0
.rodata 0 0 0 0.0
.text 112 112 0 0.0
lock cyw930739m2evb_01 (read/write) 587942 587942 0 0.0
.app_xip_area 461604 461604 0 0.0
.bss 69132 69132 0 0.0
.data 720 720 0 0.0
.rodata 0 0 0 0.0
.text 112 112 0 0.0
ota-requestor-no-progress-logging cyw930739m2evb_01 (read/write) 586494 586494 0 0.0
.app_xip_area 465732 465732 0 0.0
.bss 63612 63612 0 0.0
.data 660 660 0 0.0
.rodata 0 0 0 0.0
.text 112 112 0 0.0
efr32 lighting-app BRD4161A (read/write) 1087672 1087672 0 0.0
.bss 133220 133220 0 0.0
.data 2048 2048 0 0.0
.text 952384 952384 0 0.0
BRD4161A+rpc (read/write) 1141964 1141964 0 0.0
.bss 149892 149892 0 0.0
.data 2260 2260 0 0.0
.text 989788 989788 0 0.0
BRD4161A+rs911x (read/write) 952172 952172 0 0.0
.bss 140928 140928 0 0.0
.data 2048 2048 0 0.0
.text 809176 809176 0 0.0
lock-app BRD4161A+wf200 (read/write) 1128424 1128424 0 0.0
.bss 144304 144304 0 0.0
.data 2056 2056 0 0.0
.text 982044 982044 0 0.0
window-app BRD4161A (read/write) 1081156 1081156 0 0.0
.bss 134692 134692 0 0.0
.data 2076 2076 0 0.0
.text 944368 944368 0 0.0
esp32 all-clusters-app c3devkit (read only) 1022010 1022012 2 0.0
(read/write) 1486554 1486554 0 0.0
.dram0.bss 70232 70232 0 0.0
.dram0.data 14600 14600 0 0.0
.flash.rodata 216280 216280 0 0.0
.flash.text 1022010 1022012 2 0.0
.iram0.text 62902 62902 0 0.0
m5stack (read only) 1075799 1075799 0 0.0
(read/write) 488552 488552 0 0.0
.dram0.bss 75752 75752 0 0.0
.dram0.data 34144 34144 0 0.0
.flash.rodata 246660 246660 0 0.0
.flash.text 1070415 1070415 0 0.0
.iram0.text 123267 123267 0 0.0
k32w light k32w0+release (read/write) 641520 641520 0 0.0
.bss 69696 69696 0 0.0
.data 2028 2028 0 0.0
.text 567068 567068 0 0.0
lock k32w0+release (read/write) 698880 698880 0 0.0
.bss 70144 70144 0 0.0
.data 2036 2036 0 0.0
.text 623972 623972 0 0.0
linux chip-tool-ipv6only arm64 (read only) 9793452 9793452 0 0.0
(read/write) 680401 680401 0 0.0
.bss 32833 32833 0 0.0
.data 3272 3272 0 0.0
.data.rel.ro 625776 625776 0 0.0
.dynamic 560 560 0 0.0
.got 13560 13560 0 0.0
.init 24 24 0 0.0
.init_array 192 192 0 0.0
.rodata 458556 458556 0 0.0
.text 7748244 7748244 0 0.0
thermostat-no-ble arm64 (read only) 2341916 2341916 0 0.0
(read/write) 141249 141249 0 0.0
.bss 55233 55233 0 0.0
.data 1672 1672 0 0.0
.data.rel.ro 75592 75592 0 0.0
.dynamic 560 560 0 0.0
.got 4984 4984 0 0.0
.init 24 24 0 0.0
.init_array 400 400 0 0.0
.rodata 139572 139572 0 0.0
.text 1965536 1965536 0 0.0
mbed lock-app CY8CPROTO_062_4343W+release (read only) 6224 6224 0 0.0
(read/write) 2449240 2449240 0 0.0
.bss 214444 214444 0 0.0
.data 5872 5872 0 0.0
.text 1411884 1411884 0 0.0
nrfconnect all-clusters-app nrf52840dk_nrf52840 (read/write) 1177259 1177259 0 0.0
bss 143068 143068 0 0.0
rodata 142676 142676 0 0.0
text 812656 812656 0 0.0
all-clusters-minimal-app nrf52840dk_nrf52840 (read/write) 1157311 1157311 0 0.0
bss 142304 142304 0 0.0
rodata 134208 134208 0 0.0
text 801968 801964 -4 -0.0
p6 all-clusters-app default (read only) 881632 881632 0 0.0
(read/write) 1686780 1686780 0 0.0
.bss 149064 149064 0 0.0
.data 2648 2648 0 0.0
.text 1526680 1526680 0 0.0
all-clusters-minimal-app default (read only) 882352 882352 0 0.0
(read/write) 1630876 1630876 0 0.0
.bss 148344 148344 0 0.0
.data 2648 2648 0 0.0
.text 1471496 1471496 0 0.0
light-app default (read only) 890656 890656 0 0.0
(read/write) 1550972 1550972 0 0.0
.bss 140248 140248 0 0.0
.data 2440 2440 0 0.0
.text 1399896 1399896 0 0.0
lock-app default (read only) 886184 886184 0 0.0
(read/write) 1588564 1588564 0 0.0
.bss 144704 144704 0 0.0
.data 2456 2456 0 0.0
.text 1433016 1433016 0 0.0
telink light-switch-app tlsr9518adk80d (read/write) 799620 799620 0 0.0
bss 70744 70744 0 0.0
noinit 40416 40416 0 0.0
text 567212 567214 2 0.0
lighting-app tlsr9518adk80d (read/write) 819688 819688 0 0.0
bss 71588 71588 0 0.0
noinit 40416 40416 0 0.0
text 583752 583752 0 0.0

Copy link
Contributor

@krypton36 krypton36 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is awesome! Thank you for adding it to darwin-framework-tool!

Copy link
Contributor

@woody-apple woody-apple left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Fast tracking platform changes

@woody-apple woody-apple merged commit 5f0453c into project-chip:master Jul 25, 2022
github-actions bot pushed a commit that referenced this pull request Jul 25, 2022
…21161)

* [darwin-framework-tool] Do not exit from interactive mode if the file passed as argument to the command otasoftwareupdateapp candidate-file-path contains errors

* [documentation] Fix some typos in the documentation of the bdx protocol

* [BDX][Darwin] Add basic BDX protocol supports for Matter.framework
woody-apple added a commit that referenced this pull request Jul 25, 2022
…21161) (#21178)

* [darwin-framework-tool] Do not exit from interactive mode if the file passed as argument to the command otasoftwareupdateapp candidate-file-path contains errors

* [documentation] Fix some typos in the documentation of the bdx protocol

* [BDX][Darwin] Add basic BDX protocol supports for Matter.framework

Co-authored-by: Vivien Nicolas <[email protected]>
isiu-apple pushed a commit to isiu-apple/connectedhomeip that referenced this pull request Sep 16, 2022
…roject-chip#21161)

* [darwin-framework-tool] Do not exit from interactive mode if the file passed as argument to the command otasoftwareupdateapp candidate-file-path contains errors

* [documentation] Fix some typos in the documentation of the bdx protocol

* [BDX][Darwin] Add basic BDX protocol supports for Matter.framework
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.

3 participants