久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 2142|回復: 2
打印 上一主題 下一主題
收起左側

哪位老哥整過stm32串口硬件流控制的代碼啊

[復制鏈接]
跳轉到指定樓層
樓主
ID:630212 發表于 2023-5-25 16:28 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
90黑幣

最佳答案

查看完整內容

以下是一個使用STM32的標準庫(HAL庫)實現硬件流控制的串口代碼,用于控制UART2: #include "stm32f4xx_hal.h" UART_HandleTypeDef huart2; void SystemClock_Config(void); int main(void) { HAL_Init(); SystemClock_Config(); __HAL_RCC_GPIOA_CLK_ENABLE(); __HAL_RCC_USART2_CLK_ENABLE(); GPIO_InitTypeDef GPIO_InitStruct = {0}; GPIO_InitStruct.Pin = GPIO_PIN_2|GPIO_PIN_3; ...
分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

沙發
ID:404160 發表于 2023-5-25 16:28 | 只看該作者
以下是一個使用STM32的標準庫(HAL庫)實現硬件流控制的串口代碼,用于控制UART2:

#include "stm32f4xx_hal.h"

UART_HandleTypeDef huart2;

void SystemClock_Config(void);

int main(void)
{
  HAL_Init();

  SystemClock_Config();

  __HAL_RCC_GPIOA_CLK_ENABLE();
  __HAL_RCC_USART2_CLK_ENABLE();

  GPIO_InitTypeDef GPIO_InitStruct = {0};
  GPIO_InitStruct.Pin = GPIO_PIN_2|GPIO_PIN_3;
  GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  GPIO_InitStruct.Pull = GPIO_PULLUP;
  GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
  GPIO_InitStruct.Alternate = GPIO_AF7_USART2;
  HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);

  huart2.Instance = USART2;
  huart2.Init.BaudRate = 115200;
  huart2.Init.WordLength = UART_WORDLENGTH_8B;
  huart2.Init.StopBits = UART_STOPBITS_1;
  huart2.Init.Parity = UART_PARITY_NONE;
  huart2.Init.Mode = UART_MODE_TX_RX;
  huart2.Init.HwFlowCtl = UART_HWCONTROL_RTS_CTS;
  huart2.Init.OverSampling = UART_OVERSAMPLING_16;
  if (HAL_UART_Init(&huart2) != HAL_OK)
  {
    while (1);
  }

  uint8_t buffer[] = "Hello, world!\r\n";

  while (1)
  {
    if (HAL_UART_Transmit(&huart2, buffer, sizeof(buffer), 100) != HAL_OK)
    {
      while (1);
    }

    HAL_Delay(1000);
  }
}

void SystemClock_Config(void)
{
  RCC_OscInitTypeDef RCC_OscInitStruct = {0};
  RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};

  /** Configure the main internal regulator output voltage
  */
  __HAL_RCC_PWR_CLK_ENABLE();
  __HAL_PWR_VOLTAGESCALING_CONFIG(PWR_REGULATOR_VOLTAGE_SCALE3);
  /** Initializes the CPU, AHB and APB busses clocks
  */
  RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI;
  RCC_OscInitStruct.HSIState = RCC_HSI_ON;
  RCC_OscInitStruct.HSICalibrationValue = RCC_HSICALIBRATION_DEFAULT;
  RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
  RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSI;
  RCC_OscInitStruct.PLL.PLLM = 16;
  RCC_OscInitStruct.PLL.PLLN = 336;
  RCC_OscInitStruct.PLL.PLLP = RCC_PLLP_DIV4;
  RCC_OscInitStruct.PLL.PLLQ = 7;
  if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
  {
    while (1);
  }
  /** Initializes the CPU, AHB and APB busses clocks
  */
  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_DIV4;
  RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV2;

  if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_2) != HAL_OK)
  {
    while (1);
  }
}
在以上代碼中,我們使用了硬件流控制(RTS/CTS)來實現串口的數據傳輸。在初始化UART時,我們將Mode設置為UART_MODE_TX_RX,以允許UART同時進行發送和接收。我們還將HwFlowCtl設置為UART_HWCONTROL_RTS_CTS,以啟用硬件流控制。

此時,CTS引腳應該配置為輸入模式,如上述代碼所示,我們使用GPIOA2引腳作為CTS。在數據發送時,如果CTS引腳處于邏輯高電平,則UART不會將數據發送到接收端,而會等待CTS引腳返回邏輯低電平,然后再繼續發送數據。

請注意,上述代碼主要用于示例演示,因此省略了錯誤處理和異常情況處理。在實際應用中,需要根據具體需求添加適當的錯誤處理和異常情況處理。

回復

使用道具 舉報

板凳
ID:404160 發表于 2023-5-28 17:06 | 只看該作者
以下是一個使用STM32的標準庫(HAL庫)實現硬件流控制的串口代碼,用于控制UART2:

#include "stm32f4xx_hal.h"

UART_HandleTypeDef huart2;

void SystemClock_Config(void);

int main(void)
{
  HAL_Init();

  SystemClock_Config();

  __HAL_RCC_GPIOA_CLK_ENABLE();
  __HAL_RCC_USART2_CLK_ENABLE();

  GPIO_InitTypeDef GPIO_InitStruct = {0};
  GPIO_InitStruct.Pin = GPIO_PIN_2|GPIO_PIN_3;
  GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
  GPIO_InitStruct.Pull = GPIO_PULLUP;
  GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
  GPIO_InitStruct.Alternate = GPIO_AF7_USART2;
  HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);

  huart2.Instance = USART2;
  huart2.Init.BaudRate = 115200;
  huart2.Init.WordLength = UART_WORDLENGTH_8B;
  huart2.Init.StopBits = UART_STOPBITS_1;
  huart2.Init.Parity = UART_PARITY_NONE;
  huart2.Init.Mode = UART_MODE_TX_RX;
  huart2.Init.HwFlowCtl = UART_HWCONTROL_RTS_CTS;
  huart2.Init.OverSampling = UART_OVERSAMPLING_16;
  if (HAL_UART_Init(&huart2) != HAL_OK)
  {
    while (1);
  }

  uint8_t buffer[] = "Hello, world!\r\n";

  while (1)
  {
    if (HAL_UART_Transmit(&huart2, buffer, sizeof(buffer), 100) != HAL_OK)
    {
      while (1);
    }

    HAL_Delay(1000);
  }
}

void SystemClock_Config(void)
{
  RCC_OscInitTypeDef RCC_OscInitStruct = {0};
  RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};

  /** Configure the main internal regulator output voltage
  */
  __HAL_RCC_PWR_CLK_ENABLE();
  __HAL_PWR_VOLTAGESCALING_CONFIG(PWR_REGULATOR_VOLTAGE_SCALE3);
  /** Initializes the CPU, AHB and APB busses clocks
  */
  RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI;
  RCC_OscInitStruct.HSIState = RCC_HSI_ON;
  RCC_OscInitStruct.HSICalibrationValue = RCC_HSICALIBRATION_DEFAULT;
  RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
  RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSI;
  RCC_OscInitStruct.PLL.PLLM = 16;
  RCC_OscInitStruct.PLL.PLLN = 336;
  RCC_OscInitStruct.PLL.PLLP = RCC_PLLP_DIV4;
  RCC_OscInitStruct.PLL.PLLQ = 7;
  if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
  {
    while (1);
  }
  /** Initializes the CPU, AHB and APB busses clocks
  */
  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_DIV4;
  RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV2;

  if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_2) != HAL_OK)
  {
    while (1);
  }
}
在以上代碼中,我們使用了硬件流控制(RTS/CTS)來實現串口的數據傳輸。在初始化UART時,我們將Mode設置為UART_MODE_TX_RX,以允許UART同時進行發送和接收。我們還將HwFlowCtl設置為UART_HWCONTROL_RTS_CTS,以啟用硬件流控制。

此時,CTS引腳應該配置為輸入模式,如上述代碼所示,我們使用GPIOA2引腳作為CTS。在數據發送時,如果CTS引腳處于邏輯高電平,則UART不會將數據發送到接收端,而會等待CTS引腳返回邏輯低電平,然后再繼續發送數據。

請注意,上述代碼主要用于示例演示,因此省略了錯誤處理和異常情況處理。在實際應用中,需要根據具體需求添加適當的錯誤處理和異常情況處理。

回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 欧美成人综合 | 成人福利在线观看 | 久久久久久免费毛片精品 | 五月婷六月丁香 | 亚洲三级在线 | 日日操日日舔 | 亚洲女优在线播放 | 久久久久久99 | 亚洲va国产日韩欧美精品色婷婷 | 中文字幕亚洲精品 | 国产1区2区3区 | 老司机久久 | 国产精品自产av一区二区三区 | 91在线区 | 久久亚洲国产精品日日av夜夜 | 欧美午夜激情在线 | 一级欧美一级日韩片免费观看 | 欧美成人激情视频 | 亚洲综合在线视频 | 久久国产精99精产国高潮 | 日韩精品视频一区二区三区 | 视频精品一区 | 日韩视频区 | 国产精品99久久久久久www | 成人a视频 | 欧美一区二区三区日韩 | 亚洲国产一区在线 | 国产视频观看 | 一级毛片免费视频 | 日日天天 | 男女羞羞网站 | 国产精品美女久久久久久免费 | 麻豆成人在线视频 | 久久国产精品色av免费观看 | 日本 欧美 三级 高清 视频 | 日韩精品a在线观看图片 | 成人免费视频播放 | 欧美一级大片免费看 | 久久久亚洲成人 | 精品在线观看一区二区 | 日韩欧美国产精品一区二区 |