

## Design Register Accurate SSD Software Simulator

## haocheng.huang@starblaze-tech.com IP Design Manager Beijing Starblaze Technology

Flash Memory Summit 2018 Santa Clara, CA





# SSD Controller Design Challenge

- SSD Controller chip is hardware + firmware
  - > Firmware determines the major features of SSD Controller.
  - To get best performance and power consumption, firmware needs to be fine tuned on well-optimized hardware.
- Both hardware and firmware are customized
  - Most hardware components are designed from scratch and need to be carefully optimized according to firmware usage.
  - > SSD firmware is very customized and optimized to fit the hardware.

#### SSD Controller chip design needs very close firmware and hardware co-design!





Flash Memory Summit





### 1. Simulator Overview

- 2. SSD Key Models:
  - 1. Peripheral Model
  - 2. NAND Model
  - 3. Host Model
- 3. Software-driven Design flow

Flash Memory Summit 2018 Santa Clara, CA





# **Simulator Overview**



- In most SOC system, embedded firmware runs on embedded CPUs, and access the hardware resource by writing/reading the registers that mapped to the bus.
- To simulate the SSD SOC system, we run firmware on x86 system (compiled by GCC or Visual Studio). The hardware modules are written in C/C++ as behavior model, and are accessible by firmware through the register variables.





Santa Clara, CA

### **Starblaze Simulator Architecture**







- 1. Simulator Overview
- 2. SSD Key Models:
  - 1. Peripheral Model
  - 2. NAND Model
  - 3. Host Model
- 3. Software-driven Design flow





# **Peripheral Model**



Flash Memory Summit 2018 Santa Clara, CA





#### Firmware (run on x86)







1. Simulator Overview

### 2. SSD Key Models:

- 1. Peripheral Model
- 2. NAND Model
- 3. Host Model
- 3. Software-driven Design flow

Flash Memory Summit 2018 Santa Clara, CA





# **NAND Model**







1. Simulator Overview

### 2. SSD Key Models:

- 1. Peripheral Model
- 2. NAND Model
- 3. Host Model
- 3. Software-driven Design flow

































- 1. Simulator Overview
- 2. SSD Key Models:
  - 1. Peripheral Model
  - 2. NAND Model
  - 3. Host Model

#### 3. Software-driven Design flow









• Starblaze Booth: 649

| Invitation                                                                  | Торіс                                                             | Presenter  |
|-----------------------------------------------------------------------------|-------------------------------------------------------------------|------------|
| SSDS-102-1 Tuesday August 7 <sup>th</sup><br>Ballroom F,5:05pm to 5:22pm    | Low-Power Design of SSDs                                          | Daniel Sun |
| SOFT-201-1 Wednesday August 8 <sup>th</sup><br>GAMR 3, 8:30am to 10:50am    | Key-Value Store Friendly SSD<br>Interface Design and Optimization | Teng Yang  |
| CTRL-302A-1 Thursday August 9 <sup>th</sup><br>Ballroom A, 2:10pm to 3:25pm | Take Full Advantage of LDPC Soft<br>Bit Decoding                  | Feng Tang  |
| EMBD-302B-1 Thursday, August 9 <sup>th</sup> ,<br>Ballroom A,3:40-4:10 pm   | Computing Storage in the AI IoT<br>Era                            | Daniel Sun |

