

### RaW Access to Flash Memory (Meets Special Needs)

Kenneth Derek PILLAY, PhD YALLIP, INC. CEO and Director



### **Question Presented**

- Static RAM does not need a refresh controller
- However, for Flash (static) Memory a controller for Flash Translation Layer and other control functions has become pervasive
- Open Channel reduces control in mem device
- Could there be an opportunity for more simple direct access to such static memory ?



## **The Controller Argument**

- The various architectures of Flash Memory (S/M/T/QLC) and its use for file storage has required a Controller to provide transparent access to the memory as for disk systems
- Apparently, Eli Harari (Sundisk) early-on recognized the need for a "Controller" to manage the Flash memory arrays and also Santa Clara, perform many auxiliary functions [1] 2019 YALLIP, INC



# **Controller Functions**

- The Controller performs functions such as :
  - Logical to Physical address translation
  - Allocation
  - Garbage Collection
  - Wear Levelling
  - Error Correction
  - Periodic Data Retention moves



## The Subsequent Argument

- Where should the Control functions reside :
  - In Memory Subsystem (HW or programmable)?
  - Or External (Software or Hardware) in Host ?
  - Or Hybrid ? (part in Host, part in Mem Subsystem)
- With increased use, there has been growing demand for more direct access to memory

Amount and location of Control functions are
 Santa Clara, then left to the system designer/implementer



## Pure Storage, Inc.'s DirectFlash

**ARRAY SOFTWARE** 



Graphic copyright of Pure Storage, Inc. [2]



# **Radian Memory Systems**

- Symphonic Cooperative Flash Management [3]
- Observed latency spikes issue in RW cycles
- Some attempted to fix by (large write) stripes
- Radian "cooperative" Symphonic CFM fits in: FTL <-> Hybrid CFM <-> Host Managed RAW
- Host User program controls function in device

Santa Chara, Hides device details whilst allow user controllip, INC. 8 August 2019



## **Multi Level characteristics**

- SLC : 2  $V_{TH}$  for 2 states (01) store 1 bit
- MLC : 4  $V_{TH}$  for 4 states ( 00 01 10 10 ) store 2 bit
- Multiple V<sub>TH</sub> (Voltage Thresholds) for multiple bits on same cell reduces gap between adjacent voltage ranges which define the thresholds
  - Small gap more prone to errors : therefore requiring ECC
  - increased access to same cell results in increased wear : thereby requiring control functions to move data around

Multi bit on 1 Floating Gate = no single bit  $access_{IIP, INC.}$ 



# Propose HW Programmable Option

- Hardware programmable options are common in digital logic hardware controllers
- Memory chipsets are more limited and rigid in what they present to the system designer
- The Proposal is to petition flash memory chip manufacturers to provide a programmable option for direct RaW Access mode



#### **RaW Access mode option**

#### Control (to support RaW Access mode)

Address Data

BUS can be parallel or serial

Flash Memory Chip Or Subsystem (any Control function should be User Programmable)

Santa Clara, CA 8 August 2019 © 2019 YALLIP, INC. 10



# Toshiba 8Gb NAND TH58xxx

- 4224 bytes x 64 pages x 4096 blocks
- Read in 4224 bytes (1 page) increments
- Erase operation implemented in single block unit: 4224 bytes x 64 pages !
- App note provides that NAND Management such as Bad Block Management, ECC treatment and Wear Leveling should be Santa Clara, CA 8 August 2019 ncorporated in the system design [4] © 2019 YALLIP, INC

11



# Toshiba 8Gb NAND TH58xxx cont.

- ECC logic on-chip ; not programmable
- MODES : Read, Reset, Auto Page Program, Auto Block Erase, Status Read, Page Copy, Multi Page Read, Multi Page Program, Multi Block Erase, ECC Status Read
- Access Times :
  - Read
    ( 13.2 us/page , 25ns/cycle)
  - Auto Page Program ( 340 us/page includes read verify)
  - Auto Block Erase (2500 us/block)



# Toshiba 8Gb NAND TH58xxx cont.

- Petition to add RaW Access mode via supporting new hex value Commands for :
  - NO ECC
  - Single Page Erase ?
  - Operate TLC in SLC mode ? Samsung 840 EVO TLC reserves a portion of the die as SLC cache [5]
  - Individual bit access if multiple floating gates ?

Santa Chara, Backward pin-compatible !





- Pros
  - Design flexibility
  - Potential for increased access speed
- Cons
  - Requires HW rework first time round
  - Speed versus Density tradeoff



- For high volume deployments any cost reduction aggregates into significant saving
- Implementation of any required control functions in software provides Nick McKeown's "Software-Defined" capability
- Less hardware logic implemented in chip results in smaller die size hence lower cost



## Acknowledgements

- [1] www.ithistory.org/blog/excellent-flash-memorysummit-fms-history-session-eli-harari
- [2]www.purestorage.com/products/purity/directflas
  <u>h.html</u>
- [3] http://www.radianmemory.com/
- [4] Toshiba TH58BVG3S0HTA00 NAND EEPROM
- [5] techreport.com/review/25122/samsungs-840evo-solid-state-drive-reviewed/



