Skip to content
  • MySensors
  • OpenHardware.io
  • Categories
  • Recent
  • Tags
  • Popular
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
Brand Logo
  1. Home
  2. General Discussion
  3. Over the air updates

Over the air updates

Scheduled Pinned Locked Moved General Discussion
87 Posts 15 Posters 50.4k Views 12 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • Z Offline
    Z Offline
    Zeph
    Hero Member
    wrote on last edited by Zeph
    #34

    OK, maybe we are converging in some ways. I'll try to list the similarities as well as differences.

    So we agree that a "node type" doesn't mean a generic "termperature node" but a very specific "my sketch for controlling an 18b20 on pin 7".

    Let's suppose the sketch was called "DevDuino_18b20_7.ino" (for the moment let's leave out auto-scripting).
    This compiled into DevDuino_18b20_7.hex and the binary equivalent.

    We would know that nodes 7, 12, and 15 should have the latest version of this sketch. (node 4 might also measure temperature but with different hardware or pin configuration, so it would not use this sketch).

    If we just want to update the sketch, we would send copies of the new binary to nodes 7, 12, and 15.

    So far I think we are on nearly the same page, at the generic level described. Where the "push by node" and "pull by node type" models differ is in where the knowledge that nodes 7, 12, and 15 run the same code resides. In push-by-node, the Server knows that it should send the same code to them; in the "pull by node type" model, those three nodes themselves know they want updates for a given numeric "node type".

    Also, each node knows it has a given version of the firmware of its node type, and decides when to upgrade by comparing that with what the server offers.

    The differences are highlighted better when we make more than a version update.

    Suppose we decide to make use of pin 2 of node 7 to control an LED. At this point we need to load different firmware into node 7, and we write a sketch called "DevDuino_18b20_7_LED_2.ino". (forgive the naming, it's an example). So now we want to change the overall system configuration so that the server will load DevDuino_18b20_7_LED_2.hex into node 7. (Nodes 12 and 15 still have the other sketch without LED control and maybe always will, the new sketch is not a new version of the old sketch)

    I am suggesting that all you have to do is create the new sketch (or rather it's hex or binary compiled form) and configure the server to send that to node 7 instead of the previous sketch. It doesn't matter one bit to the node whether it's switching to a completely new sketch versus a new version of the current sketch. That's in the server logic only, not OTA.

    I think you are saying that your node.js server can accomodate changing what sketch (not just version) runs in each node, because it can load arbitrarily different (or identical) binary files to each node by node id, with no limitations based on what "type" that node used to be, right? Or not?

    In my thinking, the node has no need to know that it's running "node type 453, version 16".

    The server is free to conceptually organize firmwares by "node type" and "version" if it wishes, but those concepts do not need to be pushed down to the node level.

    Pull by node type:

     Node: I'm type 453, what is the latest version of 453?
     Server: Queries database for max version of node type 453, and say "Latest 453 version is 17"
     Node: Checks that it has version 16, asks server to send 453 ver 17 for OTA programming
     Server: sends version requested by node
     (programming done)
     Node: ask server for lastest version for node type 453
     Server: ... 17
     Node: I'm version 17, no change needed
    

    Push by node:

    Node: I'm node 7 and my PROGMEM signature if 0x54FE
    Server: My config says node 7 should have the latest DevDuino_18b120_7_LED_7.hex" with Sig 0x3EE5
    Server: Please load the following binary into your PROGMEM (sends appropriate version)
    (programming done)
    Node: I'm node 7 and my PROGMEM sig is 0x3EE5
    Server: Mark that one as updated
    

    Notice that there's no problem of forgetting to update the version number - if the signature (eg: CRC or hash) in PROGMEM isn't what the server wants there, then it starts an OTA programming session, period. Even if the sig was wrong because the programming had a glitch rather than because it is out of date, the server knows it's wrong and sends again.

    In the push-by-node model, the system is not limited to "updating all nodes with node type 453 versions <= 16 to version 17" -- it can load an entirely different sketch (node type 763 version 0 if the server thinks in those terms) into the node if it wishes. And the node doesn't care, it doesn't need to know what "node type" it is or compare versions (that's in the logic of the server), all the node needs to know is that the server wants it to load some code into PROGMEM, period.

    That's how I imagine things working. As I have understood you, you are pushing the concept of "node type" and "version number" and the comparison of version numbers down to the node itself, rather than letting the server handle that (if it chooses). I don't see the advantage of that; the server seems a more logical place for that information - both simpler and more flexible.

    Your node.js implementation might organize source code for nodes by numeric "node type" (where your node type 7 isn't the same as my node type 7) and by version within node type. That would still be supported by "push by node" model.

    But another server might choose to organize firmwares by string filename plus signature (eg; CRC). It's configured with a simple table of node_id,filename. It computes the signature of the binary file to be compared with that the node reports it has in PROGMEM. There's no numeric "node type" or "version number" needed. (If you really want to also keep obsolete versions of the binary firmware on the server, there are easy workarounds fore that too). The config is dead simple: (NodeID, Filename)* Or optionally (nodelist, Filename)* if you want to reduce the number of times you spell out the filename. Use the latest (or only) copy of the given filename.

    The cool thing about the "push by node" approach is that the same node bootloader can easily accomodate both server approaches (node type # + version # OR nodeID->filename) - since the only concepts the node uses are

    • "I can tell you the signature of what I have in PROGMEM now", and
    • "If you tell me to I'll load something of your choice".

    For OTA bootloading the node doesn't know need to know or care about "node type" numbers or versions, nor about file names or date stamps.

    So I'm not trying to eliminate your concept of the server of assigning numeric ID's to each combination of sensors and pins, and using ordered versions numbers within each "version type". I just don't see why those concepts need to also be pushed down into the node and OTA bootloader protocol. With the "push by node" model, there''s more flexibility to organize changing firmwares in the server as you prefer OR in other ways, with no meaningful cost, because the node end of the OTA programming system has been distilled to just the essence that it really needs to understand, leaving higher levels of management as a server-internal affair.

    1 Reply Last reply
    0
    • T ToSa

      Really really nice project !!!

      I worked on a similar setup about two years ago with different RF modules but didn't finish. Now I was about to restart and realized that the nRF24 modules are waaaaay less expensive. I just started adjusting the old code for the nRF24 modules I ordered when I found this great project. The raspberry PI for me is the way to go as I own two sitting almost idle and don't own a Vera.

      The one feature I'm missing after reading through the majority of the available documentation is over the air updates of the sensor node software. As this is one of the features I completed for my old design, I'll go ahead and try to port the bootloader and the RPi based state-less firmware server to work with the protocol and routing implemented here... if successful I'll post the results.

      If you worked already on over the air updates or you know somebody who did, please let me know and I'll focus my efforts on something else :-)

      Tobias

      DammeD Offline
      DammeD Offline
      Damme
      Code Contributor
      wrote on last edited by
      #35

      @ToSa I've been looking through the ota bootloader and noticed there are alot of uint16_t wich can be replaced with uint8_t.. saves 128bytes of code. Still needs ~900bytes less until 1024 words bootloader though but is makes more space for other stuff :)

      T 1 Reply Last reply
      0
      • J Offline
        J Offline
        JeJ
        wrote on last edited by
        #36

        When i'm trying to run the NodeJsController.js script i always end up with "Error: Cannot open /dev/ttyAMA0"

        I'm running a RPi with a serial gateway.

        Any ideas?

        1 Reply Last reply
        0
        • M Offline
          M Offline
          mikeones
          wrote on last edited by
          #37

          On my RPi, the serial gateway is detected as dev/ttyUSB0.

          1 Reply Last reply
          0
          • T ToSa

            Really really nice project !!!

            I worked on a similar setup about two years ago with different RF modules but didn't finish. Now I was about to restart and realized that the nRF24 modules are waaaaay less expensive. I just started adjusting the old code for the nRF24 modules I ordered when I found this great project. The raspberry PI for me is the way to go as I own two sitting almost idle and don't own a Vera.

            The one feature I'm missing after reading through the majority of the available documentation is over the air updates of the sensor node software. As this is one of the features I completed for my old design, I'll go ahead and try to port the bootloader and the RPi based state-less firmware server to work with the protocol and routing implemented here... if successful I'll post the results.

            If you worked already on over the air updates or you know somebody who did, please let me know and I'll focus my efforts on something else :-)

            Tobias

            DammeD Offline
            DammeD Offline
            Damme
            Code Contributor
            wrote on last edited by Damme
            #38

            @ToSa I've been working on getting OTA to work with MQTTgateway with some success.

            But I do have problem with some packages missing and I think the communication should be something like this;
            bootloader checks id and version and server said there is an update. (no change from today)
            but then:

            [bootloader] 0000 has CHK FF(just filler in first package) REQ 0000 type 01 version 01
            [server] load 0000 from hex, send addr 0000 0C9428030C9447240C9474240C947605 C7
            [bootloader] 0000 has CHK FF, REQ 0010 type 01 version 01
            [server] (checksum mismatch) send addr 0000 0C9428030C9447240C9474240C947605 C7
            [bootloader] 0000 has CHK C7, REQ 0010 type 01 version 01
            [server] load 0010 from hex send addr 0010 0C94A3050C94D0050C9480100C945003 00
            And so on.. :)

            what do you think about this? the total package is 32bytes, mysensors header is 7bytes. and this layout would need 19 bytes from server to bootloader..
            I Have also seen some intel hex that is not in order 0010 0020 0030 etc but it could jump address. I do not think arduino ide does this but you never know..

            EDIT:
            I havn't read this one yet but I guess there is alot of good stuff in it :)
            http://www.nordicsemi.com/eng/nordic/download_resource/10878/2/94069421

            Z T 2 Replies Last reply
            0
            • T Offline
              T Offline
              ToSa
              Code Contributor
              wrote on last edited by
              #39

              @JeJ @mikeones : how is your serial gateway connected? using a USB-Rs232 cable or via the GPIO pins on the RPi? Did you check the Readme.md in the NodeJsController directory?

              M J 2 Replies Last reply
              0
              • DammeD Damme

                @ToSa I've been working on getting OTA to work with MQTTgateway with some success.

                But I do have problem with some packages missing and I think the communication should be something like this;
                bootloader checks id and version and server said there is an update. (no change from today)
                but then:

                [bootloader] 0000 has CHK FF(just filler in first package) REQ 0000 type 01 version 01
                [server] load 0000 from hex, send addr 0000 0C9428030C9447240C9474240C947605 C7
                [bootloader] 0000 has CHK FF, REQ 0010 type 01 version 01
                [server] (checksum mismatch) send addr 0000 0C9428030C9447240C9474240C947605 C7
                [bootloader] 0000 has CHK C7, REQ 0010 type 01 version 01
                [server] load 0010 from hex send addr 0010 0C94A3050C94D0050C9480100C945003 00
                And so on.. :)

                what do you think about this? the total package is 32bytes, mysensors header is 7bytes. and this layout would need 19 bytes from server to bootloader..
                I Have also seen some intel hex that is not in order 0010 0020 0030 etc but it could jump address. I do not think arduino ide does this but you never know..

                EDIT:
                I havn't read this one yet but I guess there is alot of good stuff in it :)
                http://www.nordicsemi.com/eng/nordic/download_resource/10878/2/94069421

                Z Offline
                Z Offline
                Zeph
                Hero Member
                wrote on last edited by
                #40

                @Damme said:

                what do you think about this? the total package is 32bytes, mysensors header is 7bytes. and this layout would need 19 bytes from server to bootloader..

                16 bit offset, 16 data bytes, one byte checksum, right?

                I Have also seen some intel hex that is not in order 0010 0020 0030 etc but it could jump address. I do not think arduino ide does this but you never know..

                I see that your descriptions say "0010 from hex" etc, but I thought you would be fetching from a binary blob to satisfy requests from the bootloader. As in:

                Server reads the Intel hex and uses it to fill in an array of bytes. (one time, or each time a given file is requested)
                Server sends requested 16 byte chunks of that array to bootloader
                

                In that case, it doesn't matter what order the original hex lines are in, or even if they are 16 or 32 bytes wide (or less than 16 bytes at the end).

                DammeD 1 Reply Last reply
                0
                • Z Zeph

                  @Damme said:

                  what do you think about this? the total package is 32bytes, mysensors header is 7bytes. and this layout would need 19 bytes from server to bootloader..

                  16 bit offset, 16 data bytes, one byte checksum, right?

                  I Have also seen some intel hex that is not in order 0010 0020 0030 etc but it could jump address. I do not think arduino ide does this but you never know..

                  I see that your descriptions say "0010 from hex" etc, but I thought you would be fetching from a binary blob to satisfy requests from the bootloader. As in:

                  Server reads the Intel hex and uses it to fill in an array of bytes. (one time, or each time a given file is requested)
                  Server sends requested 16 byte chunks of that array to bootloader
                  

                  In that case, it doesn't matter what order the original hex lines are in, or even if they are 16 or 32 bytes wide (or less than 16 bytes at the end).

                  DammeD Offline
                  DammeD Offline
                  Damme
                  Code Contributor
                  wrote on last edited by Damme
                  #41

                  @Zeph true (array) and Yes, so the node can request same address twice (might be a timeout) and verify checksum on every 16byte data.

                  1 Reply Last reply
                  0
                  • DammeD Damme

                    @ToSa I've been working on getting OTA to work with MQTTgateway with some success.

                    But I do have problem with some packages missing and I think the communication should be something like this;
                    bootloader checks id and version and server said there is an update. (no change from today)
                    but then:

                    [bootloader] 0000 has CHK FF(just filler in first package) REQ 0000 type 01 version 01
                    [server] load 0000 from hex, send addr 0000 0C9428030C9447240C9474240C947605 C7
                    [bootloader] 0000 has CHK FF, REQ 0010 type 01 version 01
                    [server] (checksum mismatch) send addr 0000 0C9428030C9447240C9474240C947605 C7
                    [bootloader] 0000 has CHK C7, REQ 0010 type 01 version 01
                    [server] load 0010 from hex send addr 0010 0C94A3050C94D0050C9480100C945003 00
                    And so on.. :)

                    what do you think about this? the total package is 32bytes, mysensors header is 7bytes. and this layout would need 19 bytes from server to bootloader..
                    I Have also seen some intel hex that is not in order 0010 0020 0030 etc but it could jump address. I do not think arduino ide does this but you never know..

                    EDIT:
                    I havn't read this one yet but I guess there is alot of good stuff in it :)
                    http://www.nordicsemi.com/eng/nordic/download_resource/10878/2/94069421

                    T Offline
                    T Offline
                    ToSa
                    Code Contributor
                    wrote on last edited by ToSa
                    #42

                    @Damme said:

                    @ToSa I've been working on getting OTA to work with MQTTgateway with some success.

                    great!

                    [bootloader] 0000 has CHK FF(just filler in first package) REQ 0000 type 01 version 01
                    [server] load 0000 from hex, send addr 0000 0C9428030C9447240C9474240C947605 C7
                    [bootloader] 0000 has CHK FF, REQ 0010 type 01 version 01
                    [server] (checksum mismatch) send addr 0000 0C9428030C9447240C9474240C947605 C7
                    [bootloader] 0000 has CHK C7, REQ 0010 type 01 version 01
                    [server] load 0010 from hex send addr 0010 0C94A3050C94D0050C9480100C945003 00
                    And so on.. :)

                    what do you think about this? the total package is 32bytes, mysensors header is 7bytes. and this layout would need 19 bytes from server to bootloader..

                    If I understand correctly you would send the CRC of the previous bloak back to the server together with the request for the next package - the server would then send the next block if the CRC is correct or resend the previous block if the CRC is not ok...
                    I'm wondering how the bootloader would ever run into that situation. The package itself is checksum'ed already and wouldn't be treated as correctly received package if the checksum is incorrect. Only if the previous block was received correctly the next block is requested. If that doesn't happen within a given amount of time the same block is requested again.
                    Can you explain a bit further what issues you are running into?

                    @Damme said:

                    I Have also seen some intel hex that is not in order 0010 0020 0030 etc but it could jump address. I do not think arduino ide does this but you never know..

                    Yes, I've seen that as well - actually Codebender does that sometimes and the "HEX file loader" function on the NodeJsController would need to be adjusted to address that (I'm not reading from the .hex file when a package arrives but from a byte array in Mongo)
                    Probably the best approach for this one would be to add the next address the bootloader should request to the previous package (e.g. "here is the data for 0x0000 - next request should be for 0x0010) and allow for variable block length because that's another one where Codebender sometimes uses <16 byte rows in the hex (not just at the end). The code on the bootloader side would get a little more complex as the flash is still written in pages and these might not line-up anymore with the 16byte blocks.

                    @Damme said:

                    I havn't read this one yet but I guess there is alot of good stuff in it :)
                    http://www.nordicsemi.com/eng/nordic/download_resource/10878/2/94069421

                    That chip is a totally different animal - same RF but 8051 MCU. I'll have a look at the AppNote tomorrow.

                    1 Reply Last reply
                    0
                    • DammeD Damme

                      @ToSa I've been looking through the ota bootloader and noticed there are alot of uint16_t wich can be replaced with uint8_t.. saves 128bytes of code. Still needs ~900bytes less until 1024 words bootloader though but is makes more space for other stuff :)

                      T Offline
                      T Offline
                      ToSa
                      Code Contributor
                      wrote on last edited by ToSa
                      #43

                      @Damme said:

                      @ToSa I've been looking through the ota bootloader and noticed there are alot of uint16_t wich can be replaced with uint8_t.. saves 128bytes of code. Still needs ~900bytes less until 1024 words bootloader though but is makes more space for other stuff :)

                      I'll have a look. I've taken the code from an earlier project and adjusted to MySensors - didn't review the variable types that much. I'm using CRC16 as well where CRC8 might be sufficient...

                      EDIT: got it down a little from 0x0E18 to 0x0DD0 (72 bytes) changing a few loop counters from uint16 to uint8. I don't want to change type to 8bit looking at the large amount of sensors people are asking for / working on. FOr version I'm planning to keep some of these running for a long time with as little maintenance as possible. With some software improvements over time and minor version changes during development 16bit for version seems to be the better fit as well.

                      Z 1 Reply Last reply
                      1
                      • T ToSa

                        @JeJ @mikeones : how is your serial gateway connected? using a USB-Rs232 cable or via the GPIO pins on the RPi? Did you check the Readme.md in the NodeJsController directory?

                        M Offline
                        M Offline
                        mikeones
                        wrote on last edited by
                        #44

                        @ToSa I use a Mini-B USB cable between my PRi and my gateway.

                        T 1 Reply Last reply
                        0
                        • M mikeones

                          @ToSa I use a Mini-B USB cable between my PRi and my gateway.

                          T Offline
                          T Offline
                          ToSa
                          Code Contributor
                          wrote on last edited by
                          #45

                          @mikeones said:

                          dev/ttyUSB0

                          Then /dev/ttyUSB0 is correct. /dev/ttyAMA0 would only be valid for the on-board serial port on the GPIO pinheads.
                          Are you running into any issues once you set the port in NodeJsGateway accordingly?

                          1 Reply Last reply
                          0
                          • T ToSa

                            @JeJ @mikeones : how is your serial gateway connected? using a USB-Rs232 cable or via the GPIO pins on the RPi? Did you check the Readme.md in the NodeJsController directory?

                            J Offline
                            J Offline
                            JeJ
                            wrote on last edited by
                            #46

                            @ToSa I have my gateway connected via the GPIO and i have followed the steps in the Readme.md.
                            I will try to use a USB-Rs232 cable and see what happens.

                            T 1 Reply Last reply
                            0
                            • J JeJ

                              @ToSa I have my gateway connected via the GPIO and i have followed the steps in the Readme.md.
                              I will try to use a USB-Rs232 cable and see what happens.

                              T Offline
                              T Offline
                              ToSa
                              Code Contributor
                              wrote on last edited by
                              #47

                              @JeJ one potential reason is that the port is already in use. I mentioned somewhere that the startup script doesn't yet stop the NodeJsController correctly. Maybe you already have a NodeJsController process running? Try "sudo killall node" and then try starting it again. To check if the port itself is working you can try to open a simple terminal (minicom etc.) and reset the gateway.

                              1 Reply Last reply
                              0
                              • T ToSa

                                @Damme said:

                                @ToSa I've been looking through the ota bootloader and noticed there are alot of uint16_t wich can be replaced with uint8_t.. saves 128bytes of code. Still needs ~900bytes less until 1024 words bootloader though but is makes more space for other stuff :)

                                I'll have a look. I've taken the code from an earlier project and adjusted to MySensors - didn't review the variable types that much. I'm using CRC16 as well where CRC8 might be sufficient...

                                EDIT: got it down a little from 0x0E18 to 0x0DD0 (72 bytes) changing a few loop counters from uint16 to uint8. I don't want to change type to 8bit looking at the large amount of sensors people are asking for / working on. FOr version I'm planning to keep some of these running for a long time with as little maintenance as possible. With some software improvements over time and minor version changes during development 16bit for version seems to be the better fit as well.

                                Z Offline
                                Z Offline
                                Zeph
                                Hero Member
                                wrote on last edited by
                                #48

                                @ToSa said:

                                With some software improvements over time and minor version changes during development 16bit for version seems to be the better fit as well.

                                Hmm. That seems like overkill, if I'm understanding correctly. (So maybe I am not understanding).

                                What I heard was:

                                Each sensactuator node has a "node type" and a "version" within that node type. Each combination of sensors and pin assignments has a unique "node type" (within a given wireless network). A node can only be OTA updated to a newer (higher) version of the same "node type" of the current firmware, and all nodes of that "node type" will be updated.

                                And extra byte for "version" isn't a big deal tho.

                                Will there be one or two bytes for "node type"?

                                DammeD T 2 Replies Last reply
                                0
                                • Z Zeph

                                  @ToSa said:

                                  With some software improvements over time and minor version changes during development 16bit for version seems to be the better fit as well.

                                  Hmm. That seems like overkill, if I'm understanding correctly. (So maybe I am not understanding).

                                  What I heard was:

                                  Each sensactuator node has a "node type" and a "version" within that node type. Each combination of sensors and pin assignments has a unique "node type" (within a given wireless network). A node can only be OTA updated to a newer (higher) version of the same "node type" of the current firmware, and all nodes of that "node type" will be updated.

                                  And extra byte for "version" isn't a big deal tho.

                                  Will there be one or two bytes for "node type"?

                                  DammeD Offline
                                  DammeD Offline
                                  Damme
                                  Code Contributor
                                  wrote on last edited by
                                  #49

                                  @Zeph 16bit calculations on a 8bit mcu will always come to a price. Imo I think we should try to keep things to 8bit as much as possible. but I dont know if its possible to shred another 900bytes out of the bootloader to fit in one less size of space (1024 words instead of 2048 words). Might be if we make a mini version of mysensors/mymessage

                                  1 Reply Last reply
                                  0
                                  • Z Zeph

                                    @ToSa said:

                                    With some software improvements over time and minor version changes during development 16bit for version seems to be the better fit as well.

                                    Hmm. That seems like overkill, if I'm understanding correctly. (So maybe I am not understanding).

                                    What I heard was:

                                    Each sensactuator node has a "node type" and a "version" within that node type. Each combination of sensors and pin assignments has a unique "node type" (within a given wireless network). A node can only be OTA updated to a newer (higher) version of the same "node type" of the current firmware, and all nodes of that "node type" will be updated.

                                    And extra byte for "version" isn't a big deal tho.

                                    Will there be one or two bytes for "node type"?

                                    T Offline
                                    T Offline
                                    ToSa
                                    Code Contributor
                                    wrote on last edited by
                                    #50

                                    @Zeph said:

                                    Each combination of sensors and pin assignments has a unique "node type" (within a given wireless network).

                                    Actually that's part of the question - as @hek mentioned there is a desire to sell MySensors hardware - at some point there might be not just generic pinhead PCBs but real fit-for-use devices. Ideally these would have a unique node type assigned not just within a given network. New firmware could be published on mysensors.org (or via codebender or...) and based on the unique (but common across networks) node type less tech-savvy people could be secured from sending a firmware that doesn't fit the hardware... I know - a LOT of "IF"s...

                                    @Damme
                                    you are right - probably not the full 900 bytes but additional space could be used for encryption etc. so every reduced byte is beneficial at this point. I'll check later how much can be saved by using CRC8 instead of CRC16.
                                    I'm already using a mini version of mysensors / mymessage: not using the cpp code files at all but just the headers and if you have a look at the "#ifdef __cplusplus" statements just added for that purpose, there is almost nothing left (the MyMessage class is stripped down to a struct and the MySensors class removed completely / enums and #defines should not consume space after compilation)

                                    1 Reply Last reply
                                    0
                                    • Z Offline
                                      Z Offline
                                      Zeph
                                      Hero Member
                                      wrote on last edited by
                                      #51

                                      @ToSa

                                      I'm realizing how similar the implementations of your model of updates and mine might be. This is just an early inspiration, not fully thought out.

                                      uint8_t   node_type_id;  // same for multiple nodes
                                      uint16_t version;   // loaded version for given node_type_id
                                      ... 
                                      if(new_version > version) {  // test for OTA update needed
                                      

                                      versus

                                      uint8_t   node_id;   // unique per node
                                      uint16_t  progmem_crc;  // calculated from PROGMEM
                                      ... 
                                      if(new_progmem_crc != progmem_crc) { // test for OTA update needed
                                      

                                      This might mean that I could (eventually) use a relatively minor fork of the OTA programming code to get the per-node flexibility that I seek.

                                      T 1 Reply Last reply
                                      0
                                      • Z Zeph

                                        @ToSa

                                        I'm realizing how similar the implementations of your model of updates and mine might be. This is just an early inspiration, not fully thought out.

                                        uint8_t   node_type_id;  // same for multiple nodes
                                        uint16_t version;   // loaded version for given node_type_id
                                        ... 
                                        if(new_version > version) {  // test for OTA update needed
                                        

                                        versus

                                        uint8_t   node_id;   // unique per node
                                        uint16_t  progmem_crc;  // calculated from PROGMEM
                                        ... 
                                        if(new_progmem_crc != progmem_crc) { // test for OTA update needed
                                        

                                        This might mean that I could (eventually) use a relatively minor fork of the OTA programming code to get the per-node flexibility that I seek.

                                        T Offline
                                        T Offline
                                        ToSa
                                        Code Contributor
                                        wrote on last edited by ToSa
                                        #52

                                        @Zeph
                                        yes, that's what I meant - you might not even need any fork of the bootloader itself and just a slight adjustment on the controller end - because the nodeID is contained in the packet (not in the payload but in the header as sender address) so you have all you need for your setup

                                        Z 1 Reply Last reply
                                        0
                                        • T ToSa

                                          @Zeph
                                          yes, that's what I meant - you might not even need any fork of the bootloader itself and just a slight adjustment on the controller end - because the nodeID is contained in the packet (not in the payload but in the header as sender address) so you have all you need for your setup

                                          Z Offline
                                          Z Offline
                                          Zeph
                                          Hero Member
                                          wrote on last edited by Zeph
                                          #53

                                          @ToSa
                                          The other half is testing inequality between the computed CRC of the application firmware in PROGMEM, with the CRC of the available replacement (rather than comparing for higher version number).

                                          An example use case of the ability to load arbitrary new code into any given node. If I was diagnosing some kind of interference, I might temporarily replace the sensor firmware in some nodes (of varying node-type) with a custom radio test firmware, then later restore each with it's original sensor node firmware.

                                          Suppose we have:

                                           node 5, node type 17, version 2, PROGMEM CRC 0x4567  // attic
                                           node 6, node type 3, version 5, PROGMEM CRC 0xABCD  // crawlspace
                                           node 7, node type 3, version 5, PROGMAM CRC 0xABCD // living room
                                          

                                          And I want to temporarily replace the firmware in node 5 and 6, but keep 7 still running as a sensor.

                                          I make RF test code available on the server, with CRC 0x7E57. This is not type 17 or type 3.

                                          I edit the server's table of firmware assignments:

                                          node 5, 0x7E57
                                          node 6, 0x7E57
                                          node 7, 0xABCD  // unchanged
                                          

                                          This causes node 5 and 6 (formerly of different types) to load the test firmware when reload is triggered.

                                          Then when testing is done, I edit the table back:

                                          node 5, 0x4567   // back to its old type and version
                                          node 6, 0xABCD  // back to the same type and version as node 7
                                          node 7, 0xABCD  // still unaffected
                                          

                                          This causes the normal sensor firmware (type and version) to be loaded back in on the next reload.

                                          There could be more than just a CRC to identify the firmware (in order to avoid the birthday paradox), this is just an example.

                                          An alternate use case is loading in my Halloween firmware to the front yard nodes (but not other nodes) for a week or two, then back..

                                          Or an beta version of type 3, version 6, which I'd like to load on some type 3 nodes for in-situ testing (eg: in the crawlspace), but not all of the type 3 nodes because I want most of the system to continue functioning normally while I test. If the beta is bad, I may revert the test nodes to version 5; once the new version is good, I may convert all type 3 nodes to version 6.

                                          These are some of the reasons I'd like to be able to use OTA programming of any arbitrary firmware into any given node, without being constrained to:

                                            Only upgrades of the same node type
                                            Only upgrades to higher version numbers
                                            Only upgrades of all nodes of the same type or none
                                          

                                          And so that's why inequaity testing of the PROGMEM signature on a per-node basis is attractive, not just testing for a higher version number. For similar complexity, we can upgrade to a higher version number, downgrade to a different version number, or change the node type back and forth.

                                          The type and version dynamics (which certainly IS a common use case) can be handled on the server. For example, the server can know what type every node is (kind of a good idea anyway), and can change the node -> signature entry for every node of type 3 to the signature of the next version, and then let it proceed as above to get them all updated. But that's just one option, centrally controlled.

                                          T 1 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          17

                                          Online

                                          11.7k

                                          Users

                                          11.2k

                                          Topics

                                          113.1k

                                          Posts


                                          Copyright 2025 TBD   |   Forum Guidelines   |   Privacy Policy   |   Terms of Service
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • MySensors
                                          • OpenHardware.io
                                          • Categories
                                          • Recent
                                          • Tags
                                          • Popular