From 66bba5694e611980d2671b10ad0839ff1ad6e3e4 Mon Sep 17 00:00:00 2001 From: Cao Sen Miao Date: Tue, 14 Nov 2023 15:38:44 +0800 Subject: [PATCH] feat(spi_flash): Enable auto suspend on when flash works under 120M --- .../hal/esp32c2/include/hal/spimem_flash_ll.h | 13 +++++++++++++ .../hal/esp32c3/include/hal/spimem_flash_ll.h | 13 +++++++++++++ .../hal/esp32c6/include/hal/spimem_flash_ll.h | 13 +++++++++++++ .../hal/esp32h2/include/hal/spimem_flash_ll.h | 13 +++++++++++++ .../hal/esp32p4/include/hal/spimem_flash_ll.h | 18 ++++++++++++++++++ .../hal/esp32s2/include/hal/spimem_flash_ll.h | 13 +++++++++++++ .../hal/esp32s3/include/hal/spimem_flash_ll.h | 18 ++++++++++++++++++ components/hal/spi_flash_hal_iram.c | 3 +++ 8 files changed, 104 insertions(+) diff --git a/components/hal/esp32c2/include/hal/spimem_flash_ll.h b/components/hal/esp32c2/include/hal/spimem_flash_ll.h index 649414084d..23bddd1ba2 100644 --- a/components/hal/esp32c2/include/hal/spimem_flash_ll.h +++ b/components/hal/esp32c2/include/hal/spimem_flash_ll.h @@ -245,6 +245,19 @@ static inline void spimem_flash_ll_auto_wait_idle_init(spi_mem_dev_t *dev, bool dev->flash_sus_ctrl.flash_pes_wait_en = auto_waiti; } +/** + * This function is used to set dummy phase when auto suspend is enabled. + * + * @note This function is only used when timing tuning is enabled. + * + * @param dev Beginning address of the peripheral registers. + * @param extra_dummy extra dummy length. Get from timing tuning. + */ +static inline void spimem_flash_ll_set_wait_idle_dummy_phase(spi_mem_dev_t *dev, uint32_t extra_dummy) +{ + // Not supported on this chip. +} + /** * Return the suspend status of erase or program operations. * diff --git a/components/hal/esp32c3/include/hal/spimem_flash_ll.h b/components/hal/esp32c3/include/hal/spimem_flash_ll.h index 3a4e4389ef..73df69e3e1 100644 --- a/components/hal/esp32c3/include/hal/spimem_flash_ll.h +++ b/components/hal/esp32c3/include/hal/spimem_flash_ll.h @@ -247,6 +247,19 @@ static inline void spimem_flash_ll_auto_wait_idle_init(spi_mem_dev_t *dev, bool dev->flash_sus_ctrl.flash_pes_wait_en = auto_waiti; } +/** + * This function is used to set dummy phase when auto suspend is enabled. + * + * @note This function is only used when timing tuning is enabled. + * + * @param dev Beginning address of the peripheral registers. + * @param extra_dummy extra dummy length. Get from timing tuning. + */ +static inline void spimem_flash_ll_set_wait_idle_dummy_phase(spi_mem_dev_t *dev, uint32_t extra_dummy) +{ + // Not supported on this chip. +} + /** * Return the suspend status of erase or program operations. * diff --git a/components/hal/esp32c6/include/hal/spimem_flash_ll.h b/components/hal/esp32c6/include/hal/spimem_flash_ll.h index 3c5d93da48..b80187f2e0 100644 --- a/components/hal/esp32c6/include/hal/spimem_flash_ll.h +++ b/components/hal/esp32c6/include/hal/spimem_flash_ll.h @@ -248,6 +248,19 @@ static inline void spimem_flash_ll_auto_wait_idle_init(spi_mem_dev_t *dev, bool dev->flash_sus_ctrl.flash_pes_wait_en = auto_waiti; } +/** + * This function is used to set dummy phase when auto suspend is enabled. + * + * @note This function is only used when timing tuning is enabled. + * + * @param dev Beginning address of the peripheral registers. + * @param extra_dummy extra dummy length. Get from timing tuning. + */ +static inline void spimem_flash_ll_set_wait_idle_dummy_phase(spi_mem_dev_t *dev, uint32_t extra_dummy) +{ + // Not supported on this chip. +} + /** * Return the suspend status of erase or program operations. * diff --git a/components/hal/esp32h2/include/hal/spimem_flash_ll.h b/components/hal/esp32h2/include/hal/spimem_flash_ll.h index 34e13c02b7..76fca20e78 100644 --- a/components/hal/esp32h2/include/hal/spimem_flash_ll.h +++ b/components/hal/esp32h2/include/hal/spimem_flash_ll.h @@ -249,6 +249,19 @@ static inline void spimem_flash_ll_auto_wait_idle_init(spi_mem_dev_t *dev, bool dev->flash_sus_ctrl.flash_pes_wait_en = auto_waiti; } +/** + * This function is used to set dummy phase when auto suspend is enabled. + * + * @note This function is only used when timing tuning is enabled. + * + * @param dev Beginning address of the peripheral registers. + * @param extra_dummy extra dummy length. Get from timing tuning. + */ +static inline void spimem_flash_ll_set_wait_idle_dummy_phase(spi_mem_dev_t *dev, uint32_t extra_dummy) +{ + // Not supported on this chip. +} + /** * Return the suspend status of erase or program operations. * diff --git a/components/hal/esp32p4/include/hal/spimem_flash_ll.h b/components/hal/esp32p4/include/hal/spimem_flash_ll.h index 7bbb1aea58..f428edde56 100644 --- a/components/hal/esp32p4/include/hal/spimem_flash_ll.h +++ b/components/hal/esp32p4/include/hal/spimem_flash_ll.h @@ -251,6 +251,24 @@ static inline void spimem_flash_ll_auto_wait_idle_init(spi_mem_dev_t *dev, bool dev->flash_sus_ctrl.flash_pes_wait_en = auto_waiti; } +/** + * This function is used to set dummy phase when auto suspend is enabled. + * + * @note This function is only used when timing tuning is enabled. This function is only used in quad flash + * + * @param dev Beginning address of the peripheral registers. + * @param extra_dummy extra dummy length. Get from timing tuning. + */ +static inline void spimem_flash_ll_set_wait_idle_dummy_phase(spi_mem_dev_t *dev, uint32_t extra_dummy) +{ + if (extra_dummy > 0) { + dev->flash_waiti_ctrl.waiti_dummy_cyclelen = extra_dummy - 1; + dev->flash_waiti_ctrl.waiti_dummy = 1; + } else { + dev->flash_waiti_ctrl.waiti_dummy = 0; + } +} + /** * Return the suspend status of erase or program operations. * diff --git a/components/hal/esp32s2/include/hal/spimem_flash_ll.h b/components/hal/esp32s2/include/hal/spimem_flash_ll.h index 196079e797..ea0ca5da4c 100644 --- a/components/hal/esp32s2/include/hal/spimem_flash_ll.h +++ b/components/hal/esp32s2/include/hal/spimem_flash_ll.h @@ -217,6 +217,19 @@ static inline void spimem_flash_ll_auto_wait_idle_init(spi_mem_dev_t *dev, bool dev->flash_waiti_ctrl.waiti_en = auto_waiti; // enable auto wait-idle function. } +/** + * This function is used to set dummy phase when auto suspend is enabled. + * + * @note This function is only used when timing tuning is enabled. + * + * @param dev Beginning address of the peripheral registers. + * @param extra_dummy extra dummy length. Get from timing tuning. + */ +static inline void spimem_flash_ll_set_wait_idle_dummy_phase(spi_mem_dev_t *dev, uint32_t extra_dummy) +{ + // Not supported on this chip. +} + /** * Return the suspend status of erase or program operations. * diff --git a/components/hal/esp32s3/include/hal/spimem_flash_ll.h b/components/hal/esp32s3/include/hal/spimem_flash_ll.h index 70c809e1a3..eee9d0851d 100644 --- a/components/hal/esp32s3/include/hal/spimem_flash_ll.h +++ b/components/hal/esp32s3/include/hal/spimem_flash_ll.h @@ -274,6 +274,24 @@ static inline void spimem_flash_ll_auto_wait_idle_init(spi_mem_dev_t *dev, bool dev->flash_sus_cmd.flash_pes_wait_en = 1; } +/** + * This function is used to set dummy phase when auto suspend is enabled. + * + * @note This function is only used when timing tuning is enabled. This function is only used in quad flash + * + * @param dev Beginning address of the peripheral registers. + * @param extra_dummy extra dummy length. Get from timing tuning. + */ +static inline void spimem_flash_ll_set_wait_idle_dummy_phase(spi_mem_dev_t *dev, uint32_t extra_dummy) +{ + if (extra_dummy > 0) { + dev->flash_waiti_ctrl.waiti_dummy_cyclelen = extra_dummy - 1; + dev->flash_waiti_ctrl.waiti_dummy = 1; + } else { + dev->flash_waiti_ctrl.waiti_dummy = 0; + } +} + /** * Return the suspend status of erase or program operations. * diff --git a/components/hal/spi_flash_hal_iram.c b/components/hal/spi_flash_hal_iram.c index edcbe9e7ad..e73ead6ad9 100644 --- a/components/hal/spi_flash_hal_iram.c +++ b/components/hal/spi_flash_hal_iram.c @@ -146,6 +146,9 @@ void spi_flash_hal_setup_auto_suspend_mode(spi_flash_host_inst_t *host) spi_mem_dev_t *dev = (spi_mem_dev_t*)spi_flash_ll_get_hw(SPI1_HOST); spi_flash_hal_context_t* ctx = (spi_flash_hal_context_t*)host; spimem_flash_ll_auto_wait_idle_init(dev, true); + if (ctx->freq_mhz == 120) { + spimem_flash_ll_set_wait_idle_dummy_phase(dev, ctx->extra_dummy); + } spimem_flash_ll_auto_suspend_init(dev, true); // tsus = ceil(ctx->tsus_val * ctx->freq_mhz / spimem_flash_ll_get_tsus_unit_in_cycles); uint32_t tsus = (ctx->tsus_val * ctx->freq_mhz / spimem_flash_ll_get_tsus_unit_in_cycles(dev)) + ((ctx->tsus_val * ctx->freq_mhz) % spimem_flash_ll_get_tsus_unit_in_cycles(dev) != 0);