# **Hardware Trojans**

Engr 399/599: Hardware Security Grant Skipper, Ph.D. *Indiana University* 



Adapted from: Mark Tehranipoor of University of Florida

# Agenda

Review some of last class.

Finish Hardware Trojan Unit?

First Project Assigned: Due 2/17/25

### Course Website

# engr99.github.io

Write that down!

# First Project!

https://github.com/ENGR599/P1\_Hardware\_Trojan

Hardware Distributed Today/Soon

Chris & Grant available during office hours or via appointment.

Dr. Skipper Cell: Office Hours 4:30-5:30 Monday Luddy 3111.

# First Project!

Project 1: Hardware Trojan

Goal: "Corrupt" a working DES implementation

We give you DES in HW

You need to:

- Deploy DES
- Corrupt DES

# Side Quest: Seagate Controversy

#### 1/29/2025

Researchers found "new" Seagate hard drives profiled with performance metrics of having been run for "10,000 hours".

Investigators found Seagate HDs were being recycled and resold as new.

Seagate responds stating customers should only buy from "certified partners".

#### What gives?





### **Trojan Taxonomy**



Iterating on previous models; balancing abstraction and specificity.

### **Hardware Trojan (Detection) Taxonomy**

HT Detection methods can be roughly taxonomized via the general approach used to perform detection, the inputs used, and the output analysis provided.



#### **FANCI**

Analysis: Static

Input Artifacts: Behavioral RTL (in theory), Netlist (gate-list).

#### Method:

A tool that flags suspicious wires in a design which have the \*potential to be malicious\* i.e. hardware Trojan.

Statically identify "weakly-affecting inputs", which are input wires the authors presume to have the capability to serve as backdoor triggers.

#### **FANCI**

#### Pros:

- Static analysis of inputs make it very flexible and potentially generalizable.
- Easy to implement.
- Likely to outperform simulation based methods (eg UCI).

Chip Scan Espy Example: https://espy.chipscan.us/upload

#### Cons:

- There exists no open implementation of the FANCI algorithm.
- FANCI has received enough attention that techniques have been created for specifically defeating it (Detrust).

Notes: A practical implementation of FANCI must involve Gate-list. If you intend to perform FANCI on RTL, it needs to ultimately be synthesized (eg. run it through Yosys).

Many proposals for improving FANCI exist, including recommendations from Detrust authors, and the ANGEL algorithm - which is essentially an evolution of FANCI.

# **Examples for Layout Level Trojans**

# **Example: Type**

#### **Functional**







- Addition or deletion of components
- Sequential circuits
- Combinational circuits
- Modification to function or no change

#### **Parametric**



#### **Parametric**



- Modifications of existing components
  - Wire: e.g. thinning of wires
  - Logic: Weakening of a transistor, modification to physical geometry of a gate
  - Modification to power distribution network
- Sabotage reliability or increase the likelihood of a functional or performance failure

### **Example: Size**

### **Big**



- Size:
  - Number of components added to the circuit
    - Small transistors
    - Small gates
    - Large gates

#### **Small**



- In case of layout, depends on availability of:
  - Dead spaces
  - Filler cells
  - Decap cells
  - Change in the structure

### **Example: Distribution**

### **Tight**



- Tight Distribution
  - Trojan components are topologically close in the layout

#### Loose



- Loose Distribution
  - Trojan components are dispersed across the layout of a chip
- Distribution of Trojans depends on the availability of dead spaces on the layout

### **Example: Structure**

### **No-change**



- The adversary may be forced to regenerate the layout to be able to insert the Trojan, then the chip dimensions change
  - It could result in different placement for some or all the design components

### **Modified Layout**



- A change in physical layout can change the delay and power characteristics of chip
  - It is easier to detect the Trojan

# **Trojan Taxonomy: Activation**



# **Activation: Internally Activated**



### **Trojan Taxonomy: Action**



# **Example: Action**



### **IP Trust & IP Security**

#### IP Trust

- Detect *malicious* circuits inserted by IP designers
  - Goal to Verify Trust: Protect IP buyers, e.g., SoC integrators

### IP Security

- Information leakage, side-channel leakage, backdoors, functional bugs and flaws, illegal IP use/overuse, etc.
  - Goal to Verify Security: Protect application

### **IP Trust**

### **IP Trust**

- IPs from untrusted vendors need to be verified for trust before use in a system design
- Problem statement: How can one establish that the IP does exactly as the specification, nothing less, nothing more?

Hardware Assurance

#### IP Cores:

Soft IP, firm IP and hard IP

#### Challenges:

- No known golden model for the IP
  - Spec could be assumed as golden
- Soft IP is just a code so that we cannot read its implementation
  - Think about what Soft IP looks like through the Lifecycle!

# **Approaches for Pre-synthesis**

#### Formal verification

- Property checking
- Model checking
- Equivalence checking

#### Coverage analysis

- Code coverage
- Functional coverage
  - ATPG

### **Formal Verification**

#### Formal verification

- Ensuring IP core is exactly same as its specification
- Three types of verification methods
  - Property checking: Every requirement is defined as assertion in testbench and is checked
  - Equivalence checking: Check the equivalence of RTL code, gate-level netlist and GDSII file
  - Model checking
    - System is described in a formal model (C, HDL)
    - The desired behavior is expressed as a set of properties
    - The specification is checked against the model
- Problem with FV = ???

# **Coverage Analysis**

- Code coverage
  - Line coverage

Show which lines of the RTL have been executed

Statement Coverage

Spans multiple lines, more precise

FSM Coverage

Show which state can be reached

Toggle

- **Each Signal in gate-level netlist**
- Function coverage
  - Assertion

**Successful or Failure** 

### **Suspicious Parts**

 If one of the assertions fails, the IP is assumed untrusted.

 If coverage is not 100%, uncovered parts of the code (RTL, netlist) are assumed suspicious.

Can we cover 100% of a part?

# **IC Trust**

### IC (System) Trust

#### Objective:

 Ensure that the fabricated chip/system will carry out only our desired function and nothing more.

#### Challenges:

- Tiny: several gates to millions of gates
- Quiet: hard-to-activate (rare event) or triggered itself (time-bomb)
- Hard to model: human intelligence
- Conventional test and validation approaches fail to reliably detect hardware Trojans.
  - Focus on manufacture defects and does not target detection of additiona functionality in a design



### Classification of Trojan Detection Approaches



- Destructive Approach: Expensive and time consuming
  - Reverse engineering to extract layer-by-layer images by using delayering and Scanning Electron Microscope
  - Identify transistors, gates and routing elements by using a templatematching approach – needs golden IC/layout

### Classification of Trojan Detection Approaches

#### Non-destructive Approach

- Run-time monitoring: Monitor abnormal behavior during run-time
  - Exploit pre-existing redundancy in the circuit
  - Compare results and select a trusted part to avoid an infected part of the circuit.
- Test-time Authentication: Detect Trojans throughout test duration.
  - Logic-testing-based approaches
  - Side-channel analysis-based approaches



### **Hardware Trojan Benchmarks**

- A set of trust benchmarks for researchers in academia, industry, and government is needed to
  - Provide a baseline for examining diverse methods developed
  - Establishing a sound basis for the hardness of each benchmark instance
  - Help increase reproducibility of results by others who intend to employ certain methodologies in their design flow
- See NSF supported Trust-Hub website (<u>www.trust-hub.org</u>)
  - Complete taxonomy of Trojans
  - More than 120 trust benchmarks available which were designed at different abstraction levels, triggered in several ways, and have different effect mechanisms
  - More than 300 publications used these benchmarks'
- NIST is getting into the game!

# **Logic Testing Approach**

- Logic-testing approach focuses on test-vector generation for
  - Activating a Trojan circuit
  - Observing its malicious effect on the payload at the primary outputs
  - Both functional and structural test vectors are applicable.

#### Pros & Cons:

- Pros:
  - Straight-forward and easy to differentiate
- Cons:
  - The difficulty in exciting or observing low controllability or low observability nodes.
  - Intentionally inserted Trojans are triggered under rare conditions.
     (e.g., sequential Trojans)
  - It cannot trigger Trojans that are activated externally and can only observe functional Trojans.

# **Functional Test Deficiency**

- Functional patterns could potentially detect a "functional"
   Trojan.
  - Exhaustive test would be effective, but certainly not applicable for large circuits
  - $\square$  E.g. 64 input adder  $\square$  2<sup>65</sup> input combination (including carry in)
  - $= 2^{65} > 10^{18}$  This is impractical
  - $\Box$  100MHz is used  $\Box$  10<sup>10</sup> s  $\Box$  317 years

  - □ The fault coverage is low for manufacturing test
- In practice, structural tests are used.

# **Functional Testing**

### Feasible Trojan space inordinately large!

**Deterministic** test generation infeasible

A statistical approach is, more effective

### ● MERO: A <u>Statistical</u> Approach

- Find the rare events in the circuit
- Generate vectors to trigger each rare node <u>N times</u>
- Provides high confidence in detecting unknown Trojans!



Trojan Trigger Condition

a=0, b=1, c=1

### **MERO**

#### MERO:

- Generates a set of test vectors that can trigger each rare node to its rare value multiple times (N times)
- It improves the probability of triggering a Trojan activated by a rare combination of a selection of the nodes



Fig. 15.6 Trigger coverage and Trojan coverage and test length for two ISCAS-85 benchmark circuits for different values of "N," using the MERO approach [8]

Challenge: Triggering each net N times in a large circuit is challenging

# Comprehensive Attack Model

| Model | Description                              | 3PIP Vendor | SoC Developer | Foundry   |
|-------|------------------------------------------|-------------|---------------|-----------|
| A     | Untrusted 3PIP vendor                    | Untrusted   | Trusted       | Trusted   |
| В     | Untrusted foundry                        | Trusted     | Trusted       | Untrusted |
| С     | Untrusted EDA tool or rogue employee     | Trusted     | Untrusted     | Trusted   |
| D     | Commercial-off-the-shelf component       | Untrusted   | Untrusted     | Untrusted |
| Е     | Untrusted design house                   | Untrusted   | Untrusted     | Trusted   |
| F     | Fabless SoC design house                 | Untrusted   | Trusted       | Untrusted |
| G     | Untrusted SoC developer with trusted IPs | Trusted     | Untrusted     | Untrusted |

### **Side Channel Signal Analysis -- Power**

- Hardware Trojans inserted in a chip can change the power consumption characteristics.
- Partial activation of Trojan can be extremely valuable for power analysis.
- The more number of cells in Trojan is activated the more the Trojan will draw current from power grid.



**Golden chip required!** 

# **Hardware Trojans**

Engr 399/599: Hardware Security Grant Skipper, Ph.D. *Indiana University* 



Adapted from: Mark Tehranipoor of University of Florida

### Agenda

- Review some of last class.
- Deep(ish) Dive into DES mechanics
- Start HT Unit.
- Next week first project assigned (on HTs!)

### **Side-Channel Trojan Detection**

 Side-Channel Approach for Trojan Detection relies on observing Trojan effect in physical side-channel parameter, such as switching current, leakage current, path delay, electromagnetic (EM) emission

Due to process variations, it is extremely challenging to detect the Trojan by considering F<sub>max</sub> or I<sub>DDT</sub> individually.



### Side-channel Signals

- All the side-channel analyses are based on observing the effect of an inserted Trojan on a physical parameter such as
  - IDDQ: Extra gates will consume leakage power.
  - IDDT: Extra switching activities will consume more dynamic power.
  - Path Delay: Additional gates and capacitance will increase path delay.
  - □ **EM**: Electromagnetic radiation due to switching activity

#### Pros & Cons

- Pros: It is effective for Trojan which does not cause observable malfunction in the circuits.
- Cons: Large process variations in modern nanometer technologies and measurement noise can mask the effect of the Trojan circuits, especially for small Trojan.

**Golden chip required!** 

## **Sensitivity Metric**

### Improving Detection Sensitivity



$$Sensitivity = \frac{I_{tampered} - I_{original}}{I_{original}} \times 100\%$$

## **Comparing Approaches**

|      | Logic Testing                                                                                   | Side-Channel Analysis                                                                     |
|------|-------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|
| Pros | <ul><li>Robust under process noise</li><li>Effective for ultra-small Trojans</li></ul>          | <ul><li>Effective for large Trojans</li><li>Easy to generate test vectors</li></ul>       |
| Cons | <ul><li>Difficult to generate test vectors</li><li>Large Trojan detection challenging</li></ul> | <ul><li>Vulnerable to process noise</li><li>Ultra-small Trojan Det. challenging</li></ul> |

- A combination of logic testing & side-channel analysis could provide the good coverage!
- Online validation approaches can potentially provide a second layer of defense!

### Side-channel Approach

- Multiple-parameter Trojan Detection
  - Due to process variations, Trojan detection by F<sub>max</sub> or I<sub>DDT</sub> alone is challenging!



Consider the intrinsic relationship between I<sub>DDT</sub> and F<sub>max</sub>

**Golden chip required!** 

### **Trojan Inserted into s38417 Benchmark**



PP: Power Pad

### **Power Analysis -- Locality**



- Current difference measured from power pad 17 (Trojan-free vs Trojan-inserted)
- There is no change in layout of the circuit. Trojan was inserted in an unused space in the circuit layout.

### Power Analysis -- Challenges

#### Pattern Generation

- How to increase switching activity in Trojans?
- How to reduce background noise?
- Switching locality
- Random Patterns
  - No observation is necessary, Similar to test-per-clock
  - Measurement Device Accuracy
    - Measurement noise
      - Process Variations
        - Calibration
          - On-Chip Measurement
            - Vulnerable to attack
              - Authentication Time
                - Trojans can be inserted randomly

### Side Channel Analysis -- Delay

- Hard to detect using power analysis are:
  - Distributed Trojans
  - Hard-to-activate Trojans
- Path delay: A change in physical dimension of the wires and transistors can also change path delay.



### **Delay-based Methods**

- Shadow-register provides a possible solution for measuring internal path delay.
- From this architecture, it can be seen that the basic unit contains one shadow register, one comparator and one result register.
  Original Circuit

#### Limitations:

- PV
- Overhead
- S-clock
- Output



## **Clock Sweeping Technique**

- Clock sweeping involves applying a pattern at different clock frequencies, from a lower speed to higher speeds.
- Some paths sensitized by the pattern which are longer than the current period start to fail when the clock speed increases.
- The obtained start-to-fail clock frequency can indicate the delays of the paths sensitized by the patterns



11 October 2021 51

## **Delay Analysis -- Challenges**

- Major advantage over power analysis:
   No activation is required.
  - Detection and Isolation
    - How significant is the delay inserted by Trojan?
    - It depends on Trojan size and type
    - Location: on short paths or long paths
      - Pattern Generation
        - Delay test patterns
        - Path Coverage
          - Process Variations (V<sub>th</sub>, L, T<sub>ox</sub>)
            - Impact circuit delay characteristics significantly
            - Differentiate between Trojan and PV
              - Trojan can have impact on multiple paths (an advantage over PV)

## **Trojan Detection**

| Trojan                       |                               |                 |                  | Power<br>Analysis | Delay<br>Analysis | Fully<br>Activation |
|------------------------------|-------------------------------|-----------------|------------------|-------------------|-------------------|---------------------|
| Trojan<br>Classifi<br>cation | Physical<br>Characteristics   | Туре            | Functional       | D                 | Р                 | Р                   |
|                              |                               |                 | Parametric       | Р                 | D                 | Р                   |
|                              |                               | Size            | Small            |                   | D                 | Р                   |
|                              |                               |                 | Large            | D                 | Р                 | Р                   |
|                              |                               | Distribution    | Tight            | D                 | D                 | Р                   |
|                              |                               |                 | Loose            | Р                 | D                 | Р                   |
|                              |                               | Structure       | Modify<br>Layout | Р                 | D                 |                     |
|                              | Activation<br>Characteristics | Always-on       |                  |                   | D                 |                     |
|                              |                               | Condition-based | Logic-based      | D                 | Р                 | Р                   |
|                              |                               |                 | Sensor-<br>based | D                 |                   |                     |
|                              | Action<br>Characteristics     | Modify Function |                  | D                 | Р                 |                     |
|                              |                               | Modify Spec.    | Defects          | Р                 | D                 | Р                   |
|                              |                               |                 | Reliability      | Р                 | Р                 | Р                   |

**P:** Detection is possible

**D:** High level of confidence

### **Design for Hardware Trust**

 Since detecting Trojan is extremely challenging, design for hardware trust approaches are proposed to

#### Improve hardware Trojan detection methods

- Improve sensitive to power and delay
- Rare event removal

#### Prevent hardware Trojan insertion

Design obfuscation

### Rare Event Removal

- Intelligent attackers will choose low-frequency events to trigger the inserted Trojans.
- Improving controllability or observability can make rare events scarce, thereby facilitating detecting Trojans inside the design.
  - Design for Trojan test: inserting probing points
  - Inserting dummy scan flip-flops

#### Remember FANCI / UCI !!!!

### Increasing Probability of Partial/Full Activation

Inserting dummy FFs on path with very low activation probability

а



### Increasing Probability of Partial/Full Activation

 Dummy scan flip-flops are inserted to control hardto-excite nodes.

- Usage:
  - Full activation: increase controllability
  - Power-based: generate switching activities
  - Delay-based: activate more paths to improve coverage

### **Trojan Prevention - Design obfuscation**

- The objective is deterring attackers from inserting Trojans inside the design.
- Design obfuscation means that a design will be transformed to another one which is functionally equivalent to the original, but in which it is much harder for attackers to obtain complete understanding of the internal logic, making reverse engineering much more difficult to perform.
- It obfuscates the state transition function to add an obfuscated mode on top of the original functionality (called normal mode).
  Favorite Software Obfuscation Example:

https://github.com/xoreaxeax/movfuscator

### Design obfuscation

- Specified pattern is able to guide the circuit into its normal mode.
- The transition arc K3 is the only way the design can enter normal operation mode from the obfuscated mode.



### **BISA: Built-In Self-Authentication**

Filling all unused spaces with a circuit that can easily test itself





Question?