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.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.
  • G Offline
    G Offline
    guillaume brucker
    wrote on last edited by guillaume brucker
    #212

    Hi all,

    Happy new year
    I've just have the same idea, I'm new to arduino since chrismas :)
    and I want to test mysensor with nrf905, It seem to be compatible with RH librairies.

    Could you just say me what i have to do ?
    I'll have to include the kolaf librairies ?

    Just, If you have a link to the repository in order to work on it with you

    Thanks for all

    1 Reply Last reply
    0
    • 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
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          11

                                          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