Проблема связи с флэш-памятью SPI NAND (STM32L4, QSPI)

Я пытаюсь использовать внешнюю флэш-память (TC58CVG1S3HxAIx) с платой NUCLEO-L476RG. Я не могу заставить QSPI работать. Я использовал STM32CubeMx для настройки QSPI:

void MX_QUADSPI_Init(void)
{

hqspi.Instance = QUADSPI;
hqspi.Init.ClockPrescaler = 255;
hqspi.Init.FifoThreshold = 1;
hqspi.Init.SampleShifting = QSPI_SAMPLE_SHIFTING_NONE;
hqspi.Init.FlashSize = 30;
hqspi.Init.ChipSelectHighTime = QSPI_CS_HIGH_TIME_1_CYCLE;
hqspi.Init.ClockMode = QSPI_CLOCK_MODE_0;
if (HAL_QSPI_Init(&hqspi) != HAL_OK)
{
_Error_Handler(__FILE__, __LINE__);
}

}

void HAL_QSPI_MspInit(QSPI_HandleTypeDef* qspiHandle)
{

GPIO_InitTypeDef GPIO_InitStruct;
if(qspiHandle->Instance==QUADSPI)
{
/* USER CODE BEGIN QUADSPI_MspInit 0 */

/* USER CODE END QUADSPI_MspInit 0 */
/* QUADSPI clock enable */
__HAL_RCC_QSPI_CLK_ENABLE();/**QUADSPI GPIO Configuration
PA6     ------> QUADSPI_BK1_IO3
PA7     ------> QUADSPI_BK1_IO2
PB0     ------> QUADSPI_BK1_IO1
PB1     ------> QUADSPI_BK1_IO0
PB10     ------> QUADSPI_CLK
PB11     ------> QUADSPI_NCS
*/
GPIO_InitStruct.Pin = GPIO_PIN_6|GPIO_PIN_7;
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
GPIO_InitStruct.Pull = GPIO_NOPULL;
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
GPIO_InitStruct.Alternate = GPIO_AF10_QUADSPI;
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);

GPIO_InitStruct.Pin = GPIO_PIN_0|GPIO_PIN_1|GPIO_PIN_10|GPIO_PIN_11;
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
GPIO_InitStruct.Pull = GPIO_NOPULL;
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
GPIO_InitStruct.Alternate = GPIO_AF10_QUADSPI;
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);

/* USER CODE BEGIN QUADSPI_MspInit 1 */

/* USER CODE END QUADSPI_MspInit 1 */
}
}

И я написал простую программу для получения идентификатора из флэш-памяти:

#include "main.h"#include "stm32l4xx_hal.h"#include "quadspi.h"#include "gpio.h"
uint8_t ReadAddr = 0x9F;
uint8_t pBuffer[3];

int main(void)
{
HAL_Init();
SystemClock_Config();
MX_GPIO_Init();
MX_QUADSPI_Init();

while (1)
{
HAL_QSPI_Transmit(&hqspi, &ReadAddr, 5);
HAL_QSPI_Receive(&hqspi, pBuffer, 5);
}
}

Часы qspi не работают. Я проверил на осциллографе, и все, что я вижу, это прямая линия. Если я изменю режим часов qspi на высокий, проблема все еще остается, но я вижу линию на 3V, а не 0V. Сигнал CS работает, на осциллографе я ясно вижу время, когда UC должен передавать и принимать.

Я проверил регистр AHB3ENR, и он правильно инициализирован. Я понятия не имею, что еще может быть не так.

Может ли кто-нибудь помочь мне?

2

Решение

Это похоже на некорректное использование драйвера HAL.

QSPI является более сложной периферией, чем обычный SPI-модуль.

Связь через QSPI состоит из нескольких этапов (инструкция, адрес и данные), как описано в справочном руководстве.

Длина этих этапов должна быть записана в длина данных а также конфигурация связи регистры.

Это должно быть сделано по телефону HAL_QSPI_Command(), если вы все еще используете драйверы HAL.

Вы можете найти примеры в драйвере внешней памяти HAL (например, stm32h743i_eval_qspi.c, но я не знаю, есть ли аналог для HAL STM32L476).

Также прочитайте очень полезный документ
AN4760 Application note Quad-SPI (QSPI) interface on STM32 microcontrollers

1

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]