Hello. I’m having trouble with connecting living connect thermostat. Using yesterday’s snapshot.
I can add thermostat, but I can’t see wakeup options after, cause of error below. (full debug log: http://pastebin.com/5DWqafig )
2017-01-09 20:58:26.997 [INFO ] [g.discovery.internal.PersistentInbox] - Added new thing ‘zwave:device:zwave:node2’ to inbox.
2017-01-09 20:58:35.921 [WARN ] [ding.zwave.handler.ZWaveThingHandler] - NODE 2: Initialising Thing Node…
2017-01-09 20:58:46.350 [WARN ] [tocol.commandclass.ZWaveCommandClass] - NODE 2: Unknown command class 0x91
2017-01-09 20:58:46.386 [WARN ] [tocol.commandclass.ZWaveCommandClass] - NODE 2: Unknown command class 0x91
2017-01-09 20:58:46.435 [WARN ] [ding.zwave.handler.ZWaveThingHandler] - NODE 2: Initialising Thing Node…
2017-01-09 20:58:46.445 [ERROR] [ve.internal.protocol.ZWaveController] - Exception during ZWave thread: Input 2. {}
java.lang.IllegalStateException: Could not update status, because callback is missing
at org.eclipse.smarthome.core.thing.binding.BaseThingHandler.updateStatus(BaseThingHandler.java:388)[105:org.eclipse.smarthome.core.thing:0.9.0.201701090931]
at org.eclipse.smarthome.core.thing.binding.BaseThingHandler.updateStatus(BaseThingHandler.java:415)[105:org.eclipse.smarthome.core.thing:0.9.0.201701090931]
at org.openhab.binding.zwave.handler.ZWaveThingHandler.ZWaveIncomingEvent(ZWaveThingHandler.java:1178)[182:org.openhab.binding.zwave:2.0.0.201701091302]
at org.openhab.binding.zwave.internal.protocol.ZWaveController.notifyEventListeners(ZWaveController.java:567)[182:org.openhab.binding.zwave:2.0.0.201701091302]
at org.openhab.binding.zwave.internal.protocol.initialization.ZWaveNodeInitStageAdvancer.advanceNodeStage(ZWaveNodeInitStageAdvancer.java:1117)[182:org.openhab.binding.zwave:2.0.0.201701091302]
at org.openhab.binding.zwave.internal.protocol.initialization.ZWaveNodeInitStageAdvancer.handleNodeQueue(ZWaveNodeInitStageAdvancer.java:230)[182:org.openhab.binding.zwave:2.0.0.201701091302]
at org.openhab.binding.zwave.internal.protocol.initialization.ZWaveNodeInitStageAdvancer.ZWaveIncomingEvent(ZWaveNodeInitStageAdvancer.java:1306)[182:org.openhab.binding.zwave:2.0.0.201701091302]
at org.openhab.binding.zwave.internal.protocol.ZWaveController.notifyEventListeners(ZWaveController.java:567)[182:org.openhab.binding.zwave:2.0.0.201701091302]
at org.openhab.binding.zwave.internal.protocol.ZWaveController.handleIncomingResponseMessage(ZWaveController.java:293)[182:org.openhab.binding.zwave:2.0.0.201701091302]
at org.openhab.binding.zwave.internal.protocol.ZWaveController.handleIncomingMessage(ZWaveController.java:217)[182:org.openhab.binding.zwave:2.0.0.201701091302]
at org.openhab.binding.zwave.internal.protocol.ZWaveController.access$7(ZWaveController.java:208)[182:org.openhab.binding.zwave:2.0.0.201701091302]
at org.openhab.binding.zwave.internal.protocol.ZWaveController$ZWaveInputThread.run(ZWaveController.java:1324)[182:org.openhab.binding.zwave:2.0.0.201701091302]
2017-01-09 20:58:46.450 [WARN ] [ding.zwave.handler.ZWaveThingHandler] - NODE 2: Initialising Thing Node…
2017-01-09 20:58:51.430 [ERROR] [ocol.ZWaveController$ZWaveSendThread] - NODE 255: Timeout while sending message. Requeueing - 2 attempts left!
Is this device already fully initialized? The options are only available if the initialization was fully finished. You can check first if the xml file for this node was already created. Otherwise you should manually wakeup the device some more times.
It looks like node2 is not really fully initialized.
All steps:
Unpack openhab and launch
Install zwave binding and habmin
In paper ui add zwave stick (aeon labs) with all default params (just setted up port /dev/ttyACM0)
In habmin started discovery.
Pressed central (wakeup) button on Thermostat. And node2 appeared in list.
Added node2, but it was shown as ‘unknown node’
I’ve pressed wakeup button on thermostat once more. And ‘unknown node’ transformed to ‘LC-13 Living Connect thermostat’. And I was able to see exception in log right in that moment.
I’ve one more openhab-2 install (late november snapshot) in other place with such thermostat and node’s xml really differs.
Looks all good (except the exception ). If the xml is there and the node changed from unknown to LC-13, I think it is fully initialized.
Can you post a screenshot from your available configuration options of the device in habmin? So I can see if that differs to my options (I have several working LC-13 here).
This is not so uncommon. The binding is in active development and there could have been changes from late november to now which result in other xml files.
Yes, you are right. This xml doesn’t seem to be complete.
I would suggest: delete the xml file (only the node 2 file, not the controller node 1 file), delete the node 2 thing in habmin. Then re-add the device again (no new inclusion, only re-add it). Do 2-3 manual wakeups, until the xml is created and until the thing is properly discovered in habmin. After that, have a look at the xml file and at the configuration options in habmin to see, if everything has worked out. Furthermore, have a look at the log during this process to see, if the exception comes up again.
If this doesn’t help, we have to ask Chris (the binding developer) if he can help. But for sure he want’s a DEBUG log then.
Thanks. I will do that and will get back. Hopefully this thread will be helpfull for others.
Also I’ve tried to do hard reset of zwave stick before the experiment, but according to logs there may be chance that stick was not resetted. May be this is also the case. I will try to redo all from the beginning once more.
p.s.: I’ve already ‘added’ full debug log in first post.
I’ve analyzed debug log myself and found strange stuff. It seems that thermostat does not report any valid command class except MANUFACTURER_PROPRIETARY…
Yes. That’s what I had in mind when I asked him about the part number. There are different versions (hw and sw) of the Thermostat and some of them don’t speak zwave. Now we know for sure. Thanks.
Sorry for misunderstanding at the beginning.
Generally they ‘speak’ zwave (radio is zwave compatible), but with custom binary protocol. And this makes them unusable for usual software.