

# DEPARTMENT OF INFORMATION TECHNOLOGY AND ELECTRICAL ENGINEERING

Spring Semester 2025

# Ensuring Fault Tolerance in the CROC SoC: A Hardware-Centric Approach to Watchdog Timer Implementation

VLSI 2 Course Project

Titlepage Logo Placeholder

Miguel Correa and Elio Wanner corream@ethz.ch, ewanner@ethz.ch

May 15, 2025

Professor: Frank Kagan Gürkaynak, kgf@iis.ee.ethz.ch

# Abstract

This report summarizes the work done in the VLSI 2 course project. The project consisted of extending the Croc SoC with a Watchdog Timer.

# Contents

| 1        | Introduction                                                              | 1 |
|----------|---------------------------------------------------------------------------|---|
|          | 1.1 Overview of the Croc SoC and its open-source nature                   | 1 |
|          | 1.2 Why a watchdog timer (WDT) was needed                                 | 1 |
|          | 1.3 Goals and expected improvements                                       | 1 |
| <b>2</b> | Related Works                                                             | 2 |
|          | 2.1 Overview of existing watchdog timer implementation                    | 2 |
|          | 2.2 Justification for our approach                                        | 2 |
| 3        | Methodology                                                               | 3 |
|          | 3.1 Design choices for WDT (e.g., countdown vs. count-up, reset duration) | 3 |
|          | 3.2 Testing strategy (testbenches, simulation tools)                      | 3 |
|          | 3.3 Debugging and iteration process                                       | 3 |
| 4        | Hardware Architecture                                                     | 4 |
|          | 4.1 Simple Watchdog Timer                                                 | 4 |
|          | 4.1.1 Hardware implementation                                             | 4 |
|          | 4.1.2 Tests and Results                                                   | 4 |
|          | 4.1.3 Conclusion                                                          | 4 |
|          | 4.2 Watchdog Timer with 2 stages                                          | 4 |
| 5        | Evaluation                                                                | 6 |
|          | 5.1 Simulation results for v1 and v2                                      | 6 |
|          | 5.2 Performance comparison (goal achieved?)                               | 6 |
|          | 5.3 Trade-offs between versions                                           | 6 |
| 6        | Discussion                                                                | 7 |
|          | 6.1 Strengths and limitations of each approach                            | 7 |
|          | 6.2 Potential improvements (e.g., three-stage WDT)                        | 7 |
|          | 6.3 Lessons learned from the implementation                               | 7 |
| 7        | Conclusion                                                                | 8 |
|          | 7.1 Summary of key findings                                               | 8 |
|          | 7.2 Future work and next steps                                            | 8 |



# Introduction

- 1.1 Overview of the Croc SoC and its open-source nature
- 1.2 Why a watchdog timer (WDT) was needed
- 1.3 Goals and expected improvements



# Related Works

- 2.1 Overview of existing watchdog timer implementation
- 2.2 Justification for our approach



# Methodology

- 3.1 Design choices for WDT (e.g., countdown vs. count-up, reset duration)
- 3.2 Testing strategy (testbenches, simulation tools)
- 3.3 Debugging and iteration process



## Hardware Architecture

This chapter describes the hardware architecture of the Watchdog Timer that we implemented in the Croc SoC. In the different sections we talk about different implementations with different features and complexities.

### 4.1 Simple Watchdog Timer

### 4.1.1 Hardware implementation

The first implementation of the Watchdog Timer is the simplest one we could imagine. As shown in Figure 4.1, the WDT is composed of very few components. The main component is the counter, which is incremented every clock cycle and implemented as a flip-flop. The counter is connected to a comparator that checks if the counter has reached a certain value. If the counter reaches the value, the comparator will trigger a reset signal that will reset the system. Otherwise, we keep incrementing the counter. As soon as we get a kick signal, the counter is reset to zero.

### 4.1.2 Tests and Results

### 4.1.3 Conclusion

### 4.2 Watchdog Timer with 2 stages

This is for later.



Figure 4.1: Simple Watchdog Timer Architecture



# Evaluation

- 5.1 Simulation results for v1 and v2
- 5.2 Performance comparison (goal achieved?)
- 5.3 Trade-offs between versions



# Discussion

- 6.1 Strengths and limitations of each approach
- 6.2 Potential improvements (e.g., three-stage WDT)
- 6.3 Lessons learned from the implementation



# Conclusion

- 7.1 Summary of key findings
- 7.2 Future work and next steps