flipper-zero-tutorials/subghz/apps/genie-recorder
2023-10-18 19:39:57 -05:00
..
lib/subghz/protocols Genie v2 - supports custom protocol handler 2023-10-18 19:39:57 -05:00
application.fam Genie v2 - supports custom protocol handler 2023-10-18 19:39:57 -05:00
genie_about.h Genie v2 - supports custom protocol handler 2023-10-18 19:39:57 -05:00
genie_file.c Genie v2 - supports custom protocol handler 2023-10-18 19:39:57 -05:00
genie_file.h Genie v2 - supports custom protocol handler 2023-10-18 19:39:57 -05:00
genie_subghz_receive.c Genie v2 - supports custom protocol handler 2023-10-18 19:39:57 -05:00
genie_subghz_receive.h Genie recorder 2023-09-28 14:56:39 -05:00
genie.c Genie v2 - supports custom protocol handler 2023-10-18 19:39:57 -05:00
genie.png Genie recorder 2023-09-28 14:56:39 -05:00
README.md Genie v2 - supports custom protocol handler 2023-10-18 19:39:57 -05:00
wiring.png Fix crashing bug -- can't append 1000s of times? 2023-10-02 11:46:57 -05:00

Genie garage door recorder

IMPORTANT: This project currently requires changes to the firmware to be able to detect Genie signals. Please see the Installing section for more details.

WARNING: For my remote, the codes wrapped after 65,536 codes were sent. I'm not sure if this is the case for ALL Genie brand remotes. If it doesn't wrap, it's possible that the remote could stop working (if the manufacture implemented OVR bits).

WARNING: This could desync your remote from the receiver. Be sure you know the process to sync the remote back to the receiver. For my remote, I had to press the learn button on the receiver, then press the button on the remote.

WARNING: Don't run this app near your garage. There is no reason to open the physical garage door & you will likely burn out the motor.

Document sections:

Description

This program was written to allow the Flipper Zero to press buttons on a Genie garage door opened and record the rolling code. The goal is to capture all 65,536 signals (which hopefully repeats when it gets to the end). Our click speed is current 2000ms per click + however long it takes to get the signal. In practice, it typically takes 2 days to record all of your signals.

Once completed, the built-in Sub-GHz Read application will know how to playback your Genie garage door remote.

Installing

  • Step 1. Clone a firmware repro using git clone --recursive.
  • Step 2. Copy these files into your firmware applications_user\genie-recorder folder.
  • Step 3. Move the files from applications_user\genie-recorder\lib\subghz\protocols to lib\subghz\protocols folder.
  • Step 4. Add &subghz_protocol_genie, below the line &subghz_protocol_keeloq, in the lib\subghz\protocols\protocol_items.c file. (NOTE: You can add it lower in the file if you prefer.)
  • Step 5. Add #include "genie.h below the line #include "keeloq.h in the lib\subghz\protocols\protocol_items.h file.
  • Step 6. Build your firmware & deploy onto Flipper ./fbt FORCE=1 flash_usb_full -- "[Debug]Flash (USB, with Resources)".

Determine Genie Frequency

  • Step 1. On your Flipper Zero, load Sub-GHz app.
  • Step 2. Choose Read to start scanning.
  • Step 3. Press the LEFT button to edit the Config.
  • Step 4. Change the Frequency to 315000000.
  • Step 5. Press the BACK button to continue scanning on the new frequency.
  • Step 6. Press a button on your remote to see if it is detected.
  • Step 7. If it is NOT detected, try 390000000.

Connecting to remote

WARNING: Do this at your own risk. You could damage your remote if done improperly or if your remote doesn't support capturing all of the signals.

  • Step 1. Open the case off of your garage door remote.
  • Step 2. Connect GND from Flipper to GND pin on the remote.
  • Step 3. Connect A7 from Flipper to the signal pin on the remote.
  • Step 4. Put in a fresh battery.
    • Risky Option: Remove the battery and connect 3V3 from Flipper to the battery positive bar on the remote. Be 100% sure that GND on the Flipper is going to GND on the remote (and not the signal pin) and that no wires are shorting. If you are not 100% sure, then DON'T DO THIS! You could damage the remote and the Flipper Zero.

Capture codes

  • Step 1. Be sure you have followed the steps in the Installing section.
  • Step 2. Be sure you have followed the steps in the Connecting to remote section.
  • Step 3. Be sure you are not near your garage door (or that the door is unplugged). The application will be pushing the button many times and could burn out the motor.
  • Step 4. Run the Genie Recorder application
  • Step 5. Choose "Config" and set the frequency to the frequency you determined above.
  • Step 6. Choose "Start" to start recording signals.
    • You should see the current broadcast count (how many times the button was pressed)
    • You should see the received signal count (how many times the signal was received)
    • You should see how many codes still need to be received.
    • Every time a signal is recevied, it is written to a log file. If the application exits and restarts, it will resume the counters where it left off, but be sure to NOT press the remote because the counter will be off.
  • Step 7. Let it run for 2-3 days (the goal is to capture between 49,160-65,536 signals). If you capture less, it will still work but when it wraps back to the beginning those codes will be rejected by your garage door opener. To successfully wrap, the remote needs 49,160 button presses ("16,380 remaining codes" or less). To be near-sync with the remote, it is recommended you capture all of the codes.
  • Step 8. Press the BACK button twice to exit the application.

Sub-GHz Read

  • Step 1. Be sure you have followed the steps in the Capturing codes section.
  • Step 2. On your Flipper, press the BACK button until you are at the Desktop.
  • Step 3. On your Flipper, press the OK button and choose "Sub-GHz".
  • Step 4. Choose "Read" to start scanning.
  • Step 5. Press the LEFT button to edit the Config.
  • Step 6. Change the Frequency to the frequency you determined above.
  • Step 7. Press the BACK button to continue scanning on the new frequency.
  • Step 8. Press a button on your Genie remote. If read successfully you should hear a beep and see "Genie" followed by some code.
  • Step 9. Press the OK button to see the details of the code.
  • Step 10. Most firmware will have a "Save" button. Press "Save" to save the code to the SD Card. Press "Send" to send the code to the garage door opener.
  • Step 11. If you press "Send", it should generate the next code and open the garage door.

Sub-GHz Saved

  • Step 1. Be sure you have followed the steps in the Capturing codes section.
  • Step 2. On your Flipper, press the BACK button until you are at the Desktop.
  • Step 3. On your Flipper, press the OK button and choose "Sub-GHz".
  • Step 4. Choose "Saved".
  • Step 5. Select the file that you saved during the Sub-GHz Read section steps.
  • Step 6. Choose "Emulate".
  • Step 7. Press the OK button to generate the next code and open the garage door!
    • NOTE: If the receiver is out of sync, but within the 16K window, you may need to press the OK button twice. This will open the garage door and resync the counter on the receiver.

Troubleshooting