guo ecf2d82159
sync branch rt-smart. (#6641)
* Synchronize the code of the rt mart branch to the master branch.
  * TTY device
  * Add lwP code from rt-smart
  * Add vnode in DFS, but DFS will be re-write for rt-smart
  * There are three libcpu for rt-smart:
    * arm/cortex-a, arm/aarch64
    * riscv64

Co-authored-by: Rbb666 <zhangbingru@rt-thread.com>
Co-authored-by: zhkag <zhkag@foxmail.com>
2022-12-03 12:07:44 +08:00

91 lines
3.4 KiB
Plaintext

menu "SPINOR Devices"
config DRIVERS_SPINOR
bool "enable spinor driver"
default y
config HAL_TEST_SPINOR
bool "enable spinor hal APIs test command"
depends on DRIVERS_SPINOR
default n
config DRIVERS_SPINOR_FREQ
int "spinor frequency (MHz)"
depends on DRIVERS_SPINOR
range 10 100
default 50
help
The frequency for spi master.
config DRIVERS_SPINOR_4K_SECTORS
bool "Use small 4096 B erase sectors"
depends on DRIVERS_SPINOR
default y
help
This only tells the upper layer that the block size is 4K and the upper
layer can do 4K erase. In fact, the driver still supports 32K or 64K
erase and it may try to do 64K or 32K erase as far as possible if you
enable cache since it does really improve performance. Erasing should be
mush faster when using 64K block instead of 16 * 4K.
Why we should need this option? Even most filesystems save a file in
unit block, which is equal to nor block size generally. The larger block
is, the much space waste for a small file. Take an example, to save a 1K
size file, the filesystem allocate a block for it and waste 3K size
for 4K block size, even 63K size for 64K block size.
To balance waste-space and performance, we really support to eanble
4K block and nor cache to get more operations together.
If unsure, please says Y.
config DRIVERS_SPINOR_CACHE
bool "Enable spinor cache layer"
depends on DRIVERS_SPINOR
default n
help
To improve write performance by merging 4K page erase operation to
32K/64K erase operation. This cache layer holds a 64K buffer. It just
will cache sequential erase/write operation. There are three ways to
flush cache.
1. block buffer is fullly.
2. operate over a block.
Once operate over a 64K block, this layer will write-back directly
avoiding lose data.
3. upper layer call hal_spinor_sync()
This cache layer with the littlefs turns out no loss of data, but the
others need more tested. The upper layer (fs) should takes care of the
following issues.
1. after writing meta data, upper must call hal_spinor_sync() to flush
cache. Also, you can flush cache for fatal data too. In a word,
sync() is called only immediately after data that affects filesystem
consistency is written. The littlefs is checked ok.
2. contecting to sync()/fsync() for user in case of user codes writing
fatal file.
If unsure, please says N.
config DRIVERS_SPINOR_WRITE_LOCK
bool "Use nor dynamic write limit if support"
depends on DRIVERS_SPINOR
default y
help
Some nor flash support write protection. This feature is much usefull
for power lose case to avoid data corruption. Most of them support zone
protection, which cost much for status register and to protect
a continuous space from head or tail. That's NOT what we need. What this
option used, is individual block protection. Before we do write/erase
operation, we unlock (unprotect) the individual block we want and still
protect other blocks. As you see, the unit to lock/unlock is a block.
Beside, it just rewrite a volatile memory, not status register, which
has less time and wear costs.
In a word, It spends very little time to protect data if power lose.
If unsure, please says Y.
endmenu