Introduction
This page gives an overview of nandps driver which is available as part of the Xilinx Vivado and SDK distribution.
Source path for the driver:
https://github.com/Xilinx/embeddedsw/tree/master/XilinxProcessorIPLib/drivers/nandps
Driver source code is organized into different folders. Below diagram shows the nandpsu driver source organization
nandps
|
-- Doc - Provides the API and data structure details
|
- Examples - Reference application to show how to use the driver APIs and calling sequence
|
- Source - Driver source files
Features Supported
Controller Features:
- ONFI 1.0 compatible
- upto 1GB device
- 8/16-bit IO width with a single chip select
- 16-word read/write FIFOs
- 8-word command FIFO
- Programmable IO Cycle timing
- 1-bit ECC hardware with sw assist
- Asynchronous memory operating mode
Driver Features:
- Supports only the mandatory ONFI 1.0 commands. i.e Reset, Read status, Read ID, Read Parameter Page, Read Page, Program Page, Erase Block, Set/Get Features
- supports page cache read operations
- Support BBT management
- Support for ondie ecc devices
Bad Block management
As part of the bbt management, driver reserves the last 4 blocks of the flash device for storing the bbt information. bbt management is similar to the Linux except the offset of storing the BBT signature land version location and also the locations reserved for storing the ecc information.
Known issues and Limitations
- Driver supports polled mode only
- No support for interleaved and optional 1.0 commands
ChangeLog
2016.3
2016.4
2017.1
2017.2
2017.3
2017.4
2018.1
2018.2
2018.3
2019.1
2019.2
2020.1
2020.2
- Summary
- Update Makefile for parallel make execution
- Commits
Test cases
Nandps example:
https://github.com/Xilinx/embeddedsw/blob/master/XilinxProcessorIPLib/drivers/nandps/examples/xnandps_example.cIt verifies the nand data integrity by programing the known data pattern and verify the same by reading the data back.
In this process erase, program, read, read ID, Read Parameter Page, Reset, read status, get/set features and bbt management are covered
Output:
Code Block |
---|
|
Nand Flash Read Write Example Test
Successfully ran Nand Flash Read Write Example Tes |
Nandps skip example:
https://github.com/Xilinx/embeddedsw/blob/master/XilinxProcessorIPLib/drivers/nandps/examples/xnandps_skip_example.cSame as nandps example. In addition to that it will verify the given block is bad or not. if it is bad block it skips that block and proceed with other good block.
Output:
Code Block |
---|
|
Nand Flash Skip Block Method Example Test
Successfully ran Nand Flash Skip Block Method Example Test |
Nandps cache example:
https://github.com/Xilinx/embeddedsw/blob/master/XilinxProcessorIPLib/drivers/nandps/examples/xnandps_cache_example.cSame as nandps example. In addition to that it will use the page cache read operations.
Output:
Code Block |
---|
|
Nand Flash Read Write Example Test
Successfully ran Nand Flash Read Write Example Test |
Write(MBPS) | Read(MBPS) |
---|
7.1 | 13.8 |