]>
cvs.zerfleddert.de Git - hmcfgusb/blob - hmsniff.c
89e2e82ebb0e51ea73c0a020488cb70a06e45ea4
   1 /* HM-sniffer for HM-CFG-USB 
   3  * Copyright (c) 2013-15 Michael Gernoth <michael@gernoth.net> 
   5  * Permission is hereby granted, free of charge, to any person obtaining a copy 
   6  * of this software and associated documentation files (the "Software"), to 
   7  * deal in the Software without restriction, including without limitation the 
   8  * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or 
   9  * sell copies of the Software, and to permit persons to whom the Software is 
  10  * furnished to do so, subject to the following conditions: 
  12  * The above copyright notice and this permission notice shall be included in 
  13  * all copies or substantial portions of the Software. 
  15  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 
  16  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 
  17  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 
  18  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 
  19  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING 
  20  * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS 
  34 #include <libusb-1.0/libusb.h> 
  40 static int verbose 
= 0; 
  43 char *hm_message_types(uint8_t type
, uint8_t subtype
) 
  50                         return "Configuration"; 
  53                         if (subtype 
>= 0x80 && subtype 
<= 0x8f) { 
  55                         } else if (subtype 
== 0x01) { 
  57                         } else if (subtype 
== 0x04) { 
  90                         return "Water sensor"; 
  93                         return "Climate event"; 
  96                         return "Thermal control"; 
 102                         return "Weather event"; 
 110 static void dissect_hm(uint8_t *buf
, int len
) 
 115         static int count 
= 0; 
 118         gettimeofday(&tv
, NULL
); 
 119         tmp 
= localtime(&tv
.tv_sec
); 
 120         memset(ts
, 0, sizeof(ts
)); 
 121         strftime(ts
, sizeof(ts
)-1, "%Y-%m-%d %H:%M:%S", tmp
); 
 124                 printf("%s.%06ld: ", ts
, tv
.tv_usec
); 
 126                 for (i 
= 0; i 
< len
; i
++) { 
 127                         printf("%02X", buf
[i
]); 
 130                 printf("Packet information:\n"); 
 131                 printf("\tLength: %u\n", buf
[0]); 
 132                 printf("\tMessage ID: %u\n", buf
[1]); 
 133                 printf("\tSender: %02x%02x%02x\n", buf
[4], buf
[5], buf
[6]); 
 134                 printf("\tReceiver: %02x%02x%02x\n", buf
[7], buf
[8], buf
[9]); 
 135                 printf("\tControl Byte: 0x%02x\n", buf
[2]); 
 136                 printf("\t\tFlags: "); 
 137                 if (buf
[2] & (1 << 0)) printf("WAKEUP "); 
 138                 if (buf
[2] & (1 << 1)) printf("WAKEMEUP "); 
 139                 if (buf
[2] & (1 << 2)) printf("CFG "); 
 140                 if (buf
[2] & (1 << 3)) printf("? "); 
 141                 if (buf
[2] & (1 << 4)) printf("BURST "); 
 142                 if (buf
[2] & (1 << 5)) printf("BIDI "); 
 143                 if (buf
[2] & (1 << 6)) printf("RPTED "); 
 144                 if (buf
[2] & (1 << 7)) printf("RPTEN "); 
 146                 printf("\tMessage type: %s (0x%02x 0x%02x)\n", hm_message_types(buf
[3], buf
[10]), buf
[3], buf
[10]); 
 147                 printf("\tMessage: "); 
 148                 for (i 
= 10; i 
< len
; i
++) { 
 149                         printf("%02X", buf
[i
]); 
 156                         printf("                         LL NR FL CM sender recvr  payload\n"); 
 158                 printf("%s.%03ld: %02X %02X %02X %02X %02X%02X%02X %02X%02X%02X ", 
 160                                 buf
[0], buf
[1], buf
[2], buf
[3], 
 161                                 buf
[4], buf
[5], buf
[6], 
 162                                 buf
[7], buf
[8], buf
[9]); 
 164                 for (i 
= 10; i 
< len
; i
++) { 
 165                         printf("%02X", buf
[i
]); 
 167                 printf("%s(%s)\n", (i
>10)?" ":"", hm_message_types(buf
[3], buf
[10])); 
 175 static int parse_hmcfgusb(uint8_t *buf
, int buf_len
, void *data
) 
 177         struct recv_data 
*rdata 
= data
; 
 184                         dissect_hm(buf 
+ 13, buf
[13] + 1); 
 187                         if ((buf
[27] != 0x00) || 
 190                                 printf("hmId is currently set to: %02x%02x%02x\n", buf
[27], buf
[28], buf
[29]); 
 191                                 rdata
->wrong_hmid 
= 1; 
 198                         hexdump(buf
, buf_len
, "Unknown> "); 
 205 void hmsniff_syntax(char *prog
) 
 207         fprintf(stderr
, "Syntax: %s options\n\n", prog
); 
 208         fprintf(stderr
, "Possible options:\n"); 
 209         fprintf(stderr
, "\t-v\t\tverbose mode\n"); 
 210         fprintf(stderr
, "\t-V\t\tshow version (" VERSION 
")\n"); 
 214 int main(int argc
, char **argv
) 
 216         struct hmcfgusb_dev 
*dev
; 
 217         struct recv_data rdata
; 
 221         while((opt 
= getopt(argc
, argv
, "vV")) != -1) { 
 227                                 printf("hmsniff " VERSION 
"\n"); 
 228                                 printf("Copyright (c) 2013-15 Michael Gernoth\n\n"); 
 234                                 hmsniff_syntax(argv
[0]); 
 240         hmcfgusb_set_debug(0); 
 243                 memset(&rdata
, 0, sizeof(rdata
)); 
 244                 rdata
.wrong_hmid 
= 0; 
 246                 dev 
= hmcfgusb_init(parse_hmcfgusb
, &rdata
); 
 248                         fprintf(stderr
, "Can't initialize HM-CFG-USB, retrying in 1s...\n"); 
 252                 printf("HM-CFG-USB opened!\n"); 
 254                 hmcfgusb_send_null_frame(dev
, 1); 
 255                 hmcfgusb_send(dev
, (unsigned char*)"K", 1, 1); 
 260                         if (rdata
.wrong_hmid
) { 
 261                                 printf("changing hmId to 000000, this might reboot the device!\n"); 
 262                                 hmcfgusb_send(dev
, (unsigned char*)"A\00\00\00", 4, 1); 
 263                                 rdata
.wrong_hmid 
= 0; 
 264                                 hmcfgusb_send(dev
, (unsigned char*)"K", 1, 1); 
 266                         fd 
= hmcfgusb_poll(dev
, 1000); 
 268                                 fprintf(stderr
, "activity on unknown fd %d!\n", fd
); 
 270                         } else if (fd 
== -1) { 
 272                                         if (errno 
!= ETIMEDOUT
) { 
 273                                                 perror("hmcfgusb_poll"); 
 276                                                 /* periodically wakeup the device */ 
 277                                                 hmcfgusb_send_null_frame(dev
, 1);