From 917ad44b8d4153dce81cf635310d16fdfb1106c6 Mon Sep 17 00:00:00 2001 From: DrZlo13 Date: Sat, 11 Dec 2021 05:59:54 +1000 Subject: [PATCH 1/6] Fixed the "ibutton can only emulate after reading" bug --- applications/ibutton/helpers/key-emulator.cpp | 4 ++++ applications/ibutton/helpers/key-reader.cpp | 10 +++++----- applications/ibutton/helpers/pulse-sequencer.cpp | 2 +- applications/lfrfid/helpers/rfid-writer.cpp | 4 +++- firmware/targets/f6/furi-hal/furi-hal-rfid.c | 4 ++++ firmware/targets/f7/furi-hal/furi-hal-rfid.c | 4 ++++ firmware/targets/furi-hal-include/furi-hal-rfid.h | 4 ++++ 7 files changed, 25 insertions(+), 7 deletions(-) diff --git a/applications/ibutton/helpers/key-emulator.cpp b/applications/ibutton/helpers/key-emulator.cpp index 7c8c5c9781e..307985f3662 100644 --- a/applications/ibutton/helpers/key-emulator.cpp +++ b/applications/ibutton/helpers/key-emulator.cpp @@ -17,6 +17,9 @@ void KeyEmulator::start(iButtonKey* key) { anything_emulated = false; stop(); + // release pull pin, to prevent low-pass filtering by the RFID part of the schematic + furi_hal_rfid_pin_pull_release(); + switch(key->get_key_type()) { case iButtonKeyType::KeyDallas: start_dallas_emulate(key); @@ -44,6 +47,7 @@ bool KeyEmulator::emulated() { void KeyEmulator::stop() { onewire_slave->stop(); pulser.stop(); + furi_hal_rfid_pins_reset(); } void KeyEmulator::start_cyfral_emulate(iButtonKey* key) { diff --git a/applications/ibutton/helpers/key-reader.cpp b/applications/ibutton/helpers/key-reader.cpp index fcb2a4800b2..c42aac26c77 100644 --- a/applications/ibutton/helpers/key-reader.cpp +++ b/applications/ibutton/helpers/key-reader.cpp @@ -115,12 +115,10 @@ bool KeyReader::verify_key(iButtonKeyType key_type, const uint8_t* const data, u } void KeyReader::start_comaparator(void) { - // pulldown lf-rfid pins to prevent interference - hal_gpio_init(&gpio_rfid_pull, GpioModeOutputOpenDrain, GpioPullNo, GpioSpeedLow); - hal_gpio_write(&gpio_rfid_pull, false); + furi_hal_rfid_pins_reset(); - hal_gpio_init(&gpio_rfid_carrier_out, GpioModeOutputOpenDrain, GpioPullNo, GpioSpeedLow); - hal_gpio_write(&gpio_rfid_carrier_out, false); + // release pull pin, we sense the signal through the analog part of the RFID schematic + furi_hal_rfid_pin_pull_release(); comparator_callback_pointer = cbc::obtain_connector(this, &KeyReader::comparator_trigger_callback); @@ -130,6 +128,8 @@ void KeyReader::start_comaparator(void) { } void KeyReader::stop_comaparator(void) { + furi_hal_rfid_pins_reset(); + HAL_COMP_Stop(&hcomp1); api_interrupt_remove(comparator_callback_pointer, InterruptTypeComparatorTrigger); } diff --git a/applications/ibutton/helpers/pulse-sequencer.cpp b/applications/ibutton/helpers/pulse-sequencer.cpp index 328df7ac71e..9a8b0d98114 100644 --- a/applications/ibutton/helpers/pulse-sequencer.cpp +++ b/applications/ibutton/helpers/pulse-sequencer.cpp @@ -56,7 +56,7 @@ void PulseSequencer::init_timer(uint32_t period) { HAL_NVIC_EnableIRQ(TIM1_UP_TIM16_IRQn); - hal_gpio_init(&ibutton_gpio, GpioModeOutputOpenDrain, GpioPullNo, GpioSpeedLow); + hal_gpio_init(&ibutton_gpio, GpioModeOutputOpenDrain, GpioPullNo, GpioSpeedVeryHigh); } void PulseSequencer::deinit_timer() { diff --git a/applications/lfrfid/helpers/rfid-writer.cpp b/applications/lfrfid/helpers/rfid-writer.cpp index f983ce35898..0f4b8c96dfb 100644 --- a/applications/lfrfid/helpers/rfid-writer.cpp +++ b/applications/lfrfid/helpers/rfid-writer.cpp @@ -37,7 +37,9 @@ void RfidWriter::start() { furi_hal_rfid_tim_read(125000, 0.5); furi_hal_rfid_pins_read(); furi_hal_rfid_tim_read_start(); - hal_gpio_write(&gpio_rfid_pull, true); + + // do not ground the antenna + furi_hal_rfid_pin_pull_release(); } void RfidWriter::stop() { diff --git a/firmware/targets/f6/furi-hal/furi-hal-rfid.c b/firmware/targets/f6/furi-hal/furi-hal-rfid.c index d7092f88ead..18a07d57836 100644 --- a/firmware/targets/f6/furi-hal/furi-hal-rfid.c +++ b/firmware/targets/f6/furi-hal/furi-hal-rfid.c @@ -61,6 +61,10 @@ void furi_hal_rfid_pins_read() { hal_gpio_init(&gpio_rfid_data_in, GpioModeAnalog, GpioPullNo, GpioSpeedLow); } +void furi_hal_rfid_pin_pull_release() { + hal_gpio_write(&gpio_rfid_pull, true); +} + void furi_hal_rfid_tim_read(float freq, float duty_cycle) { // TODO LL init uint32_t period = (uint32_t)((SystemCoreClock) / freq) - 1; diff --git a/firmware/targets/f7/furi-hal/furi-hal-rfid.c b/firmware/targets/f7/furi-hal/furi-hal-rfid.c index 02a82bd163f..700f84094d6 100644 --- a/firmware/targets/f7/furi-hal/furi-hal-rfid.c +++ b/firmware/targets/f7/furi-hal/furi-hal-rfid.c @@ -66,6 +66,10 @@ void furi_hal_rfid_pins_read() { hal_gpio_init(&gpio_rfid_data_in, GpioModeAnalog, GpioPullNo, GpioSpeedLow); } +void furi_hal_rfid_pin_pull_release() { + hal_gpio_write(&gpio_rfid_pull, true); +} + void furi_hal_rfid_tim_read(float freq, float duty_cycle) { // TODO LL init uint32_t period = (uint32_t)((SystemCoreClock) / freq) - 1; diff --git a/firmware/targets/furi-hal-include/furi-hal-rfid.h b/firmware/targets/furi-hal-include/furi-hal-rfid.h index 5e11c6d6bb7..a54bc0c1829 100644 --- a/firmware/targets/furi-hal-include/furi-hal-rfid.h +++ b/firmware/targets/furi-hal-include/furi-hal-rfid.h @@ -29,6 +29,10 @@ void furi_hal_rfid_pins_emulate(); */ void furi_hal_rfid_pins_read(); +/** Release rfid pull pin + */ +void furi_hal_rfid_pin_pull_release(); + /** Config rfid timer to read state * * @param freq timer frequency From 98c0315456953b82a683c4c8af58261d6f3b274a Mon Sep 17 00:00:00 2001 From: DrZlo13 Date: Sat, 11 Dec 2021 07:05:35 +1000 Subject: [PATCH 2/6] Fixed previous fix. FIXES FOR THE FIX GOD! BUGS FOR THE BUG THRONE! --- applications/ibutton/helpers/key-emulator.cpp | 4 ++-- applications/ibutton/helpers/key-reader.cpp | 7 +++++-- firmware/targets/f6/furi-hal/furi-hal-rfid.c | 4 ++++ firmware/targets/f7/furi-hal/furi-hal-rfid.c | 4 ++++ firmware/targets/furi-hal-include/furi-hal-rfid.h | 4 ++++ 5 files changed, 19 insertions(+), 4 deletions(-) diff --git a/applications/ibutton/helpers/key-emulator.cpp b/applications/ibutton/helpers/key-emulator.cpp index 307985f3662..a09d83e8a43 100644 --- a/applications/ibutton/helpers/key-emulator.cpp +++ b/applications/ibutton/helpers/key-emulator.cpp @@ -17,8 +17,8 @@ void KeyEmulator::start(iButtonKey* key) { anything_emulated = false; stop(); - // release pull pin, to prevent low-pass filtering by the RFID part of the schematic - furi_hal_rfid_pin_pull_release(); + // pulldown pull pin, to prevent low-pass filtering by the RFID part of the schematic + furi_hal_rfid_pin_pull_pulldown(); switch(key->get_key_type()) { case iButtonKeyType::KeyDallas: diff --git a/applications/ibutton/helpers/key-reader.cpp b/applications/ibutton/helpers/key-reader.cpp index c42aac26c77..7abe5df7e7c 100644 --- a/applications/ibutton/helpers/key-reader.cpp +++ b/applications/ibutton/helpers/key-reader.cpp @@ -117,8 +117,8 @@ bool KeyReader::verify_key(iButtonKeyType key_type, const uint8_t* const data, u void KeyReader::start_comaparator(void) { furi_hal_rfid_pins_reset(); - // release pull pin, we sense the signal through the analog part of the RFID schematic - furi_hal_rfid_pin_pull_release(); + // pulldown pull pin, we sense the signal through the analog part of the RFID schematic + furi_hal_rfid_pin_pull_pulldown(); comparator_callback_pointer = cbc::obtain_connector(this, &KeyReader::comparator_trigger_callback); @@ -130,6 +130,9 @@ void KeyReader::start_comaparator(void) { void KeyReader::stop_comaparator(void) { furi_hal_rfid_pins_reset(); + // rfid_pins_reset will disable ibutton pin + furi_hal_ibutton_start(); + HAL_COMP_Stop(&hcomp1); api_interrupt_remove(comparator_callback_pointer, InterruptTypeComparatorTrigger); } diff --git a/firmware/targets/f6/furi-hal/furi-hal-rfid.c b/firmware/targets/f6/furi-hal/furi-hal-rfid.c index 18a07d57836..c14d48fd213 100644 --- a/firmware/targets/f6/furi-hal/furi-hal-rfid.c +++ b/firmware/targets/f6/furi-hal/furi-hal-rfid.c @@ -65,6 +65,10 @@ void furi_hal_rfid_pin_pull_release() { hal_gpio_write(&gpio_rfid_pull, true); } +void furi_hal_rfid_pin_pull_pulldown() { + hal_gpio_write(&gpio_rfid_pull, false); +} + void furi_hal_rfid_tim_read(float freq, float duty_cycle) { // TODO LL init uint32_t period = (uint32_t)((SystemCoreClock) / freq) - 1; diff --git a/firmware/targets/f7/furi-hal/furi-hal-rfid.c b/firmware/targets/f7/furi-hal/furi-hal-rfid.c index 700f84094d6..b4b5af50818 100644 --- a/firmware/targets/f7/furi-hal/furi-hal-rfid.c +++ b/firmware/targets/f7/furi-hal/furi-hal-rfid.c @@ -70,6 +70,10 @@ void furi_hal_rfid_pin_pull_release() { hal_gpio_write(&gpio_rfid_pull, true); } +void furi_hal_rfid_pin_pull_pulldown() { + hal_gpio_write(&gpio_rfid_pull, false); +} + void furi_hal_rfid_tim_read(float freq, float duty_cycle) { // TODO LL init uint32_t period = (uint32_t)((SystemCoreClock) / freq) - 1; diff --git a/firmware/targets/furi-hal-include/furi-hal-rfid.h b/firmware/targets/furi-hal-include/furi-hal-rfid.h index a54bc0c1829..68ac18c1077 100644 --- a/firmware/targets/furi-hal-include/furi-hal-rfid.h +++ b/firmware/targets/furi-hal-include/furi-hal-rfid.h @@ -33,6 +33,10 @@ void furi_hal_rfid_pins_read(); */ void furi_hal_rfid_pin_pull_release(); +/** Pulldown rfid pull pin + */ +void furi_hal_rfid_pin_pull_pulldown(); + /** Config rfid timer to read state * * @param freq timer frequency From 4d70092414b30a352d097d584d538a1ba9cc78c4 Mon Sep 17 00:00:00 2001 From: DrZlo13 Date: Sat, 11 Dec 2021 07:37:31 +1000 Subject: [PATCH 3/6] Fixed "Repeat code" position on code input screen --- applications/gui/modules/code_input.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/applications/gui/modules/code_input.c b/applications/gui/modules/code_input.c index 9e220d54a66..c119a9fb5b3 100644 --- a/applications/gui/modules/code_input.c +++ b/applications/gui/modules/code_input.c @@ -312,7 +312,7 @@ static void code_input_view_draw_callback(Canvas* canvas, void* _model) { 44 + y_offset, model->current); - if(model->current) canvas_draw_str(canvas, 2, 39 - y_offset, "Repeat code"); + if(model->current) canvas_draw_str(canvas, 2, 48 - y_offset, "Repeat code"); break; default: From e4be323ae10771b5266965089f2adaf227cc15ea Mon Sep 17 00:00:00 2001 From: DrZlo13 Date: Sat, 11 Dec 2021 07:39:08 +1000 Subject: [PATCH 4/6] Changed CAME protocol icon --- lib/subghz/protocols/subghz_protocol_came_atomo.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/subghz/protocols/subghz_protocol_came_atomo.c b/lib/subghz/protocols/subghz_protocol_came_atomo.c index fbf9ca38ff6..ff4dff676e6 100644 --- a/lib/subghz/protocols/subghz_protocol_came_atomo.c +++ b/lib/subghz/protocols/subghz_protocol_came_atomo.c @@ -26,7 +26,7 @@ SubGhzProtocolCameAtomo* subghz_protocol_came_atomo_alloc() { instance->common.te_short = 600; instance->common.te_long = 1200; instance->common.te_delta = 250; - instance->common.type_protocol = SubGhzProtocolCommonTypeStatic; + instance->common.type_protocol = SubGhzProtocolCommonTypeDynamic; instance->common.to_string = (SubGhzProtocolCommonToStr)subghz_protocol_came_atomo_to_str; instance->common.to_load_protocol = (SubGhzProtocolCommonLoadFromRAW)subghz_decoder_came_atomo_to_load_protocol; From ce0d80d1f79953bb9d7807abb00f35a29295d901 Mon Sep 17 00:00:00 2001 From: Aleksandr Kutuzov Date: Sat, 11 Dec 2021 15:39:06 +0300 Subject: [PATCH 5/6] Brewfile: add imagemagick missing assets compiler dependency --- Brewfile | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/Brewfile b/Brewfile index aa88d6428cc..64f9d9bc3a8 100644 --- a/Brewfile +++ b/Brewfile @@ -3,4 +3,5 @@ brew "protobuf" brew "heatshrink" brew "open-ocd" brew "clang-format" -brew "dfu-util" \ No newline at end of file +brew "dfu-util" +brew "imagemagick" \ No newline at end of file From c536a783a345d7071b4415eb77804fd916cfb993 Mon Sep 17 00:00:00 2001 From: DrZlo13 Date: Sun, 12 Dec 2021 06:17:10 +1000 Subject: [PATCH 6/6] Correct fix for "Repeat code" position on code input screen --- applications/gui/modules/code_input.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/applications/gui/modules/code_input.c b/applications/gui/modules/code_input.c index c119a9fb5b3..988742f9fc6 100644 --- a/applications/gui/modules/code_input.c +++ b/applications/gui/modules/code_input.c @@ -312,7 +312,7 @@ static void code_input_view_draw_callback(Canvas* canvas, void* _model) { 44 + y_offset, model->current); - if(model->current) canvas_draw_str(canvas, 2, 48 - y_offset, "Repeat code"); + if(model->current) canvas_draw_str(canvas, 2, 39 + y_offset, "Repeat code"); break; default: