Car remote controls keys use "rolling codes" - means each code sent from the remote control to the car is single use, unique and hard to guess.
The way open the car is to capture the remote code, on sterile environment (with no car around), this way we can ensure that the cade will not be "blacklisted" by the car.
After we captured and saved the code, then we can reply this to the car.
- RTL-SDR (Software Define Radio) dongle with 16 cm antenna
- Raspberry pi 3
- LED and switch soldered to GPIO.
- Antenna soldered to GPIO.
- RPITX software installation on raspberry pi.
 
- Power bank.
- First we need to find the remote control transmission frequency. This can be done by searching for the remote control FCC no. to get frequency range. I hade an educated guess that it will be around 868 MHz
- Connecting the RTL-SDR dongle to the computer. Using SDR# software to identify the exact frequency.
- Found the exact frequency is 867.8625 MHz
- Then connecting the SDR dongle to the raspberry pi, connecting to the pi using SSH, and recording the remote control codes using rpitx:
sudo rtl_sdr -s 250000 -g 35 -f 867.8625e6 lexus_open.iq - Connecting the SDR dongle back to the computer, and using SDR# software to listen to the frequency.
- From the raspberry pi, transmitting the recorded codes
sudo sendiq -s 250000 -f 867.8625e6 -t u8 -i lexus_open.iq - Validating on computer that the message is sent.
- Writing a python script that will run the transmission code when pressing the button on the raspberry pi.
- Adding the python script to run on boot.
crontab -e
Adding this:
@reboot python RPI_replay.py- Testing it on real.
- KABOOM
A good mitigation will by 2 way hand shake - like using NTLM authentication.
When paring the remote keys with the car system, a secret key will be exchanged.
Opening the car with a remote key will have the following steps:
- remote control car key will send a rolling code to the car.
- The car then will send a random message back to the remote.
- The remote control car key will encrypt the message using pre defined key, and send it back to the car.
- The car then decrypt the message with the key and validate massage integrity.