|  | # Flash driver configuration options | 
|  |  | 
|  | # Copyright (c) 2016 Intel Corporation | 
|  | # SPDX-License-Identifier: Apache-2.0 | 
|  |  | 
|  | # | 
|  | # Flash driver | 
|  | # | 
|  | config FLASH_HAS_DRIVER_ENABLED | 
|  | bool | 
|  | help | 
|  | This option is enabled when any flash driver is enabled. | 
|  |  | 
|  | config FLASH_HAS_EX_OP | 
|  | bool | 
|  | help | 
|  | This option is selected by drivers that support flash extended | 
|  | operations. | 
|  |  | 
|  | config FLASH_HAS_EXPLICIT_ERASE | 
|  | bool | 
|  | help | 
|  | Device does not do erase-on-write (erase-on-program, auto-erase | 
|  | on write) and requires explicit erase procedure to be programmed | 
|  | with random value, in place where it has already been programmed with | 
|  | some other value, as program can only change bits from erased-value | 
|  | to the opposite. | 
|  | All pure Flash devices are evolution of EEPROM where erase has | 
|  | been separated from write, EEPROM has erase-on-write, giving | 
|  | it advantage of higher write speeds at a cost of larger erase block. | 
|  | Note that explicit-erase capability does not warrants that | 
|  | write without erase is not allowed, taking the above restrictions, | 
|  | it only states that write of a random information will require | 
|  | erase. | 
|  | Erase is usually performed in pages, as we have chosen to name | 
|  | the unit in Zephyr, that may have different naming in device | 
|  | specifications, like pages, sectors or blocks, and may vary | 
|  | in size, depending how they are named by vendor. | 
|  | This option should be selected by drivers that serve devices with | 
|  | such characteristic and is used and may be used by users to provide | 
|  | paths in code that only serve such devices, and could be | 
|  | optimized-out by compiler in case where there is no such device in | 
|  | a system. | 
|  |  | 
|  | config FLASH_HAS_NO_EXPLICIT_ERASE | 
|  | bool | 
|  | help | 
|  | Device does not require explicit erase before programming | 
|  | a new random value at any location that has been previously | 
|  | programmed with some other value. | 
|  | Note that the device may have erase-on-write (auto-erase), | 
|  | as for example in EEPROM devices, but may also have no erase | 
|  | at all. | 
|  | A device driver may still provide erase callback, | 
|  | especially if it is able to perform erase to accelerate | 
|  | further writes or is able to fill the area requested for | 
|  | erase, with single value, faster than consecutive writes | 
|  | that would be used to emulate erase. | 
|  | This option should be selected by drivers that serve | 
|  | devices with such characteristic and is used and may be | 
|  | used by users to provide paths in code that only serve | 
|  | such devices, and could be optimized-out by compiler in | 
|  | case where there is no such device in a system. | 
|  | This option should be selected for any device that | 
|  | can change storage bits, by write, from any value to opposite | 
|  | value at any time. | 
|  | When your driver sets this option you also need to set | 
|  | no_explicit_erase capability in your drivers flash_parameters. | 
|  |  | 
|  | config FLASH_HAS_PAGE_LAYOUT | 
|  | bool | 
|  | help | 
|  | This option is enabled when the SoC flash driver supports | 
|  | retrieving the layout of flash memory pages. | 
|  |  | 
|  | config FLASH_JESD216 | 
|  | bool | 
|  | help | 
|  | Selected by drivers that support JESD216-compatible flash | 
|  | devices to enable building a common support module. | 
|  |  | 
|  | menuconfig FLASH | 
|  | bool "Flash drivers" | 
|  | help | 
|  | Enable support for the flash hardware. | 
|  |  | 
|  | if FLASH | 
|  |  | 
|  | config FLASH_JESD216_API | 
|  | bool "Provide API to read JESD216 flash parameters" | 
|  | depends on FLASH_JESD216 | 
|  | help | 
|  | This option extends the Zephyr flash API with the ability | 
|  | to access the Serial Flash Discoverable Parameter section | 
|  | allowing runtime determination of serial flash parameters | 
|  | for flash drivers that expose this capability. | 
|  |  | 
|  | config FLASH_SHELL | 
|  | bool "Flash shell" | 
|  | depends on SHELL && FLASH_PAGE_LAYOUT | 
|  | select MPU_ALLOW_FLASH_WRITE if ARM_MPU | 
|  | help | 
|  | Enable the flash shell with flash related commands such as test, | 
|  | write, read and erase. | 
|  |  | 
|  | if FLASH_SHELL | 
|  |  | 
|  | config FLASH_SHELL_TEST_COMMANDS | 
|  | bool "Flash read/write/erase test commands" | 
|  | select CBPRINTF_FP_SUPPORT | 
|  | help | 
|  | Enable additional flash shell commands for performing | 
|  | read/write/erase tests with speed output. | 
|  |  | 
|  | config FLASH_SHELL_BUFFER_SIZE | 
|  | hex "Flash shell buffer size" | 
|  | default 0x4000 if FLASH_SHELL_TEST_COMMANDS | 
|  | default 0x1000 | 
|  | range 0x400 0x1000000 | 
|  | help | 
|  | Size of the buffer used for flash commands, will determine the | 
|  | maximum size that can be used with a read/write test. | 
|  |  | 
|  | endif # FLASH_SHELL | 
|  |  | 
|  | config FLASH_FILL_BUFFER_SIZE | 
|  | int "Buffer size of flash_fill function" | 
|  | default 32 | 
|  | help | 
|  | Size of a buffer used by flash_fill function to fill a device with | 
|  | specific value; this buffer is allocated on stack. | 
|  | The buffer is needed as most devices have write-block alignment | 
|  | requirements that which imposes minimal size of data, which can | 
|  | be written to a device, and alignment of write offset. | 
|  | Even if device does not have such requirement, filling device by | 
|  | single bytes is not efficient. | 
|  | Value selected here should be a multiple of the largest write-block-size | 
|  | among all the memory devices used in system. | 
|  |  | 
|  | if FLASH_HAS_PAGE_LAYOUT | 
|  |  | 
|  | config FLASH_PAGE_LAYOUT | 
|  | bool "API for retrieving the layout of pages" | 
|  | default FLASH_HAS_PAGE_LAYOUT | 
|  | help | 
|  | Enables API for retrieving the layout of flash memory pages. | 
|  |  | 
|  | endif | 
|  |  | 
|  | config FLASH_EX_OP_ENABLED | 
|  | bool "API for extended flash operations" | 
|  | depends on FLASH_HAS_EX_OP | 
|  | default n | 
|  | help | 
|  | Enables flash extended operations API. It can be used to perform | 
|  | non-standard operations e.g. manipulating flash protection. | 
|  |  | 
|  | config FLASH_INIT_PRIORITY | 
|  | int "Flash init priority" | 
|  | default KERNEL_INIT_PRIORITY_DEVICE | 
|  | help | 
|  | Flash driver device initialization priority. This initialization | 
|  | priority is used unless the driver implementation has its own | 
|  | initialization priority | 
|  |  | 
|  | # zephyr-keep-sorted-start | 
|  | source "drivers/flash/Kconfig.ambiq" | 
|  | source "drivers/flash/Kconfig.andes" | 
|  | source "drivers/flash/Kconfig.at45" | 
|  | source "drivers/flash/Kconfig.b91" | 
|  | source "drivers/flash/Kconfig.cadence_nand" | 
|  | source "drivers/flash/Kconfig.cadence_qspi_nor" | 
|  | source "drivers/flash/Kconfig.cc13xx_cc26xx" | 
|  | source "drivers/flash/Kconfig.cc23x0" | 
|  | source "drivers/flash/Kconfig.esp32" | 
|  | source "drivers/flash/Kconfig.gd32" | 
|  | source "drivers/flash/Kconfig.gecko" | 
|  | source "drivers/flash/Kconfig.ifx_cat1" | 
|  | source "drivers/flash/Kconfig.it8xxx2" | 
|  | source "drivers/flash/Kconfig.lpc" | 
|  | source "drivers/flash/Kconfig.max32" | 
|  | source "drivers/flash/Kconfig.mcux" | 
|  | source "drivers/flash/Kconfig.mspi" | 
|  | source "drivers/flash/Kconfig.nios2_qspi" | 
|  | source "drivers/flash/Kconfig.nor" | 
|  | source "drivers/flash/Kconfig.nordic_qspi_nor" | 
|  | source "drivers/flash/Kconfig.npcx_fiu" | 
|  | source "drivers/flash/Kconfig.nrf" | 
|  | source "drivers/flash/Kconfig.nrf_mram" | 
|  | source "drivers/flash/Kconfig.nrf_rram" | 
|  | source "drivers/flash/Kconfig.numaker" | 
|  | source "drivers/flash/Kconfig.numaker_rmc" | 
|  | source "drivers/flash/Kconfig.nxp_s32" | 
|  | source "drivers/flash/Kconfig.renesas_ra" | 
|  | source "drivers/flash/Kconfig.rpi_pico" | 
|  | source "drivers/flash/Kconfig.rv32m1" | 
|  | source "drivers/flash/Kconfig.sam" | 
|  | source "drivers/flash/Kconfig.sam0" | 
|  | source "drivers/flash/Kconfig.si32" | 
|  | source "drivers/flash/Kconfig.silabs" | 
|  | source "drivers/flash/Kconfig.simulator" | 
|  | source "drivers/flash/Kconfig.siwx91x" | 
|  | source "drivers/flash/Kconfig.smartbond" | 
|  | source "drivers/flash/Kconfig.stm32" | 
|  | source "drivers/flash/Kconfig.stm32_ospi" | 
|  | source "drivers/flash/Kconfig.stm32_qspi" | 
|  | source "drivers/flash/Kconfig.stm32_xspi" | 
|  | source "drivers/flash/Kconfig.xmc4xxx" | 
|  | # zephyr-keep-sorted-stop | 
|  |  | 
|  | module = FLASH | 
|  | module-str = flash | 
|  | source "subsys/logging/Kconfig.template.log_config" | 
|  |  | 
|  | endif # FLASH |