Skip to content
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 Q-walk_by to Wireless-MBus #2997

Draft
wants to merge 5 commits into
base: master
Choose a base branch
from
Draft

Conversation

zuckschwerdt
Copy link
Collaborator

As analyzed an protoyped by Detlef (Boing) Hassper

@merbanan
Copy link
Owner

LGTM

@zuckschwerdt
Copy link
Collaborator Author

zuckschwerdt commented Jul 14, 2024

TODO:

  • Binary int vs BCD for the values?
  • DATA_COND vs an new else if
  • CI == 0x78 in output vs a flag on block1
  • role of A_DevType for this mode?

@zuckschwerdt
Copy link
Collaborator Author

zuckschwerdt commented Jul 15, 2024

@merbanan checking the offsets in parsing block 2 I stumbled upon the CRC data, the application specific payload for QDS 0x78 seems to span 3 blocks.
Is there a particular reason to feed link-layer data (data->in) to parse_block2() or should we maybe feed the application-layer data (payload, data->out)? I.e. perhaps make that parse_block2pp()?
Or should parse_block2() employ it's own checks and "de-blocking" for needed further blocks? Although I'm not clear on wether all further blocks will actually be 16 bytes wide?

edit Or maybe we should not parse a payload in parse_block2() but rather branch parse_payload() for QDS… seems like that was the intended flow.

@merbanan
Copy link
Owner

@merbanan checking the offsets in parsing block 2 I stumbled upon the CRC data, the application specific payload for QDS 0x78 seems to span 3 blocks. Is there a particular reason to feed link-layer data (data->in) to parse_block2() or should we maybe feed the application-layer data (payload, data->out)? I.e. perhaps make that parse_block2pp()? Or should parse_block2() employ it's own checks and "de-blocking" for needed further blocks? Although I'm not clear on wether all further blocks will actually be 16 bytes wide?

It sounds like this is not really wmbus/OMS compliant data. In that case it can be whatever.

edit Or maybe we should not parse a payload in parse_block2() but rather branch parse_payload() for QDS… seems like that was the intended flow.

I dont really understand, can you post a few telegrams ?

@merbanan
Copy link
Owner

@zuckschwerdt
Copy link
Collaborator Author

Test data for -y is
55555555543d54cd49449344259764131806fa2f780dff5f3500828a0000110007c113ff5d24ff69540400ff2c452304001e36325104720200780000005d00140026005100000000aa8f0000005a0093002a002f046d02090f37537270
which is

in  : 494493442597641318 06 fa2f 780dff5f 3500828a0000110007c113ff 5d24 ff 69540400 ff2c 45230400 1e36 325104 7202 00 780000005d00140026005100000000 aa8f 0000005a0093002a00
out : 474493442597641318 06  CRC 780dff5f 3500828a0000110007c113ff  CRC ff 69540400 ff2c 45230400 1e36 325104  CRC 00 780000005d00140026005100000000  CRC 0000005a0093002a002f046d02090f37 5372
                                                                           ^^^^^^^^      ^^^^^^^^      ^^^^^^      ^^

the marked (8 char) BCDs are decoded by this PR.

@zuckschwerdt
Copy link
Collaborator Author

I guess I answered my own question, parse_block2() should just parse the block2 headers and full payload should be parsed in parse_payload(). There we can simply place a switch to not assume standard data when custom QDS is detected.

@merbanan
Copy link
Owner

If applicable send some telegrams to the wmbusmeeters projects @weetmuts.

But from your comments it sounds like the correct place to add handling of non standards compliant data data.

@zuckschwerdt
Copy link
Collaborator Author

@merbanan
Copy link
Owner

@weetmuts I guess the red part is think that is currently unknown in wmbusmeters. If you look at the patch you can see that some of the unknown things are at an offset of 10.

@weetmuts
Copy link

Yes manufacturer specific binary blobs inside a wmbus telegram are colored red. Any driver specific decoding that extracts from this blob are then printe below ***.

@weetmuts
Copy link

Wmbusmeters focuses on mbus compliant meter values. For all these it is now possible to write text drivers that can be loaded at runtime.
https://github.com/wmbusmeters/wmbusmeters/blob/master/drivers/src/eltako.xmq

But if someone cares to decode mfct specific data this decoding will be in the processContent function in driver cc source file.
https://github.com/wmbusmeters/wmbusmeters/blob/master/src/driver_qwater.cc

@weetmuts
Copy link

But the mftct specific blob will still be red even after some parts of it has been decoded. You see the *** as proof that something was extracted.

@merbanan
Copy link
Owner

So this is missing from the driver ?

di.addDetection(MANUFACTURER_QDS, 0x08, 0x35);

With regards to being able to parse the HCA telegram.

@merbanan
Copy link
Owner

Well I guess detect. Parsing might need more stuff.

@merbanan
Copy link
Owner

@weetmuts looks like that is the only part missing for HCA support.

@merbanan
Copy link
Owner

@weetmuts I have opened a ticket :).

@AkaBoing
Copy link

some more QDS hca CI fields
780dff5f3500823b0000ee0007b06effff10000000ff2c510000001e360800000009000c000c00000001000000cdff000000000000030005002f046d190812373588
780dff5f350082af0000800007b06effff35020000ff2c780500001e363502000003000300020017006400870047fe32002c000300000001002f046d23081237290b
780dff5f3500823c0000ef0007b06effff10000000ff2c510000001e360800000009000c000c00000001000000cdff000000000000030005002f046d21081237f1f9
780dff5f350082af00000e0007b06effff35020000ff2c780500001e363502000003000300020017006400870047fe32002c000300000001002f046d25081237b3ab
780dff5f350082b00000600107b06effff35020000ff2c780500001e363502000003000300020017006400870047fe32002c000300000001002f046d27081237c5cb
780dff5f3500823d00005f0107b06effff10000000ff2c510000001e360800000009000c000c00000001000000cdff000000000000030005002f046d260812375069
780dff5f350082b00000110007b06effff35020000ff2c780500001e363502000003000300020017006400870047fe32002c000300000001002f046d2c0812376c7e
780dff5f350082b100005e0107b06effff35020000ff2c780500001e363502000003000300020017006400870047fe32002c000300000001002f046d2e0812371a1e

@AkaBoing
Copy link

Good work.
short way from draft to final i think

@AkaBoing
Copy link

2nd change with timestamps compiled and running
thx

@AkaBoing
Copy link

changes from 21.7.2024 19:45 compiled and running.
thx

@zuckschwerdt
Copy link
Collaborator Author

Reading some values for HCA I get the keys
"inst_hca_0", "inst_date_1", "inst_hca_1", "inst_date_17", "inst_hca_17", "inst_timedate_0"
pretty names are
"HCA[0]", "Date[1]", "HCA[1]", "Date[17]", "HCA[17]", "TimeDate[0]"
which looks useable.

But for reading values for Warm Water I get the keys
"inst_volume_0", "inst_date_1", "inst_volume_1", "inst_date_17", "inst_volume_m10_9", "inst_timedate_0"
pretty names are
"Volume[0]", "Date[1]", "Volume[1]", "Date[17]", "Volume of month -10", "TimeDate[0]"

Note the key "inst_volume_m10_9" (pretty: "Volume of month -10").
(mapped by https://github.com/jedi7/rtl_433/blob/master/src/devices/m_bus.c#L198)

I guess this special decoding is some OMS extension? Is this even used with Wireless MBus?
Shouldn't we simply output the "17" postfixed key?

This change was added with #1610 from @jedi7 -- was this a bulk change "by spec" or is this actually used?

Is it possible to limit the renaming to detected OMS messages?

At a minimum the _9 suffix is plain wrong. It should not be there as _m10 (month ten) is already added, and the real storage number is 17, not the adjusted value for the months table. (Bug is https://github.com/jedi7/rtl_433/blob/master/src/devices/m_bus.c#L537)

@AkaBoing
Copy link

The OMS specs (the findable) are from 2008, a few from 2014, all for wired "M-Bus" devices. "EN 1434"
Wireless M-Bus started 2018 (Europe) now EN 1434-4 (costs 212 Euro+)
in short: "inst_date_17", "inst_volume_17" is OK for me.
just my 17cents

@AkaBoing
Copy link

QDS HCA: desciption

consumption current total : 235
Deadline : MD 31.12
consumption Deadline : 578
last month Date : MD 07.30
consumption last month : 190
check number : c 3360 P
K-Level :060
Identifier Info : FC-2.2 S
: Ident Q-walk_by & Q-AMR Mode C
: algorithm 20x
: 2-sensor measuring system

@AkaBoing
Copy link

QDS Warm Water
Error Code if present : b43
Error Date : MDY 24.12.16
cum. volume : 1.823 m3
Deadline : MDY 31.12.23
consumption Deadline : : 1.567 m3
last month Date : MD 07.30
consumption last month : 0.302 m3
Identifier Info :FC C 7908 Mode C

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants