subghz_protocol_princeton.c 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. #include "subghz_protocol_princeton.h"
  2. /*
  3. * Help
  4. * https://phreakerclub.com/447
  5. *
  6. */
  7. struct SubGhzProtocolPrinceton {
  8. SubGhzProtocolCommon common;
  9. };
  10. SubGhzProtocolPrinceton* subghz_protocol_princeton_alloc(void) {
  11. SubGhzProtocolPrinceton* instance = furi_alloc(sizeof(SubGhzProtocolPrinceton));
  12. instance->common.name = "Princeton";
  13. instance->common.code_min_count_bit_for_found = 24;
  14. instance->common.te_shot = 450;//150;
  15. instance->common.te_long = 1350;//450;
  16. instance->common.te_delta = 200;//50;
  17. return instance;
  18. }
  19. void subghz_protocol_princeton_free(SubGhzProtocolPrinceton* instance) {
  20. furi_assert(instance);
  21. free(instance);
  22. }
  23. void subghz_protocol_princeton_send_bit(SubGhzProtocolPrinceton* instance, uint8_t bit) {
  24. if (bit) {
  25. //send bit 1
  26. SUBGHZ_TX_PIN_LOW();
  27. delay_us(instance->common.te_long);
  28. SUBGHZ_TX_PIN_HIGTH();
  29. delay_us(instance->common.te_shot);
  30. } else {
  31. //send bit 0
  32. SUBGHZ_TX_PIN_LOW();
  33. delay_us(instance->common.te_shot);
  34. SUBGHZ_TX_PIN_HIGTH();
  35. delay_us(instance->common.te_long);
  36. }
  37. }
  38. void subghz_protocol_princeton_send_key(SubGhzProtocolPrinceton* instance, uint64_t key, uint8_t bit,uint8_t repeat) {
  39. while (repeat--) {
  40. SUBGHZ_TX_PIN_LOW();
  41. //Send start bit
  42. subghz_protocol_princeton_send_bit(instance, 1);
  43. //Send header
  44. delay_us(instance->common.te_shot * 33); //+2 interval v bit 1
  45. //Send key data
  46. for (uint8_t i = bit; i > 0; i--) {
  47. subghz_protocol_princeton_send_bit(instance, bit_read(key, i - 1));
  48. }
  49. }
  50. }
  51. void subghz_protocol_princeton_parse(SubGhzProtocolPrinceton* instance, LevelPair data) {
  52. switch (instance->common.parser_step) {
  53. case 0:
  54. if ((data.level == ApiHalSubGhzCaptureLevelLow)
  55. && (DURATION_DIFF(data.duration,instance->common.te_shot * 36)< instance->common.te_delta * 36)) {
  56. //Found Preambula
  57. instance->common.parser_step = 1;
  58. instance->common.code_found = 0;
  59. instance->common.code_count_bit = 0;
  60. } else {
  61. instance->common.parser_step = 0;
  62. }
  63. break;
  64. case 1:
  65. //save duration
  66. if (data.level == ApiHalSubGhzCaptureLevelHigh) {
  67. instance->common.te_last = data.duration;
  68. instance->common.parser_step = 2;
  69. }
  70. break;
  71. case 2:
  72. if (data.level == ApiHalSubGhzCaptureLevelLow) {
  73. if (data.duration>= (instance->common.te_shot * 10+ instance->common.te_delta)) {
  74. instance->common.parser_step = 1;
  75. if (instance->common.code_count_bit>= instance->common.code_min_count_bit_for_found) {
  76. //ToDo out data display
  77. if (instance->common.callback) instance->common.callback((SubGhzProtocolCommon*)instance, instance->common.context);
  78. }
  79. instance->common.code_found = 0;
  80. instance->common.code_count_bit = 0;
  81. break;
  82. }
  83. if ((DURATION_DIFF(instance->common.te_last,instance->common.te_shot)< instance->common.te_delta)
  84. && (DURATION_DIFF(data.duration,instance->common.te_long)< instance->common.te_delta*3)) {
  85. subghz_protocol_common_add_bit(&instance->common, 0);
  86. instance->common.parser_step = 1;
  87. } else if ((DURATION_DIFF(instance->common.te_last,instance->common.te_long)< instance->common.te_delta*3)
  88. && (DURATION_DIFF(data.duration,instance->common.te_shot)< instance->common.te_delta)) {
  89. subghz_protocol_common_add_bit(&instance->common, 1);
  90. instance->common.parser_step = 1;
  91. } else {
  92. instance->common.parser_step = 0;
  93. }
  94. } else {
  95. instance->common.parser_step = 0;
  96. }
  97. break;
  98. }
  99. }