本帖最后由 xld0932 于 2019-6-4 19:42 编辑

1.概述

欲先善其事,必先利其器。开发应用程序的基础就是基于底层硬件驱动的实现,欲先修炼如来神掌,必先打通任督二脉^_^,本文将说明基于uFun开发板板载资源的硬件调试测试和运行,为后期的实现应用层打好基础。

2.硬件准备

2.1.uFun开发板及其它
1.jpg

说明:
uFun开发板、调试烧录工具使用J-LINK V9.6,使用SWD接口、示波器等。

2.2.uFun开发板板载资源分配

3.png

说明:
根据uFun开发板的原理图,再结合MCU的引脚资源,对uFun开发板板载资源进行设计规划;在后期的实际调试中PWM_R和PWM_G的硬件对调了,所以如上图中的更正了一下。

3.STM32CubeMX设置

3.1.RCC设置如下图,根据原理图得。

4.png

3.2.SYS设置如下图,将Debug选择Serial Wire,即为SWD接口调试。

5.png

3.3.ADC设置如下图,配置AD_SIG1和AD_SIG2,分别为ADC1的IN12和IN13,ADC的数据采集使用DMA方式,启动ADC转换后,MCU自动完成。

6.png 7.png 8.png

3.4.TIM1设置如下图,使用TIM1的Channel1产生1kHz的PWM波形驱动无源蜂鸣器发出声音。

9.png 10.png

3.5.TIM4设置如下图,使用TIM4的Channel3和Channel4这两个通道产生频率为1kHz,点空比为50%的PWM波形输出,通过示波器测量PWMCH1和PWMCH2的输出波形。

11.png 12.png

3.6.TIM5设置如下图,使用TIM5的Channel1、Channel2和Channel3这3个通道生产PWM波形输出,通过控制输出PWM波形的点空比来控制RGB灯的显示颜色。


13.png 14.png

3.7.TIM6设置如下图,使用TIM6的计数中断功能,给系统运行的时间根本提供时间基准,每间隔1ms产生一次中断。

15.png

3.8.USART1设置如下图,使用USART1通过USB转串口芯片CH340与PC实现数据通讯。

16.png

3.9.I2C设置如下图,使用I2C1串行总线与传感器进行数据通讯。

17.png 18.png

3.10.GPIO设置如下图,将LED的控制引脚配置为输出,将按键KEY的控制引脚配置为输入。

19.png

4.主要程序
  1. /**
  2.   ******************************************************************************
  3.   * @file    uFun.c
  4.   * @version V1.00
  5.   * @author  xld0932
  6.   * @brief   
  7.   ******************************************************************************
  8.   * @attention
  9.   *
  10.   * Copyright (c) 2019. All rights reserved.
  11.   *
  12.   ******************************************************************************
  13.   */
  14. /* Define to prevent recursive inclusion -------------------------------------*/
  15. #define __UFUN_C__
  16. /* Includes ------------------------------------------------------------------*/
  17. #include "uFun.h"
  18. /* Private constants ---------------------------------------------------------*/
  19. /* Private defines -----------------------------------------------------------*/
  20. /* Private typedef -----------------------------------------------------------*/
  21. /* Private macro -------------------------------------------------------------*/
  22. #define uFUN_RGB(r,g,b) {TIM5->CCR1 = (g); TIM5->CCR2 = (r); TIM5->CCR3 = (b);}
  23. /* Private variables ---------------------------------------------------------*/
  24. ADC_HandleTypeDef  hadc1;
  25. DMA_HandleTypeDef  hdma_adc1;
  26. I2C_HandleTypeDef  hi2c1;
  27. TIM_HandleTypeDef  htim1;
  28. TIM_HandleTypeDef  htim4;
  29. TIM_HandleTypeDef  htim5;
  30. TIM_HandleTypeDef  htim6;
  31. UART_HandleTypeDef huart1;
  32. /* Private variables ---------------------------------------------------------*/
  33. static volatile uint32_t ADC_Value[100];
  34. /* Private function prototypes -----------------------------------------------*/
  35. /* Exported variables --------------------------------------------------------*/
  36. /* Exported function prototypes ----------------------------------------------*/
  37. extern void HAL_TIM_MspPostInit(TIM_HandleTypeDef *htim);
  38. /**
  39. * @brief  : ADC1 Initialization Function
  40. * @param  :
  41. * @returns:
  42. * @details:
  43. */
  44. static void MX_ADC1_Init(void)
  45. {
  46.     ADC_ChannelConfTypeDef sConfig = {0};
  47.     /**
  48.      * Common config
  49.      */
  50.     hadc1.Instance                    = ADC1;
  51.     hadc1.Init.ScanConvMode           = ADC_SCAN_ENABLE;
  52.     hadc1.Init.ContinuousConvMode     = ENABLE;
  53.     hadc1.Init.DiscontinuousConvMode  = DISABLE;
  54.     hadc1.Init.ExternalTrigConv       = ADC_SOFTWARE_START;
  55.     hadc1.Init.DataAlign              = ADC_DATAALIGN_RIGHT;
  56.     hadc1.Init.NbrOfConversion        = 2;
  57.     if (HAL_ADC_Init(&hadc1) != HAL_OK)
  58.     {
  59.     }
  60.     /**
  61.      * Configure Regular Channel
  62.      */
  63.     sConfig.Channel      = ADC_CHANNEL_12;
  64.     sConfig.Rank         = ADC_REGULAR_RANK_1;
  65.     sConfig.SamplingTime = ADC_SAMPLETIME_1CYCLE_5;
  66.     if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
  67.     {
  68.     }
  69.     /**
  70.      * Configure Regular Channel
  71.      */
  72.     sConfig.Channel      = ADC_CHANNEL_13;
  73.     sConfig.Rank         = ADC_REGULAR_RANK_2;
  74.     sConfig.SamplingTime = ADC_SAMPLETIME_1CYCLE_5;
  75.     if (HAL_ADC_ConfigChannel(&hadc1, &sConfig) != HAL_OK)
  76.     {
  77.     }
  78.     HAL_ADC_Start_DMA(&hadc1, (uint32_t *)&ADC_Value, 100);
  79. }
  80. /**
  81. * @brief  : Enable DMA controller clock
  82. * @param  :
  83. * @returns:
  84. * @details:
  85. */
  86. static void MX_DMA_Init(void)
  87. {
  88.     /* DMA controller clock enable */
  89.     __HAL_RCC_DMA1_CLK_ENABLE();
  90.     /* DMA interrupt init */
  91.     /* DMA1_Channel1_IRQn interrupt configuration */
  92.     HAL_NVIC_SetPriority(DMA1_Channel1_IRQn, 0, 0);
  93.     HAL_NVIC_EnableIRQ(DMA1_Channel1_IRQn);
  94. }
  95. /**
  96. * @brief  : I2C1 Initialization Function
  97. * @param  :
  98. * @returns:
  99. * @details:
  100. */
  101. static void MX_I2C1_Init(void)
  102. {
  103.     hi2c1.Instance             = I2C1;
  104.     hi2c1.Init.ClockSpeed      = 100000;
  105.     hi2c1.Init.DutyCycle       = I2C_DUTYCYCLE_2;
  106.     hi2c1.Init.OwnAddress1     = 0;
  107.     hi2c1.Init.AddressingMode  = I2C_ADDRESSINGMODE_7BIT;
  108.     hi2c1.Init.DualAddressMode = I2C_DUALADDRESS_DISABLE;
  109.     hi2c1.Init.OwnAddress2     = 0;
  110.     hi2c1.Init.GeneralCallMode = I2C_GENERALCALL_DISABLE;
  111.     hi2c1.Init.NoStretchMode   = I2C_NOSTRETCH_DISABLE;
  112.     if (HAL_I2C_Init(&hi2c1) != HAL_OK)
  113.     {
  114.     }
  115. }
  116. /**
  117. * @brief  : TIM1 Initialization Function
  118. * @param  :
  119. * @returns:
  120. * @details: PWM 1kHz For BEEP
  121. */
  122. static void MX_TIM1_Init(void)
  123. {
  124.     TIM_MasterConfigTypeDef sMasterConfig               = {0};
  125.     TIM_OC_InitTypeDef sConfigOC                        = {0};
  126.     TIM_BreakDeadTimeConfigTypeDef sBreakDeadTimeConfig = {0};
  127.     htim1.Instance               = TIM1;
  128.     htim1.Init.Prescaler         = 72-1;
  129.     htim1.Init.CounterMode       = TIM_COUNTERMODE_UP;
  130.     htim1.Init.Period            = 1000-1;
  131.     htim1.Init.ClockDivision     = TIM_CLOCKDIVISION_DIV1;
  132.     htim1.Init.RepetitionCounter = 0;
  133.     htim1.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_ENABLE;
  134.     if (HAL_TIM_PWM_Init(&htim1) != HAL_OK)
  135.     {
  136.     }
  137.     sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
  138.     sMasterConfig.MasterSlaveMode     = TIM_MASTERSLAVEMODE_DISABLE;
  139.     if (HAL_TIMEx_MasterConfigSynchronization(&htim1, &sMasterConfig) != HAL_OK)
  140.     {
  141.     }
  142.     sConfigOC.OCMode       = TIM_OCMODE_PWM1;
  143.     sConfigOC.Pulse        = 500;
  144.     sConfigOC.OCPolarity   = TIM_OCPOLARITY_HIGH;
  145.     sConfigOC.OCNPolarity  = TIM_OCNPOLARITY_HIGH;
  146.     sConfigOC.OCFastMode   = TIM_OCFAST_DISABLE;
  147.     sConfigOC.OCIdleState  = TIM_OCIDLESTATE_RESET;
  148.     sConfigOC.OCNIdleState = TIM_OCNIDLESTATE_RESET;
  149.     if (HAL_TIM_PWM_ConfigChannel(&htim1, &sConfigOC, TIM_CHANNEL_1) != HAL_OK)
  150.     {
  151.     }
  152.     sBreakDeadTimeConfig.OffStateRunMode  = TIM_OSSR_DISABLE;
  153.     sBreakDeadTimeConfig.OffStateIDLEMode = TIM_OSSI_DISABLE;
  154.     sBreakDeadTimeConfig.LockLevel        = TIM_LOCKLEVEL_OFF;
  155.     sBreakDeadTimeConfig.DeadTime         = 0;
  156.     sBreakDeadTimeConfig.BreakState       = TIM_BREAK_DISABLE;
  157.     sBreakDeadTimeConfig.BreakPolarity    = TIM_BREAKPOLARITY_HIGH;
  158.     sBreakDeadTimeConfig.AutomaticOutput  = TIM_AUTOMATICOUTPUT_DISABLE;
  159.     if (HAL_TIMEx_ConfigBreakDeadTime(&htim1, &sBreakDeadTimeConfig) != HAL_OK)
  160.     {
  161.     }
  162.     HAL_TIM_MspPostInit(&htim1);
  163. }
  164. /**
  165. * @brief  : TIM4 Initialization Function
  166. * @param  :
  167. * @returns:
  168. * @details: PWM 1kHz for PWMCH1 & PWMCH2
  169. */
  170. static void MX_TIM4_Init(void)
  171. {
  172.     TIM_MasterConfigTypeDef sMasterConfig = {0};
  173.     TIM_OC_InitTypeDef sConfigOC          = {0};
  174.     htim4.Instance               = TIM4;
  175.     htim4.Init.Prescaler         = 72-1;
  176.     htim4.Init.CounterMode       = TIM_COUNTERMODE_UP;
  177.     htim4.Init.Period            = 1000-1;
  178.     htim4.Init.ClockDivision     = TIM_CLOCKDIVISION_DIV1;
  179.     htim4.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_ENABLE;
  180.     if (HAL_TIM_PWM_Init(&htim4) != HAL_OK)
  181.     {
  182.     }
  183.     sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
  184.     sMasterConfig.MasterSlaveMode     = TIM_MASTERSLAVEMODE_DISABLE;
  185.     if (HAL_TIMEx_MasterConfigSynchronization(&htim4, &sMasterConfig) != HAL_OK)
  186.     {
  187.     }
  188.     sConfigOC.OCMode     = TIM_OCMODE_PWM1;
  189.     sConfigOC.Pulse      = 500;
  190.     sConfigOC.OCPolarity = TIM_OCPOLARITY_HIGH;
  191.     sConfigOC.OCFastMode = TIM_OCFAST_DISABLE;
  192.     if (HAL_TIM_PWM_ConfigChannel(&htim4, &sConfigOC, TIM_CHANNEL_3) != HAL_OK)
  193.     {
  194.     }
  195.     if (HAL_TIM_PWM_ConfigChannel(&htim4, &sConfigOC, TIM_CHANNEL_4) != HAL_OK)
  196.     {
  197.     }
  198.     HAL_TIM_MspPostInit(&htim4);
  199. }
  200. /**
  201. * @brief  : TIM5 Initialization Function
  202. * @param  :
  203. * @returns:
  204. * @details: PWM 1kHz for RGB
  205. */
  206. static void MX_TIM5_Init(void)
  207. {
  208.     TIM_MasterConfigTypeDef sMasterConfig = {0};
  209.     TIM_OC_InitTypeDef sConfigOC          = {0};
  210.     htim5.Instance               = TIM5;
  211.     htim5.Init.Prescaler         = 72-1;
  212.     htim5.Init.CounterMode       = TIM_COUNTERMODE_UP;
  213.     htim5.Init.Period            = 256-1;
  214.     htim5.Init.ClockDivision     = TIM_CLOCKDIVISION_DIV1;
  215.     htim5.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_ENABLE;
  216.     if (HAL_TIM_PWM_Init(&htim5) != HAL_OK)
  217.     {
  218.     }
  219.     sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
  220.     sMasterConfig.MasterSlaveMode     = TIM_MASTERSLAVEMODE_DISABLE;
  221.     if (HAL_TIMEx_MasterConfigSynchronization(&htim5, &sMasterConfig) != HAL_OK)
  222.     {
  223.     }
  224.     sConfigOC.OCMode     = TIM_OCMODE_PWM1;
  225.     sConfigOC.Pulse      = 8;
  226.     sConfigOC.OCPolarity = TIM_OCPOLARITY_LOW;
  227.     sConfigOC.OCFastMode = TIM_OCFAST_DISABLE;
  228.     if (HAL_TIM_PWM_ConfigChannel(&htim5, &sConfigOC, TIM_CHANNEL_1) != HAL_OK)
  229.     {
  230.     }
  231.     if (HAL_TIM_PWM_ConfigChannel(&htim5, &sConfigOC, TIM_CHANNEL_2) != HAL_OK)
  232.     {
  233.     }
  234.     if (HAL_TIM_PWM_ConfigChannel(&htim5, &sConfigOC, TIM_CHANNEL_3) != HAL_OK)
  235.     {
  236.     }
  237.     HAL_TIM_MspPostInit(&htim5);
  238.     HAL_TIM_PWM_Start(&htim5, TIM_CHANNEL_1);
  239.     HAL_TIM_PWM_Start(&htim5, TIM_CHANNEL_2);
  240.     HAL_TIM_PWM_Start(&htim5, TIM_CHANNEL_3);
  241. }
  242. /**
  243. * @brief  : TIM6 Initialization Function : 1ms
  244. * @param  :
  245. * @returns:
  246. * @details: For System Run Tick
  247. */
  248. static void MX_TIM6_Init(void)
  249. {
  250.     TIM_MasterConfigTypeDef sMasterConfig = {0};
  251.     htim6.Instance               = TIM6;
  252.     htim6.Init.Prescaler         = 72-1;
  253.     htim6.Init.CounterMode       = TIM_COUNTERMODE_UP;
  254.     htim6.Init.Period            = 1000-1;
  255.     htim6.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_ENABLE;
  256.     if (HAL_TIM_Base_Init(&htim6) != HAL_OK)
  257.     {
  258.     }
  259.     sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
  260.     sMasterConfig.MasterSlaveMode     = TIM_MASTERSLAVEMODE_DISABLE;
  261.     if (HAL_TIMEx_MasterConfigSynchronization(&htim6, &sMasterConfig) != HAL_OK)
  262.     {
  263.     }
  264.     if (HAL_TIM_Base_Start_IT(&htim6) != HAL_OK)
  265.     {
  266.     }
  267. }
  268. /**
  269. * @brief  : USART1 Initialization Function
  270. * @param  :
  271. * @returns:
  272. * @details:
  273. */
  274. static void MX_USART1_UART_Init(void)
  275. {
  276.     huart1.Instance          = USART1;
  277.     huart1.Init.BaudRate     = 115200;
  278.     huart1.Init.WordLength   = UART_WORDLENGTH_8B;
  279.     huart1.Init.StopBits     = UART_STOPBITS_1;
  280.     huart1.Init.Parity       = UART_PARITY_NONE;
  281.     huart1.Init.Mode         = UART_MODE_TX_RX;
  282.     huart1.Init.HwFlowCtl    = UART_HWCONTROL_NONE;
  283.     huart1.Init.OverSampling = UART_OVERSAMPLING_16;
  284.     if (HAL_UART_Init(&huart1) != HAL_OK)
  285.     {
  286.     }
  287.     SET_BIT(huart1.Instance->CR1, USART_CR1_PEIE | USART_CR1_RXNEIE);
  288. }
  289. /**
  290. * @brief  : GPIO Initialization Function
  291. * @param  :
  292. * @returns:
  293. * @details:
  294. */
  295. static void MX_GPIO_Init(void)
  296. {
  297.     GPIO_InitTypeDef GPIO_InitStruct = {0};
  298.     /* GPIO Ports Clock Enable */
  299.     __HAL_RCC_GPIOC_CLK_ENABLE();
  300.     __HAL_RCC_GPIOD_CLK_ENABLE();
  301.     __HAL_RCC_GPIOA_CLK_ENABLE();
  302.     __HAL_RCC_GPIOB_CLK_ENABLE();
  303.     /*Configure GPIO pins : KEY1_Pin KEY0_Pin */
  304.     GPIO_InitStruct.Pin  = KEY1_Pin | KEY0_Pin;
  305.     GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
  306.     GPIO_InitStruct.Pull = GPIO_NOPULL;
  307.     HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
  308.     /*Configure GPIO pins : KEY2_Pin KEY3_Pin G_INT_Pin */
  309.     GPIO_InitStruct.Pin  = KEY2_Pin | KEY3_Pin | G_INT_Pin;
  310.     GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
  311.     GPIO_InitStruct.Pull = GPIO_NOPULL;
  312.     HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
  313.     /*Configure GPIO pin Output Level */
  314.     HAL_GPIO_WritePin(GPIOA, GPIO_PIN_3, GPIO_PIN_SET);
  315.     /*Configure LED GPIO pin : PA3 */
  316.     GPIO_InitStruct.Pin   = LED_Pin;
  317.     GPIO_InitStruct.Mode  = GPIO_MODE_OUTPUT_PP;
  318.     GPIO_InitStruct.Pull  = GPIO_NOPULL;
  319.     GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
  320.     HAL_GPIO_Init(LED_GPIO_Port, &GPIO_InitStruct);
  321. }
  322. /**
  323. * @brief  :
  324. * @param  :
  325. * @returns:
  326. * @details:
  327. */
  328. void uFUN_Init(void)
  329. {
  330.     uint8_t flag = 0;
  331.     /* Initialize all configured peripherals */
  332.     MX_GPIO_Init();
  333.     MX_DMA_Init();
  334.     MX_ADC1_Init();
  335.     if(flag) MX_I2C1_Init();
  336.     MX_TIM1_Init();
  337.     MX_TIM4_Init();
  338.     MX_TIM5_Init();
  339.     MX_TIM6_Init();
  340.     MX_USART1_UART_Init();
  341. }
  342. /**
  343. * @brief  :
  344. * @param  :
  345. * @returns:
  346. * @details:
  347. */
  348. void uFUN_TestBEEP(void)
  349. {
  350.     HAL_TIM_PWM_Start(&htim1, TIM_CHANNEL_1);
  351.     HAL_Delay(250);
  352.     HAL_TIM_PWM_Stop(&htim1, TIM_CHANNEL_1);
  353. }
  354. /**
  355. * @brief  :
  356. * @param  :
  357. * @returns:
  358. * @details:
  359. */
  360. void uFUN_TestPWMn(void)
  361. {
  362.     HAL_TIM_PWM_Start(&htim4, TIM_CHANNEL_3);
  363.     HAL_TIM_PWM_Start(&htim4, TIM_CHANNEL_4);
  364.     HAL_Delay(1000);
  365.     HAL_TIM_PWM_Stop(&htim4, TIM_CHANNEL_3);
  366.     HAL_TIM_PWM_Stop(&htim4, TIM_CHANNEL_4);
  367. }
  368. /**
  369. * @brief  :
  370. * @param  :
  371. * @returns:
  372. * @details:
  373. */
  374. void uFUN_TestRGB(void)
  375. {
  376.     uFUN_RGB(255, 0, 0); HAL_Delay(500);
  377.     uFUN_RGB(0, 255, 0); HAL_Delay(500);
  378.     uFUN_RGB(0, 0, 255); HAL_Delay(500);
  379.     uFUN_RGB(16, 16, 16);
  380. }
  381. /**
  382. * @brief  :
  383. * @param  :
  384. * @returns:
  385. * @details:
  386. */
  387. void uFUN_TestLED(void)
  388. {
  389.     uint8_t i = 0;
  390.     for(i = 0; i < 10; i++)
  391.     {
  392.         if((i % 2) == 0)
  393.         {
  394.             HAL_GPIO_WritePin(LED_GPIO_Port, LED_Pin, GPIO_PIN_RESET);  //---ON
  395.         }
  396.         else
  397.         {
  398.             HAL_GPIO_WritePin(LED_GPIO_Port, LED_Pin, GPIO_PIN_SET);    //---OFF
  399.         }
  400.         HAL_Delay(100);
  401.     }
  402. }
  403. /**
  404. * @brief  :
  405. * @param  :
  406. * @returns:
  407. * @details:
  408. */
  409. void uFUN_TestADC(void)
  410. {
  411.     uint32_t i = 0, AD_SIG1 = 0, AD_SIG2 = 0;
  412.     for(i = 0; i < 100;)
  413.     {
  414.         AD_SIG1 += ADC_Value[i++];
  415.         AD_SIG2 += ADC_Value[i++];
  416.     }
  417.     AD_SIG1 /= 50;
  418.     AD_SIG2 /= 50;
  419.     printf("%d, %d\r\n", AD_SIG1, AD_SIG2);
  420. }
  421. /**
  422. * @brief  :
  423. * @param  :
  424. * @returns:
  425. * @details:
  426. */
  427. void uFUN_TestI2C(void)
  428. {
  429. }
  430. /**
  431. * @brief  :
  432. * @param  :
  433. * @returns:
  434. * @details:
  435. */
  436. void uFUN_Test(void)
  437. {
  438.     printf("\r\n----------uFun Hardware Test----------\r\n");
  439.     printf("Test BEEP\r\n");
  440.     uFUN_TestBEEP();
  441.     printf("Test PWM\r\n");
  442.     uFUN_TestPWMn();
  443.     printf("Test LED\r\n");
  444.     uFUN_TestLED();
  445.     printf("Test RGB\r\n");
  446.     uFUN_TestRGB();
  447.     printf("Test ADC :: ");
  448.     uFUN_TestADC();
  449.     printf("Test I2C\r\n");
  450.     uFUN_TestI2C();
  451.     printf("--------------------------------------\r\n\r\n");
  452. }
  453. /************************ (C) COPYRIGHT ************************END OF FILE****/

5.运行结果

20.png 2.png

6.工程代码

CubeMX.rar (2.64 KB, 下载次数: 0)