-
-
Notifications
You must be signed in to change notification settings - Fork 694
SubGhz: Fix Honeywell Security and TX141THBv2 save/load #513
Comments
Would like to add that there seems to be another issue involved with this protocol. If you read the signal (not raw) and it comes up as Honeywell Security, then open it to inspect it will give you the serial number, channel etc. |
cc @htotoo i tried to make sense of the code but don't see anything inherently wrong. only thing is maybe the bit count, saw that one of the two deserialize functions for honeywell sec protocol enforces bit count, while some of your comments mention something about 62 bits + 2 hardcoded at the start? maybe its saved with all 64 bits but checked for no clue, just giving ideas, altho the last one seems the most logical explanation to me if you can provide a raw file i can try to investigate further @X3r0C00L , i dont have access to a system using this protocol. feel free to message me on our discord if you prefer while im pinging you @htotoo , i also wanted to ask a few things about the protocol integrations you made in #399 :
|
actually just found a raw file from the bounty channel first asking for honeywell sec to be implemented, can replicate the issue. ill try to figure this out but no promises, still easier if we hear back from htotoo probably. also found example files for TX141THBv2 here, noticed that 40bit loads, 41bit doesnt, my guess is its the same check for bit count thats the issue, ill see now |
DoorSensor.txt |
i think i have found the issue. it is not a bit count issue, its a logic issue. when decoding in real time, the decoder is fed data received and tries to match the protocol and understand it. when it succeeds, it copies the result to generic data instance. then when saving, the generic helper uses generic instance to save to file. then when loading from file, it loads into generic instance. issue is that the protocol only copies from decode into generic on successful decode, and load always puts it into generic, while the rest of the protocol always reads from decode data, not from generic data. it works right after receiving only because th decoded data is not reset. however i suspect that in current state, if you receive 2 different honeywell sec signals, no matter which one you open from the history, it will show the data of latest one, since it is the last one to be decoded, and protocol looks at decoded data not loaded data. looking at how other protocols handle this, it seems like decode data buffer should only be used when decoding, and copied into generic data right after successful decode. after that, all logic should read from generic data. this way, even loading from data allows protocol to function correctly. also an update on TX141THBv2, it was indeed a 40/41 bit conflict issue, i have fixed this, will push soon |
actually i was partially wrong. the protocol does only use decode data while decoding, then later always reads from generic data. the issue is that the decode fills in the specific protocol info like serial number, btn, heartbeat and so on that are used to show info on screen, while load from file doesnt. quick look at the code makes me think that this is onloy a visual glitch, atleast the serial number stored after decoding is not used anywhere except in showing info on screen, so maybe sending it still works as normal? can you try that @X3r0C00L ? |
either way its fixed now |
When it is made I tested the load and save (for Honeywell) it worked, and the structure is from another weather proto, so there maybe another issue with loading (if i didn't messed up something, and didn't noticed). Anyway, thanks for looking into it and fixed! |
perfect, thanks |
Thanks a bunch. Super awesome work. |
Describe the bug.
Ive use the read function under subghz on 345mhz and read some honeywell security protocol signals. But when I save them and go to reopen them it either opens it up but all the data are zeros, or it wont open and says protocol missing.
This is on latest version of xtreme.
Ive went back and recorded the signal raw and then transmitted it to my other flipper and read it and saved it and same issue.
Reproduction
Read signal in SubGHZ, itll display honeywell security protocol. view signal and it looks good. shows serial number channel etc.
Save signal and then try to reopen it and it fails.
Target
No response
Logs
No response
Anything else?
No response
The text was updated successfully, but these errors were encountered: