Mercurial > pub > halpp
comparison l476rg/Src/tim.c @ 0:32a3b1785697
a rough draft of Hardware Abstraction Layer for C++
STM32L476RG drivers
| author | cin |
|---|---|
| date | Thu, 12 Jan 2017 02:45:43 +0300 |
| parents | |
| children |
comparison
equal
deleted
inserted
replaced
| -1:000000000000 | 0:32a3b1785697 |
|---|---|
| 1 /** | |
| 2 ****************************************************************************** | |
| 3 * File Name : TIM.c | |
| 4 * Description : This file provides code for the configuration | |
| 5 * of the TIM instances. | |
| 6 ****************************************************************************** | |
| 7 * | |
| 8 * COPYRIGHT(c) 2017 STMicroelectronics | |
| 9 * | |
| 10 * Redistribution and use in source and binary forms, with or without modification, | |
| 11 * are permitted provided that the following conditions are met: | |
| 12 * 1. Redistributions of source code must retain the above copyright notice, | |
| 13 * this list of conditions and the following disclaimer. | |
| 14 * 2. Redistributions in binary form must reproduce the above copyright notice, | |
| 15 * this list of conditions and the following disclaimer in the documentation | |
| 16 * and/or other materials provided with the distribution. | |
| 17 * 3. Neither the name of STMicroelectronics nor the names of its contributors | |
| 18 * may be used to endorse or promote products derived from this software | |
| 19 * without specific prior written permission. | |
| 20 * | |
| 21 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | |
| 22 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | |
| 23 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | |
| 24 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | |
| 25 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | |
| 26 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | |
| 27 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER | |
| 28 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | |
| 29 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | |
| 30 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | |
| 31 * | |
| 32 ****************************************************************************** | |
| 33 */ | |
| 34 | |
| 35 /* Includes ------------------------------------------------------------------*/ | |
| 36 #include "tim.h" | |
| 37 | |
| 38 /* USER CODE BEGIN 0 */ | |
| 39 | |
| 40 /* USER CODE END 0 */ | |
| 41 | |
| 42 TIM_HandleTypeDef htim2; | |
| 43 | |
| 44 /* TIM2 init function */ | |
| 45 void MX_TIM2_Init(void) | |
| 46 { | |
| 47 TIM_MasterConfigTypeDef sMasterConfig; | |
| 48 TIM_OC_InitTypeDef sConfigOC; | |
| 49 | |
| 50 htim2.Instance = TIM2; | |
| 51 htim2.Init.Prescaler = 799; | |
| 52 htim2.Init.CounterMode = TIM_COUNTERMODE_UP; | |
| 53 htim2.Init.Period = 99; | |
| 54 htim2.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1; | |
| 55 if (HAL_TIM_PWM_Init(&htim2) != HAL_OK) | |
| 56 { | |
| 57 Error_Handler(); | |
| 58 } | |
| 59 | |
| 60 sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET; | |
| 61 sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE; | |
| 62 if (HAL_TIMEx_MasterConfigSynchronization(&htim2, &sMasterConfig) != HAL_OK) | |
| 63 { | |
| 64 Error_Handler(); | |
| 65 } | |
| 66 | |
| 67 sConfigOC.OCMode = TIM_OCMODE_PWM1; | |
| 68 sConfigOC.Pulse = 29; | |
| 69 sConfigOC.OCPolarity = TIM_OCPOLARITY_HIGH; | |
| 70 sConfigOC.OCFastMode = TIM_OCFAST_DISABLE; | |
| 71 if (HAL_TIM_PWM_ConfigChannel(&htim2, &sConfigOC, TIM_CHANNEL_1) != HAL_OK) | |
| 72 { | |
| 73 Error_Handler(); | |
| 74 } | |
| 75 | |
| 76 HAL_TIM_MspPostInit(&htim2); | |
| 77 | |
| 78 } | |
| 79 | |
| 80 void HAL_TIM_PWM_MspInit(TIM_HandleTypeDef* tim_pwmHandle) | |
| 81 { | |
| 82 | |
| 83 if(tim_pwmHandle->Instance==TIM2) | |
| 84 { | |
| 85 /* USER CODE BEGIN TIM2_MspInit 0 */ | |
| 86 | |
| 87 /* USER CODE END TIM2_MspInit 0 */ | |
| 88 /* Peripheral clock enable */ | |
| 89 __HAL_RCC_TIM2_CLK_ENABLE(); | |
| 90 /* USER CODE BEGIN TIM2_MspInit 1 */ | |
| 91 | |
| 92 /* USER CODE END TIM2_MspInit 1 */ | |
| 93 } | |
| 94 } | |
| 95 void HAL_TIM_MspPostInit(TIM_HandleTypeDef* timHandle) | |
| 96 { | |
| 97 | |
| 98 GPIO_InitTypeDef GPIO_InitStruct; | |
| 99 if(timHandle->Instance==TIM2) | |
| 100 { | |
| 101 /* USER CODE BEGIN TIM2_MspPostInit 0 */ | |
| 102 | |
| 103 /* USER CODE END TIM2_MspPostInit 0 */ | |
| 104 | |
| 105 /**TIM2 GPIO Configuration | |
| 106 PA5 ------> TIM2_CH1 | |
| 107 */ | |
| 108 GPIO_InitStruct.Pin = GPIO_PIN_5; | |
| 109 GPIO_InitStruct.Mode = GPIO_MODE_AF_PP; | |
| 110 GPIO_InitStruct.Pull = GPIO_NOPULL; | |
| 111 GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW; | |
| 112 GPIO_InitStruct.Alternate = GPIO_AF1_TIM2; | |
| 113 HAL_GPIO_Init(GPIOA, &GPIO_InitStruct); | |
| 114 | |
| 115 /* USER CODE BEGIN TIM2_MspPostInit 1 */ | |
| 116 | |
| 117 /* USER CODE END TIM2_MspPostInit 1 */ | |
| 118 } | |
| 119 | |
| 120 } | |
| 121 | |
| 122 void HAL_TIM_PWM_MspDeInit(TIM_HandleTypeDef* tim_pwmHandle) | |
| 123 { | |
| 124 | |
| 125 if(tim_pwmHandle->Instance==TIM2) | |
| 126 { | |
| 127 /* USER CODE BEGIN TIM2_MspDeInit 0 */ | |
| 128 | |
| 129 /* USER CODE END TIM2_MspDeInit 0 */ | |
| 130 /* Peripheral clock disable */ | |
| 131 __HAL_RCC_TIM2_CLK_DISABLE(); | |
| 132 } | |
| 133 /* USER CODE BEGIN TIM2_MspDeInit 1 */ | |
| 134 | |
| 135 /* USER CODE END TIM2_MspDeInit 1 */ | |
| 136 } | |
| 137 | |
| 138 /* USER CODE BEGIN 1 */ | |
| 139 | |
| 140 /* USER CODE END 1 */ | |
| 141 | |
| 142 /** | |
| 143 * @} | |
| 144 */ | |
| 145 | |
| 146 /** | |
| 147 * @} | |
| 148 */ | |
| 149 | |
| 150 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ |
