xtensa/esp32s3: SPI support psram and flash timing tuning
Signed-off-by: chenwen@espressif.com <chenwen@espressif.com>
This commit is contained in:
parent
33c3abb706
commit
75999d247f
@ -603,6 +603,12 @@ int IRAM_ATTR psram_enable(int mode, int vaddrmode)
|
|||||||
psram_reg.mr2.density == 0x5 ? PSRAM_SIZE_16MB :
|
psram_reg.mr2.density == 0x5 ? PSRAM_SIZE_16MB :
|
||||||
psram_reg.mr2.density == 0x7 ? PSRAM_SIZE_32MB : 0;
|
psram_reg.mr2.density == 0x7 ? PSRAM_SIZE_32MB : 0;
|
||||||
|
|
||||||
|
/* Do PSRAM timing tuning, we use SPI1 to do the tuning, and set the SPI0
|
||||||
|
* PSRAM timing related registers accordingly
|
||||||
|
*/
|
||||||
|
|
||||||
|
esp32s3_spi_timing_set_mspi_psram_tuning();
|
||||||
|
|
||||||
/* Back to the high speed mode. Flash/PSRAM clocks are set to the clock
|
/* Back to the high speed mode. Flash/PSRAM clocks are set to the clock
|
||||||
* that user selected. SPI0/1 registers are all set correctly.
|
* that user selected. SPI0/1 registers are all set correctly.
|
||||||
*/
|
*/
|
||||||
|
@ -29,6 +29,7 @@
|
|||||||
|
|
||||||
#include "esp32s3_gpio.h"
|
#include "esp32s3_gpio.h"
|
||||||
#include "esp32s3_psram.h"
|
#include "esp32s3_psram.h"
|
||||||
|
#include "esp32s3_spi_timing.h"
|
||||||
|
|
||||||
#include "rom/esp32s3_spiflash.h"
|
#include "rom/esp32s3_spiflash.h"
|
||||||
#include "rom/esp32s3_opi_flash.h"
|
#include "rom/esp32s3_opi_flash.h"
|
||||||
@ -453,7 +454,7 @@ int psram_enable(int mode, int vaddrmode)
|
|||||||
* PSRAM timing related registers accordingly
|
* PSRAM timing related registers accordingly
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* FIXME: spi_timing_psram_tuning(); */
|
esp32s3_spi_timing_set_mspi_psram_tuning();
|
||||||
|
|
||||||
/* Configure SPI0 PSRAM related SPI Phases */
|
/* Configure SPI0 PSRAM related SPI Phases */
|
||||||
|
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -72,10 +72,6 @@ extern "C"
|
|||||||
# define ESP32S3_SPI_TIMING_FLASH_TUNING 0
|
# define ESP32S3_SPI_TIMING_FLASH_TUNING 0
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if ESP32S3_SPI_TIMING_FLASH_TUNING
|
|
||||||
# error "SPI flash tuning is not supported"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_ESP32S3_SPIRAM)
|
#if defined(CONFIG_ESP32S3_SPIRAM)
|
||||||
# if defined(CONFIG_ESP32S3_SPIRAM_SPEED_40M)
|
# if defined(CONFIG_ESP32S3_SPIRAM_SPEED_40M)
|
||||||
# define ESP32S3_SPI_TIMING_PSRAM_CLOCK 40
|
# define ESP32S3_SPI_TIMING_PSRAM_CLOCK 40
|
||||||
@ -104,8 +100,115 @@ extern "C"
|
|||||||
# define ESP32S3_SPI_TIMING_PSRAM_TUNING 0
|
# define ESP32S3_SPI_TIMING_PSRAM_TUNING 0
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if ESP32S3_SPI_TIMING_PSRAM_TUNING
|
#if ESP32S3_SPI_TIMING_FLASH_TUNING || ESP32S3_SPI_TIMING_PSRAM_TUNING
|
||||||
# error "SPI PSRAM tuning is not supported"
|
|
||||||
|
/* This should be larger than the max available timing config num */
|
||||||
|
|
||||||
|
#define MSPI_TIMING_CONFIG_NUM_DEFAULT 20
|
||||||
|
|
||||||
|
#define __GET_TUNING_CONFIG(type, core_clock, module_clock, mode) \
|
||||||
|
(tuning_config_s) { .config_table = MSPI_TIMING_##type##_CONFIG_TABLE_CORE_CLK_##core_clock##M_MODULE_CLK_##module_clock##M_##mode, \
|
||||||
|
.config_num = MSPI_TIMING_##type##_CONFIG_NUM_CORE_CLK_##core_clock##M_MODULE_CLK_##module_clock##M_##mode, \
|
||||||
|
.default_config_id = MSPI_TIMING_##type##_DEFAULT_CONFIG_ID_CORE_CLK_##core_clock##M_MODULE_CLK_##module_clock##M_##mode }
|
||||||
|
|
||||||
|
#define _GET_TUNING_CONFIG(type, core_clock, module_clock, mode) __GET_TUNING_CONFIG(type, core_clock, module_clock, mode)
|
||||||
|
#define MSPI_TIMING_FLASH_GET_TUNING_CONFIG(core_clock_mhz, module_clock_mhz, mode) _GET_TUNING_CONFIG(FLASH, core_clock_mhz, module_clock_mhz, mode)
|
||||||
|
#define MSPI_TIMING_PSRAM_GET_TUNING_CONFIG(core_clock_mhz, module_clock_mhz, mode) _GET_TUNING_CONFIG(PSRAM, core_clock_mhz, module_clock_mhz, mode)
|
||||||
|
|
||||||
|
/* Timing Tuning Parameters */
|
||||||
|
|
||||||
|
/* FLASH: core clock 160M, module clock 40M, DTR mode */
|
||||||
|
|
||||||
|
#define MSPI_TIMING_FLASH_CONFIG_TABLE_CORE_CLK_160M_MODULE_CLK_40M_DTR_MODE {{1, 0, 0}, {0, 0, 0}, {2, 1, 1}, {2, 0, 1}, {2, 2, 2}, {2, 1, 2}, {1, 0, 1}, {0, 0, 1}}
|
||||||
|
#define MSPI_TIMING_FLASH_CONFIG_NUM_CORE_CLK_160M_MODULE_CLK_40M_DTR_MODE 8
|
||||||
|
#define MSPI_TIMING_FLASH_DEFAULT_CONFIG_ID_CORE_CLK_160M_MODULE_CLK_40M_DTR_MODE 2
|
||||||
|
|
||||||
|
/* FLASH: core clock 160M, module clock 80M, DTR mode */
|
||||||
|
|
||||||
|
#define MSPI_TIMING_FLASH_CONFIG_TABLE_CORE_CLK_160M_MODULE_CLK_80M_DTR_MODE {{0, 0, 0}, {4, 2, 2}, {2, 1, 2}, {4, 1, 2}, {1, 0, 1}, {4, 0, 2}, {0, 0, 1}, {4, 2, 3}, {2, 1, 3}, {4, 1, 3}, {1, 0, 2}, {4, 0, 3}, {0, 0, 2}, {4, 2, 4}}
|
||||||
|
#define MSPI_TIMING_FLASH_CONFIG_NUM_CORE_CLK_160M_MODULE_CLK_80M_DTR_MODE 14
|
||||||
|
#define MSPI_TIMING_FLASH_DEFAULT_CONFIG_ID_CORE_CLK_160M_MODULE_CLK_80M_DTR_MODE 1
|
||||||
|
|
||||||
|
/* FLASH: core clock 240M, module clock 120M, DTR mode */
|
||||||
|
|
||||||
|
#define MSPI_TIMING_FLASH_CONFIG_TABLE_CORE_CLK_240M_MODULE_CLK_120M_DTR_MODE {{0, 0, 0}, {4, 1, 2}, {1, 0, 1}, {4, 0, 2}, {0, 0, 1}, {4, 1, 3}, {1, 0, 2}, {4, 0, 3}, {0, 0, 2}, {4, 1, 4}, {1, 0, 3}, {4, 0, 4}, {0, 0, 3}, {4, 1, 5}}
|
||||||
|
#define MSPI_TIMING_FLASH_CONFIG_NUM_CORE_CLK_240M_MODULE_CLK_120M_DTR_MODE 14
|
||||||
|
#define MSPI_TIMING_FLASH_DEFAULT_CONFIG_ID_CORE_CLK_240M_MODULE_CLK_120M_DTR_MODE 1
|
||||||
|
|
||||||
|
/* FLASH: core clock 160M, module clock 80M, STR mode */
|
||||||
|
|
||||||
|
#define MSPI_TIMING_FLASH_CONFIG_TABLE_CORE_CLK_160M_MODULE_CLK_80M_STR_MODE {{1, 0, 0}, {0, 0, 0}, {2, 1, 1}, {2, 0, 1}, {2, 2, 2}, {2, 1, 2}, {1, 0, 1}, {0, 0, 1}}
|
||||||
|
#define MSPI_TIMING_FLASH_CONFIG_NUM_CORE_CLK_160M_MODULE_CLK_80M_STR_MODE 8
|
||||||
|
#define MSPI_TIMING_FLASH_DEFAULT_CONFIG_ID_CORE_CLK_160M_MODULE_CLK_80M_STR_MODE 2
|
||||||
|
|
||||||
|
/* FLASH: core clock 120M, module clock 120M, STR mode */
|
||||||
|
|
||||||
|
#define MSPI_TIMING_FLASH_CONFIG_TABLE_CORE_CLK_120M_MODULE_CLK_120M_STR_MODE {{2, 0, 1}, {0, 0, 0}, {2, 2, 2}, {1, 0, 1}, {2, 0, 2}, {0, 0, 1}, {2, 2, 3}, {1, 0, 2}, {2, 0, 3}, {0, 0, 2}, {2, 2, 4}, {1, 0, 3}}
|
||||||
|
#define MSPI_TIMING_FLASH_CONFIG_NUM_CORE_CLK_120M_MODULE_CLK_120M_STR_MODE 12
|
||||||
|
#define MSPI_TIMING_FLASH_DEFAULT_CONFIG_ID_CORE_CLK_120M_MODULE_CLK_120M_STR_MODE 2
|
||||||
|
|
||||||
|
/* FLASH: core clock 240M, module clock 120M, STR mode */
|
||||||
|
|
||||||
|
#define MSPI_TIMING_FLASH_CONFIG_TABLE_CORE_CLK_240M_MODULE_CLK_120M_STR_MODE {{1, 0, 0}, {0, 0, 0}, {1, 1, 1}, {2, 3, 2}, {1, 0, 1}, {0, 0, 1}, {1, 1, 2}, {2, 3, 3}, {1, 0, 2}, {0, 0, 2}, {1, 1, 3}, {2, 3, 4}}
|
||||||
|
#define MSPI_TIMING_FLASH_CONFIG_NUM_CORE_CLK_240M_MODULE_CLK_120M_STR_MODE 12
|
||||||
|
#define MSPI_TIMING_FLASH_DEFAULT_CONFIG_ID_CORE_CLK_240M_MODULE_CLK_120M_STR_MODE 2
|
||||||
|
|
||||||
|
/* PSRAM: core clock 80M, module clock 40M, DTR mode */
|
||||||
|
|
||||||
|
#define MSPI_TIMING_PSRAM_CONFIG_TABLE_CORE_CLK_80M_MODULE_CLK_40M_DTR_MODE {{1, 0, 0}, {2, 1, 1}, {2, 0, 1}, {0, 0, 0}, {3, 1, 1}, {3, 0, 1}, {1, 0, 1}, {2, 1, 2}, {2, 0, 2}, {0, 0, 1}, {3, 1, 2}, {3, 0, 2}}
|
||||||
|
#define MSPI_TIMING_PSRAM_CONFIG_NUM_CORE_CLK_80M_MODULE_CLK_40M_DTR_MODE 12
|
||||||
|
#define MSPI_TIMING_PSRAM_DEFAULT_CONFIG_ID_CORE_CLK_80M_MODULE_CLK_40M_DTR_MODE 4
|
||||||
|
|
||||||
|
/* PSRAM: core clock 160M, module clock 80M, DTR mode */
|
||||||
|
|
||||||
|
#define MSPI_TIMING_PSRAM_CONFIG_TABLE_CORE_CLK_160M_MODULE_CLK_80M_DTR_MODE {{0, 0, 0}, {4, 2, 2}, {2, 1, 2}, {4, 1, 2}, {1, 0, 1}, {4, 0, 2}, {0, 0, 1}, {4, 2, 3}, {2, 1, 3}, {4, 1, 3}, {1, 0, 2}, {4, 0, 3}, {0, 0, 2}, {4, 2, 4}}
|
||||||
|
#define MSPI_TIMING_PSRAM_CONFIG_NUM_CORE_CLK_160M_MODULE_CLK_80M_DTR_MODE 14
|
||||||
|
#define MSPI_TIMING_PSRAM_DEFAULT_CONFIG_ID_CORE_CLK_160M_MODULE_CLK_80M_DTR_MODE 5
|
||||||
|
|
||||||
|
/* PSRAM: core clock 240M, module clock 120M, STR mode */
|
||||||
|
|
||||||
|
#define MSPI_TIMING_PSRAM_CONFIG_TABLE_CORE_CLK_240M_MODULE_CLK_120M_STR_MODE {{1, 0, 0}, {0, 0, 0}, {1, 1, 1}, {2, 3, 2}, {1, 0, 1}, {0, 0, 1}, {1, 1, 2}, {2, 3, 3}, {1, 0, 2}, {0, 0, 2}, {1, 1, 3}, {2, 3, 4}}
|
||||||
|
#define MSPI_TIMING_PSRAM_CONFIG_NUM_CORE_CLK_240M_MODULE_CLK_120M_STR_MODE 12
|
||||||
|
#define MSPI_TIMING_PSRAM_DEFAULT_CONFIG_ID_CORE_CLK_240M_MODULE_CLK_120M_STR_MODE 2
|
||||||
|
|
||||||
|
/* PSRAM: core clock 120M, module clock 120M, STR mode */
|
||||||
|
|
||||||
|
#define MSPI_TIMING_PSRAM_CONFIG_TABLE_CORE_CLK_120M_MODULE_CLK_120M_STR_MODE {{2, 0, 1}, {0, 0, 0}, {2, 2, 2}, {1, 0, 1}, {2, 0, 2}, {0, 0, 1}, {2, 2, 3}, {1, 0, 2}, {2, 0, 3}, {0, 0, 2}, {2, 2, 4}, {1, 0, 3}}
|
||||||
|
#define MSPI_TIMING_PSRAM_CONFIG_NUM_CORE_CLK_120M_MODULE_CLK_120M_STR_MODE 12
|
||||||
|
#define MSPI_TIMING_PSRAM_DEFAULT_CONFIG_ID_CORE_CLK_120M_MODULE_CLK_120M_STR_MODE 2
|
||||||
|
|
||||||
|
/* PSRAM: core clock 240M, module clock 120M, DTR mode */
|
||||||
|
|
||||||
|
#define MSPI_TIMING_PSRAM_CONFIG_TABLE_CORE_CLK_240M_MODULE_CLK_120M_DTR_MODE {{0, 0, 0}, {4, 1, 2}, {1, 0, 1}, {4, 0, 2}, {0, 0, 1}, {4, 1, 3}, {1, 0, 2}, {4, 0, 3}, {0, 0, 2}, {4, 1, 4}, {1, 0, 3}, {4, 0, 4}, {0, 0, 3}, {4, 1, 5}}
|
||||||
|
#define MSPI_TIMING_PSRAM_CONFIG_NUM_CORE_CLK_240M_MODULE_CLK_120M_DTR_MODE 14
|
||||||
|
#define MSPI_TIMING_PSRAM_DEFAULT_CONFIG_ID_CORE_CLK_240M_MODULE_CLK_120M_DTR_MODE 1
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Public Types
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#if ESP32S3_SPI_TIMING_FLASH_TUNING || ESP32S3_SPI_TIMING_PSRAM_TUNING
|
||||||
|
|
||||||
|
/* SPI timing tuning registers.
|
||||||
|
* Upper layer rely on these 3 registers to tune the timing.
|
||||||
|
*/
|
||||||
|
|
||||||
|
typedef struct
|
||||||
|
{
|
||||||
|
uint8_t spi_din_mode; /* input signal delay mode */
|
||||||
|
uint8_t spi_din_num; /* input signal delay number */
|
||||||
|
uint8_t extra_dummy_len; /* extra dummy length */
|
||||||
|
} tuning_param_s;
|
||||||
|
|
||||||
|
typedef struct
|
||||||
|
{
|
||||||
|
tuning_param_s config_table[MSPI_TIMING_CONFIG_NUM_DEFAULT];
|
||||||
|
uint32_t config_num;
|
||||||
|
uint32_t default_config_id; /* If tuning fails, we use this one as default */
|
||||||
|
} tuning_config_s;
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
@ -161,6 +264,38 @@ void esp32s3_spi_timing_set_mspi_high_speed(bool control_spi1);
|
|||||||
|
|
||||||
void esp32s3_spi_timing_set_pin_drive_strength(void);
|
void esp32s3_spi_timing_set_pin_drive_strength(void);
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: esp32s3_spi_timing_set_mspi_psram_tuning
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Tune MSPI psram timing to make it work under high frequency
|
||||||
|
*
|
||||||
|
* Input Parameters:
|
||||||
|
* None
|
||||||
|
*
|
||||||
|
* Returned Value:
|
||||||
|
* None.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
void esp32s3_spi_timing_set_mspi_psram_tuning(void);
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: esp32s3_spi_timing_set_mspi_flash_tuning
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Tune MSPI flash timing to make it work under high frequency
|
||||||
|
*
|
||||||
|
* Input Parameters:
|
||||||
|
* None
|
||||||
|
*
|
||||||
|
* Returned Value:
|
||||||
|
* None.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
void esp32s3_spi_timing_set_mspi_flash_tuning(void);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -123,7 +123,8 @@ static const struct esp32s3_mtd_dev_s g_esp32s3_spiflash =
|
|||||||
#endif
|
#endif
|
||||||
.name = "esp32s3_spiflash"
|
.name = "esp32s3_spiflash"
|
||||||
},
|
},
|
||||||
.data = &rom_spiflash_legacy_data,
|
.data = (const struct spiflash_legacy_data_s **)
|
||||||
|
(&rom_spiflash_legacy_data),
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct esp32s3_mtd_dev_s g_esp32s3_spiflash_encrypt =
|
static const struct esp32s3_mtd_dev_s g_esp32s3_spiflash_encrypt =
|
||||||
@ -140,7 +141,8 @@ static const struct esp32s3_mtd_dev_s g_esp32s3_spiflash_encrypt =
|
|||||||
#endif
|
#endif
|
||||||
.name = "esp32s3_spiflash_encrypt"
|
.name = "esp32s3_spiflash_encrypt"
|
||||||
},
|
},
|
||||||
.data = &rom_spiflash_legacy_data,
|
.data = (const struct spiflash_legacy_data_s **)
|
||||||
|
(&rom_spiflash_legacy_data),
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Ensure exclusive access to the driver */
|
/* Ensure exclusive access to the driver */
|
||||||
|
@ -356,6 +356,7 @@ void noreturn_function IRAM_ATTR __esp32s3_start(void)
|
|||||||
esp32s3_spi_timing_set_pin_drive_strength();
|
esp32s3_spi_timing_set_pin_drive_strength();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
esp32s3_spi_timing_set_mspi_flash_tuning();
|
||||||
#if defined(CONFIG_ESP32S3_SPIRAM_BOOT_INIT)
|
#if defined(CONFIG_ESP32S3_SPIRAM_BOOT_INIT)
|
||||||
if (esp_spiram_init() != OK)
|
if (esp_spiram_init() != OK)
|
||||||
{
|
{
|
||||||
|
@ -1008,7 +1008,7 @@ void spi_flash_enable_cache(uint32_t cpuid);
|
|||||||
* Public Data
|
* Public Data
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
extern const struct spiflash_legacy_data_s *rom_spiflash_legacy_data;
|
extern struct spiflash_legacy_data_s *rom_spiflash_legacy_data;
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user