|
|
@@ -57,7 +57,7 @@ typedef typeof(GPSPI2.clock) gpspi_flash_ll_clock_reg_t;
|
|
|
* Control
|
|
|
*----------------------------------------------------------------------------*/
|
|
|
/**
|
|
|
- * Reset peripheral registers before configuration and starting control
|
|
|
+ * Reset peripheral registers before configuration and starting control.
|
|
|
*
|
|
|
* @param dev Beginning address of the peripheral registers.
|
|
|
*/
|
|
|
@@ -65,6 +65,15 @@ static inline void gpspi_flash_ll_reset(spi_dev_t *dev)
|
|
|
{
|
|
|
dev->user.val = 0;
|
|
|
dev->ctrl.val = 0;
|
|
|
+
|
|
|
+ dev->clk_gate.clk_en = 1;
|
|
|
+ dev->clk_gate.mst_clk_active = 1;
|
|
|
+ dev->clk_gate.mst_clk_sel = 1;
|
|
|
+
|
|
|
+ dev->dma_conf.val = 0;
|
|
|
+ dev->dma_conf.tx_seg_trans_clr_en = 1;
|
|
|
+ dev->dma_conf.rx_seg_trans_clr_en = 1;
|
|
|
+ dev->dma_conf.dma_seg_trans_en = 0;
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
@@ -144,6 +153,8 @@ static inline void gpspi_flash_ll_set_buffer_data(spi_dev_t *dev, const void *bu
|
|
|
*/
|
|
|
static inline void gpspi_flash_ll_user_start(spi_dev_t *dev)
|
|
|
{
|
|
|
+ dev->cmd.update = 1;
|
|
|
+ while (dev->cmd.update);
|
|
|
dev->cmd.usr = 1;
|
|
|
}
|
|
|
|
|
|
@@ -156,7 +167,7 @@ static inline void gpspi_flash_ll_user_start(spi_dev_t *dev)
|
|
|
*/
|
|
|
static inline bool gpspi_flash_ll_host_idle(const spi_dev_t *dev)
|
|
|
{
|
|
|
- return false;
|
|
|
+ return dev->cmd.usr == 0;
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
@@ -203,10 +214,10 @@ static inline void gpspi_flash_ll_set_read_mode(spi_dev_t *dev, esp_flash_io_mod
|
|
|
ctrl.val &= ~(SPI_FCMD_QUAD_M | SPI_FADDR_QUAD_M | SPI_FREAD_QUAD_M | SPI_FCMD_DUAL_M | SPI_FADDR_DUAL_M | SPI_FREAD_DUAL_M);
|
|
|
user.val &= ~(SPI_FWRITE_QUAD_M | SPI_FWRITE_DUAL_M);
|
|
|
|
|
|
- // ctrl.val |= SPI_FAST_RD_MODE_M;
|
|
|
switch (read_mode) {
|
|
|
case SPI_FLASH_FASTRD:
|
|
|
//the default option
|
|
|
+ case SPI_FLASH_SLOWRD:
|
|
|
break;
|
|
|
case SPI_FLASH_QIO:
|
|
|
ctrl.fread_quad = 1;
|
|
|
@@ -226,9 +237,6 @@ static inline void gpspi_flash_ll_set_read_mode(spi_dev_t *dev, esp_flash_io_mod
|
|
|
ctrl.fread_dual = 1;
|
|
|
user.fwrite_dual = 1;
|
|
|
break;
|
|
|
- // case SPI_FLASH_SLOWRD:
|
|
|
- // ctrl.fast_rd_mode = 0;
|
|
|
- // break;
|
|
|
default:
|
|
|
abort();
|
|
|
}
|
|
|
@@ -257,6 +265,9 @@ static inline void gpspi_flash_ll_set_clock(spi_dev_t *dev, gpspi_flash_ll_clock
|
|
|
static inline void gpspi_flash_ll_set_miso_bitlen(spi_dev_t *dev, uint32_t bitlen)
|
|
|
{
|
|
|
dev->user.usr_miso = bitlen > 0;
|
|
|
+ if (bitlen) {
|
|
|
+ dev->ms_dlen.ms_data_bitlen = bitlen - 1;
|
|
|
+ }
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
@@ -269,20 +280,24 @@ static inline void gpspi_flash_ll_set_miso_bitlen(spi_dev_t *dev, uint32_t bitle
|
|
|
static inline void gpspi_flash_ll_set_mosi_bitlen(spi_dev_t *dev, uint32_t bitlen)
|
|
|
{
|
|
|
dev->user.usr_mosi = bitlen > 0;
|
|
|
+ if (bitlen) {
|
|
|
+ dev->ms_dlen.ms_data_bitlen = bitlen - 1;
|
|
|
+ }
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
- * Set the command with fixed length (8 bits).
|
|
|
+ * Set the command.
|
|
|
*
|
|
|
* @param dev Beginning address of the peripheral registers.
|
|
|
* @param command Command to send
|
|
|
+ * @param bitlen Length of the command
|
|
|
*/
|
|
|
-static inline void gpspi_flash_ll_set_command8(spi_dev_t *dev, uint8_t command)
|
|
|
+static inline void gpspi_flash_ll_set_command(spi_dev_t *dev, uint8_t command, uint32_t bitlen)
|
|
|
{
|
|
|
dev->user.usr_command = 1;
|
|
|
typeof(dev->user2) user2 = {
|
|
|
.usr_command_value = command,
|
|
|
- .usr_command_bitlen = (8 - 1),
|
|
|
+ .usr_command_bitlen = (bitlen - 1),
|
|
|
};
|
|
|
dev->user2 = user2;
|
|
|
}
|
|
|
@@ -318,9 +333,12 @@ static inline void gpspi_flash_ll_set_addr_bitlen(spi_dev_t *dev, uint32_t bitle
|
|
|
*/
|
|
|
static inline void gpspi_flash_ll_set_usr_address(spi_dev_t *dev, uint32_t addr, uint32_t bitlen)
|
|
|
{
|
|
|
- dev->addr = (addr << (32 - bitlen));
|
|
|
+ // The blank region should be all ones
|
|
|
+ uint32_t padding_ones = (bitlen == 32? 0 : UINT32_MAX >> bitlen);
|
|
|
+ dev->addr = (addr << (32 - bitlen)) | padding_ones;
|
|
|
}
|
|
|
|
|
|
+
|
|
|
/**
|
|
|
* Set the address to send. Should be called before commands that requires the address e.g. erase sector, read, write...
|
|
|
*
|
|
|
@@ -358,6 +376,12 @@ static inline void gpspi_flash_ll_set_dummy_out(spi_dev_t *dev, uint32_t out_en,
|
|
|
dev->ctrl.d_pol = out_lev;
|
|
|
}
|
|
|
|
|
|
+static inline void gpspi_flash_ll_set_hold(spi_dev_t *dev, uint32_t hold_n)
|
|
|
+{
|
|
|
+ dev->user1.cs_hold_time = hold_n - 1;
|
|
|
+ dev->user.cs_hold = (hold_n > 0? 1: 0);
|
|
|
+}
|
|
|
+
|
|
|
#ifdef __cplusplus
|
|
|
}
|
|
|
#endif
|