/fault-injector

A fault injection toolkit based on ESP8266 for glitching electronic circuits. It's low-cost, reliable and can be built anywhere. A must have DIY tool for Hardware Hackers.

Primary LanguageC++MIT LicenseMIT

Fault Injector for ESP8266 and Arduino Boards

Intro

From the Workbench to the Battleground - Crafting a Fault Injection Attacker with an ESP8266 (or nearly any microcontrollers!)

What is Fault Injection Attack?

Fault Injection Attacks is an hardware attack that glitches a hardware circuit to behave in a way which is not intended and cause uncertain behaviour that would be useful for a hacker.

This attack is useful in cases of jumping instructions inside a microprocessor or microcontrollers by gltiching the power supply to the chip. This maybe useful for escaping loops, bypassing authentication, etc. More destructive results can be obtained in cases of glitches that has undefined parameters set and may cause the whole electronic circuit to become unusuable due to deleting firmwares or bootloaders.

Device Information

Since fault injections are so cool and need to be precise, a lot of work has to be put into doing it. It becomes expensive to carry out these attacks with dedicated tools and circuit. Hence, this project was developed, where efforts have been made to develop a device that can be crafted with inexpensive microcontrollers like ESP8266, which is developed with all required functionalities, or as much as possible.

Note that this is a controller which takes user input and provided a digital output (3.3V in case of ESP8266). With other circuits with different operatinal voltage, it is recommended to use supplimentary components to adjust them. This devive works as the logic module in the whole setup and not the physical parameter deciding module. Hence, physical parameters should be setup by the user themselves.

Features

Precise Time Adjustments

This prototype with ESP8266 supports fault injections with microseconds of delay which can be adjusted. This is something that dependes upon the hardware used and it's support to causing delays.

Incremental and Decremental Fault Injections

The time adjustments in fault injections is an important factor to consider and varies according to different circuits. Hence, moving step by step with increasing and decreasing fault injection periods can help find the exact glitch required for the attack. This helps in analysing the circuit behaviour of the circuit and developing stratergy of attack, or even hit the goal in time.

Feedback Loop Support Via Interrupt Pin

Triggering of Injections can be varied with feedbacks with external signals. This allows fault injections with precise timing into the electronic circuits upon certian events. This is included in the triggered fault injections, incremental fault injections as well as decremental fault injections.

Step by Step Increments and Decrements

Stepping up and down with push buttons to adjust voltage glitches helps in finding the exact spot for the fault injection attack with manual analysis. This feature allows users to use push button to increment or decrement (as per the functions setup) and step through various time delays to manually analyse the behaviour of the target.

Power of Feedback Loop

While performing Fault Injections, it is important to glitch the signals with very precise timing. This becomes tedious when performing sophisticated attacks over an hardware circuit. Hence, automating the glitching process to find the perfect spot for attack should be automated.

When faults are injected into circuits, various circuits behave differently. Hence, this behaviour needs to be taken into account while automating the hunting process. For example, certian hardware with Serial Ouput tend to flood the Serial Console with huge ammount of data, which might contain some useful information about the device. Hence, capturing it and triggering halt can be useful to stop the attack in that case. Furthermore, too much hard glitches can cause the device to reset. Hence, getting a feedback from reset leds or testpoints can be useful to stop the attack with high magnitude of faults in the circuit.

Feedback loops open a lot of doors for advancements in automating the fault injection and exposing vulnerabilities. This interrupt feedback can be paired with computers with higher processing power than the microcontroller and use algorithms to analyse and adjust the parameters.

Automated Scripts

Since Serial Communication is used to interact with the fault-injector, right commands at the right time are required. Hence, developing automated scripts with Python (or any other language) can automate tasks that are repetative or triggering logics are required.

Since ESP8266 is a single core microcontroller, parallel task simultaneously is not possible. Writing Scripts to provide instructions with a multi-core CPU system would allow faster response to events.

Example for Serial Communication with Python:

import serial
import time 

serial_port = '/dev/<esp8266>'      # modify this with the usb connection  
baud_rate = 115200 

# Include commands here
commands = [
    "command1",
    "command2",
    "command3",
    "command4",
]

console = serial.Serial(serial_port, baud_rate, timeout=1)

time.sleep(2)

try:
    while True:
        # To read the Serial Data
        if console.in_waiting > 0:
            data = console.readline().decode('utf-8').rstrip()
            print("Received:", data)
            
        # Executing all the commands one by one
        for command in commands:
            console.write(command.data_to_send.encode('utf-8') + b'\n'')

except KeyboardInterrupt:
    console.close()

Setting up the circuit

The code provided here is nearly enough to explain the wiring diagram of the circuit. Various parameters needs to be adjusted while developing the circuit, hence adjusting them before flashing the microcontroller is a good practice.

#define TRIGGER_PIN D1                // Trigger Input Pin (Pull Down Register is Required)
#define DIGITAL_FAULT_PIN D2          // Digital Output Pin
#define ANALOG_FAULT_PIN D3           // Analog Output Pin
#define INTERRUPT_PIN D4              // Interupt Input Pin (Pull Down Register is Required)

Requirements:

  • ESP8266 (or ESP32, Arduino, etc. just adjust the code as per the device interfacing)
  • Push Buttons
  • Pull Down Registors (10K Ohms)
  • Workbench Components like Breadboard, Jumper Cables, Switching Mosfets are per requirements, Logic Analysers (for visualising digital fault injections), Oscilloscope (for digital and analog fault injections), etc.
  • Required Interfaces (for example, EMF induction circuit if EMF is to be used for fault injection)

Flash the Code:

Flash the code into the ESP8266 NodeMCU (For example, with Arduino IDE). It is recommended to flash the NodeMCU before connecting it to other components in the circuit as it might interfer with programming it.

Connect the Circuit

Connect the components as per configured in the code. In case default configurations are made, connect them as per the comments mentioned in the code.

The circuit architecture is very simple. All the pins marked with input just needs a 3.3V input signal to get triggered. For output pins, it would throw 3.3V. These signals can be interfaced with various other modules for controlling the fault injection.

Getting Started

Connect the board with the computer and get access to the Serial Console. It is recommended to use Arduino IDE for it's capability to show enterred commands. Although, any Serial Communication tool can be used like picocom, minicom, screen, etc. To interact with the board, start with the help menu:

HELP

This will provide all the parameters and commands to set up the device for attacking. For example, use the following command to list all the parameters that are to be set:

LIST

By default, parameters are set to default values and need to be adjusted as per the attack.

Warning!

Note that this attack can unintentionally damage the circuit due to a lot of factors. Fault Injection attacks can be dangeruous and can cause permenant damage to the device. Hence, use this tool wih caution.

The author of the project is not responsible for any damage caused by the project. So use it responsibly.

Development of the Project

This project is under development process and the steps might vary from the documentation. Efforts are made to keep the documentation in par with the development process. Hence, refering to the code is useful while working with it to make sure things go as expected.

License

This project is licensed under the MIT License - see the LICENSE file for details.