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. My Project
  3. nRF5 action!

nRF5 action!

Scheduled Pinned Locked Moved My Project
1.9k Posts 49 Posters 637.2k Views 44 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.
  • NeverDieN NeverDie

    @toyman OTA updates.

    T Offline
    T Offline
    Toyman
    wrote on last edited by
    #1734

    @neverdie I am afraid it still relies on Softdevice

    monteM NeverDieN 2 Replies Last reply
    0
    • T Toyman

      @neverdie I am afraid it still relies on Softdevice

      monteM Offline
      monteM Offline
      monte
      wrote on last edited by
      #1735

      @toyman no, if your code is in python. So the deal is "just" to port mysensors to python.

      1 Reply Last reply
      1
      • T Toyman

        @neverdie I am afraid it still relies on Softdevice

        NeverDieN Offline
        NeverDieN Offline
        NeverDie
        Hero Member
        wrote on last edited by NeverDie
        #1736

        @toyman Micropython on the BBC micro:bit (which uses the nRF51822) has a Radio library that uses Nordic's proprietary radio modes and doesn't involve Bluetooth. I suppose the question is: what would be involved in getting it to run on the nRF52832 or the nRF52840. Seems like it would be substantially the same.

        Faiing that, if I can directly manipulate the radio registers from miropython as I can from C, then it shouldn't be too hard to get at least minimal radio capability up and running from within micropython.

        If I can get rudimentary radio communications working in micropython, then from there it should be easy to do OTA updates via REPL. I did some proof of concept to that effect on the micro:bit, but quickly ran out of memory--the micro:bit has only a total of 16K of RAM, so there's very little headroom to begin with. On the nRF52840, lack of RAM shouldn't be an issue.

        U 1 Reply Last reply
        0
        • NeverDieN Offline
          NeverDieN Offline
          NeverDie
          Hero Member
          wrote on last edited by
          #1737

          @scalz hinted at it previously, but it looks like MyNewt OS might offer yet another way to do OTA updates. According to their posted information, it offers:

          A open-source Bluetooth 5.0 stack (both Host & Controller), NimBLE, that completely replaces the proprietary SoftDevice on Nordic chipsets. (https://github.com/apache/mynewt-core/blob/master/README.md)

          Apparentlly it runs on both the nRF52832 and the nRF52840.

          S 1 Reply Last reply
          0
          • NeverDieN NeverDie

            @scalz hinted at it previously, but it looks like MyNewt OS might offer yet another way to do OTA updates. According to their posted information, it offers:

            A open-source Bluetooth 5.0 stack (both Host & Controller), NimBLE, that completely replaces the proprietary SoftDevice on Nordic chipsets. (https://github.com/apache/mynewt-core/blob/master/README.md)

            Apparentlly it runs on both the nRF52832 and the nRF52840.

            S Offline
            S Offline
            speechsupply
            wrote on last edited by
            #1738

            @neverdie
            1737 posts and counting
            Spend hours reading this. Amazing journey so far.

            T 1 Reply Last reply
            1
            • NeverDieN NeverDie

              @toyman Micropython on the BBC micro:bit (which uses the nRF51822) has a Radio library that uses Nordic's proprietary radio modes and doesn't involve Bluetooth. I suppose the question is: what would be involved in getting it to run on the nRF52832 or the nRF52840. Seems like it would be substantially the same.

              Faiing that, if I can directly manipulate the radio registers from miropython as I can from C, then it shouldn't be too hard to get at least minimal radio capability up and running from within micropython.

              If I can get rudimentary radio communications working in micropython, then from there it should be easy to do OTA updates via REPL. I did some proof of concept to that effect on the micro:bit, but quickly ran out of memory--the micro:bit has only a total of 16K of RAM, so there's very little headroom to begin with. On the nRF52840, lack of RAM shouldn't be an issue.

              U Offline
              U Offline
              Uhrheber
              wrote on last edited by
              #1739

              @neverdie There are three ways to manipulate registers directly from Micropython:

              1. Use machine.mem16

              2. Use the decorator @micropython_viper
                The Viper code emitter implements integer types and pointers, allowing to access memory and registers directly.

              3. Use the decorator @micropython.asm_thumb
                Write your code in ARM assembler.

              Problem: I don't know whether any of this is already implemented and works reliably in Micropython for nRF.

              NeverDieN 1 Reply Last reply
              1
              • S speechsupply

                @neverdie
                1737 posts and counting
                Spend hours reading this. Amazing journey so far.

                T Offline
                T Offline
                Toyman
                wrote on last edited by
                #1740

                @speechsupply this thread is golden. I was so empowered that was able to easily switch to nRF SDK and to start producing (semi) commercial BLE-ANT device

                S 1 Reply Last reply
                1
                • T Toyman

                  @speechsupply this thread is golden. I was so empowered that was able to easily switch to nRF SDK and to start producing (semi) commercial BLE-ANT device

                  S Offline
                  S Offline
                  speechsupply
                  wrote on last edited by
                  #1741

                  @toyman
                  Yea, On monday I'll order a couple of nRF52840 EVAL boards. Any suggestion regarding what to get?
                  Looked at both the BMD-340-EVAL and ofcourse the NRF52840-DK

                  1 Reply Last reply
                  0
                  • U Uhrheber

                    @neverdie There are three ways to manipulate registers directly from Micropython:

                    1. Use machine.mem16

                    2. Use the decorator @micropython_viper
                      The Viper code emitter implements integer types and pointers, allowing to access memory and registers directly.

                    3. Use the decorator @micropython.asm_thumb
                      Write your code in ARM assembler.

                    Problem: I don't know whether any of this is already implemented and works reliably in Micropython for nRF.

                    NeverDieN Offline
                    NeverDieN Offline
                    NeverDie
                    Hero Member
                    wrote on last edited by NeverDie
                    #1742

                    @uhrheber said in nRF5 action!:

                    @neverdie There are three ways to manipulate registers directly from Micropython:

                    1. Use machine.mem16

                    2. Use the decorator @micropython_viper
                      The Viper code emitter implements integer types and pointers, allowing to access memory and registers directly.

                    3. Use the decorator @micropython.asm_thumb
                      Write your code in ARM assembler.

                    Problem: I don't know whether any of this is already implemented and works reliably in Micropython for nRF.

                    Thanks! We finally nailed it all the way down on this thread here: https://forum.micropython.org/viewtopic.php?f=12&t=5377

                    :smiley:

                    1 Reply Last reply
                    0
                    • O Offline
                      O Offline
                      Omemanti
                      wrote on last edited by Omemanti
                      #1743

                      I see somewhat strange behaviour when using millis() for intervals.

                      I'm not sure it's my mistake, but one thing is that it seems that the millis rollover is around; 131.068.570 (36 hours)

                      When the rollover happens, it looks like it interrupts my sleep. Does that make sense?

                      sleep(digitalPinToInterrupt(PIR_Pin), CHANGE, LongSleep); 
                      

                      Debug lines => (Temp / RH - Millis)

                      21.44 / 61.15 - 130977952
                      21.43 / 61.16 - 131008158
                      21.42 / 61.15 - 131038364
                      21.44 / 61.14 - 131068570
                      I woke up because I saw movement at: 26576
                      Sleep Duration : -131042000  Im going back to sleep for 150000       
                      21.43 / 61.16 - 176822
                      
                      

                      20-10-2018 => its been ±36 hours laters, and he woke up again at the same moment.

                      18.57 / 56.88 - 131007553
                      18.56 / 56.86 - 131037759
                      18.58 / 56.85 - 131067965
                      I woke up because I saw movement at: 25971
                      Sleep duration : -131042000 => Rollover??
                      18.55 / 56.89 - 206423
                      18.53 / 56.89 - 236628
                      18.54 / 56.90 - 266834
                      18.55 / 56.89 - 297040
                      18.54 / 56.90 - 327246
                      1 Reply Last reply
                      0
                      • M maciekczwa

                        I have the same problem with brand news ebyte modeules.

                        Here are my openocd logs:

                        Open On-Chip Debugger 0.10.0-dev-gdc53227 (2016-04-09-13:45)
                        Licensed under GNU GPL v2
                        For bug reports, read
                        http://openocd.org/doc/doxygen/bugs.html
                        debug_level: 2
                        0x4000
                        Info : The selected transport took over low-level target control. The results might differ compared to plain JTAG/SWD
                        adapter speed: 10000 kHz
                        Info : Unable to match requested speed 10000 kHz, using 4000 kHz
                        Info : Unable to match requested speed 10000 kHz, using 4000 kHz
                        Info : clock speed 4000 kHz
                        Info : STLINK v2 JTAG v17 API v2 SWIM v4 VID 0x0483 PID 0x3748
                        Info : using stlink api v2
                        Info : Target voltage: 3.241270
                        Info : nrf52.cpu: hardware has 0 breakpoints, 2 watchpoints
                        Error: timed out while waiting for target halted
                        TARGET: nrf52.cpu - Not halted
                        in procedure 'program'
                        in procedure 'reset' called at file "embedded:startup.tcl", line 478
                        in procedure 'ocd_bouncer'

                        embedded:startup.tcl:454: Error: ** Unable to reset target **
                        in procedure 'program'
                        in procedure 'program_error' called at file "embedded:startup.tcl", line 479
                        at file "embedded:startup.tcl", line 454
                        wybrany port szeregowy at file "embedded:startup.tcl", line 454
                        nie istnieje albo Twoja płytka nie jest podłączona

                        O Offline
                        O Offline
                        Omemanti
                        wrote on last edited by Omemanti
                        #1744

                        @maciekczwa said in nRF5 action!:

                        Licensed under GNU GPL v2
                        For bug reports, read
                        http://openocd.org/doc/doxygen/bugs.html
                        debug_level: 2
                        0x4000
                        Info : The selected transport took over low-level target control. The results might differ compared to plain JTAG/SWD
                        adapter speed: 10000 kHz
                        Info : Unable to match requested speed 10000 kHz, using 4000 kHz
                        Info : Unable to match requested speed 10000 kHz, using 4000 kHz
                        Info : clock speed 4000 kHz
                        Info : STLINK v2 JTAG v17 API v2 SWIM v4 VID 0x0483 PID 0x3748
                        Info : using stlink api v2
                        Info : Target voltage: 3.241270
                        Info : nrf52.cpu: hardware has 0 breakpoints, 2 watchpoints
                        Error: timed out while waiting for target halted
                        TARGET: nrf52.cpu - Not halted
                        in procedure 'program'
                        in procedure 'reset' called at file "embedded:startup.tcl", line 478
                        in procedure 'ocd_bouncer'

                        **embedded:startup.tcl:454: Error: ** Unable to reset target ****
                        in procedure 'program'
                        in procedure 'program_error' called at file "embedded:startup.tcl", line 479
                        at file "embedded:startup.tcl", line 454
                        wybrany port szeregowy at file "embedded:startup.tcl", line 454

                        maybe someone else already found the solution, but it took me a while to figure it out for myself.

                        So for documentation sake:

                        Just had the exact same things with new Ebyte NRF52832 modules, ST-Link v2 couldn't erase it. (the old once did erase without a single problem )

                        After some digging, I found the following:
                        (I'm using my NRF52832-DK for it, maybe other devices work as well, just tested this one)

                        DK => Ebyte module
                        GND(detect) => GND
                        SWDIO => SWDIO
                        SWDCLK => SWCLK
                        VTG => 3,3V
                        3,3V => 3,3V
                        GND =>GND

                        you can erase the protection using nRFgo Studio

                        1. On the left, you can find a header named Segger, click on that.
                        2. then it shows that it is locked, and you can click recover.
                        3. after that you can erase it
                        4. upload a new sketch using an ST-link V2 or the DK while you are still at it.

                        0_1540825164917_f8695040-bd25-422c-9f43-49e1d762c29d-image.png

                        T 1 Reply Last reply
                        2
                        • alowhumA alowhum

                          This looks like an Arduino-nano/pro-mini style device with an NRF51:

                          https://www.aliexpress.com/item/Nrf51822-LIS3DH-Bluetooth-Module-CJMCU-8223-Bluetooth-acceleration-module/32821873481.html

                          alowhumA Offline
                          alowhumA Offline
                          alowhum
                          Plugin Developer
                          wrote on last edited by
                          #1745

                          @alowhum said in nRF5 action!:

                          This looks like an Arduino-nano/pro-mini style device with an NRF51:

                          https://www.aliexpress.com/item/Nrf51822-LIS3DH-Bluetooth-Module-CJMCU-8223-Bluetooth-acceleration-module/32821873481.html

                          I tried uploading a simple blink sketch today. I found some code on github which suggested pin 23 and 24 are LED pins.

                          I got an error uploading via STM32 though.

                          debug_level: 2
                          0x4000
                          Info : The selected transport took over low-level target control. The results might differ compared to plain JTAG/SWD
                          adapter speed: 10000 kHz
                          Info : Unable to match requested speed 10000 kHz, using 4000 kHz
                          Info : Unable to match requested speed 10000 kHz, using 4000 kHz
                          Info : clock speed 4000 kHz
                          Info : STLINK v2 JTAG v17 API v2 SWIM v4 VID 0x0483 PID 0x3748
                          Info : using stlink api v2
                          Info : Target voltage: 3.233552
                          Warn : UNEXPECTED idcode: 0x0bb11477
                          Error: expected 1 of 1: 0x2ba01477

                          in procedure 'program'
                          in procedure 'init' called at file "embedded:startup.tcl", line 473
                          in procedure 'ocd_bouncer'
                          ** OpenOCD init failed **
                          shutdown command invoked

                          1 Reply Last reply
                          0
                          • O Omemanti

                            @maciekczwa said in nRF5 action!:

                            Licensed under GNU GPL v2
                            For bug reports, read
                            http://openocd.org/doc/doxygen/bugs.html
                            debug_level: 2
                            0x4000
                            Info : The selected transport took over low-level target control. The results might differ compared to plain JTAG/SWD
                            adapter speed: 10000 kHz
                            Info : Unable to match requested speed 10000 kHz, using 4000 kHz
                            Info : Unable to match requested speed 10000 kHz, using 4000 kHz
                            Info : clock speed 4000 kHz
                            Info : STLINK v2 JTAG v17 API v2 SWIM v4 VID 0x0483 PID 0x3748
                            Info : using stlink api v2
                            Info : Target voltage: 3.241270
                            Info : nrf52.cpu: hardware has 0 breakpoints, 2 watchpoints
                            Error: timed out while waiting for target halted
                            TARGET: nrf52.cpu - Not halted
                            in procedure 'program'
                            in procedure 'reset' called at file "embedded:startup.tcl", line 478
                            in procedure 'ocd_bouncer'

                            **embedded:startup.tcl:454: Error: ** Unable to reset target ****
                            in procedure 'program'
                            in procedure 'program_error' called at file "embedded:startup.tcl", line 479
                            at file "embedded:startup.tcl", line 454
                            wybrany port szeregowy at file "embedded:startup.tcl", line 454

                            maybe someone else already found the solution, but it took me a while to figure it out for myself.

                            So for documentation sake:

                            Just had the exact same things with new Ebyte NRF52832 modules, ST-Link v2 couldn't erase it. (the old once did erase without a single problem )

                            After some digging, I found the following:
                            (I'm using my NRF52832-DK for it, maybe other devices work as well, just tested this one)

                            DK => Ebyte module
                            GND(detect) => GND
                            SWDIO => SWDIO
                            SWDCLK => SWCLK
                            VTG => 3,3V
                            3,3V => 3,3V
                            GND =>GND

                            you can erase the protection using nRFgo Studio

                            1. On the left, you can find a header named Segger, click on that.
                            2. then it shows that it is locked, and you can click recover.
                            3. after that you can erase it
                            4. upload a new sketch using an ST-link V2 or the DK while you are still at it.

                            0_1540825164917_f8695040-bd25-422c-9f43-49e1d762c29d-image.png

                            T Offline
                            T Offline
                            Toyman
                            wrote on last edited by
                            #1746

                            @omemanti actually, all you need is to issue the following command:
                            nrfjprog.exe --recover

                            O mr_redM 2 Replies Last reply
                            0
                            • T Toyman

                              @omemanti actually, all you need is to issue the following command:
                              nrfjprog.exe --recover

                              O Offline
                              O Offline
                              Omemanti
                              wrote on last edited by Omemanti
                              #1747

                              @toyman yup, I tried that one, but all it kept saying was something like; can't find programmer.. and this method, which has a GUI, worked without incident :)

                              T 1 Reply Last reply
                              0
                              • O Omemanti

                                @toyman yup, I tried that one, but all it kept saying was something like; can't find programmer.. and this method, which has a GUI, worked without incident :)

                                T Offline
                                T Offline
                                Toyman
                                wrote on last edited by
                                #1748

                                @omemanti that's strange, I use the methos regularly and it worls fine.
                                Oh! Actually, sandeep's installation messes up Jlink drivers so they require reinstall for the method to work.
                                That's why I am using arduino nrf5 with BMP to completely separate Arduino from Jlink

                                1 Reply Last reply
                                1
                                • NeverDieN Offline
                                  NeverDieN Offline
                                  NeverDie
                                  Hero Member
                                  wrote on last edited by NeverDie
                                  #1749

                                  FYI, I'm switching from uPython over to uLisp. It already worked on the BBC:microbit, and I just now got uLisp working on the nRF52832. Because uLisp relies on Sandeep's library, it doesn't yet support the nRF52840. However, if/when Sandeep's library does support the nRF52840, the uLisp upgrade will be fairly easy.

                                  http://www.ulisp.com/

                                  Nca78N 1 Reply Last reply
                                  1
                                  • NeverDieN NeverDie

                                    FYI, I'm switching from uPython over to uLisp. It already worked on the BBC:microbit, and I just now got uLisp working on the nRF52832. Because uLisp relies on Sandeep's library, it doesn't yet support the nRF52840. However, if/when Sandeep's library does support the nRF52840, the uLisp upgrade will be fairly easy.

                                    http://www.ulisp.com/

                                    Nca78N Offline
                                    Nca78N Offline
                                    Nca78
                                    Hardware Contributor
                                    wrote on last edited by
                                    #1750

                                    @neverdie said in nRF5 action!:

                                    FYI, I'm switching from uPython over to uLisp.

                                    What is the reason for this switch ?

                                    NeverDieN 1 Reply Last reply
                                    0
                                    • Nca78N Nca78

                                      @neverdie said in nRF5 action!:

                                      FYI, I'm switching from uPython over to uLisp.

                                      What is the reason for this switch ?

                                      NeverDieN Offline
                                      NeverDieN Offline
                                      NeverDie
                                      Hero Member
                                      wrote on last edited by NeverDie
                                      #1751

                                      @nca78

                                      1. uPython seemed to require an intimate understanding of a rather complicated build process. I kept running into build-related snags. Maybe in the future they will simplify it.
                                      2. Its garbage collector can't handle heap fragmentation, and it appears that it never will.
                                      3. Adding c-extensions is a rather arcane process.

                                      In contrast, the uLisp build process is far simpler, and uLisp appears to have a proper garbage collector. Adding c-extensions is relatively easy.

                                      1 Reply Last reply
                                      1
                                      • NeverDieN Offline
                                        NeverDieN Offline
                                        NeverDie
                                        Hero Member
                                        wrote on last edited by
                                        #1752

                                        For anyone interested, I posted a simple nRF52 Tx and Rx demo program written in Forth: https://github.com/rabbithat/nRF52_SimpleTxRxDemo

                                        This code is a good starting point for beginners, because it is already working. You can easily modify the code to do whatever transmitting and receiving you want.

                                        1 Reply Last reply
                                        1
                                        • NeverDieN Offline
                                          NeverDieN Offline
                                          NeverDie
                                          Hero Member
                                          wrote on last edited by NeverDie
                                          #1753

                                          I just now posted a wireless Forth REPL for nRF52's on github:
                                          https://github.com/rabbithat/nRF52_wireless_Forth_REPL

                                          This allows you to wirelessly connect with a nRF52 remote node to update and/or interact with your code exactly the same as if the remote node was directly connected to your computer.
                                          :grinning: :grinning: :grinning:

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


                                          30

                                          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