SPI获取不符合SCK的数据

SPI获取不符合SCK的数据,c,spi,stm32f4discovery,hal,C,Spi,Stm32f4discovery,Hal,我一直在尝试在DMA模式下的STM32F407发现模式上实现spi。我得到了数据,但问题是,我有112位通过脉冲位置调制的数据,数据的频率是1MHz。由于这个信息信号是任意的,所以我将我的板配置为从板(尽管没有真正的主板),并通过PWM从板本身生成SCK。问题是,我正在接收数据,但我在42个脉冲中获得了全部112位。我不确定SCK是如何触发SPI的,因为硬度不匹配。 我的SPI有以下配置: static void MX_SPI1_Init(void) { /* SPI1 parameter co

我一直在尝试在DMA模式下的STM32F407发现模式上实现spi。我得到了数据,但问题是,我有112位通过脉冲位置调制的数据,数据的频率是1MHz。由于这个信息信号是任意的,所以我将我的板配置为从板(尽管没有真正的主板),并通过PWM从板本身生成SCK。问题是,我正在接收数据,但我在42个脉冲中获得了全部112位。我不确定SCK是如何触发SPI的,因为硬度不匹配。 我的SPI有以下配置:

static void MX_SPI1_Init(void)
{
/* SPI1 parameter configuration*/
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_HIGH;
hspi1.Init.CLKPhase = SPI_PHASE_1EDGE;
hspi1.Init.NSS = SPI_NSS_HARD_INPUT;
hspi1.Init.FirstBit = SPI_FIRSTBIT_MSB;
hspi1.Init.BaudRatePrescaler=SPI_BAUDRATEPRESCALER_4;
hspi1.Init.TIMode = SPI_TIMODE_DISABLE;
hspi1.Init.CRCCalculation = SPI_CRCCALCULATION_DISABLE;
hspi1.Init.CRCPolynomial = 7;
if (HAL_SPI_Init(&hspi1) != HAL_OK)
{
_Error_Handler(__FILE__, __LINE__);
}}
我的msp.c文件

void HAL_SPI_MspInit(SPI_HandleTypeDef* hspi)
{
GPIO_InitTypeDef GPIO_InitStruct;
if(hspi->Instance==SPI1)
{
/* USER CODE BEGIN SPI1_MspInit 0 */
    __HAL_RCC_GPIOA_CLK_ENABLE();
    __HAL_RCC_GPIOB_CLK_ENABLE();
/* USER CODE END SPI1_MspInit 0 */
/* Peripheral clock enable */
__HAL_RCC_SPI1_CLK_ENABLE();

/**SPI1 GPIO Configuration    
PA4     ------> SPI1_NSS
PA6     ------> SPI1_MISO
PA7     ------> SPI1_MOSI
PB3     ------> SPI1_SCK 
*/
GPIO_InitStruct.Pin = GPIO_PIN_4|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_AF5_SPI1;
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);

GPIO_InitStruct.Pin = GPIO_PIN_3;
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
GPIO_InitStruct.Pull = GPIO_NOPULL;
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
GPIO_InitStruct.Alternate = GPIO_AF5_SPI1;
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);

/* SPI1 DMA Init */
/* SPI1_RX Init */
hdma_spi1_rx.Instance = DMA2_Stream0;
hdma_spi1_rx.Init.Channel = DMA_CHANNEL_3;
hdma_spi1_rx.Init.Direction = DMA_PERIPH_TO_MEMORY;
hdma_spi1_rx.Init.PeriphInc = DMA_PINC_DISABLE;
hdma_spi1_rx.Init.MemInc = DMA_MINC_ENABLE;
hdma_spi1_rx.Init.PeriphDataAlignment = DMA_PDATAALIGN_BYTE;
hdma_spi1_rx.Init.MemDataAlignment = DMA_MDATAALIGN_BYTE;
hdma_spi1_rx.Init.Mode = DMA_NORMAL;
hdma_spi1_rx.Init.Priority = DMA_PRIORITY_LOW;
hdma_spi1_rx.Init.FIFOMode = DMA_FIFOMODE_DISABLE;
if (HAL_DMA_Init(&hdma_spi1_rx) != HAL_OK)
{
  _Error_Handler(__FILE__, __LINE__);
}

__HAL_LINKDMA(hspi,hdmarx,hdma_spi1_rx);

/* SPI1 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 */
}}
我通过以下方式启动SPI:

HAL_SPI_Receive_DMA(&hspi1, data, 14); //data is array uint8_t
HAL_GPIO_WritePin(GPIOA, GPIO_PIN_5, GPIO_PIN_RESET); //NSS out which is shortened with real NSS of Slave
HAL_TIM_PWM_Start(&htim3, TIM_CHANNEL_1); /clock
在获得数据后,我在SPI处理程序中使用了以下内容:

HAL_GPIO_WritePin(GPIOA, GPIO_PIN_5, GPIO_PIN_SET);
HAL_TIM_PWM_Stop(&htim3, TIM_CHANNEL_1);
在内存中,我得到了所有的112(14字节)

这是示波图

有什么想法吗?
我使用CubeMX作为代码的基础

如果不了解整个应用程序,包括原理图(在这种情况下,应该在电子网站上而不是在这里询问),我不确定是否可以回答这个问题。但有一个问题。。。为什么信号在你的示波器图片上看起来像个垃圾?你没有把探头接地吗?否则,你可能会受到一些严重的EMI噪音。我目前正在通过任意函数发生器模拟ADS-B软件包,是的,接地电缆从接地引脚上脱落。目标是检测4个脉冲,这表明包正在传入,我通过它同步以解码数据。由于我的资源不足,我正试图尽可能少地使用CPU,因为我需要将数据传输到其他地方。在不了解整个应用程序(包括原理图)的情况下,我不确定这个问题是否可以回答(在这种情况下,应该在电子网站上而不是在这里询问)。但有一个问题。。。为什么信号在你的示波器图片上看起来像个垃圾?你没有把探头接地吗?否则,你可能会受到一些严重的EMI噪音。我目前正在通过任意函数发生器模拟ADS-B软件包,是的,接地电缆从接地引脚上脱落。目标是检测4个脉冲,这表明包正在传入,我通过它同步以解码数据。因为我的资源很低,所以我尝试使用尽可能少的CPU,因为我需要将数据传输到其他地方。