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 631.3k 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.
  • rmtuckerR rmtucker

    @NeverDie
    I am puzzled with your 596ua?
    I thought you were under 10ua with the mysensors sleep some time ago?
    Mine only measures 4-5ua when in sleep?

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

    @rmtucker said in nRF5 Bluetooth action!:

    I am puzzled with your 596ua?
    I thought you were under 10ua with the mysensors sleep some time ago?

    There's no contradiction. It's a different scenario. The MySensors hwSleep function turns off the High Frequency oscillator when sleeping and turns it back on when it wakes up. So, it's perfectly fine for sleeping your device, having it wake up to send something, and then go back to sleep.

    The present scenario that I'm working on though is where the MCU sleeps and the PPI manages a "listen mode" where the PPI wakes up the radio once every 100ms for a roughly 200us window of time to listen for an incoming packet. Then it goes back to sleep if nothing is received. On the other hand, if a packet is received, it wakes up the MCU so that the packet can be read and dealt with. Presently I have the PPI turn off the high-frequency oscillator each time after it has finished RX in the listen-mode cycle. Before entering RX again to listen for a new packet, it first ramps up the high frequency oscillator. According to the datasheet, the high frequency crystal oscillator must be operating in order for the radio to either transmit or receive. i.e. it can't simply run off the high frequency RC oscillator the way the MCU can.

    My measurements show that while the High Frequency oscillator is running, it consumes about 596ua.

    1 Reply Last reply
    1
    • M Offline
      M Offline
      Mike_Lemo
      wrote on last edited by
      #935

      Did anyone managed to get two NRF52832 to connect to each other with the arduino IDE and communicate?

      Also why does I2C initializes only after an SWD programmed gets connected?

      Wierd phenomenon when I use an I2C oled display with that chip and program it with an st link V2 after it displays alright when it's booted if the SWD programmer is connected but as soon as you disconnect it everything else works but the I2C display...

      NeverDieN U 2 Replies Last reply
      0
      • M Mike_Lemo

        Did anyone managed to get two NRF52832 to connect to each other with the arduino IDE and communicate?

        Also why does I2C initializes only after an SWD programmed gets connected?

        Wierd phenomenon when I use an I2C oled display with that chip and program it with an st link V2 after it displays alright when it's booted if the SWD programmer is connected but as soon as you disconnect it everything else works but the I2C display...

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

        @Mike_Lemo said in nRF5 Bluetooth action!:

        Did anyone managed to get two NRF52832 to connect to each other with the arduino IDE and communicate?

        Yes. @d00616's demo code will do this.

        I don't know the answers to the rest of your questions, because I don't use the ST.

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

          Here's a scopeshot of how the revised current draw looks:
          0_1506116792416_NewFile7.png
          As you can see, there is now about a 370us warm-up time at the beginning for the High Frequency oscillator to come up to speed before the RX cycle can be started. Then it takes about 100us for the receiver to warm-up to RXIDLE. From there it finally achieves about 200us of actual productive RX time. Then everything powers down until the end of the 100ms cycle, after which it all repeats again. To conserve energy, all this is managed by the PPI while the MCU sleeps.
          Scale: 1mv=1ma

          I think this is about as energy efficient as it's ever going to get, short of chipping away at the number of bits in the frame/packet size, as I indicated earlier.

          NeverDieN 2 Replies Last reply
          0
          • NeverDieN NeverDie

            @Mike_Lemo said in nRF5 Bluetooth action!:

            Did anyone managed to get two NRF52832 to connect to each other with the arduino IDE and communicate?

            Yes. @d00616's demo code will do this.

            I don't know the answers to the rest of your questions, because I don't use the ST.

            M Offline
            M Offline
            Mike_Lemo
            wrote on last edited by Mike_Lemo
            #938

            @NeverDie said in nRF5 Bluetooth action!:

            @Mike_Lemo said in nRF5 Bluetooth action!:

            Did anyone managed to get two NRF52832 to connect to each other with the arduino IDE and communicate?
            

            Yes. @d00616's demo code will do this.

            I don't know the answers to the rest of your questions, because I don't use the ST.

            Any idea how I reach to this code?

            Also you say you don't experience any issues with I2C like that?

            NeverDieN 1 Reply Last reply
            0
            • M Mike_Lemo

              @NeverDie said in nRF5 Bluetooth action!:

              @Mike_Lemo said in nRF5 Bluetooth action!:

              Did anyone managed to get two NRF52832 to connect to each other with the arduino IDE and communicate?
              

              Yes. @d00616's demo code will do this.

              I don't know the answers to the rest of your questions, because I don't use the ST.

              Any idea how I reach to this code?

              Also you say you don't experience any issues with I2C like that?

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

              @Mike_Lemo said in nRF5 Bluetooth action!:

              Any idea how I reach to this code?

              Yes, it's all explained in detail by @d00616 here: https://www.openhardware.io/view/376/MySensors-NRF5-Platform

              Also you say you don't experience any issues with I2C like that?

              Haven't tried I2C on this platform yet. I'd be very surprised if it didn't work though, as that's ARM Cortex M4 stuff, which is well vetted. i.e. no real dependency on anything Nordic per se.

              M 1 Reply Last reply
              0
              • NeverDieN NeverDie

                @Mike_Lemo said in nRF5 Bluetooth action!:

                Any idea how I reach to this code?

                Yes, it's all explained in detail by @d00616 here: https://www.openhardware.io/view/376/MySensors-NRF5-Platform

                Also you say you don't experience any issues with I2C like that?

                Haven't tried I2C on this platform yet. I'd be very surprised if it didn't work though, as that's ARM Cortex M4 stuff, which is well vetted. i.e. no real dependency on anything Nordic per se.

                M Offline
                M Offline
                Mike_Lemo
                wrote on last edited by
                #940

                @NeverDie said in nRF5 Bluetooth action!:

                @Mike_Lemo said in nRF5 Bluetooth action!:

                Any idea how I reach to this code?

                Yes, it's all explained in detail by @d00616 here: https://www.openhardware.io/view/376/MySensors-NRF5-Platform

                Also you say you don't experience any issues with I2C like that?

                Haven't tried I2C on this platform yet. I'd be very surprised if it didn't work though, as that's ARM Cortex M4 stuff, which is well vetted. i.e. no real dependency on anything Nordic per se.

                The link you attached links me to a getting started page not wireing two nrf's together

                NeverDieN M 2 Replies Last reply
                0
                • M Mike_Lemo

                  @NeverDie said in nRF5 Bluetooth action!:

                  @Mike_Lemo said in nRF5 Bluetooth action!:

                  Any idea how I reach to this code?

                  Yes, it's all explained in detail by @d00616 here: https://www.openhardware.io/view/376/MySensors-NRF5-Platform

                  Also you say you don't experience any issues with I2C like that?

                  Haven't tried I2C on this platform yet. I'd be very surprised if it didn't work though, as that's ARM Cortex M4 stuff, which is well vetted. i.e. no real dependency on anything Nordic per se.

                  The link you attached links me to a getting started page not wireing two nrf's together

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

                  @Mike_Lemo said in nRF5 Bluetooth action!:

                  The link you attached links me to a getting started page not wireing two nrf's together

                  Your question was ambiguous. When you said "connect" I just assumed you meant wirelessly connect.

                  Sorry, I can't help you. Seems like @scalz has gotten I2C to work with it though, but more likely for reading a TH sensor than for the purpose of wiring two nRF52832's. Still, that would prove that it works. If you know the I2C protocol, it shouldn't be hard to go from that to wiring two nRF52832's together.

                  1 Reply Last reply
                  0
                  • NeverDieN NeverDie

                    Here's a scopeshot of how the revised current draw looks:
                    0_1506116792416_NewFile7.png
                    As you can see, there is now about a 370us warm-up time at the beginning for the High Frequency oscillator to come up to speed before the RX cycle can be started. Then it takes about 100us for the receiver to warm-up to RXIDLE. From there it finally achieves about 200us of actual productive RX time. Then everything powers down until the end of the 100ms cycle, after which it all repeats again. To conserve energy, all this is managed by the PPI while the MCU sleeps.
                    Scale: 1mv=1ma

                    I think this is about as energy efficient as it's ever going to get, short of chipping away at the number of bits in the frame/packet size, as I indicated earlier.

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

                    @NeverDie said in nRF5 Bluetooth action!:

                    I think this is about as energy efficient as it's ever going to get, short of chipping away at the number of bits in the frame/packet size, as I indicated earlier.

                    I also measured the current between the peaks shown in the scopeshot. By increasing the period between listens, I was able to do the measurement using a uCurrent Gold. Doing so, I found that the current drawn was 10.7ua using the Low Frequency crystal oscillator, and 11.2ua using the Low Frequency RC oscillator. I'm now sure how to square that with some of the earlier measurements I had taken with the nRF52832 sleeping using the MySensors sleep routine, as those measurements came out to about 6ua. Perhaps the difference is the extra current required to run the PPI in this configuration? With neither oscillator configured, and no PPI, it measures, as I said earlier, at 2.2ua, which is close to what the datasheet predicts.

                    1 Reply Last reply
                    0
                    • M Mike_Lemo

                      @NeverDie said in nRF5 Bluetooth action!:

                      @Mike_Lemo said in nRF5 Bluetooth action!:

                      Any idea how I reach to this code?

                      Yes, it's all explained in detail by @d00616 here: https://www.openhardware.io/view/376/MySensors-NRF5-Platform

                      Also you say you don't experience any issues with I2C like that?

                      Haven't tried I2C on this platform yet. I'd be very surprised if it didn't work though, as that's ARM Cortex M4 stuff, which is well vetted. i.e. no real dependency on anything Nordic per se.

                      The link you attached links me to a getting started page not wireing two nrf's together

                      M Offline
                      M Offline
                      Mike_Lemo
                      wrote on last edited by
                      #943

                      @Mike_Lemo said in nRF5 Bluetooth action!:

                      @NeverDie said in nRF5 Bluetooth action!:

                      @Mike_Lemo said in nRF5 Bluetooth action!:

                      Any idea how I reach to this code?

                      Yes, it's all explained in detail by @d00616 here: https://www.openhardware.io/view/376/MySensors-NRF5-Platform

                      Also you say you don't experience any issues with I2C like that?

                      Haven't tried I2C on this platform yet. I'd be very surprised if it didn't work though, as that's ARM Cortex M4 stuff, which is well vetted. i.e. no real dependency on anything Nordic per se.

                      The link you attached links me to a getting started page not wireing two nrf's together

                      Yes I did mean wirelessly like central and peripherial connection... Is that supported?

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

                        I'm sorry, but I can't help you any more than I already have.

                        1 Reply Last reply
                        0
                        • NeverDieN NeverDie

                          Here's a scopeshot of how the revised current draw looks:
                          0_1506116792416_NewFile7.png
                          As you can see, there is now about a 370us warm-up time at the beginning for the High Frequency oscillator to come up to speed before the RX cycle can be started. Then it takes about 100us for the receiver to warm-up to RXIDLE. From there it finally achieves about 200us of actual productive RX time. Then everything powers down until the end of the 100ms cycle, after which it all repeats again. To conserve energy, all this is managed by the PPI while the MCU sleeps.
                          Scale: 1mv=1ma

                          I think this is about as energy efficient as it's ever going to get, short of chipping away at the number of bits in the frame/packet size, as I indicated earlier.

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

                          @NeverDie said in nRF5 Bluetooth action!:

                          I think this is about as energy efficient as it's ever going to get

                          Epilog: I ran it overnight on a 10F capacitor, and it dropped only 0.011v per hour. I'm very happy with that, considering it's listening every 100ms as to whether or not it has received a packet. :)

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

                            @d00616 Your posting says,

                            At the moment on Arduino, there is no definition of various OUTPUT modes. If you want to access all nRF5 output modes, you have to use hwPinMode and the OUTPUT_... macro.

                            Exactly which macro would that be? It looks to me as though what most users will want is the function nrf5_pinmode(..,..), which appears to do all the actual work. Is that right? It is defined in the file nrf5_wiring_digital.c.

                            Meanwhile, hwPinMode appears to be merely a straight pass-through for pinMode:

                            
                            void hwPinMode(uint8_t pin, uint8_t mode)
                            {
                              pinMode(pin, mode);
                            }
                            
                            1 Reply Last reply
                            0
                            • M Offline
                              M Offline
                              Mike_Lemo
                              wrote on last edited by
                              #947

                              Where is it possible to find a reference schematic for using the NTF52832 E73-2G4M04S module with NFC?

                              not much is being given in the datasheet not even where the NFC pins go.

                              d00616D T 2 Replies Last reply
                              0
                              • M Mike_Lemo

                                Where is it possible to find a reference schematic for using the NTF52832 E73-2G4M04S module with NFC?

                                not much is being given in the datasheet not even where the NFC pins go.

                                d00616D Offline
                                d00616D Offline
                                d00616
                                Contest Winner
                                wrote on last edited by
                                #948

                                @Mike_Lemo said in nRF5 Bluetooth action!:

                                Where is it possible to find a reference schematic for using the NTF52832 E73-2G4M04S module with NFC?
                                not much is being given in the datasheet not even where the NFC pins go.

                                Please look into the product documentation:
                                http://infocenter.nordicsemi.com/topic/com.nordic.infocenter.nrf52832.ps.v1.1/nfc.html?cp=2_1_0_41_8#concept_ryw_4hk_1s

                                @NeverDie said in nRF5 Bluetooth action!:

                                At the moment on Arduino, there is no definition of various OUTPUT modes. If you want to access all nRF5 output modes, you have to use hwPinMode and the OUTPUT_... macro.

                                Exactly which macro would that be? It looks to me as though what most users will want is the function nrf5_pinmode(..,..), which appears to do all the actual work. Is that right? It is defined in the file nrf5_wiring_digital.c.

                                hwPinMode allows to define platform specific PinMode replacements. Code may be portable. This is the reason pointing to nrf5_pinmode().

                                nrf5_pinmode() has a little bit more functionality than the original pinmode function.

                                Meanwhile, hwPinMode appears to be merely a straight pass-through for pinMode:

                                void hwPinMode(uint8_t pin, uint8_t mode)
                                {
                                pinMode(pin, mode);
                                }

                                This disables the capability using nRF5 specific pin modes with the MySensors API.

                                M 1 Reply Last reply
                                1
                                • d00616D d00616

                                  @Mike_Lemo said in nRF5 Bluetooth action!:

                                  Where is it possible to find a reference schematic for using the NTF52832 E73-2G4M04S module with NFC?
                                  not much is being given in the datasheet not even where the NFC pins go.

                                  Please look into the product documentation:
                                  http://infocenter.nordicsemi.com/topic/com.nordic.infocenter.nrf52832.ps.v1.1/nfc.html?cp=2_1_0_41_8#concept_ryw_4hk_1s

                                  @NeverDie said in nRF5 Bluetooth action!:

                                  At the moment on Arduino, there is no definition of various OUTPUT modes. If you want to access all nRF5 output modes, you have to use hwPinMode and the OUTPUT_... macro.

                                  Exactly which macro would that be? It looks to me as though what most users will want is the function nrf5_pinmode(..,..), which appears to do all the actual work. Is that right? It is defined in the file nrf5_wiring_digital.c.

                                  hwPinMode allows to define platform specific PinMode replacements. Code may be portable. This is the reason pointing to nrf5_pinmode().

                                  nrf5_pinmode() has a little bit more functionality than the original pinmode function.

                                  Meanwhile, hwPinMode appears to be merely a straight pass-through for pinMode:

                                  void hwPinMode(uint8_t pin, uint8_t mode)
                                  {
                                  pinMode(pin, mode);
                                  }

                                  This disables the capability using nRF5 specific pin modes with the MySensors API.

                                  M Offline
                                  M Offline
                                  Mike_Lemo
                                  wrote on last edited by
                                  #949

                                  @d00616 said in nRF5 Bluetooth action!:

                                  @Mike_Lemo said in nRF5 Bluetooth action!:

                                  Where is it possible to find a reference schematic for using the NTF52832 E73-2G4M04S module with NFC?
                                  not much is being given in the datasheet not even where the NFC pins go.

                                  Please look into the product documentation:
                                  http://infocenter.nordicsemi.com/topic/com.nordic.infocenter.nrf52832.ps.v1.1/nfc.html?cp=2_1_0_41_8#concept_ryw_4hk_1s

                                  @NeverDie said in nRF5 Bluetooth action!:

                                  At the moment on Arduino, there is no definition of various OUTPUT modes. If you want to access all nRF5 output modes, you have to use hwPinMode and the OUTPUT_... macro.

                                  Exactly which macro would that be? It looks to me as though what most users will want is the function nrf5_pinmode(..,..), which appears to do all the actual work. Is that right? It is defined in the file nrf5_wiring_digital.c.

                                  hwPinMode allows to define platform specific PinMode replacements. Code may be portable. This is the reason pointing to nrf5_pinmode().

                                  nrf5_pinmode() has a little bit more functionality than the original pinmode function.

                                  Meanwhile, hwPinMode appears to be merely a straight pass-through for pinMode:

                                  void hwPinMode(uint8_t pin, uint8_t mode)
                                  {
                                  pinMode(pin, mode);
                                  }

                                  This disables the capability using nRF5 specific pin modes with the MySensors API.

                                  I'm talking about the module it's self isn't there a reference schematic for that? I see there are some component in there but else do I have to add to make this work?

                                  1 Reply Last reply
                                  0
                                  • M Mike_Lemo

                                    @Mike_Lemo said in nRF5 Bluetooth action!:

                                    @NeverDie said in nRF5 Bluetooth action!:

                                    @Mike_Lemo said in nRF5 Bluetooth action!:

                                    Any idea how I reach to this code?

                                    Yes, it's all explained in detail by @d00616 here: https://www.openhardware.io/view/376/MySensors-NRF5-Platform

                                    Also you say you don't experience any issues with I2C like that?

                                    Haven't tried I2C on this platform yet. I'd be very surprised if it didn't work though, as that's ARM Cortex M4 stuff, which is well vetted. i.e. no real dependency on anything Nordic per se.

                                    The link you attached links me to a getting started page not wireing two nrf's together

                                    Yes I did mean wirelessly like central and peripherial connection... Is that supported?

                                    scalzS Offline
                                    scalzS Offline
                                    scalz
                                    Hardware Contributor
                                    wrote on last edited by scalz
                                    #950

                                    @Mike_Lemo said in nRF5 Bluetooth action!:

                                    Yes I did mean wirelessly like central and peripherial connection... Is that supported?

                                    You're mixing things maybe. You're talking about bluetooth. that's not Mysensors ;)
                                    But if you want to get a connection between two nrf52832 or nrf52832/nrf24, take a look at d00616 docs.

                                    a nrf52 is a nrf52, no matter the module.

                                    So nfc pins (which are fixed) will be the same on every nrf52 you'll find. It can just happen that you get a board where those pins are used for other purpose (then you can't use nfc without little hack).

                                    But regarding the cdebyte modules, these are simply nrf52 with pinout. So no problem here. Just take a look at the nordic link d00616 showed about using nfc.

                                    In case.. pins are P0.09 and P0.10. But you'll need to tune your nfc antenna, and add capacitors. Sparkfun, adafruit have some infos on this as they're selling boards.

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

                                      Also, if you're interested in NFC, the Nordic nRF52832 DK comes with an antenna for it. It would probably be the easiest to use, because a connector for the antenna is already on the board.

                                      1 Reply Last reply
                                      1
                                      • scalzS scalz

                                        @Mike_Lemo said in nRF5 Bluetooth action!:

                                        Yes I did mean wirelessly like central and peripherial connection... Is that supported?

                                        You're mixing things maybe. You're talking about bluetooth. that's not Mysensors ;)
                                        But if you want to get a connection between two nrf52832 or nrf52832/nrf24, take a look at d00616 docs.

                                        a nrf52 is a nrf52, no matter the module.

                                        So nfc pins (which are fixed) will be the same on every nrf52 you'll find. It can just happen that you get a board where those pins are used for other purpose (then you can't use nfc without little hack).

                                        But regarding the cdebyte modules, these are simply nrf52 with pinout. So no problem here. Just take a look at the nordic link d00616 showed about using nfc.

                                        In case.. pins are P0.09 and P0.10. But you'll need to tune your nfc antenna, and add capacitors. Sparkfun, adafruit have some infos on this as they're selling boards.

                                        M Offline
                                        M Offline
                                        Mike_Lemo
                                        wrote on last edited by
                                        #952

                                        @scalz

                                        Yeah but my question was about what is connected in the module and what components I have to use....

                                        Also about the NFC I'm planning to use it with the arduino IDE so just wanted to ask if there is a library for it because the SDK is quite useless in this case as well as the Central peripheral connection.

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

                                          I was able to reduce the active listen period to about 100us:
                                          0_1506303847635_NewFile3.png
                                          Now listening every 100ms yields a 10F supercap voltage measured decline of just 9mv per hour. i.e. a decline of 0.108v by the end of 12 hours.

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


                                          9

                                          Online

                                          11.7k

                                          Users

                                          11.2k

                                          Topics

                                          113.0k

                                          Posts


                                          Copyright 2019 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