2017-02-16 51 views
1

У меня есть простой проект, созданный с использованием CubeMX для периферийной инициализации.STM32F0 SPI получить прерывание не сжигание

SPI находится в режиме ведомого и, по-видимому, инициализирован правильно, но когда я запускаю 8 бит данных, прерывание не вызывается.

Вот код

/* SPI1 init function */ 
static void MX_SPI1_Init(void) 
{ 

    hspi1.Instance = SPI1; 
    hspi1.Init.Mode = SPI_MODE_SLAVE; 
    hspi1.Init.Direction = SPI_DIRECTION_2LINES; 
    hspi1.Init.DataSize = SPI_DATASIZE_8BIT; 
    hspi1.Init.CLKPolarity = SPI_POLARITY_LOW; 
    hspi1.Init.CLKPhase = SPI_PHASE_1EDGE; 
    hspi1.Init.NSS = SPI_NSS_SOFT; 
    hspi1.Init.FirstBit = SPI_FIRSTBIT_MSB; 
    hspi1.Init.TIMode = SPI_TIMODE_DISABLE; 
    hspi1.Init.CRCCalculation = SPI_CRCCALCULATION_DISABLE; 
    hspi1.Init.CRCPolynomial = 7; 
    hspi1.Init.CRCLength = SPI_CRC_LENGTH_DATASIZE; 
    hspi1.Init.NSSPMode = SPI_NSS_PULSE_DISABLE; 

    if (HAL_SPI_Init(&hspi1) != HAL_OK) 
    { 
    Error_Handler(); 
    } 

} 

void HAL_SPI_MspInit(SPI_HandleTypeDef* hspi) 
{ 

    GPIO_InitTypeDef GPIO_InitStruct; 
    if(hspi->Instance==SPI1) 
    { 
    /* USER CODE BEGIN SPI1_MspInit 0 */ 

    /* USER CODE END SPI1_MspInit 0 */ 
    /* Peripheral clock enable */ 
    __HAL_RCC_SPI1_CLK_ENABLE(); 

    /**SPI1 GPIO Configuration  
    PA5  ------> SPI1_SCK 
    PA6  ------> SPI1_MISO 
    PA7  ------> SPI1_MOSI 
    */ 
    GPIO_InitStruct.Pin = GPIO_PIN_5|GPIO_PIN_6|GPIO_PIN_7; 
    GPIO_InitStruct.Mode = GPIO_MODE_AF_PP; 
    GPIO_InitStruct.Pull = GPIO_NOPULL; 
    GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH; 
    GPIO_InitStruct.Alternate = GPIO_AF0_SPI1; 
    HAL_GPIO_Init(GPIOA, &GPIO_InitStruct); 

    /* Peripheral interrupt init */ 
    HAL_NVIC_SetPriority(SPI1_IRQn, 0, 0); 
    HAL_NVIC_EnableIRQ(SPI1_IRQn); 
    /* USER CODE BEGIN SPI1_MspInit 1 */ 

    /* USER CODE END SPI1_MspInit 1 */ 
    } 

} 

void SPI1_IRQHandler(void) 
{ 
    /* USER CODE BEGIN SPI1_IRQn 0 */ 

    /* USER CODE END SPI1_IRQn 0 */ 
    HAL_SPI_IRQHandler(&hspi1); 
    /* USER CODE BEGIN SPI1_IRQn 1 */ 
    spi_interrupt(); 
    /* USER CODE END SPI1_IRQn 1 */ 
} 

spi_interrupt() мой специальный код для прерывания действия и точки останова там не срабатывает.

У меня есть область на булавке CLKIN, и ее определенно получили 8 часов.

+1

Вы вызывали 'HAL_SPI_Receive_IT' в любом месте вашего кода? Поскольку для фактического включения прерывания вы должны вызвать этот макрос '__HAL_SPI_ENABLE_IT (hspi, (SPI_IT_RXNE | SPI_IT_ERR)),' 'HAL_SPI_Receive_IT' вызывает его для вас, а обработчик IRQ отключает его после получения заданного количества байтов. –

+0

Спасибо, Бенс, это было правильное решение :) – OXO

+0

Рад, что он здесь, тогда я отвечу. –

ответ

2

В STA-библиотеке HAL не будут задействованы фактические периферийные прерывания в функции инициализации.

Для почти всех периферийных устройств необходимо вызвать дополнительную функцию, которая всегда имеет следующую структуру имен HAL_<peripheral>_<action>_IT, поэтому в случае SPI RX она называется HAL_SPI_Receive_IT.

Это позволяет фактически прерывать SPI RX, установив правильный бит с помощью макроса, называемого: __HAL_SPI_ENABLE_IT(hspi, (SPI_IT_RXNE | SPI_IT_ERR)).

Обратите внимание, что если число ожидаемых байт (это значение передается в HAL_SPI_Receive_IT пользователе) достигается тогда HAL_SPI_IRQHandler отключит SPI RX прерывания снова, таким образом, повторное HAL_SPI_Receive_IT вызова необходим в случае нового приема ,