【问题标题】:How do I program AD5930 serially using SPI and the STM32 HAL Libraries? [closed]如何使用 SPI 和 STM32 HAL 库对 AD5930 进行串行编程? [关闭]
【发布时间】:2019-02-22 19:06:29
【问题描述】:

我正在使用 Analog Devices 波形发生器 (AD5930) 并尝试使用 STM32f767 评估板上的 spi 外设对其进行编程。波形发生器将通过使用 SPI 的串行时钟以 16 位字的形式将数据加载到设备寄存器中来进行编程。数据字包括寄存器地址(前 4 位)和命令(后 12 位)。从 STM32 到 AD5930 的连接放置正确,当用示波器检查线路时,我可以看到数据、时钟和控制都从板上脱落。 截至目前,我正在尝试使用 HAL_SPI_Transmit 命令发送 8 个 16 位命令字。以下是我的 ma​​in.c 中包含的内容:

`

HAL_Init();
  SystemClock_Config();
  MX_GPIO_Init();
  MX_SPI1_Init();`

 `HAL_GPIO_WritePin(GPIOA, GPIO_PIN_4, GPIO_PIN_SET);
    HAL_Delay(5);  `

    spiData[0] = 0x0E83;
    spiData[1] = 0x13E8;
    spiData[2] = 0x2000;
    spiData[3] = 0x3800;
    spiData[4] = 0x63E8;
    spiData[5] = 0xC0C5;
    spiData[6] = 0xD002;
    spiData[7] = 0xA3E8;

    HAL_GPIO_WritePin(GPIOA, GPIO_PIN_4, GPIO_PIN_RESET);
    if((HAL_SPI_Transmit(&hspi1,(uint8_t*)&spiData,8,5)) ==HAL_TIMEOUT){
            HAL_Delay(100);
        }
    while(HAL_SPI_GetState(&hspi1) != HAL_SPI_STATE_READY);
    HAL_GPIO_WritePin(GPIOA, GPIO_PIN_4, GPIO_PIN_SET);
    HAL_Delay(1);


        HAL_GPIO_WritePin(GPIOB, GPIO_PIN_8, GPIO_PIN_RESET);       
    HAL_Delay(1);
        HAL_GPIO_WritePin(GPIOB, GPIO_PIN_8, GPIO_PIN_SET);
        HAL_Delay(1);`

以下是我的初始化规范:

`

hspi1.Instance = SPI1;
  hspi1.Init.Mode = SPI_MODE_MASTER;
  hspi1.Init.Direction = SPI_DIRECTION_2LINES;
  hspi1.Init.DataSize = SPI_DATASIZE_16BIT;
  hspi1.Init.CLKPolarity = SPI_POLARITY_LOW;
  hspi1.Init.CLKPhase = SPI_PHASE_1EDGE;
  hspi1.Init.NSS = SPI_NSS_SOFT;
  hspi1.Init.BaudRatePrescaler = SPI_BAUDRATEPRESCALER_64;
  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(__FILE__, __LINE__);
  }

  RCC_OscInitTypeDef RCC_OscInitStruct;
  RCC_ClkInitTypeDef RCC_ClkInitStruct;


  __HAL_RCC_PWR_CLK_ENABLE();

  __HAL_PWR_VOLTAGESCALING_CONFIG(PWR_REGULATOR_VOLTAGE_SCALE3);

  RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI;
  RCC_OscInitStruct.HSIState = RCC_HSI_ON;
  RCC_OscInitStruct.HSICalibrationValue = 16;
  RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
  RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSI;
  RCC_OscInitStruct.PLL.PLLM = 16;
  RCC_OscInitStruct.PLL.PLLN = 192;
  RCC_OscInitStruct.PLL.PLLP = RCC_PLLP_DIV2;
  RCC_OscInitStruct.PLL.PLLQ = 2;
  if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
  {
    _Error_Handler(__FILE__, __LINE__);
  }


  if (HAL_PWREx_EnableOverDrive() != HAL_OK)
  {
    _Error_Handler(__FILE__, __LINE__);
  }


  RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
                              |RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;
  RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
  RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
  RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV2;
  RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;

  if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_3) != HAL_OK)
  {
    _Error_Handler(__FILE__, __LINE__);
  }

  HAL_SYSTICK_Config(HAL_RCC_GetHCLKFreq()/1000);

  HAL_SYSTICK_CLKSourceConfig(SYSTICK_CLKSOURCE_HCLK);


  HAL_NVIC_SetPriority(SysTick_IRQn, 0, 0);


GPIO_InitStruct.Pin = GPIO_PIN_5;
    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_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(GPIOD, &GPIO_InitStruct);

  GPIO_InitStruct.Pin = LD3_Pin|LD2_Pin|GPIO_PIN_8;
  GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
  GPIO_InitStruct.Pull = GPIO_NOPULL;
  GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
  HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);

  GPIO_InitStruct.Pin = GPIO_PIN_4;
  GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
  GPIO_InitStruct.Pull = GPIO_NOPULL;
  GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
  HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);

引脚PB8用作控制触发器,在寄存器编程后开始波形生成,引脚PA5用作SPI时钟,PD7用作SPI数据或MOSI,引脚PA4用作片选。

我在示波器上观察到的(查看时钟 + 数据时)是正在输入的数据,似乎正确但在 clk 停止时高悬。我没有收到 HAL TIMEOUT 错误,所以我的假设是数据已正确格式化以进行传输。当程序继续运行并且触发器(引脚 PB8)转换时,我在输出中看不到波形。我的配置可能会阻止我与 AD5930 正确通信?

【问题讨论】:

  • 我投票决定将此问题作为题外话结束,因为无法从外部确定它是硬件错误的软件。还需要访问 实际 硬件来判断。调试您的代码并使用与代码执行相结合的逻辑分析器。摆脱 HAL 膨胀软件也将大大简化调试并大大减少开销。最后查看所有设备的数据表/参考手册。
  • @toohonestforthissite 检查硬件后,连接松动导致一些数据丢失。
  • 那么你为什么要接受一个与问题无关的答案呢?只有解决了实际问题的答案才应该被接受。

标签: c embedded stm32 spi hal


【解决方案1】:

HAL_SPI_Transmit 第三个参数是要传输的字节数。您的数据缓冲区包含 16 个字节(8 * sizeof(uint16) = 8 * 2 个字节),但您只发送 8 个。

【讨论】:

    猜你喜欢
    • 2021-08-27
    • 2021-05-07
    • 2018-01-09
    • 2018-02-01
    • 2022-01-20
    • 2018-09-10
    • 2015-09-24
    • 1970-01-01
    • 2019-04-17
    相关资源
    最近更新 更多