1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00

mtd_spi_nor: Add wait timings to parameters

This commit is contained in:
Koen Zandberg 2020-02-10 22:28:42 +01:00
parent dde05355c5
commit dc04b86d1b
No known key found for this signature in database
GPG Key ID: 0E63411F8FCA8247
2 changed files with 9 additions and 20 deletions

View File

@ -88,6 +88,10 @@ typedef struct __attribute__((packed)) {
*/ */
typedef struct { typedef struct {
const mtd_spi_nor_opcode_t *opcode; /**< Opcode table for the device */ const mtd_spi_nor_opcode_t *opcode; /**< Opcode table for the device */
uint32_t wait_chip_erase; /**< Full chip erase wait time in µs */
uint32_t wait_sector_erase; /**< Sector erase wait time in µs */
uint32_t wait_32k_erase; /**< 32KB page erase wait time in µs */
uint32_t wait_4k_erase; /**< 4KB page erase wait time in µs */
spi_clk_t clk; /**< SPI clock */ spi_clk_t clk; /**< SPI clock */
uint16_t flag; /**< Config flags */ uint16_t flag; /**< Config flags */
spi_t spi; /**< SPI bus the device is connected to */ spi_t spi; /**< SPI bus the device is connected to */
@ -105,6 +109,7 @@ typedef struct {
mtd_dev_t base; /**< inherit from mtd_dev_t object */ mtd_dev_t base; /**< inherit from mtd_dev_t object */
const mtd_spi_nor_params_t *params; /**< SPI NOR params */ const mtd_spi_nor_params_t *params; /**< SPI NOR params */
mtd_jedec_id_t jedec_id; /**< JEDEC ID of the chip */ mtd_jedec_id_t jedec_id; /**< JEDEC ID of the chip */
/** /**
* @brief bitmask to corresponding to the page address * @brief bitmask to corresponding to the page address
* *

View File

@ -49,22 +49,6 @@
#define MTD_4K (4096ul) #define MTD_4K (4096ul)
#define MTD_4K_ADDR_MASK (0xFFF) #define MTD_4K_ADDR_MASK (0xFFF)
#ifndef MTD_SPI_NOR_WAIT_C_ER
#define MTD_SPI_NOR_WAIT_C_ER (16 * US_PER_SEC)
#endif
#ifndef MTD_SPI_NOR_WAIT_S_ER
#define MTD_SPI_NOR_WAIT_S_ER (40 * US_PER_MS)
#endif
#ifndef MTD_SPI_NOR_WAIT_32K_ER
#define MTD_SPI_NOR_WAIT_32K_ER (20 * US_PER_MS)
#endif
#ifndef MTD_SPI_NOR_WAIT_4K_ER
#define MTD_SPI_NOR_WAIT_4K_ER (10 * US_PER_MS)
#endif
static int mtd_spi_nor_init(mtd_dev_t *mtd); static int mtd_spi_nor_init(mtd_dev_t *mtd);
static int mtd_spi_nor_read(mtd_dev_t *mtd, void *dest, uint32_t addr, uint32_t size); static int mtd_spi_nor_read(mtd_dev_t *mtd, void *dest, uint32_t addr, uint32_t size);
static int mtd_spi_nor_write(mtd_dev_t *mtd, const void *src, uint32_t addr, uint32_t size); static int mtd_spi_nor_write(mtd_dev_t *mtd, const void *src, uint32_t addr, uint32_t size);
@ -514,7 +498,7 @@ static int mtd_spi_nor_erase(mtd_dev_t *mtd, uint32_t addr, uint32_t size)
if (size == total_size) { if (size == total_size) {
mtd_spi_cmd(dev, dev->params->opcode->chip_erase); mtd_spi_cmd(dev, dev->params->opcode->chip_erase);
size -= total_size; size -= total_size;
us = MTD_SPI_NOR_WAIT_C_ER; us = dev->params->wait_chip_erase;
} }
else if ((dev->params->flag & SPI_NOR_F_SECT_32K) && (size >= MTD_32K) && else if ((dev->params->flag & SPI_NOR_F_SECT_32K) && (size >= MTD_32K) &&
((addr & MTD_32K_ADDR_MASK) == 0)) { ((addr & MTD_32K_ADDR_MASK) == 0)) {
@ -522,7 +506,7 @@ static int mtd_spi_nor_erase(mtd_dev_t *mtd, uint32_t addr, uint32_t size)
mtd_spi_cmd_addr_write(dev, dev->params->opcode->block_erase_32k, addr_be, NULL, 0); mtd_spi_cmd_addr_write(dev, dev->params->opcode->block_erase_32k, addr_be, NULL, 0);
addr += MTD_32K; addr += MTD_32K;
size -= MTD_32K; size -= MTD_32K;
us = MTD_SPI_NOR_WAIT_32K_ER; us = dev->params->wait_32k_erase;
} }
else if ((dev->params->flag & SPI_NOR_F_SECT_4K) && (size >= MTD_4K) && else if ((dev->params->flag & SPI_NOR_F_SECT_4K) && (size >= MTD_4K) &&
((addr & MTD_4K_ADDR_MASK) == 0)) { ((addr & MTD_4K_ADDR_MASK) == 0)) {
@ -530,13 +514,13 @@ static int mtd_spi_nor_erase(mtd_dev_t *mtd, uint32_t addr, uint32_t size)
mtd_spi_cmd_addr_write(dev, dev->params->opcode->sector_erase, addr_be, NULL, 0); mtd_spi_cmd_addr_write(dev, dev->params->opcode->sector_erase, addr_be, NULL, 0);
addr += MTD_4K; addr += MTD_4K;
size -= MTD_4K; size -= MTD_4K;
us = MTD_SPI_NOR_WAIT_4K_ER; us = dev->params->wait_4k_erase;
} }
else { else {
mtd_spi_cmd_addr_write(dev, dev->params->opcode->block_erase, addr_be, NULL, 0); mtd_spi_cmd_addr_write(dev, dev->params->opcode->block_erase, addr_be, NULL, 0);
addr += sector_size; addr += sector_size;
size -= sector_size; size -= sector_size;
us = MTD_SPI_NOR_WAIT_S_ER; us = dev->params->wait_sector_erase;
} }
/* waiting for the command to complete before continuing */ /* waiting for the command to complete before continuing */