



# How does a Client SSD Controller Fit the Bill in Hyperscale Applications?

**Phison Electronics Corp.** 

Grace Chen
SSD Project Manager
grace\_cy\_chen@phison.com

# What can happen in









**2013** 

VS.

2014







4,190,000 4,190,000 Google search queries



46,805 Facebook logins



1006 hours of video contents uploaded



66 00 Amazon sales



34×000 tweets sent



67,000 38,000 photos uploaded





# D<sub>Data Volume</sub> e shapes storage industry, creating more expectations for solid Solid State Disk.

**Consumer Applications** 

**Hyerscale Applications** 







# Now, what are hyperscale applications looking for in ?







## HIGH PERFORMANCE



## ERROR CORRECTION DESIGN: RAID ECC RECOVERY



Layer and layer of correction schemes to fight against any errors that may have been caused by NAND flash.

#### pFAIL CIRCUIT



## END TO END DATA PROTECTION



Data needs to be protected all the way.

#### **BCH vs. LDPC**



ECC capability matters.

#### **HIGH CAPACITY**



## DESIGN BETTER SSD







#### **Design to Maximize Performance**

Multi-core is essential for delivering a sustaining performance.



- Quad- vs. Octa-core controller implementations
- Each CPU is designed to carry out specific tasks.
- Sustaining performance also includes promising QoS.
- Multi-core design increases complexity of firmware architecture.





#### **Design to Fight Against Power Loss**

PFail Design: Data is guaranteed <u>safe</u> in any power cycle event.



- During power failure, user data in an external memory must be programmed to NAND in a short period of time.
- The design needs to consider all possible corner cases from hardware and firmware perspectives.
- Characterization of on-board power segments.





#### **Data Reliability: E2E Data Protection**

Data is always protected during read/write operations.



- Different parities will be tagged to data during its travelling path.
- Data protection with E2E parity
- RAM protection with RAM parity
- Flash protection with ECC parity









#### **Data Reliability: Flash ECC Schemes**

Which correction scheme suits better for hyperscale applications?

|                         | ВСН           | LDPC                  |  |
|-------------------------|---------------|-----------------------|--|
| Decoding                | Algebraic     | Probability           |  |
| Algorithm<br>Correction | 7.1186.014.14 |                       |  |
|                         | Guaranteed    | <b>Not Guaranteed</b> |  |
| Strength Soft Bit       |               |                       |  |
| Decoding                | Difficult     | Easy                  |  |
| Decoding                | Sustained     | Sustained → Drop      |  |
| Performance             | Sustained     | Sustained → Drop      |  |
| Cost (Gate              | Low           | High                  |  |
| Count)                  | LOW           | High                  |  |
| Power                   | Low           | High                  |  |
| Consumption             | LOW           | 111811                |  |





#### Additional ECC to Recover Erroneous Data

RAID ECC (SmartECC<sup>TM</sup>) for data reconstruction

- When an uncorrectable ECC occurs, RAID ECC will be responsible to recover error bits based on additional parities ("RAID Parity") stored previously.
- Recovery scale: Block level vs. Die level
- RAID ECC consumes additional drive capacity in order to achieve different levels of data reconstruction.











## **Triple Layers of Data Protection**



#### Front-end: End to End Data Protection

Prevent any soft errors caused by bit flips along the travelling path of data.

#### **Core: SmartECC<sup>TM</sup> Engine**

If an uncorrectable error is detected, SmartECC<sup>TM</sup> is capable of reconstructing the damaged data by using RAID parity.

#### **Back-end: Flash ECC Protection**

Error-detect-and-correct performed during read operations.





#### **Design to Maximize SSD Capacity**

When it comes to capacity, more means better.



- Higher capacity means more memory components required in a compact board design.
- Flash controller still needs to maintain high performance with maximum capacity.
- High capacity also introduces additional complexity to firmware architecture.





# Client Controller



**Enterprise Features** 



Hyperscale **4** 







#### It all comes from a client SSD controller.

But what differentiates entry-level from consumer SSD?



To record any activity during drive lifetime so that when any fault occurs, it can be analyzed.

To fight against data retention of flash by refreshing data at real time or idle state.





Throttling operation to be implemented for reducing power consumption.

AES and TCG is a common requirement for entry-level SSD.







# For more information on Phison SSD, please visit us at Booth #712 & #714.









# THANK YOU FOR YOUR TIME & ATTENTION!