diff options
| author | Damien George <damien.p.george@gmail.com> | 2018-03-11 18:28:48 +1100 | 
|---|---|---|
| committer | Damien George <damien.p.george@gmail.com> | 2018-03-11 18:28:48 +1100 | 
| commit | 1345093401ed0812aa72dc5206cb8fd5fe61917f (patch) | |
| tree | 34006495fde421c21d54a29fdfdfeb2a6ee826a8 | |
| parent | cc34b087f0fe121afb03dcfe99180737ab925372 (diff) | |
stm32/qspi: Do an explicit read instead of using memory-mapped mode.
Using an explicit read eliminates the need to invalidate the D-cache after
enabling the memory mapping mode, which takes additional time.
| -rw-r--r-- | ports/stm32/qspi.c | 35 | 
1 files changed, 32 insertions, 3 deletions
| diff --git a/ports/stm32/qspi.c b/ports/stm32/qspi.c index e1ba38c61..50cf5eb48 100644 --- a/ports/stm32/qspi.c +++ b/ports/stm32/qspi.c @@ -48,6 +48,7 @@ void qspi_init(void) {      QUADSPI->CR =          2 << QUADSPI_CR_PRESCALER_Pos // F_CLK = F_AHB/3 (72MHz when CPU is 216MHz) +        | 3 << QUADSPI_CR_FTHRES_Pos // 4 bytes must be available to read/write          #if defined(QUADSPI_CR_FSEL_Pos)          | 0 << QUADSPI_CR_FSEL_Pos // FLASH 1 selected          #endif @@ -232,9 +233,37 @@ STATIC uint32_t qspi_read_cmd(void *self_in, uint8_t cmd, size_t len) {  STATIC void qspi_read_cmd_qaddr_qdata(void *self_in, uint8_t cmd, uint32_t addr, size_t len, uint8_t *dest) {      (void)self_in; -    // This assumes that cmd=0xeb -    qspi_memory_map(); -    memcpy(dest, (void*)(0x90000000 + addr), len); +    QUADSPI->FCR = QUADSPI_FCR_CTCF; // clear TC flag + +    QUADSPI->DLR = len - 1; // number of bytes to read + +    QUADSPI->CCR = +        0 << QUADSPI_CCR_DDRM_Pos // DDR mode disabled +        | 0 << QUADSPI_CCR_SIOO_Pos // send instruction every transaction +        | 1 << QUADSPI_CCR_FMODE_Pos // indirect read mode +        | 3 << QUADSPI_CCR_DMODE_Pos // data on 4 lines +        | 4 << QUADSPI_CCR_DCYC_Pos // 4 dummy cycles +        | 0 << QUADSPI_CCR_ABSIZE_Pos // 8-bit alternate byte +        | 3 << QUADSPI_CCR_ABMODE_Pos // alternate byte on 4 lines +        | 2 << QUADSPI_CCR_ADSIZE_Pos // 24-bit address size +        | 3 << QUADSPI_CCR_ADMODE_Pos // address on 4 lines +        | 1 << QUADSPI_CCR_IMODE_Pos // instruction on 1 line +        | cmd << QUADSPI_CCR_INSTRUCTION_Pos // quad read opcode +        ; + +    QUADSPI->ABR = 0; // alternate byte: disable continuous read mode +    QUADSPI->AR = addr; // addres to read from + +    // Read in the data +    while (len) { +        while (!(QUADSPI->SR & QUADSPI_SR_FTF)) { +        } +        *(uint32_t*)dest = QUADSPI->DR; +        dest += 4; +        len -= 4; +    } + +    QUADSPI->FCR = QUADSPI_FCR_CTCF; // clear TC flag  }  const mp_qspi_proto_t qspi_proto = { | 
