-
Notifications
You must be signed in to change notification settings - Fork 67
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add support for newer Ethera devices #95
base: master
Are you sure you want to change the base?
Conversation
Doesn't work as is on older devices, the initialization will just get stuck in an endless loop due to restarting at handshake 13. |
Ok, i assume on older devices it will just continue after the ignored 13/16 handshake while on ethera it will be stuck there. [00:12:26][D][panasonic_ac.dnskp11:595]: Answering handshake [12/16] [20:26:54][D][panasonic_ac.dnskp11:595]: Answering handshake [12/16] |
Restart init if ethera handshake fails on 13
I only found one other dump from the handshake 13. It appears the ethera answer to handshake 13 is alot longer than older gen devices and actually the last consistent field (5A) is not present on older gen. I have added a detection for it now. Can you please |
Still gets stuck, here's the full log: https://gist.github.com/DomiStyle/ba7520e98992b5661e9e6a9c4b662908 |
For reference, this is what a normal handshake looks like: https://gist.github.com/DomiStyle/38ec59ed4d4707f7cc9ec89ad6389abf |
match on 83 5A packet
Apparently the 5A is also sent by your unit. However it seems its possible to match on the 14 and 15th field, that is 83 and 5A - which seems consistent only on etherea. |
Is this still a thing for newer Etherea devices? How do I know if my Etherea device is still compatible with this PR? |
This pull adds support for newer Ethera devices.
Major changes required are larger buffer size (and timeout for that) since the packets are now >128 bytes big.
Also on temp change it requires field 4 to be set to 02 instead of 00 of the packet. I implented this with a quite dirty hack and
if there is a better way to do it - please change it.
Also changed INIT_END_TIMEOUT and INIT_FAIL_TIMEOUT due to initialization restarts requiring this (or component will fail before restarted init could complete). Needed this since from time to time it would stop at handshake 13 and just hang there.
With this change it will directly restart initialization if it encounters the handshake 13 and in my tests it always succeeds the init after that.
All of these changes should have no impact on other generations of panasonic ACs besides the temp change field "hack". I dont have access to different panasonic equipment so i cant test this and see if others are fine with the change, too.
Maybe some special config flag for the YAML should be added to implent the 02 field for ethera devices to avoid bricking support for other devices.