stm32l4xx_hal_tsc.h 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726
  1. /**
  2. ******************************************************************************
  3. * @file stm32l4xx_hal_tsc.h
  4. * @author MCD Application Team
  5. * @version V1.7.2
  6. * @date 16-June-2017
  7. * @brief Header file of TSC HAL module.
  8. ******************************************************************************
  9. * @attention
  10. *
  11. * <h2><center>&copy; COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
  12. *
  13. * Redistribution and use in source and binary forms, with or without modification,
  14. * are permitted provided that the following conditions are met:
  15. * 1. Redistributions of source code must retain the above copyright notice,
  16. * this list of conditions and the following disclaimer.
  17. * 2. Redistributions in binary form must reproduce the above copyright notice,
  18. * this list of conditions and the following disclaimer in the documentation
  19. * and/or other materials provided with the distribution.
  20. * 3. Neither the name of STMicroelectronics nor the names of its contributors
  21. * may be used to endorse or promote products derived from this software
  22. * without specific prior written permission.
  23. *
  24. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
  25. * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  26. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  27. * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
  28. * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  29. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
  30. * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
  31. * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  32. * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  33. * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  34. *
  35. ******************************************************************************
  36. */
  37. /* Define to prevent recursive inclusion -------------------------------------*/
  38. #ifndef __STM32L4xx_HAL_TSC_H
  39. #define __STM32L4xx_HAL_TSC_H
  40. #ifdef __cplusplus
  41. extern "C" {
  42. #endif
  43. /* Includes ------------------------------------------------------------------*/
  44. #include "stm32l4xx_hal_def.h"
  45. /** @addtogroup STM32L4xx_HAL_Driver
  46. * @{
  47. */
  48. /** @addtogroup TSC
  49. * @{
  50. */
  51. /* Exported types ------------------------------------------------------------*/
  52. /** @defgroup TSC_Exported_Types TSC Exported Types
  53. * @{
  54. */
  55. /**
  56. * @brief TSC state structure definition
  57. */
  58. typedef enum
  59. {
  60. HAL_TSC_STATE_RESET = 0x00, /*!< TSC registers have their reset value */
  61. HAL_TSC_STATE_READY = 0x01, /*!< TSC registers are initialized or acquisition is completed with success */
  62. HAL_TSC_STATE_BUSY = 0x02, /*!< TSC initialization or acquisition is on-going */
  63. HAL_TSC_STATE_ERROR = 0x03 /*!< Acquisition is completed with max count error */
  64. } HAL_TSC_StateTypeDef;
  65. /**
  66. * @brief TSC group status structure definition
  67. */
  68. typedef enum
  69. {
  70. TSC_GROUP_ONGOING = 0x00, /*!< Acquisition on group is on-going or not started */
  71. TSC_GROUP_COMPLETED = 0x01 /*!< Acquisition on group is completed with success (no max count error) */
  72. } TSC_GroupStatusTypeDef;
  73. /**
  74. * @brief TSC init structure definition
  75. */
  76. typedef struct
  77. {
  78. uint32_t CTPulseHighLength; /*!< Charge-transfer high pulse length
  79. This parameter can be a value of @ref TSC_CTPulseHL_Config */
  80. uint32_t CTPulseLowLength; /*!< Charge-transfer low pulse length
  81. This parameter can be a value of @ref TSC_CTPulseLL_Config */
  82. uint32_t SpreadSpectrum; /*!< Spread spectrum activation
  83. This parameter can be a value of @ref TSC_CTPulseLL_Config */
  84. uint32_t SpreadSpectrumDeviation; /*!< Spread spectrum deviation
  85. This parameter must be a number between Min_Data = 0 and Max_Data = 127 */
  86. uint32_t SpreadSpectrumPrescaler; /*!< Spread spectrum prescaler
  87. This parameter can be a value of @ref TSC_SpreadSpec_Prescaler */
  88. uint32_t PulseGeneratorPrescaler; /*!< Pulse generator prescaler
  89. This parameter can be a value of @ref TSC_PulseGenerator_Prescaler */
  90. uint32_t MaxCountValue; /*!< Max count value
  91. This parameter can be a value of @ref TSC_MaxCount_Value */
  92. uint32_t IODefaultMode; /*!< IO default mode
  93. This parameter can be a value of @ref TSC_IO_Default_Mode */
  94. uint32_t SynchroPinPolarity; /*!< Synchro pin polarity
  95. This parameter can be a value of @ref TSC_Synchro_Pin_Polarity */
  96. uint32_t AcquisitionMode; /*!< Acquisition mode
  97. This parameter can be a value of @ref TSC_Acquisition_Mode */
  98. uint32_t MaxCountInterrupt; /*!< Max count interrupt activation
  99. This parameter can be set to ENABLE or DISABLE. */
  100. uint32_t ChannelIOs; /*!< Channel IOs mask */
  101. uint32_t ShieldIOs; /*!< Shield IOs mask */
  102. uint32_t SamplingIOs; /*!< Sampling IOs mask */
  103. } TSC_InitTypeDef;
  104. /**
  105. * @brief TSC IOs configuration structure definition
  106. */
  107. typedef struct
  108. {
  109. uint32_t ChannelIOs; /*!< Channel IOs mask */
  110. uint32_t ShieldIOs; /*!< Shield IOs mask */
  111. uint32_t SamplingIOs; /*!< Sampling IOs mask */
  112. } TSC_IOConfigTypeDef;
  113. /**
  114. * @brief TSC handle Structure definition
  115. */
  116. typedef struct
  117. {
  118. TSC_TypeDef *Instance; /*!< Register base address */
  119. TSC_InitTypeDef Init; /*!< Initialization parameters */
  120. __IO HAL_TSC_StateTypeDef State; /*!< Peripheral state */
  121. HAL_LockTypeDef Lock; /*!< Lock feature */
  122. } TSC_HandleTypeDef;
  123. /**
  124. * @}
  125. */
  126. /* Exported constants --------------------------------------------------------*/
  127. /** @defgroup TSC_Exported_Constants TSC Exported Constants
  128. * @{
  129. */
  130. /** @defgroup TSC_CTPulseHL_Config CTPulse High Length
  131. * @{
  132. */
  133. #define TSC_CTPH_1CYCLE ((uint32_t)((uint32_t) 0 << 28))
  134. #define TSC_CTPH_2CYCLES ((uint32_t)((uint32_t) 1 << 28))
  135. #define TSC_CTPH_3CYCLES ((uint32_t)((uint32_t) 2 << 28))
  136. #define TSC_CTPH_4CYCLES ((uint32_t)((uint32_t) 3 << 28))
  137. #define TSC_CTPH_5CYCLES ((uint32_t)((uint32_t) 4 << 28))
  138. #define TSC_CTPH_6CYCLES ((uint32_t)((uint32_t) 5 << 28))
  139. #define TSC_CTPH_7CYCLES ((uint32_t)((uint32_t) 6 << 28))
  140. #define TSC_CTPH_8CYCLES ((uint32_t)((uint32_t) 7 << 28))
  141. #define TSC_CTPH_9CYCLES ((uint32_t)((uint32_t) 8 << 28))
  142. #define TSC_CTPH_10CYCLES ((uint32_t)((uint32_t) 9 << 28))
  143. #define TSC_CTPH_11CYCLES ((uint32_t)((uint32_t)10 << 28))
  144. #define TSC_CTPH_12CYCLES ((uint32_t)((uint32_t)11 << 28))
  145. #define TSC_CTPH_13CYCLES ((uint32_t)((uint32_t)12 << 28))
  146. #define TSC_CTPH_14CYCLES ((uint32_t)((uint32_t)13 << 28))
  147. #define TSC_CTPH_15CYCLES ((uint32_t)((uint32_t)14 << 28))
  148. #define TSC_CTPH_16CYCLES ((uint32_t)((uint32_t)15 << 28))
  149. /**
  150. * @}
  151. */
  152. /** @defgroup TSC_CTPulseLL_Config CTPulse Low Length
  153. * @{
  154. */
  155. #define TSC_CTPL_1CYCLE ((uint32_t)((uint32_t) 0 << 24))
  156. #define TSC_CTPL_2CYCLES ((uint32_t)((uint32_t) 1 << 24))
  157. #define TSC_CTPL_3CYCLES ((uint32_t)((uint32_t) 2 << 24))
  158. #define TSC_CTPL_4CYCLES ((uint32_t)((uint32_t) 3 << 24))
  159. #define TSC_CTPL_5CYCLES ((uint32_t)((uint32_t) 4 << 24))
  160. #define TSC_CTPL_6CYCLES ((uint32_t)((uint32_t) 5 << 24))
  161. #define TSC_CTPL_7CYCLES ((uint32_t)((uint32_t) 6 << 24))
  162. #define TSC_CTPL_8CYCLES ((uint32_t)((uint32_t) 7 << 24))
  163. #define TSC_CTPL_9CYCLES ((uint32_t)((uint32_t) 8 << 24))
  164. #define TSC_CTPL_10CYCLES ((uint32_t)((uint32_t) 9 << 24))
  165. #define TSC_CTPL_11CYCLES ((uint32_t)((uint32_t)10 << 24))
  166. #define TSC_CTPL_12CYCLES ((uint32_t)((uint32_t)11 << 24))
  167. #define TSC_CTPL_13CYCLES ((uint32_t)((uint32_t)12 << 24))
  168. #define TSC_CTPL_14CYCLES ((uint32_t)((uint32_t)13 << 24))
  169. #define TSC_CTPL_15CYCLES ((uint32_t)((uint32_t)14 << 24))
  170. #define TSC_CTPL_16CYCLES ((uint32_t)((uint32_t)15 << 24))
  171. /**
  172. * @}
  173. */
  174. /** @defgroup TSC_SpreadSpec_Prescaler Spread Spectrum Prescaler
  175. * @{
  176. */
  177. #define TSC_SS_PRESC_DIV1 ((uint32_t)0)
  178. #define TSC_SS_PRESC_DIV2 (TSC_CR_SSPSC)
  179. /**
  180. * @}
  181. */
  182. /** @defgroup TSC_PulseGenerator_Prescaler Pulse Generator Prescaler
  183. * @{
  184. */
  185. #define TSC_PG_PRESC_DIV1 ((uint32_t)(0 << 12))
  186. #define TSC_PG_PRESC_DIV2 ((uint32_t)(1 << 12))
  187. #define TSC_PG_PRESC_DIV4 ((uint32_t)(2 << 12))
  188. #define TSC_PG_PRESC_DIV8 ((uint32_t)(3 << 12))
  189. #define TSC_PG_PRESC_DIV16 ((uint32_t)(4 << 12))
  190. #define TSC_PG_PRESC_DIV32 ((uint32_t)(5 << 12))
  191. #define TSC_PG_PRESC_DIV64 ((uint32_t)(6 << 12))
  192. #define TSC_PG_PRESC_DIV128 ((uint32_t)(7 << 12))
  193. /**
  194. * @}
  195. */
  196. /** @defgroup TSC_MaxCount_Value Max Count Value
  197. * @{
  198. */
  199. #define TSC_MCV_255 ((uint32_t)(0 << 5))
  200. #define TSC_MCV_511 ((uint32_t)(1 << 5))
  201. #define TSC_MCV_1023 ((uint32_t)(2 << 5))
  202. #define TSC_MCV_2047 ((uint32_t)(3 << 5))
  203. #define TSC_MCV_4095 ((uint32_t)(4 << 5))
  204. #define TSC_MCV_8191 ((uint32_t)(5 << 5))
  205. #define TSC_MCV_16383 ((uint32_t)(6 << 5))
  206. /**
  207. * @}
  208. */
  209. /** @defgroup TSC_IO_Default_Mode IO Default Mode
  210. * @{
  211. */
  212. #define TSC_IODEF_OUT_PP_LOW ((uint32_t)0)
  213. #define TSC_IODEF_IN_FLOAT (TSC_CR_IODEF)
  214. /**
  215. * @}
  216. */
  217. /** @defgroup TSC_Synchro_Pin_Polarity Synchro Pin Polarity
  218. * @{
  219. */
  220. #define TSC_SYNC_POLARITY_FALLING ((uint32_t)0)
  221. #define TSC_SYNC_POLARITY_RISING (TSC_CR_SYNCPOL)
  222. /**
  223. * @}
  224. */
  225. /** @defgroup TSC_Acquisition_Mode Acquisition Mode
  226. * @{
  227. */
  228. #define TSC_ACQ_MODE_NORMAL ((uint32_t)0)
  229. #define TSC_ACQ_MODE_SYNCHRO (TSC_CR_AM)
  230. /**
  231. * @}
  232. */
  233. /** @defgroup TSC_IO_Mode IO Mode
  234. * @{
  235. */
  236. #define TSC_IOMODE_UNUSED ((uint32_t)0)
  237. #define TSC_IOMODE_CHANNEL ((uint32_t)1)
  238. #define TSC_IOMODE_SHIELD ((uint32_t)2)
  239. #define TSC_IOMODE_SAMPLING ((uint32_t)3)
  240. /**
  241. * @}
  242. */
  243. /** @defgroup TSC_interrupts_definition Interrupts definition
  244. * @{
  245. */
  246. #define TSC_IT_EOA ((uint32_t)TSC_IER_EOAIE)
  247. #define TSC_IT_MCE ((uint32_t)TSC_IER_MCEIE)
  248. /**
  249. * @}
  250. */
  251. /** @defgroup TSC_flags_definition Flags definition
  252. * @{
  253. */
  254. #define TSC_FLAG_EOA ((uint32_t)TSC_ISR_EOAF)
  255. #define TSC_FLAG_MCE ((uint32_t)TSC_ISR_MCEF)
  256. /**
  257. * @}
  258. */
  259. /** @defgroup TSC_Group_definition Group definition
  260. * @{
  261. */
  262. #define TSC_NB_OF_GROUPS (8)
  263. #define TSC_GROUP1 ((uint32_t)0x00000001)
  264. #define TSC_GROUP2 ((uint32_t)0x00000002)
  265. #define TSC_GROUP3 ((uint32_t)0x00000004)
  266. #define TSC_GROUP4 ((uint32_t)0x00000008)
  267. #define TSC_GROUP5 ((uint32_t)0x00000010)
  268. #define TSC_GROUP6 ((uint32_t)0x00000020)
  269. #define TSC_GROUP7 ((uint32_t)0x00000040)
  270. #define TSC_GROUP8 ((uint32_t)0x00000080)
  271. #define TSC_ALL_GROUPS ((uint32_t)0x000000FF)
  272. #define TSC_GROUP1_IDX ((uint32_t)0)
  273. #define TSC_GROUP2_IDX ((uint32_t)1)
  274. #define TSC_GROUP3_IDX ((uint32_t)2)
  275. #define TSC_GROUP4_IDX ((uint32_t)3)
  276. #define TSC_GROUP5_IDX ((uint32_t)4)
  277. #define TSC_GROUP6_IDX ((uint32_t)5)
  278. #define TSC_GROUP7_IDX ((uint32_t)6)
  279. #define TSC_GROUP8_IDX ((uint32_t)7)
  280. #define TSC_GROUP1_IO1 ((uint32_t)0x00000001)
  281. #define TSC_GROUP1_IO2 ((uint32_t)0x00000002)
  282. #define TSC_GROUP1_IO3 ((uint32_t)0x00000004)
  283. #define TSC_GROUP1_IO4 ((uint32_t)0x00000008)
  284. #define TSC_GROUP1_ALL_IOS ((uint32_t)0x0000000F)
  285. #define TSC_GROUP2_IO1 ((uint32_t)0x00000010)
  286. #define TSC_GROUP2_IO2 ((uint32_t)0x00000020)
  287. #define TSC_GROUP2_IO3 ((uint32_t)0x00000040)
  288. #define TSC_GROUP2_IO4 ((uint32_t)0x00000080)
  289. #define TSC_GROUP2_ALL_IOS ((uint32_t)0x000000F0)
  290. #define TSC_GROUP3_IO1 ((uint32_t)0x00000100)
  291. #define TSC_GROUP3_IO2 ((uint32_t)0x00000200)
  292. #define TSC_GROUP3_IO3 ((uint32_t)0x00000400)
  293. #define TSC_GROUP3_IO4 ((uint32_t)0x00000800)
  294. #define TSC_GROUP3_ALL_IOS ((uint32_t)0x00000F00)
  295. #define TSC_GROUP4_IO1 ((uint32_t)0x00001000)
  296. #define TSC_GROUP4_IO2 ((uint32_t)0x00002000)
  297. #define TSC_GROUP4_IO3 ((uint32_t)0x00004000)
  298. #define TSC_GROUP4_IO4 ((uint32_t)0x00008000)
  299. #define TSC_GROUP4_ALL_IOS ((uint32_t)0x0000F000)
  300. #define TSC_GROUP5_IO1 ((uint32_t)0x00010000)
  301. #define TSC_GROUP5_IO2 ((uint32_t)0x00020000)
  302. #define TSC_GROUP5_IO3 ((uint32_t)0x00040000)
  303. #define TSC_GROUP5_IO4 ((uint32_t)0x00080000)
  304. #define TSC_GROUP5_ALL_IOS ((uint32_t)0x000F0000)
  305. #define TSC_GROUP6_IO1 ((uint32_t)0x00100000)
  306. #define TSC_GROUP6_IO2 ((uint32_t)0x00200000)
  307. #define TSC_GROUP6_IO3 ((uint32_t)0x00400000)
  308. #define TSC_GROUP6_IO4 ((uint32_t)0x00800000)
  309. #define TSC_GROUP6_ALL_IOS ((uint32_t)0x00F00000)
  310. #define TSC_GROUP7_IO1 ((uint32_t)0x01000000)
  311. #define TSC_GROUP7_IO2 ((uint32_t)0x02000000)
  312. #define TSC_GROUP7_IO3 ((uint32_t)0x04000000)
  313. #define TSC_GROUP7_IO4 ((uint32_t)0x08000000)
  314. #define TSC_GROUP7_ALL_IOS ((uint32_t)0x0F000000)
  315. #define TSC_GROUP8_IO1 ((uint32_t)0x10000000)
  316. #define TSC_GROUP8_IO2 ((uint32_t)0x20000000)
  317. #define TSC_GROUP8_IO3 ((uint32_t)0x40000000)
  318. #define TSC_GROUP8_IO4 ((uint32_t)0x80000000)
  319. #define TSC_GROUP8_ALL_IOS ((uint32_t)0xF0000000)
  320. #define TSC_ALL_GROUPS_ALL_IOS ((uint32_t)0xFFFFFFFF)
  321. /**
  322. * @}
  323. */
  324. /**
  325. * @}
  326. */
  327. /* Exported macros -----------------------------------------------------------*/
  328. /** @defgroup TSC_Exported_Macros TSC Exported Macros
  329. * @{
  330. */
  331. /** @brief Reset TSC handle state.
  332. * @param __HANDLE__: TSC handle
  333. * @retval None
  334. */
  335. #define __HAL_TSC_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = HAL_TSC_STATE_RESET)
  336. /**
  337. * @brief Enable the TSC peripheral.
  338. * @param __HANDLE__: TSC handle
  339. * @retval None
  340. */
  341. #define __HAL_TSC_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->CR |= TSC_CR_TSCE)
  342. /**
  343. * @brief Disable the TSC peripheral.
  344. * @param __HANDLE__: TSC handle
  345. * @retval None
  346. */
  347. #define __HAL_TSC_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->CR &= (uint32_t)(~TSC_CR_TSCE))
  348. /**
  349. * @brief Start acquisition.
  350. * @param __HANDLE__: TSC handle
  351. * @retval None
  352. */
  353. #define __HAL_TSC_START_ACQ(__HANDLE__) ((__HANDLE__)->Instance->CR |= TSC_CR_START)
  354. /**
  355. * @brief Stop acquisition.
  356. * @param __HANDLE__: TSC handle
  357. * @retval None
  358. */
  359. #define __HAL_TSC_STOP_ACQ(__HANDLE__) ((__HANDLE__)->Instance->CR &= (uint32_t)(~TSC_CR_START))
  360. /**
  361. * @brief Set IO default mode to output push-pull low.
  362. * @param __HANDLE__: TSC handle
  363. * @retval None
  364. */
  365. #define __HAL_TSC_SET_IODEF_OUTPPLOW(__HANDLE__) ((__HANDLE__)->Instance->CR &= (uint32_t)(~TSC_CR_IODEF))
  366. /**
  367. * @brief Set IO default mode to input floating.
  368. * @param __HANDLE__: TSC handle
  369. * @retval None
  370. */
  371. #define __HAL_TSC_SET_IODEF_INFLOAT(__HANDLE__) ((__HANDLE__)->Instance->CR |= TSC_CR_IODEF)
  372. /**
  373. * @brief Set synchronization polarity to falling edge.
  374. * @param __HANDLE__: TSC handle
  375. * @retval None
  376. */
  377. #define __HAL_TSC_SET_SYNC_POL_FALL(__HANDLE__) ((__HANDLE__)->Instance->CR &= (uint32_t)(~TSC_CR_SYNCPOL))
  378. /**
  379. * @brief Set synchronization polarity to rising edge and high level.
  380. * @param __HANDLE__: TSC handle
  381. * @retval None
  382. */
  383. #define __HAL_TSC_SET_SYNC_POL_RISE_HIGH(__HANDLE__) ((__HANDLE__)->Instance->CR |= TSC_CR_SYNCPOL)
  384. /**
  385. * @brief Enable TSC interrupt.
  386. * @param __HANDLE__: TSC handle
  387. * @param __INTERRUPT__: TSC interrupt
  388. * @retval None
  389. */
  390. #define __HAL_TSC_ENABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->IER |= (__INTERRUPT__))
  391. /**
  392. * @brief Disable TSC interrupt.
  393. * @param __HANDLE__: TSC handle
  394. * @param __INTERRUPT__: TSC interrupt
  395. * @retval None
  396. */
  397. #define __HAL_TSC_DISABLE_IT(__HANDLE__, __INTERRUPT__) ((__HANDLE__)->Instance->IER &= (uint32_t)(~(__INTERRUPT__)))
  398. /** @brief Check whether the specified TSC interrupt source is enabled or not.
  399. * @param __HANDLE__: TSC Handle
  400. * @param __INTERRUPT__: TSC interrupt
  401. * @retval SET or RESET
  402. */
  403. #define __HAL_TSC_GET_IT_SOURCE(__HANDLE__, __INTERRUPT__) ((((__HANDLE__)->Instance->IER & (__INTERRUPT__)) == (__INTERRUPT__)) ? SET : RESET)
  404. /**
  405. * @brief Check whether the specified TSC flag is set or not.
  406. * @param __HANDLE__: TSC handle
  407. * @param __FLAG__: TSC flag
  408. * @retval SET or RESET
  409. */
  410. #define __HAL_TSC_GET_FLAG(__HANDLE__, __FLAG__) ((((__HANDLE__)->Instance->ISR & (__FLAG__)) == (__FLAG__)) ? SET : RESET)
  411. /**
  412. * @brief Clear the TSC's pending flag.
  413. * @param __HANDLE__: TSC handle
  414. * @param __FLAG__: TSC flag
  415. * @retval None
  416. */
  417. #define __HAL_TSC_CLEAR_FLAG(__HANDLE__, __FLAG__) ((__HANDLE__)->Instance->ICR = (__FLAG__))
  418. /**
  419. * @brief Enable schmitt trigger hysteresis on a group of IOs.
  420. * @param __HANDLE__: TSC handle
  421. * @param __GX_IOY_MASK__: IOs mask
  422. * @retval None
  423. */
  424. #define __HAL_TSC_ENABLE_HYSTERESIS(__HANDLE__, __GX_IOY_MASK__) ((__HANDLE__)->Instance->IOHCR |= (__GX_IOY_MASK__))
  425. /**
  426. * @brief Disable schmitt trigger hysteresis on a group of IOs.
  427. * @param __HANDLE__: TSC handle
  428. * @param __GX_IOY_MASK__: IOs mask
  429. * @retval None
  430. */
  431. #define __HAL_TSC_DISABLE_HYSTERESIS(__HANDLE__, __GX_IOY_MASK__) ((__HANDLE__)->Instance->IOHCR &= (uint32_t)(~(__GX_IOY_MASK__)))
  432. /**
  433. * @brief Open analog switch on a group of IOs.
  434. * @param __HANDLE__: TSC handle
  435. * @param __GX_IOY_MASK__: IOs mask
  436. * @retval None
  437. */
  438. #define __HAL_TSC_OPEN_ANALOG_SWITCH(__HANDLE__, __GX_IOY_MASK__) ((__HANDLE__)->Instance->IOASCR &= (uint32_t)(~(__GX_IOY_MASK__)))
  439. /**
  440. * @brief Close analog switch on a group of IOs.
  441. * @param __HANDLE__: TSC handle
  442. * @param __GX_IOY_MASK__: IOs mask
  443. * @retval None
  444. */
  445. #define __HAL_TSC_CLOSE_ANALOG_SWITCH(__HANDLE__, __GX_IOY_MASK__) ((__HANDLE__)->Instance->IOASCR |= (__GX_IOY_MASK__))
  446. /**
  447. * @brief Enable a group of IOs in channel mode.
  448. * @param __HANDLE__: TSC handle
  449. * @param __GX_IOY_MASK__: IOs mask
  450. * @retval None
  451. */
  452. #define __HAL_TSC_ENABLE_CHANNEL(__HANDLE__, __GX_IOY_MASK__) ((__HANDLE__)->Instance->IOCCR |= (__GX_IOY_MASK__))
  453. /**
  454. * @brief Disable a group of channel IOs.
  455. * @param __HANDLE__: TSC handle
  456. * @param __GX_IOY_MASK__: IOs mask
  457. * @retval None
  458. */
  459. #define __HAL_TSC_DISABLE_CHANNEL(__HANDLE__, __GX_IOY_MASK__) ((__HANDLE__)->Instance->IOCCR &= (uint32_t)(~(__GX_IOY_MASK__)))
  460. /**
  461. * @brief Enable a group of IOs in sampling mode.
  462. * @param __HANDLE__: TSC handle
  463. * @param __GX_IOY_MASK__: IOs mask
  464. * @retval None
  465. */
  466. #define __HAL_TSC_ENABLE_SAMPLING(__HANDLE__, __GX_IOY_MASK__) ((__HANDLE__)->Instance->IOSCR |= (__GX_IOY_MASK__))
  467. /**
  468. * @brief Disable a group of sampling IOs.
  469. * @param __HANDLE__: TSC handle
  470. * @param __GX_IOY_MASK__: IOs mask
  471. * @retval None
  472. */
  473. #define __HAL_TSC_DISABLE_SAMPLING(__HANDLE__, __GX_IOY_MASK__) ((__HANDLE__)->Instance->IOSCR &= (uint32_t)(~(__GX_IOY_MASK__)))
  474. /**
  475. * @brief Enable acquisition groups.
  476. * @param __HANDLE__: TSC handle
  477. * @param __GX_MASK__: Groups mask
  478. * @retval None
  479. */
  480. #define __HAL_TSC_ENABLE_GROUP(__HANDLE__, __GX_MASK__) ((__HANDLE__)->Instance->IOGCSR |= (__GX_MASK__))
  481. /**
  482. * @brief Disable acquisition groups.
  483. * @param __HANDLE__: TSC handle
  484. * @param __GX_MASK__: Groups mask
  485. * @retval None
  486. */
  487. #define __HAL_TSC_DISABLE_GROUP(__HANDLE__, __GX_MASK__) ((__HANDLE__)->Instance->IOGCSR &= (uint32_t)(~(__GX_MASK__)))
  488. /** @brief Gets acquisition group status.
  489. * @param __HANDLE__: TSC Handle
  490. * @param __GX_INDEX__: Group index
  491. * @retval SET or RESET
  492. */
  493. #define __HAL_TSC_GET_GROUP_STATUS(__HANDLE__, __GX_INDEX__) \
  494. ((((__HANDLE__)->Instance->IOGCSR & (uint32_t)((uint32_t)1 << ((__GX_INDEX__) + (uint32_t)16))) == (uint32_t)((uint32_t)1 << ((__GX_INDEX__) + (uint32_t)16))) ? TSC_GROUP_COMPLETED : TSC_GROUP_ONGOING)
  495. /**
  496. * @}
  497. */
  498. /* Private macros ------------------------------------------------------------*/
  499. /** @defgroup TSC_Private_Macros TSC Private Macros
  500. * @{
  501. */
  502. #define IS_TSC_CTPH(VAL) (((VAL) == TSC_CTPH_1CYCLE) || \
  503. ((VAL) == TSC_CTPH_2CYCLES) || \
  504. ((VAL) == TSC_CTPH_3CYCLES) || \
  505. ((VAL) == TSC_CTPH_4CYCLES) || \
  506. ((VAL) == TSC_CTPH_5CYCLES) || \
  507. ((VAL) == TSC_CTPH_6CYCLES) || \
  508. ((VAL) == TSC_CTPH_7CYCLES) || \
  509. ((VAL) == TSC_CTPH_8CYCLES) || \
  510. ((VAL) == TSC_CTPH_9CYCLES) || \
  511. ((VAL) == TSC_CTPH_10CYCLES) || \
  512. ((VAL) == TSC_CTPH_11CYCLES) || \
  513. ((VAL) == TSC_CTPH_12CYCLES) || \
  514. ((VAL) == TSC_CTPH_13CYCLES) || \
  515. ((VAL) == TSC_CTPH_14CYCLES) || \
  516. ((VAL) == TSC_CTPH_15CYCLES) || \
  517. ((VAL) == TSC_CTPH_16CYCLES))
  518. #define IS_TSC_CTPL(VAL) (((VAL) == TSC_CTPL_1CYCLE) || \
  519. ((VAL) == TSC_CTPL_2CYCLES) || \
  520. ((VAL) == TSC_CTPL_3CYCLES) || \
  521. ((VAL) == TSC_CTPL_4CYCLES) || \
  522. ((VAL) == TSC_CTPL_5CYCLES) || \
  523. ((VAL) == TSC_CTPL_6CYCLES) || \
  524. ((VAL) == TSC_CTPL_7CYCLES) || \
  525. ((VAL) == TSC_CTPL_8CYCLES) || \
  526. ((VAL) == TSC_CTPL_9CYCLES) || \
  527. ((VAL) == TSC_CTPL_10CYCLES) || \
  528. ((VAL) == TSC_CTPL_11CYCLES) || \
  529. ((VAL) == TSC_CTPL_12CYCLES) || \
  530. ((VAL) == TSC_CTPL_13CYCLES) || \
  531. ((VAL) == TSC_CTPL_14CYCLES) || \
  532. ((VAL) == TSC_CTPL_15CYCLES) || \
  533. ((VAL) == TSC_CTPL_16CYCLES))
  534. #define IS_TSC_SS(VAL) (((VAL) == DISABLE) || ((VAL) == ENABLE))
  535. #define IS_TSC_SSD(VAL) (((VAL) == 0) || (((VAL) > 0) && ((VAL) < 128)))
  536. #define IS_TSC_SS_PRESC(VAL) (((VAL) == TSC_SS_PRESC_DIV1) || ((VAL) == TSC_SS_PRESC_DIV2))
  537. #define IS_TSC_PG_PRESC(VAL) (((VAL) == TSC_PG_PRESC_DIV1) || \
  538. ((VAL) == TSC_PG_PRESC_DIV2) || \
  539. ((VAL) == TSC_PG_PRESC_DIV4) || \
  540. ((VAL) == TSC_PG_PRESC_DIV8) || \
  541. ((VAL) == TSC_PG_PRESC_DIV16) || \
  542. ((VAL) == TSC_PG_PRESC_DIV32) || \
  543. ((VAL) == TSC_PG_PRESC_DIV64) || \
  544. ((VAL) == TSC_PG_PRESC_DIV128))
  545. #define IS_TSC_MCV(VAL) (((VAL) == TSC_MCV_255) || \
  546. ((VAL) == TSC_MCV_511) || \
  547. ((VAL) == TSC_MCV_1023) || \
  548. ((VAL) == TSC_MCV_2047) || \
  549. ((VAL) == TSC_MCV_4095) || \
  550. ((VAL) == TSC_MCV_8191) || \
  551. ((VAL) == TSC_MCV_16383))
  552. #define IS_TSC_IODEF(VAL) (((VAL) == TSC_IODEF_OUT_PP_LOW) || ((VAL) == TSC_IODEF_IN_FLOAT))
  553. #define IS_TSC_SYNC_POL(VAL) (((VAL) == TSC_SYNC_POLARITY_FALLING) || ((VAL) == TSC_SYNC_POLARITY_RISING))
  554. #define IS_TSC_ACQ_MODE(VAL) (((VAL) == TSC_ACQ_MODE_NORMAL) || ((VAL) == TSC_ACQ_MODE_SYNCHRO))
  555. #define IS_TSC_IOMODE(VAL) (((VAL) == TSC_IOMODE_UNUSED) || \
  556. ((VAL) == TSC_IOMODE_CHANNEL) || \
  557. ((VAL) == TSC_IOMODE_SHIELD) || \
  558. ((VAL) == TSC_IOMODE_SAMPLING))
  559. #define IS_TSC_MCE_IT(VAL) (((VAL) == DISABLE) || ((VAL) == ENABLE))
  560. #define IS_TSC_GROUP_INDEX(VAL) (((VAL) == 0) || (((VAL) > 0) && ((VAL) < TSC_NB_OF_GROUPS)))
  561. /**
  562. * @}
  563. */
  564. /* Exported functions --------------------------------------------------------*/
  565. /** @addtogroup TSC_Exported_Functions
  566. * @{
  567. */
  568. /** @addtogroup TSC_Exported_Functions_Group1 Initialization and de-initialization functions
  569. * @{
  570. */
  571. /* Initialization and de-initialization functions *****************************/
  572. HAL_StatusTypeDef HAL_TSC_Init(TSC_HandleTypeDef* htsc);
  573. HAL_StatusTypeDef HAL_TSC_DeInit(TSC_HandleTypeDef *htsc);
  574. void HAL_TSC_MspInit(TSC_HandleTypeDef* htsc);
  575. void HAL_TSC_MspDeInit(TSC_HandleTypeDef* htsc);
  576. /**
  577. * @}
  578. */
  579. /** @addtogroup TSC_Exported_Functions_Group2 Input and Output operation functions
  580. * @{
  581. */
  582. /* IO operation functions *****************************************************/
  583. HAL_StatusTypeDef HAL_TSC_Start(TSC_HandleTypeDef* htsc);
  584. HAL_StatusTypeDef HAL_TSC_Start_IT(TSC_HandleTypeDef* htsc);
  585. HAL_StatusTypeDef HAL_TSC_Stop(TSC_HandleTypeDef* htsc);
  586. HAL_StatusTypeDef HAL_TSC_Stop_IT(TSC_HandleTypeDef* htsc);
  587. HAL_StatusTypeDef HAL_TSC_PollForAcquisition(TSC_HandleTypeDef* htsc);
  588. TSC_GroupStatusTypeDef HAL_TSC_GroupGetStatus(TSC_HandleTypeDef* htsc, uint32_t gx_index);
  589. uint32_t HAL_TSC_GroupGetValue(TSC_HandleTypeDef* htsc, uint32_t gx_index);
  590. /**
  591. * @}
  592. */
  593. /** @addtogroup TSC_Exported_Functions_Group3 Peripheral Control functions
  594. * @{
  595. */
  596. /* Peripheral Control functions ***********************************************/
  597. HAL_StatusTypeDef HAL_TSC_IOConfig(TSC_HandleTypeDef* htsc, TSC_IOConfigTypeDef* config);
  598. HAL_StatusTypeDef HAL_TSC_IODischarge(TSC_HandleTypeDef* htsc, uint32_t choice);
  599. /**
  600. * @}
  601. */
  602. /** @addtogroup TSC_Exported_Functions_Group4 Peripheral State and Errors functions
  603. * @{
  604. */
  605. /* Peripheral State and Error functions ***************************************/
  606. HAL_TSC_StateTypeDef HAL_TSC_GetState(TSC_HandleTypeDef* htsc);
  607. /**
  608. * @}
  609. */
  610. /** @addtogroup TSC_IRQ_Handler_and_Callbacks IRQ Handler and Callbacks
  611. * @{
  612. */
  613. /******* TSC IRQHandler and Callbacks used in Interrupt mode */
  614. void HAL_TSC_IRQHandler(TSC_HandleTypeDef* htsc);
  615. void HAL_TSC_ConvCpltCallback(TSC_HandleTypeDef* htsc);
  616. void HAL_TSC_ErrorCallback(TSC_HandleTypeDef* htsc);
  617. /**
  618. * @}
  619. */
  620. /**
  621. * @}
  622. */
  623. /**
  624. * @}
  625. */
  626. /**
  627. * @}
  628. */
  629. #ifdef __cplusplus
  630. }
  631. #endif
  632. #endif /* __STM32L4xx_HAL_TSC_H */
  633. /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/