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. Development
  3. Porting MySensors to work with the RadioHead library

Porting MySensors to work with the RadioHead library

Scheduled Pinned Locked Moved Development
portingradiohead
288 Posts 24 Posters 187.5k 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.
  • G Offline
    G Offline
    guillaume brucker
    wrote on last edited by
    #213

    So, I'm working on it with the developpement branch of mysensor.

    I've find some nrf905 librairies arround the web, but the RadioHead seem to be more powerfull and complete.
    I'll give you news soon,

    First of all, i probably need help to diagnose because i've had only one raspberry, one arduino and two atmega328p chipset more

    1 Reply Last reply
    0
    • A Offline
      A Offline
      andrewm844
      wrote on last edited by
      #214

      Did anyone ever solve the this compile error?

      In file included from /home/andrew/sketchbook/libraries/MySensors/MyConfig.h:27,
      from /home/andrew/sketchbook/libraries/MySensors/MySensor.h:17,
      from SerialGateway.ino:27:
      /home/andrew/sketchbook/libraries/MySensors/MyDriverRF69.h:40: error: ISO C++ forbids initialization of member ‘radio’
      /home/andrew/sketchbook/libraries/MySensors/MyDriverRF69.h:40: error: making ‘radio’ static
      /home/andrew/sketchbook/libraries/MySensors/MyDriverRF69.h:40: error: invalid in-class initialization of static data member of non-integral type ‘RFM69*’

      I have tried with IDEs 1.04, 1.05 and 1.06

      G 1 Reply Last reply
      0
      • A andrewm844

        Did anyone ever solve the this compile error?

        In file included from /home/andrew/sketchbook/libraries/MySensors/MyConfig.h:27,
        from /home/andrew/sketchbook/libraries/MySensors/MySensor.h:17,
        from SerialGateway.ino:27:
        /home/andrew/sketchbook/libraries/MySensors/MyDriverRF69.h:40: error: ISO C++ forbids initialization of member ‘radio’
        /home/andrew/sketchbook/libraries/MySensors/MyDriverRF69.h:40: error: making ‘radio’ static
        /home/andrew/sketchbook/libraries/MySensors/MyDriverRF69.h:40: error: invalid in-class initialization of static data member of non-integral type ‘RFM69*’

        I have tried with IDEs 1.04, 1.05 and 1.06

        G Offline
        G Offline
        guillaume brucker
        wrote on last edited by
        #215

        @andrewm844
        Hi,
        I'm working on 905, so I don't have to check the 69, but I've the same compile error
        I just replace
        // RFM69 *radio = NULL;
        RFM69 *radio;
        in the MyDriverRF69.h file

        1 Reply Last reply
        0
        • B Offline
          B Offline
          BenjaminK87
          wrote on last edited by
          #216

          Hi everyone,
          i am new to MySensors. I already made sime Arduino pro mini running with a NRF24L01.
          But i also bought some Anarduino with the RF69 installed. Can anybody tell me how i can tell the library to use the RF69 instead of the NRF24L01?
          I used the Developement version of the MySensor library. I tried to find the point in MyConfig.h but i could only find the NRF24L01 Driver Defaults part.

          Maybe someone could help me.

          Thanks in advance.
          Benjamin

          1 Reply Last reply
          0
          • L Offline
            L Offline
            lafleur
            wrote on last edited by
            #217

            I'm interested in the progress of getting RadioHead working with MySensor....

            what the current status??

            where is the current code for this effort?

            Thanks

            hekH 1 Reply Last reply
            0
            • L lafleur

              I'm interested in the progress of getting RadioHead working with MySensor....

              what the current status??

              where is the current code for this effort?

              Thanks

              hekH Offline
              hekH Offline
              hek
              Admin
              wrote on last edited by hek
              #218

              @lafleur

              In the development branch on github we have support for RF69. We have not incorporated the full RadioHead library.

              1 Reply Last reply
              0
              • L Offline
                L Offline
                lafleur
                wrote on last edited by
                #219

                Is there support for the MoteinoMega? with the rfm69? can you point me to a code base to start with??

                I have used the MoteinoMega in other project, so I know a bit on how they work

                Thanks

                1 Reply Last reply
                0
                • T ToSa

                  @kolaf
                  I've been busy with other stuff for some time but looking at the driver separation now once again. With nRF24 working (even bootloader adjusted to pick the right header files etc.) and two Moteinos at hand (Moteino RFM69W 868/915), I compiled and flashed a serial gateway and a simple temperature sensor node. Both appear to work fine looking at the debug messages except the fact that they don't listen to eachother. Both are sending but none is receiving anything (2m distance).
                  I did not touch or even closely look at the RFM69 driver code yet but will try to do so over the weekend. Do you have any hint where to check first?

                  L Offline
                  L Offline
                  lafleur
                  wrote on last edited by
                  #220

                  @ToSa do you have a sample project (serial Gateway or ?) that I could start from that uses the RF69W radio?? Want to develop with Moteino-Mega

                  thanks

                  1 Reply Last reply
                  0
                  • hekH Offline
                    hekH Offline
                    hek
                    Admin
                    wrote on last edited by
                    #221

                    You only need to initiate the MySensor class with the rfm69 class like this in the gateway (and sensors):

                    https://github.com/mysensors/Arduino/blob/development/libraries/MySensors/examples/SerialGateway/SerialGateway.ino#L44

                    MyTransportRF69 radio;  
                    
                    1 Reply Last reply
                    0
                    • L Offline
                      L Offline
                      lafleur
                      wrote on last edited by
                      #222

                      I had done that, getting error...

                      Some questions:

                      I notice that the MyTransportNRF24 had definition for the pins in the function, RM69, has none...
                      I take it, its defaulted to the Moteino standards pinout?

                      The file MyHwATMega328.cpp is for the 328, i assume that I would need to make one for the ATmega1284P chip? if there are any changes needed.

                      Thanks I will work on these error, if you have any insight on cause, please let me know...

                      (sure wish the IDE was better.....)


                      Arduino: 1.6.1 (Mac OS X), Board: "MoteinoMEGA"

                      SerialGateway.ino:56:26: error: no matching function for call to 'MySensor::MySensor(MyTransportRF69 (&)(), MySigningNone&)'
                      SerialGateway.ino:56:26: note: candidates are:
                      In file included from SerialGateway.ino:34:0:
                      /Users/lafleur/Desktop/MySensor-Arduino-development/libraries/MySensors/MySensor.h:78:2: note: MySensor::MySensor(MyTransport&, MyHw&, MySigning&)
                      MySensor(MyTransport &radio =*new MyTransportNRF24(), MyHw &hw=*new MyHwDriver()
                      ^
                      /Users/lafleur/Desktop/MySensor-Arduino-development/libraries/MySensors/MySensor.h:78:2: note: no known conversion for argument 1 from 'MyTransportRF69()' to 'MyTransport&'
                      /Users/lafleur/Desktop/MySensor-Arduino-development/libraries/MySensors/MySensor.h:69:7: note: MySensor::MySensor(const MySensor&)
                      class MySensor
                      ^
                      /Users/lafleur/Desktop/MySensor-Arduino-development/libraries/MySensors/MySensor.h:69:7: note: candidate expects 1 argument, 2 provided
                      Error compiling.

                      hekH 1 Reply Last reply
                      0
                      • L lafleur

                        I had done that, getting error...

                        Some questions:

                        I notice that the MyTransportNRF24 had definition for the pins in the function, RM69, has none...
                        I take it, its defaulted to the Moteino standards pinout?

                        The file MyHwATMega328.cpp is for the 328, i assume that I would need to make one for the ATmega1284P chip? if there are any changes needed.

                        Thanks I will work on these error, if you have any insight on cause, please let me know...

                        (sure wish the IDE was better.....)


                        Arduino: 1.6.1 (Mac OS X), Board: "MoteinoMEGA"

                        SerialGateway.ino:56:26: error: no matching function for call to 'MySensor::MySensor(MyTransportRF69 (&)(), MySigningNone&)'
                        SerialGateway.ino:56:26: note: candidates are:
                        In file included from SerialGateway.ino:34:0:
                        /Users/lafleur/Desktop/MySensor-Arduino-development/libraries/MySensors/MySensor.h:78:2: note: MySensor::MySensor(MyTransport&, MyHw&, MySigning&)
                        MySensor(MyTransport &radio =*new MyTransportNRF24(), MyHw &hw=*new MyHwDriver()
                        ^
                        /Users/lafleur/Desktop/MySensor-Arduino-development/libraries/MySensors/MySensor.h:78:2: note: no known conversion for argument 1 from 'MyTransportRF69()' to 'MyTransport&'
                        /Users/lafleur/Desktop/MySensor-Arduino-development/libraries/MySensors/MySensor.h:69:7: note: MySensor::MySensor(const MySensor&)
                        class MySensor
                        ^
                        /Users/lafleur/Desktop/MySensor-Arduino-development/libraries/MySensors/MySensor.h:69:7: note: candidate expects 1 argument, 2 provided
                        Error compiling.

                        hekH Offline
                        hekH Offline
                        hek
                        Admin
                        wrote on last edited by
                        #223

                        @lafleur

                        Yeah, the work on the TransportRF69 need some polishing. It defaults to monteino pins right now. If you have the time add configuration to the driver, please help out.

                        I don't have any MonteinoMega so I really don't know how it differs regarding hw. Hopefully not too much.

                        1 Reply Last reply
                        0
                        • L Offline
                          L Offline
                          lafleur
                          wrote on last edited by
                          #224

                          I get the same error's if I select the standard Moteino and the RF24 radio???

                          so, I must have a version skew or IDE issue...

                          I'm using the source code form the development branch....

                          Arduino: 1.6.1 (Mac OS X), Board: "Moteino"

                          SerialGateway.ino:57:26: error: no matching function for call to 'MySensor::MySensor(MyTransportNRF24&, MySigningNone&)'
                          SerialGateway.ino:57:26: note: candidates are:
                          In file included from SerialGateway.ino:34:0:
                          /Users/lafleur/Desktop/MySensor-Arduino-development/libraries/MySensors/MySensor.h:78:2: note: MySensor::MySensor(MyTransport&, MyHw&, MySigning&)
                          MySensor(MyTransport &radio =*new MyTransportNRF24(), MyHw &hw=*new MyHwDriver()
                          ^
                          /Users/lafleur/Desktop/MySensor-Arduino-development/libraries/MySensors/MySensor.h:78:2: note: no known conversion for argument 2 from 'MySigningNone' to 'MyHw&'
                          /Users/lafleur/Desktop/MySensor-Arduino-development/libraries/MySensors/MySensor.h:69:7: note: MySensor::MySensor(const MySensor&)
                          class MySensor
                          ^
                          /Users/lafleur/Desktop/MySensor-Arduino-development/libraries/MySensors/MySensor.h:69:7: note: candidate expects 1 argument, 2 provided
                          Error compiling.

                          This report would have more information with
                          "Show verbose output during compilation"
                          enabled in File > Preferences.

                          1 Reply Last reply
                          0
                          • ? Offline
                            ? Offline
                            A Former User
                            wrote on last edited by
                            #225

                            @lafleur:
                            I got the same error, also 1.6.1 (Mac OSX) board Uno, and Nano. My solution was to remove the signing object in the initialization:

                            // Construct MySensors library
                            MySensor gw(radio);
                            

                            Then it compiles without issues. I have other issues though, but they might be related to the radios.

                            1 Reply Last reply
                            0
                            • L Offline
                              L Offline
                              lafleur
                              wrote on last edited by
                              #226

                              removing the Construct object, will cause other error, as the gw is not defined at this point...

                              SerialGateway.ino: In function 'void setup()':
                              SerialGateway.ino:67:3: error: 'gw' was not declared in this scope
                              SerialGateway.ino: In function 'void loop()':
                              SerialGateway.ino:85:3: error: 'gw' was not declared in this scope

                              I'm new to Arduino and this IDE, so it painful trying to work my way into this code...

                              1 Reply Last reply
                              0
                              • K Offline
                                K Offline
                                kolaf
                                Hero Member
                                wrote on last edited by
                                #227

                                Hi guys,

                                I lost some of my inspiration when I couldn't get the RF69 implementation to be stable for more than a few days and TOSA said he could before he disappeared without telling me how :-(. However, Easter is upon us and I thought I would give it another try.

                                I updated to the latest version of the development branch, and things seem to have changed a bit since I was here last time. Is there anything that needs to be updated on the RF69 side? At the very least it seems to be missing a definition for IS_RF69HW, as well as probably some useful defaults.

                                1 Reply Last reply
                                0
                                • K Offline
                                  K Offline
                                  kolaf
                                  Hero Member
                                  wrote on last edited by
                                  #228

                                  I also note that there now is an include for a specific radio in the serial Gateway example. This is different from the way it was earlier where the radio type was defined in MyConfig. Wasn't this a better solution?

                                  Anyway, is it sufficient simply to change the included radio and then expect the serial Gateway code to work correctly on a moteino?

                                  hekH 1 Reply Last reply
                                  0
                                  • K kolaf

                                    I also note that there now is an include for a specific radio in the serial Gateway example. This is different from the way it was earlier where the radio type was defined in MyConfig. Wasn't this a better solution?

                                    Anyway, is it sufficient simply to change the included radio and then expect the serial Gateway code to work correctly on a moteino?

                                    hekH Offline
                                    hekH Offline
                                    hek
                                    Admin
                                    wrote on last edited by
                                    #229

                                    @kolaf

                                    The defines in MyConfig started to become a big mess. Especially if we would want to have a Moteino variant of the gateways downloadable using codebender.

                                    Ok, just updated gateway classes to include the available options like this:

                                    // NRFRF24L01 radio driver (set low transmit power by default) 
                                    MyTransportNRF24 transport(RF24_CE_PIN, RF24_CS_PIN, RF24_PA_LEVEL_GW);  
                                    //MyTransportRF69 transport;
                                    
                                    // Message signing driver (signer needed if MY_SIGNING_FEATURE is turned on in MyConfig.h)
                                    //MySigningNone signer;
                                    //MySigningAtsha204Soft signer;
                                    //MySigningAtsha204 signer;
                                    
                                    // Hardware profile 
                                    MyHwATMega328 hw;
                                    
                                    // Construct MySensors library (signer needed if MY_SIGNING_FEATURE is turned on in MyConfig.h)
                                    MySensor gw(transport, hw /*, signer*/);
                                    
                                    

                                    So you should only have to enable the one you want to use. Do the same in the sensor/actuator sketch (haven't updated all of them yet).

                                    1 Reply Last reply
                                    0
                                    • D Offline
                                      D Offline
                                      dzairo
                                      wrote on last edited by
                                      #230

                                      .. and hardware distance test? rfm69hw have +20dB .. pls make test in building .. or make compare test with nRF24L01+ ..
                                      we waiting for this ..
                                      best regards..

                                      hekH 1 Reply Last reply
                                      0
                                      • D dzairo

                                        .. and hardware distance test? rfm69hw have +20dB .. pls make test in building .. or make compare test with nRF24L01+ ..
                                        we waiting for this ..
                                        best regards..

                                        hekH Offline
                                        hekH Offline
                                        hek
                                        Admin
                                        wrote on last edited by
                                        #231

                                        @dzairo said:

                                        we waiting for this

                                        I'm waiting also. Please do the test @dzairo!

                                        1 Reply Last reply
                                        0
                                        • D Offline
                                          D Offline
                                          dzairo
                                          wrote on last edited by
                                          #232

                                          sorry .. is possible make test with this module if you have it ?
                                          I can compare only nrf24l01+ with cc1101 868mhz ..
                                          in free area is possible with standard nrf24l01+ with good antenna from wifi get 200m .. pcb antenna give less then 30m . rfm69hw is good because is possible set lowe transfer speed less then in nrf24l01+ ..
                                          if make test with CC1101 868mhz version with +14dB output power then no problem get distance in my house 3 floor ..

                                          best regards

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


                                          21

                                          Online

                                          11.7k

                                          Users

                                          11.2k

                                          Topics

                                          113.0k

                                          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