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. Controllers
  3. Home Assistant
  4. MySensor on Hass.io - can't get it work

MySensor on Hass.io - can't get it work

Scheduled Pinned Locked Moved Home Assistant
28 Posts 6 Posters 9.9k Views 6 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.
  • N nelsonov

    Are you sure that's the right device? It's /dev/ttyUSB0 that is the source of the error in your output. Maybe the device is something like /dev/ttyAMA0 or /dev/ttyACM0?

    MaTyM Offline
    MaTyM Offline
    MaTy
    wrote on last edited by MaTy
    #12

    @nelsonov
    when i use "hassio homeassistant hardware" command it displays only ttyUSB0 and ttyUSB1. I have RFLink connected to USB1 and it works great, so MySensors gateway must be the ttyUSB0.
    https://pastebin.com/wTn72d1D Am I right?

    1 Reply Last reply
    0
    • N Offline
      N Offline
      nelsonov
      wrote on last edited by nelsonov
      #13

      What do you get from ls -l /dev/tty*?

      https://keybase.io/nelsonov

      MaTyM 1 Reply Last reply
      0
      • N nelsonov

        What do you get from ls -l /dev/tty*?

        MaTyM Offline
        MaTyM Offline
        MaTy
        wrote on last edited by MaTy
        #14

        @nelsonov resault
        https://ibb.co/cyPQqG

        1 Reply Last reply
        0
        • MaTyM Offline
          MaTyM Offline
          MaTy
          wrote on last edited by
          #15

          After I disconnected gateway and connected it again, I checked command "dmesg | grep usb" and this showed up
          https://hastebin.com/leqocowaco.vbs before there was nothing after command. Command ls -l /dev/tty* still the same.

          1 Reply Last reply
          0
          • N Offline
            N Offline
            nelsonov
            wrote on last edited by nelsonov
            #16

            You might need to take this to the [Home Assistant Forum]
            (https://community.home-assistant.io). Something strange is going on at the OS level. Your kernel is recognizing the USB device, but the OS isn't creating the tty. You can try lsusb just to see if it's still there, but beyond that I'm out of advice. The error you are getting from Home Assistant has awkward wording, but it means that it can't find the serial device.

            https://keybase.io/nelsonov

            1 Reply Last reply
            0
            • MaTyM MaTy

              @martinhjelmare

              Oh, sorry, im so confused after I moved from domoticz to Hass.io. But I don't need Z-wave. What I have is serial gateway based on arduino mega 2560, with a sketch (example) https://hastebin.com/cinokiraka.cpp which controles all lights in my house. The arduino mega is connected to my RPI3 (with Hass.io) via usb (ttyUSB0). It worked perfectly on Domoticz, all lights was discovered automatically. I've checked the documentation of MySensors implementation on Hass.io web site, and read plenty of forums and still nothing :/
              I'm still getting errors. https://pastebin.com/VDaVRKkV

              martinhjelmareM Offline
              martinhjelmareM Offline
              martinhjelmare
              Plugin Developer
              wrote on last edited by martinhjelmare
              #17

              @maty
              If you read the Z-wave documentation I linked to you will get instructions how to add a specific USB device to Hass.io docker. My guess is this could solve your problem.

              For some devices the /dev/ttyAMA0 device is not detected by udev and is therefore not mapped by Docker. To explicitly set this device for mapping to Home-Assistant, execute the following command using the ssh add-on:

              $ curl -d '{"devices": ["ttyAMA0"]}' http://hassio/homeassistant/options
              

              Replace ttyAMA0 above with the correct device in your case.

              MaTyM 1 Reply Last reply
              0
              • martinhjelmareM martinhjelmare

                @maty
                If you read the Z-wave documentation I linked to you will get instructions how to add a specific USB device to Hass.io docker. My guess is this could solve your problem.

                For some devices the /dev/ttyAMA0 device is not detected by udev and is therefore not mapped by Docker. To explicitly set this device for mapping to Home-Assistant, execute the following command using the ssh add-on:

                $ curl -d '{"devices": ["ttyAMA0"]}' http://hassio/homeassistant/options
                

                Replace ttyAMA0 above with the correct device in your case.

                MaTyM Offline
                MaTyM Offline
                MaTy
                wrote on last edited by MaTy
                #18

                @martinhjelmare
                I did It. resault But I'm still getting errors :/

                I guess I'm hopeless. It's probably sthg silly as always.

                update:
                after trying different solutions i typed hardware check command and new serial appeared 'AMA0' but I did nothing physically with RPi (din't attach any devices). I tried to check mysensors config with ttyAMA0 instead of USB0, but I still got the same resault.
                ps. of course when I was trying your command ($ curl -d '{"devices": ["ttyAMA0"]}' http://hassio/homeassistant/options), I did it with USB0 parameter, not AMA0.

                1 Reply Last reply
                0
                • MaTyM Offline
                  MaTyM Offline
                  MaTy
                  wrote on last edited by MaTy
                  #19

                  Yesterday I accidentally restarted Hass.io with all that errors in config. I was afraid that it'll crush after restart but it actually worked. After restart I turned on switch on the wall, and Switch (light relay) appeared on Hass.io home screen.

                  There are still the same errors in config, and I have some issues with those light switches. Most annoying issue is that Hass.io doesn't update switch state after change via gui. Switch state changes in Hass.io when i use manual switch on the wall but when I use gui it doesn't
                  http://ibb.co/f8Rvum

                  martinhjelmareM 1 Reply Last reply
                  0
                  • MaTyM MaTy

                    Yesterday I accidentally restarted Hass.io with all that errors in config. I was afraid that it'll crush after restart but it actually worked. After restart I turned on switch on the wall, and Switch (light relay) appeared on Hass.io home screen.

                    There are still the same errors in config, and I have some issues with those light switches. Most annoying issue is that Hass.io doesn't update switch state after change via gui. Switch state changes in Hass.io when i use manual switch on the wall but when I use gui it doesn't
                    http://ibb.co/f8Rvum

                    martinhjelmareM Offline
                    martinhjelmareM Offline
                    martinhjelmare
                    Plugin Developer
                    wrote on last edited by martinhjelmare
                    #20

                    @maty

                    You should send feedback of state changes to home assistant from your device. This is done from the receive function. The switch in home assistant will switch as soon as the feedback comes in.

                    Also set optimistic to false in your mysensors config section.

                    MaTyM 1 Reply Last reply
                    0
                    • martinhjelmareM martinhjelmare

                      @maty

                      You should send feedback of state changes to home assistant from your device. This is done from the receive function. The switch in home assistant will switch as soon as the feedback comes in.

                      Also set optimistic to false in your mysensors config section.

                      MaTyM Offline
                      MaTyM Offline
                      MaTy
                      wrote on last edited by MaTy
                      #21

                      @martinhjelmare
                      You mean in my sketch, something like this?

                      void receive(const MyMessage &message) {
                        // We only expect one type of message from controller. But we better check anyway.
                        if (message.type==V_LIGHT) {
                           // Change relay state
                           digitalWrite(message.sensor-1+RELAY_1, message.getBool()?RELAY_ON:RELAY_OFF);
                           // Store state in eeprom
                           saveState(message.sensor, message.getBool());
                           // Write some debug info
                           Serial.print("Incoming change for sensor:");
                           Serial.print(message.sensor);
                           Serial.print(", New status: ");
                           Serial.println(message.getBool());
                      

                      I had optimistic set false.

                      BTW: Strange thing, baud rate in my sketch is 38400, but when I set it up in Hass.io, lights won't work, when I changed to 115200 in .yaml (in sketch is still 38400), all works fine, except the states update.

                      martinhjelmareM 1 Reply Last reply
                      0
                      • MaTyM MaTy

                        @martinhjelmare
                        You mean in my sketch, something like this?

                        void receive(const MyMessage &message) {
                          // We only expect one type of message from controller. But we better check anyway.
                          if (message.type==V_LIGHT) {
                             // Change relay state
                             digitalWrite(message.sensor-1+RELAY_1, message.getBool()?RELAY_ON:RELAY_OFF);
                             // Store state in eeprom
                             saveState(message.sensor, message.getBool());
                             // Write some debug info
                             Serial.print("Incoming change for sensor:");
                             Serial.print(message.sensor);
                             Serial.print(", New status: ");
                             Serial.println(message.getBool());
                        

                        I had optimistic set false.

                        BTW: Strange thing, baud rate in my sketch is 38400, but when I set it up in Hass.io, lights won't work, when I changed to 115200 in .yaml (in sketch is still 38400), all works fine, except the states update.

                        martinhjelmareM Offline
                        martinhjelmareM Offline
                        martinhjelmare
                        Plugin Developer
                        wrote on last edited by
                        #22

                        @maty

                        In your example above you never send the feedback from receive. Use the send method
                        from within receive to do that.

                        In what sketch have you set baud rate to 38400? For the light device or for the gateway? It's only the gateway baud rate that is relevant for home assistant config, since it's the gateway that interfaces via the serial connection to home assistant.

                        MaTyM 1 Reply Last reply
                        0
                        • martinhjelmareM martinhjelmare

                          @maty

                          In your example above you never send the feedback from receive. Use the send method
                          from within receive to do that.

                          In what sketch have you set baud rate to 38400? For the light device or for the gateway? It's only the gateway baud rate that is relevant for home assistant config, since it's the gateway that interfaces via the serial connection to home assistant.

                          MaTyM Offline
                          MaTyM Offline
                          MaTy
                          wrote on last edited by MaTy
                          #23

                          @martinhjelmare

                          Should it be something like this added to my sketch?

                          send(msg.set(RELAY_1;V_LIGHT)
                          send(msg.set(RELAY_2;V_LIGHT)
                          ...
                          

                          I ment BAUD_RATE defined in this sketch

                          #if F_CPU == 8000000L
                          #define MY_BAUD_RATE 38400
                          #endif
                          

                          Once again, sorry for tons of noob questions. But I didn't write that sketch by myself, and my knowledge about programming is below basic.

                          1 Reply Last reply
                          0
                          • martinhjelmareM Offline
                            martinhjelmareM Offline
                            martinhjelmare
                            Plugin Developer
                            wrote on last edited by
                            #24

                            Something like this:

                            send(msg.set(state));
                            

                            The arduino mega runs at 16 MHz so that if block won't be entered, and the define of baud rate won't change.

                            MaTyM 1 Reply Last reply
                            0
                            • martinhjelmareM martinhjelmare

                              Something like this:

                              send(msg.set(state));
                              

                              The arduino mega runs at 16 MHz so that if block won't be entered, and the define of baud rate won't change.

                              MaTyM Offline
                              MaTyM Offline
                              MaTy
                              wrote on last edited by
                              #25

                              @martinhjelmare

                              Hi,
                              I checked my sketch once again, and confronted it with MySensors documentation, and I actually found the send message command in it. Should I change something to make it work properly with Hass.io

                              void loop() {
                                // Send locally attached sensor data here
                                if (debouncer.update()) {
                                  // Get the update value.
                                  int value = debouncer.read();
                                  // Send in the new value.
                                  if(value == LOW){
                                       saveState(1, !loadState(1));
                                       digitalWrite(RELAY_1, loadState(1)?RELAY_ON:RELAY_OFF);
                                       send(msg.set(loadState(1)));
                              
                              martinhjelmareM 1 Reply Last reply
                              0
                              • MaTyM MaTy

                                @martinhjelmare

                                Hi,
                                I checked my sketch once again, and confronted it with MySensors documentation, and I actually found the send message command in it. Should I change something to make it work properly with Hass.io

                                void loop() {
                                  // Send locally attached sensor data here
                                  if (debouncer.update()) {
                                    // Get the update value.
                                    int value = debouncer.read();
                                    // Send in the new value.
                                    if(value == LOW){
                                         saveState(1, !loadState(1));
                                         digitalWrite(RELAY_1, loadState(1)?RELAY_ON:RELAY_OFF);
                                         send(msg.set(loadState(1)));
                                
                                martinhjelmareM Offline
                                martinhjelmareM Offline
                                martinhjelmare
                                Plugin Developer
                                wrote on last edited by martinhjelmare
                                #26

                                @maty

                                Yes. There are two ways of interacting with the device to make a state change. Either by pressing the button or by sending a message from home assistant to the device. The send command you showed above will only happen if the button is pressed when the loop is running.

                                When you send a message from home assistant to the device, to change the state, the message will be received in your sketch by the receive function.

                                So you need to add a send command to the receive function and send the new state back to home assistant after doing the digitalWrite call and saving the state.

                                1 Reply Last reply
                                0
                                • MaTyM MaTy

                                  @tom-carpenter
                                  How did You make it? Is it via serial gateway?

                                  Tom CarpenterT Offline
                                  Tom CarpenterT Offline
                                  Tom Carpenter
                                  wrote on last edited by
                                  #27

                                  @maty Yes serial gateway hooked to the pi

                                  R 1 Reply Last reply
                                  0
                                  • Tom CarpenterT Tom Carpenter

                                    @maty Yes serial gateway hooked to the pi

                                    R Offline
                                    R Offline
                                    Rincewind
                                    wrote on last edited by
                                    #28

                                    @tom-carpenter How did you configure the serial gateway in configuration.yaml? can you please post that section?

                                    Also what arduino hardware did you use?

                                    Thanks

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


                                    22

                                    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