subghz_protocol_princeton.c 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  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. /** Send bit
  24. *
  25. * @param instance - SubGhzProtocolPrinceton instance
  26. * @param bit - bit
  27. */
  28. void subghz_protocol_princeton_send_bit(SubGhzProtocolPrinceton* instance, uint8_t bit) {
  29. if (bit) {
  30. //send bit 1
  31. SUBGHZ_TX_PIN_LOW();
  32. delay_us(instance->common.te_long);
  33. SUBGHZ_TX_PIN_HIGTH();
  34. delay_us(instance->common.te_shot);
  35. } else {
  36. //send bit 0
  37. SUBGHZ_TX_PIN_LOW();
  38. delay_us(instance->common.te_shot);
  39. SUBGHZ_TX_PIN_HIGTH();
  40. delay_us(instance->common.te_long);
  41. }
  42. }
  43. void subghz_protocol_princeton_send_key(SubGhzProtocolPrinceton* instance, uint64_t key, uint8_t bit,uint8_t repeat) {
  44. while (repeat--) {
  45. SUBGHZ_TX_PIN_LOW();
  46. //Send start bit
  47. subghz_protocol_princeton_send_bit(instance, 1);
  48. //Send header
  49. delay_us(instance->common.te_shot * 33); //+2 interval v bit 1
  50. //Send key data
  51. for (uint8_t i = bit; i > 0; i--) {
  52. subghz_protocol_princeton_send_bit(instance, bit_read(key, i - 1));
  53. }
  54. }
  55. }
  56. void subghz_protocol_princeton_reset(SubGhzProtocolPrinceton* instance) {
  57. instance->common.parser_step = 0;
  58. }
  59. void subghz_protocol_princeton_parse(SubGhzProtocolPrinceton* instance, bool level, uint32_t duration) {
  60. switch (instance->common.parser_step) {
  61. case 0:
  62. if ((!level)
  63. && (DURATION_DIFF(duration,instance->common.te_shot * 36) < instance->common.te_delta * 36)) {
  64. //Found Preambula
  65. instance->common.parser_step = 1;
  66. instance->common.code_found = 0;
  67. instance->common.code_count_bit = 0;
  68. } else {
  69. instance->common.parser_step = 0;
  70. }
  71. break;
  72. case 1:
  73. //save duration
  74. if (level) {
  75. instance->common.te_last = duration;
  76. instance->common.parser_step = 2;
  77. }
  78. break;
  79. case 2:
  80. if (!level) {
  81. if (duration >= (instance->common.te_shot * 10 + instance->common.te_delta)) {
  82. instance->common.parser_step = 1;
  83. if (instance->common.code_count_bit>= instance->common.code_min_count_bit_for_found) {
  84. instance->common.serial = instance->common.code_found >> 4;
  85. instance->common.btn = (uint8_t)instance->common.code_found & 0x00000F;
  86. if (instance->common.callback) instance->common.callback((SubGhzProtocolCommon*)instance, instance->common.context);
  87. }
  88. instance->common.code_found = 0;
  89. instance->common.code_count_bit = 0;
  90. break;
  91. }
  92. if ((DURATION_DIFF(instance->common.te_last,instance->common.te_shot)< instance->common.te_delta)
  93. && (DURATION_DIFF(duration,instance->common.te_long)< instance->common.te_delta*3)) {
  94. subghz_protocol_common_add_bit(&instance->common, 0);
  95. instance->common.parser_step = 1;
  96. } else if ((DURATION_DIFF(instance->common.te_last,instance->common.te_long)< instance->common.te_delta*3)
  97. && (DURATION_DIFF(duration,instance->common.te_shot)< instance->common.te_delta)) {
  98. subghz_protocol_common_add_bit(&instance->common, 1);
  99. instance->common.parser_step = 1;
  100. } else {
  101. instance->common.parser_step = 0;
  102. }
  103. } else {
  104. instance->common.parser_step = 0;
  105. }
  106. break;
  107. }
  108. }