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****/ |