



**DIGITAL SYSTEM DESIGN FINAL PROJECT REPORT**  
**DEPARTMENT OF ELECTRICAL ENGINEERING**  
**UNIVERSITAS INDONESIA**

**ROLLING CAR KEY: State Machine Logic for Secure Car Access using  
Synchronized Rolling Codes**

**GROUP 1:**

|                              |                   |
|------------------------------|-------------------|
| <b>Nadira Fayyaza Aisy</b>   | <b>2406368933</b> |
| <b>Nayla Pramesti Adhina</b> | <b>2406368901</b> |
| <b>Hanif Mulia Nugroho</b>   | <b>2406369066</b> |

## PREFACE

We are thankful to the Almighty God who has granted us inexhaustible grace and blessings that have made us accomplish this final project report. The report is being prepared in the context of completing the final project of the Digital System Design course in the academic year 2025/2026, which is called ROLLING CAR KEY: State Machine Logic of Secure Car Access with the rolling codes synchronized. The approach adopted in this project is VHDL (VHSIC Hardware Description Language), through which a hardware-based digital system can be designed and implemented to provide us with secure access control of vehicles.

The project will develop and optimize a keyless entry system that combines a remote key device with a car-side authentication unit, using the SPI (serial peripheral interface) protocol to facilitate reliable data transmission. The system uses an OTP (One-Time Password) mechanism and counter synchronization to provide strong security and prevent unauthorized access.

We would also like to acknowledge that the lab assistants, Mr. M. Nadzhif Fikri, helped with the implementation and testing process and were very patient. The project is an outcome of strong teamwork, and every step of the work has provided more insights into how theoretical concepts can be applied to the field of computer engineering, namely, in the area of digital systems and safe data transport. We won't deny that this report might still be limited and deficient. Hence, positive comments and recommendations are most welcome to be reviewed and further enhanced

Depok, December 07, 2025

Group 1

## TABLE OF CONTENTS

|                                            |           |
|--------------------------------------------|-----------|
| <b>TABLE OF CONTENTS.....</b>              | <b>3</b>  |
| <b>CHAPTER 1.....</b>                      | <b>4</b>  |
| <b>INTRODUCTION.....</b>                   | <b>4</b>  |
| <b>1.1 BACKGROUND.....</b>                 | <b>4</b>  |
| <b>1.3 OBJECTIVES.....</b>                 | <b>5</b>  |
| <b>1.4 ROLES AND RESPONSIBILITIES.....</b> | <b>5</b>  |
| <b>CHAPTER 2.....</b>                      | <b>6</b>  |
| <b>IMPLEMENTATION.....</b>                 | <b>6</b>  |
| <b>2.1 EQUIPMENT.....</b>                  | <b>6</b>  |
| <b>2.2 IMPLEMENTATION.....</b>             | <b>6</b>  |
| <b>CHAPTER 3.....</b>                      | <b>8</b>  |
| <b>TESTING AND ANALYSIS.....</b>           | <b>8</b>  |
| <b>3.1 TESTING.....</b>                    | <b>8</b>  |
| <b>3.2 RESULT.....</b>                     | <b>9</b>  |
| <b>3.3 ANALYSIS.....</b>                   | <b>9</b>  |
| <b>CHAPTER 4.....</b>                      | <b>10</b> |
| <b>CONCLUSION.....</b>                     | <b>10</b> |

# **CHAPTER 1**

## **INTRODUCTION**

### **1.1 BACKGROUND**

The issue of vehicle security is highly acute in the modern world because the key-based system is becoming more and more susceptible to theft and unauthorized access. Current car models have electronic access controls based on wireless communication between the remote key and the control unit installed on the car. Nevertheless, most of the current systems implement fixed or foreseeable authentication systems, which could be hacked, repeated, or duplicated, which is rather dangerous.

In order to deal with these weaknesses, authentication systems like One Time Passwords (OTP) and dynamic counter-based systems have been implemented in other secure communications. These techniques make every authentication unique and time-sensitive. The introduction of these security functions in an embedded system is to be done in a co-design of both hardware and software, an effective communication protocol, and a strong synchronization of the transmitter to the receiver.

This project aims at the design and implementation of a secure vehicle entry system with the use of VHDL to model the hardware behavior of the key device (transmitter) and the car unit (receiver). It uses the SPI protocol to transmit the data reliably with low latency and has an OTP generator based on a secret key and a running counter. The design focuses on authenticating on the fly, handling keys in a secure manner, and having a smooth interaction between the key and the vehicle control system.

With the creation of this system as a hardware-based project, we will be investigating the practical issues of the design of the secure embedded system, such as the state machine control, data integrity, protocol management, synchronization, and the limitations of the FPGA or ASIC implementation. This project doesn't just implement any theoretical learning of digital design and communication protocols; it also proves the need to observe the issue of security in contemporary electronic systems.

## 1.2 PROJECT DESCRIPTION

The design of this project is a safe remote keyless entry system in VHDL, comprising a key transmitter and a car receiver that are in communication through SPI. The system practices a rolling code system with the help of a one-time password (OTP) to avoid replay attacks. The pressing of each button will add a counter and, together with a shared secret key, produce a unique OTP hash.

Three packets are sent sequentially with the help of a finite state machine, namely: User ID, Counter, and OTP, which are exchanged by the key. These packets are sent to the Car unit, which accesses the secret key through an internal database with the User ID and then recalculates the expected OTP. Authentication only works when the OTP received matches the locally generated OTP, and the counter received falls within a valid synchronization window before the stored counter.

Key Features that were included in this project are as follows:

- Rolling Code Security: This type of security uses a non-linear algorithm (XOR, rotate bits, constants) to make each transmission have a unique OTP.
- Communication: SPI Master (Key) and SPI Slave (Car). Custom implementation of SPI Master and SPI Slave to ensure reliable data transfer.
- Synchronization Window: The receiver tolerates counters in a certain range to deal with desynchronization to deter replay attacks.
- Database Management: The Car has a database of authorized UserID, Secret Key, and last valid Counter values.
- Finite State Machine (FSM): Coordinates the complex control flow of a sequence of packet transmission and validation code.

A successful authentication opens the door and fills the counter-database of the car; an unsuccessful attempt raises an alarm. The system is completely coded in synthesizable VHDL, which shows a realistic hardware-based approach to automotive security, synchronization, and embedded communication.

### **1.3 OBJECTIVES**

The objectives of this project are as follows:

1. To establish a rolling code authentication scheme based on the One-Time Password (OTP) that is calculated by using a counter and a secret key, which is effective in preventing replay attacks.
2. To establish reliable master-slave communication between the key and car unit using the Serial Peripheral Interface (SPI) protocol.
3. To develop and integrate a synchronized counter system that increments with each transmission and validates counter freshness within a defined window on the receiver side.
4. To create modular VHDL components, including finite state machines (FSMs), an OTP generator, SPI controllers, and a secure database for key and counter storage.
5. To ensure the complete system is synthesizable and capable of real-time authentication, with clear outputs for door lock/unlock status and alarm activation.

### **1.4 ROLES AND RESPONSIBILITIES**

The roles and responsibilities assigned to the group members are as follows:

| <b>Roles</b>                                                    | <b>Responsibilities</b>                                                                                                                                                                            | <b>Person</b> |
|-----------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| Car_Database.vhd,<br>Key_Database.vhd, Final<br>Report document | <ul style="list-style-type: none"><li>● Database creation and integration for both Car and Key.</li><li>● Documentation and report creation.</li><li>● PowerPoint presentation creation.</li></ul> | Nayla         |
| Car.vhd, Car_FSM.vhd,<br>SPI_Slave, SPI_Master,<br>System_tb    | <ul style="list-style-type: none"><li>● Initiator of the Final Project Idea</li><li>● Creation of the main program,</li></ul>                                                                      | Hanif         |

|                                                                            |                                                                                                                                                                                                                                                                                           |        |
|----------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
|                                                                            | <p>especially the Car System, which includes top-level and FSM, and Serial Communication.</p> <ul style="list-style-type: none"> <li>● System testbench that combines both the key and the car system to be tested</li> <li>● Discussion and design of the application concept</li> </ul> |        |
| Key.vhd, Key_FSM.vhd, OTP_Generator, Button_Debouncer, Counter_Inc, README | <ul style="list-style-type: none"> <li>● Key Systems that include top-level, FSM, button debouncers, counter increment, and OTP Generator creation and integration.</li> <li>● Documentation and report creation.</li> <li>● PowerPoint presentation creation.</li> </ul>                 | Nadira |

Table 1. Roles and Responsibilities

## CHAPTER 2

### IMPLEMENTATION

#### **2.1 EQUIPMENT**

The tools that are going to be used in this project are as follows:

- Visual Studio Code
- ModelSim & Quartus Prime
- Github

#### **2.2 IMPLEMENTATION**

In working on this Digital System Design Final Project, we applied basic concepts such as:

##### **1. Dataflow Style Programming in VHDL**

Dataflow Style is implemented through concurrent signal assignments that directly wire internal signals to outputs, such as `SCK<=sck_int` in the SPI master and `Tx_Active<=spi_is_busy` in the key unit. It also appears in combinational processes like the packet selector MUX, where outputs update immediately when inputs change, emphasizing parallel signal propagation over sequential execution.

##### **2. Behavioral Style Programming in VHDL**

In this project, behavioral styles were mainly implemented through process statements with sensitivity lists that describe sequentially and are driven by clock behavior. It's used extensively in all finite state machines, such as `key_fsm`, `car_fsm` for state transitions, in modules like `counter_inc` and `spi_master` for sequential counting and shifting, and in the otp generator for algorithmic computation. This enables a procedural description of functionality using if-then-else, case, and synchronous updates on clock edges, and focuses on what the system does rather than its structural wiring.

### **3. Testbench**

Testbench, in this project, was handled in a single VHD. file. Our testbench uses structural instantiation of both key and car units, creates a clock process with controlled timing, and implements stimulus procedures such as press\_unlock\_button, lock\_car to simulate user interactions. It monitors outputs such as car\_door, car\_siren, and key\_tx\_active to track authentication success through unlock\_count. Although in our case we don't use asserts and reports, this testbench still validates our SPI communication system and state machine synchronization across multiple unlock attempts.

### **4. Structural Programming**

Although it was done hybridly (behavioral and structural combinations), with behavioral implemented in packet selection, signal assignment & control logic, and constant configurations, structural programming was also comprehensively implemented through component instantiation for flexibility and ease in modifying or debugging to check its functionality. The system is also built by connecting pre-designed modules (component declarations) using a port map. In key.vhd six components are instantiated: button\_debouncer, counter\_inc, otp\_generator, key\_fsm, SPI\_master, and internal signals are wired to form the complete system itself. Similarly done in a car.vhd, instantiations made: SPI\_slave, Car\_Database, OTP\_Generator, and Car\_FSM.

The testbench also uses structural programming by instantiating both key and car top-level entities, connecting their SPI ports directly to simulate full system communication. This approach allows for independent development, testing, and reuse of each functional block. Arrays are also implemented in this project, primarily in the Car\_Database and Key\_Database, where they are used to create an efficient table structure for storing and retrieving authentication credentials.

### **5. Looping Construct**

This module is implemented in the Car\_Database using a for loop to perform a sequential search operation through the database array. It iterates

through all 4 database entries (0 to 3 for loops) to execute two functions, the first one being to search for a matching user ID during the authentication lookup, and the second is to update the corresponding counter value after successful verification. The choice made for a for-loop over something like while or for-generate is due to a fixed number of iterations aligning with the known size of the database, ensuring it was gonna be able to be synthesized and readable.

## 6. Finite State Machine

Finite State Machines (FSMs) are actually central to our project's control logic, implemented in both Key\_FSM and Car\_FSM using a behavioral style with explicit state and next-state logic.

### 1.) Key\_FSM (transmitter)

This FSM has a purpose to control the sequential transmission of three authentication packets (user ID to counter to OTP) via SPI. There are 13 states in total:



The FSM starts in IDLE and transitions to START\_ID when the Button\_Press is received. The FSM subsequently transmits the User\_ID, the Counter, followed by the OTP (Rolling Code), and states such as WAIT\_DONE\_ID, WAIT\_DONE\_CNT, and

`WAIT_DONE_OTP` are used to synchronize the SPI after a packet.

Importantly, the `WAIT_BUSY_CNT` state provides the obligatory operation of the increased value of the counter state, `Counter++`, prepping the system for the next transaction. Last, the `UPDATE` state indicates success of the transaction with the car, and it'll permanently record the counter in `Key_DB` if successful, & goes back to `IDLE`.

The following table is a more detailed state functions:

| State                         | Trigger                       | Next State                    | Outputs                                                                                       | Type  |
|-------------------------------|-------------------------------|-------------------------------|-----------------------------------------------------------------------------------------------|-------|
| <code>ST_IDLE</code>          | <code>Button_Press='1'</code> | <code>ST_START_ID</code>      | <code>SPI_Start='0'</code><br><code>Packet_Select="00"</code><br><code>Inc_Counter='0'</code> | Moore |
| <code>ST_START_ID</code>      | Always triggering             | <code>ST_WAIT_BUSY_ID</code>  | <code>SPI_Start='1'</code> ,<br><code>Packet_Select="00"</code>                               | Moore |
| <code>ST_WAIT_BUSY_ID</code>  | <code>SPI_Busy='1'</code>     | <code>ST_WAIT_DONE_ID</code>  | <code>Packet_Select="00"</code>                                                               | Mealy |
| <code>ST_WAIT_DONE_ID</code>  | <code>SPI_Busy='0'</code>     | <code>ST_GAP_1</code>         | <code>Packet_Select="00"</code>                                                               | Mealy |
| <code>ST_GAP_1</code>         | Always triggering             | <code>ST_START_CNT</code>     | <code>Packet_Select="01"</code>                                                               | Moore |
| <code>ST_START_CNT</code>     | Always triggering             | <code>ST_WAIT_BUSY_CNT</code> | <code>SPI_Start='1'</code> ,<br><code>Packet_Select="01"</code>                               | Moore |
| <code>ST_WAIT_BUSY_CNT</code> | <code>SPI_Busy='1'</code>     | <code>ST_WAIT_DONE_CNT</code> | <code>Packet_Select="01"</code>                                                               | Mealy |
| <code>ST_WAIT_DONE_CNT</code> | <code>SPI_Busy='0'</code>     | <code>ST_GAP_2</code>         | <code>Packet_Select="01"</code>                                                               | Mealy |

|                  |                   |                  |                                      |       |
|------------------|-------------------|------------------|--------------------------------------|-------|
| ST_GAP_2         | Always triggering | ST_START OTP     | Packet_Select="10"                   | Moore |
| ST_START OTP     | Always triggering | ST_WAIT_BUSY OTP | SPI_Start='1',<br>Packet_Select="10" | Moore |
| ST_WAIT_BUSY OTP | SPI_Busy='1'      | ST_WAIT_DONE OTP | Packet_Select="10"                   | Mealy |
| ST_WAIT_DONE_OTP | SPI_Busy='0'      | ST_UPDATE        | Packet_Select="10"                   | Mealy |
| ST_UPDATE        | Always triggering | ST_IDLE          | Inc_Counter='1'<br>(1-cycle pulse)   | Moore |

## 2.) Car\_FSM (Receiver Security)

This state machine has a purpose to manage the car's response to authentication attempts (whether it's unlock or alarm). It has 5 states as visualized below:



IDLE transitions to CHECK upon receiving the initial trigger. In CHECK, the FSM quickly performs the critical validation: receiving

all three packets (ID, Counter, OTP) via SPI, looking up the User ID, calculating the Expected OTP, and comparing the two OTP values.

**Success Path (Code\_Is\_Correct = '1')**: The FSM passes to UPDATE (permanently incrementing the Counter C in the database), and then to OPEN (setting Door\_Open = '1'), and again to IDLE.

**Failure Path (Code\_Is\_Correct = '0')**: When ALARM (activating Alarm\_Siren = '1') is entered, ALARM\_WAIT (forcing a lockout timer to prevent brute-force attacks) is enforced, then at last the FSM is returned to IDLE.

The following table is a more detailed state function:

| State         | Trigger                 | Next State                           | Outputs                                                                  | Type                              |
|---------------|-------------------------|--------------------------------------|--------------------------------------------------------------------------|-----------------------------------|
| ST_IDLE       | Remote_Tri<br>gger='1'  | ST_CHECK                             | Door_Open='0',<br>Alarm_Siren='0',<br>Check_Enable='0',<br>Update_DB='0' | Moore                             |
| ST_CHECK      | Code_Is_C<br>orrect='1' | ST_UPDATE<br>Code_Is_Correc<br>t='0' | ST_ALARM                                                                 | Check_<br>Enable<br>='1'<br>Mealy |
| ST_UPDAT<br>E | Always                  | ST_OPEN                              | Update_DB='1'                                                            | Moore                             |
| ST_OPEN       | Always                  | ST_OPEN<br>(hold)                    | Door_Open='1'                                                            | Moore                             |
| ST_ALAR       | Always                  | ST_ALARM                             | Alarm_Siren='1'                                                          | Mooreq                            |

|   |  |        |  |  |
|---|--|--------|--|--|
| M |  | (hold) |  |  |
|---|--|--------|--|--|

## **CHAPTER 3**

### **TESTING AND ANALYSIS**

#### **3.1 TESTING**

Among other things, to debug the output of the Secure Vehicle Entry System as well as ensure that all the security features of the system are safe, extensive testing based on a planned VHDL testbench was done. To replicate the coordinated communication and cryptographic activities between the Key device (SPI Master) and the Car unit (SPI Slave), a testbench was required. The simulation involved 5 discrete cycles to be executed one after another in order to test the integrity and recovery of the system, and it was found that the system can handle normal as well as security challenges. The testing platform was strictly concerned with the robustness of the rolling-code scheme and its sensitivity to various cases of attacks, to warrant the Counter to be stateful and the Database update to be integrally sound.

The simulation featured 5 discrete cycles, which were performed one at a time in order to test both system correctness and recovery, which proved that the system would be capable of managing both normal and security challenges:

- Cycle 1 and 2 (Success): The authentication is performed successfully in a sequence Counter Freshness and Database Integrity Door\Lock = '1'.
- Cycle 3 (Failure): Replay Attack Simulation, Alarm\Siren = '1' Rejection of Stale Counter.
- Cycle 4 (Failure): Synchronization Failure (First Recovery Attempt), Alarm\Siren = '1' (Second failure), Security Tolerance Window.
- Cycle 5 (Success): Full Recovery, Door\Lock = 1 and Counter Update Usability after Alarm.

The testbench used particular VHDL functions to simulate button presses and key resets, thus providing proper control of the Event Counter value of each scenario.

## 3.2 RESULT

The following are the simulation results from a testbench created using ModelSIM.



Fig 2. Testing Result

## 3.3 ANALYSIS

The safe vehicle entry system is efficient in meeting all the project objectives due to the analysis that depicts the high degree of security validation and recovery systems. The security test of the system is completely deterministic and aligned with the security objectives of the project.

### Sequential Success Validation

#### 1. Key Transmission Sequence (Master Side)

The waveform confirms the Key\_FSM follows the correct three-packet sequence required by the protocol:

- Trigger and Counter Increment: The system is initiated by a key event (implied by debounced button signals), causing the System.DUT.Key\_Counter to increment (e.g., 0→1→2 in the later part of the trace). This fresh counter is the first input to the OTP generator.

- OTP Calculation: The OTP\_Generator calculates the unique OTP\_Result using the new counter and the Secret\_Key *before* transmission begins, fulfilling the rolling code requirement.
- SPI Transmission: The system executes three distinct transmission phases (indicated by System.DUT.SPI\_busy activity) to send:
  - Packet 1: User ID (for database lookup).
  - Packet 2: Current Counter Value (for synchronization check).
  - Packet 3: Calculated OTP (for final authentication)

## 2. Car Authentication Sequence (Slave Side)

First, the system checks the database. When System.DUT.db\_key\_found goes high; it means the user ID matches, and the system pulls up the right credentials. Next, it looks at the counter. If System.Counter\_Valid goes high, the system knows the counter from Packet 2 is fresh and sits inside the allowed sync window, or basically, it's not too old or too far ahead.

Now comes the main part of the security check, when the System.Match\_Flag goes high (this all happens super fast, around 0.04 ms), and the received OTP matches what the system expected. That's the green light. With the match, the state machine kicks into gear. System.System\_State moves through its steps, first ST\_CHECK, then ST\_UPDATE, and finally ST\_OPEN. At the end, the door actually unlocks: System.Door\_Open goes high, and System.Door\_Lock drops low. And after a successful login, the system updates the database, saving the new counter value. This way, nobody can replay the same code and sneak in again.

## Security Failure Validation

### 1. Prevention of Replay Attack

The waveform shows how the system defends itself against big security threats, mainly replay attacks and synchronization problems.

The most crucial defense is the Synchronization Window and Database Update:

- Counter Freshness: The System.Counter\_Valid check ensures that a re-sent (replayed) old counter value would fail the test, specifically the condition  $Recv \leq Stored$ . If an attacker captures and re-sends an old packet, the System.Counter\_Valid signal will remain low, preventing the System.Match\_Flag from ever going high, thereby forcing the Car\_FSM into the failure sequence (ST\_ALARM).
- Post-Success Update: By updating the stored counter in the Car\_Database immediately after a successful unlock (ST\_UPDATE state), the system invalidates the currently used OTP and counter for any future attempt, making the captured transaction useless for an attacker.

### 2. Synchronization Handling

The system is designed to tolerate benign desynchronization using the upper limit of the window (example:  $Recv \leq Stored + 10$ ):

- Tolerance: The  $Recv \leq UpperLimit$  check allows a few missed button presses (and thus missed counter increments) to still result in a System.Counter\_Valid high signal. This ensures that the legitimate user is not locked out due to minor transmission failures. A successful authentication visible in the waveform implies that any desynchronization that occurred remained within the +10 tolerance.

The analyzed waveform confirms that the RKE system is both functionally correct in its operational sequence and secure against replay attacks through its counter and validation logic.

## CHAPTER 4

### CONCLUSION

Secure Vehicle Entry System Implementation and design with the help of VHDL has been successfully done, and in all aspects, the objectives of the project were achieved and the main goals were to develop a strong hardware-based authentication system. This project will tackle the vital vulnerability of replay attacks in contemporary automotive security as they will be replacing the fixed-code systems with a dynamic rolling code architecture.

**Achievement of Security Objectives** The main success of this project will be the implementation of the One-Time Password (OTP) scheme supported by a synchronized counter system. As it is shown in the analysis of the simulation, the system successfully authenticates the legitimate users and prevents unsuccessful attempts of access by unauthorized ones. Logic that is implemented in the CarFSM and CarDatabase verify that any packet that has been captured or replayed is automatically invalidated by the freshness of a check on the counter. Moreover, the addition of a synchronization window comes in as a key functionality, where the system can afford small desynchronizations (to a specified threshold) without freezing the user, to allow compromising maximum security with reasonable ease of use.

**Stability of Communication and Control** The addition of the Serial Peripheral Interface (SPI) offered a dependable and effective communication platform between the Key (Master) and the Car (Slave). The separation of the transmission into three different packets, namely: User ID, Counter, and OTP, that the Key\_FSM managed, guaranteed the integrity of the data in the transmission channel. The Finite State Machines were also instrumental in the coordination of the complex timing requirements, and a smooth transition between idle, verification, and actuation states (Door Open/Alarm,) depending on the real-time inputs.

**System Synthesis and Verification.** The system was thoroughly checked by applying the ModelSim testbench, which tested the system functionality under different conditions. The results of the waveforms showed that:

- **Successful Authentication:** This Authentication is achieved only when the created OTP matches the expected hash, and the counter is within the valid window.

- Database Management: This system will properly update the internal database upon successful entry to ensure that the same code is not reused in the future.
- Threat Mitigation: The mitigation, which is to evoke the alarm state when stale counters are detected or invalid OTPs are detected, is effective as shown by the security logic.

To sum up, in this project, it has been shown that VHDL is an effective tool when it comes to creating complex and secure embedded systems. It emphasizes the fact that the optimal architecture for modern vehicle security is the co-design of cryptographic algorithms (OTP), state-machine logic, and trusted communication protocols. The resultant system is a modular, scalable, and synthesizable solution that can combat the dangers of wireless keyless entry quite successfully.

## REFERENCES

- [1] “Module 9 - Microprogramm | Digilab UI,” Digilabdte.com, 2025.  
<https://learn.digilabdte.com/books/digital-sistem-design-psddsg/chapter/module-9-microprogramming>
- [2] GeeksforGeeks, “What is Serial Peripheral Interface (SPI)?,” GeeksforGeeks, Mar. 13, 2024.  
<https://www.geeksforgeeks.org/electronics-engineering/what-is-serial-peripheral-interface-spi/>
- [3] “Bypassing Rolling Code Systems – AndrewNohawk.”  
<https://www.andrewmohhawk.com/2016/02/05/bypassing-rolling-code-systems/>
- [4] mohamedamine99, “GitHub - mohamedamine99/Digital-Lock-with-VHDL-state-machine,” GitHub, 2025.  
<https://github.com/mohamedamine99/Digital-Lock-with-VHDL-state-machine>
- [5] harryli0088, “GitHub - harryli0088/rolling-code,” GitHub, 2025.  
<https://github.com/harryli0088/rolling-code>
- [6] robert-mcdermott, “GitHub - robert-mcdermott/rolling-code-auth: A basic implementation of a rolling code authentication system.,” GitHub, 2025.  
<https://github.com/robert-mcdermott/rolling-code-auth>
- [7] kyori19, “GitHub - kyori19/verilog-otp: VerilogHDL implementation of One-Time Password Algorithm (HOTP),” GitHub, 2025. <https://github.com/kyori19/verilog-otp>
- [8] A. Hari, K. Sai, Madhavi Macharapu, and E. S. Babu, “Secure Rolling Code Generation for Remote Keyless Entry Systems Using AES-CTR, Encryption with ChaCha20,” pp. 1–6, Dec. 2023, doi:  
[https://doi.org/10.1109/smartencon60755.2023.10442146.](https://doi.org/10.1109/smartencon60755.2023.10442146)

## APPENDICES

### Appendix A: Project Schematic



Fig. Car system



Fig. Key system

## Appendix B: Documentation

