added prescaler for 16 bit pwm in LPC1347 target

Fork of mbed-dev by mbed official

Committer:
<>
Date:
Fri Sep 02 15:07:44 2016 +0100
Revision:
144:ef7eb2e8f9f7
Parent:
83:a036322b8637
This updates the lib to the mbed lib v125

Who changed what in which revision?

UserRevisionLine numberNew contents of line
<> 144:ef7eb2e8f9f7 1 /**
<> 144:ef7eb2e8f9f7 2 ******************************************************************************
<> 144:ef7eb2e8f9f7 3 * @file stm32f7xx_hal_cec.c
<> 144:ef7eb2e8f9f7 4 * @author MCD Application Team
<> 144:ef7eb2e8f9f7 5 * @version V1.1.0
<> 144:ef7eb2e8f9f7 6 * @date 22-April-2016
<> 144:ef7eb2e8f9f7 7 * @brief CEC HAL module driver.
<> 144:ef7eb2e8f9f7 8 * This file provides firmware functions to manage the following
<> 144:ef7eb2e8f9f7 9 * functionalities of the High Definition Multimedia Interface
<> 144:ef7eb2e8f9f7 10 * Consumer Electronics Control Peripheral (CEC).
<> 144:ef7eb2e8f9f7 11 * + Initialization and de-initialization function
<> 144:ef7eb2e8f9f7 12 * + IO operation function
<> 144:ef7eb2e8f9f7 13 * + Peripheral Control function
<> 144:ef7eb2e8f9f7 14 *
<> 144:ef7eb2e8f9f7 15 *
<> 144:ef7eb2e8f9f7 16 @verbatim
<> 144:ef7eb2e8f9f7 17 ===============================================================================
<> 144:ef7eb2e8f9f7 18 ##### How to use this driver #####
<> 144:ef7eb2e8f9f7 19 ===============================================================================
<> 144:ef7eb2e8f9f7 20 [..]
<> 144:ef7eb2e8f9f7 21 The CEC HAL driver can be used as follow:
<> 144:ef7eb2e8f9f7 22
<> 144:ef7eb2e8f9f7 23 (#) Declare a CEC_HandleTypeDef handle structure.
<> 144:ef7eb2e8f9f7 24 (#) Initialize the CEC low level resources by implementing the HAL_CEC_MspInit ()API:
<> 144:ef7eb2e8f9f7 25 (##) Enable the CEC interface clock.
<> 144:ef7eb2e8f9f7 26 (##) CEC pins configuration:
<> 144:ef7eb2e8f9f7 27 (+++) Enable the clock for the CEC GPIOs.
<> 144:ef7eb2e8f9f7 28 (+++) Configure these CEC pins as alternate function pull-up.
<> 144:ef7eb2e8f9f7 29 (##) NVIC configuration if you need to use interrupt process (HAL_CEC_Transmit_IT()
<> 144:ef7eb2e8f9f7 30 and HAL_CEC_Receive_IT() APIs):
<> 144:ef7eb2e8f9f7 31 (+++) Configure the CEC interrupt priority.
<> 144:ef7eb2e8f9f7 32 (+++) Enable the NVIC CEC IRQ handle.
<> 144:ef7eb2e8f9f7 33 (+++) The specific CEC interrupts (Transmission complete interrupt,
<> 144:ef7eb2e8f9f7 34 RXNE interrupt and Error Interrupts) will be managed using the macros
<> 144:ef7eb2e8f9f7 35 __HAL_CEC_ENABLE_IT() and __HAL_CEC_DISABLE_IT() inside the transmit
<> 144:ef7eb2e8f9f7 36 and receive process.
<> 144:ef7eb2e8f9f7 37
<> 144:ef7eb2e8f9f7 38 (#) Program the Signal Free Time (SFT) and SFT option, Tolerance, reception stop in
<> 144:ef7eb2e8f9f7 39 in case of Bit Rising Error, Error-Bit generation conditions, device logical
<> 144:ef7eb2e8f9f7 40 address and Listen mode in the hcec Init structure.
<> 144:ef7eb2e8f9f7 41
<> 144:ef7eb2e8f9f7 42 (#) Initialize the CEC registers by calling the HAL_CEC_Init() API.
<> 144:ef7eb2e8f9f7 43
<> 144:ef7eb2e8f9f7 44 [..]
<> 144:ef7eb2e8f9f7 45 (@) This API (HAL_CEC_Init()) configures also the low level Hardware (GPIO, CLOCK, CORTEX...etc)
<> 144:ef7eb2e8f9f7 46 by calling the customed HAL_CEC_MspInit() API.
<> 144:ef7eb2e8f9f7 47
<> 144:ef7eb2e8f9f7 48 @endverbatim
<> 144:ef7eb2e8f9f7 49 ******************************************************************************
<> 144:ef7eb2e8f9f7 50 * @attention
<> 144:ef7eb2e8f9f7 51 *
<> 144:ef7eb2e8f9f7 52 * <h2><center>&copy; COPYRIGHT(c) 2016 STMicroelectronics</center></h2>
<> 144:ef7eb2e8f9f7 53 *
<> 144:ef7eb2e8f9f7 54 * Redistribution and use in source and binary forms, with or without modification,
<> 144:ef7eb2e8f9f7 55 * are permitted provided that the following conditions are met:
<> 144:ef7eb2e8f9f7 56 * 1. Redistributions of source code must retain the above copyright notice,
<> 144:ef7eb2e8f9f7 57 * this list of conditions and the following disclaimer.
<> 144:ef7eb2e8f9f7 58 * 2. Redistributions in binary form must reproduce the above copyright notice,
<> 144:ef7eb2e8f9f7 59 * this list of conditions and the following disclaimer in the documentation
<> 144:ef7eb2e8f9f7 60 * and/or other materials provided with the distribution.
<> 144:ef7eb2e8f9f7 61 * 3. Neither the name of STMicroelectronics nor the names of its contributors
<> 144:ef7eb2e8f9f7 62 * may be used to endorse or promote products derived from this software
<> 144:ef7eb2e8f9f7 63 * without specific prior written permission.
<> 144:ef7eb2e8f9f7 64 *
<> 144:ef7eb2e8f9f7 65 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
<> 144:ef7eb2e8f9f7 66 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
<> 144:ef7eb2e8f9f7 67 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
<> 144:ef7eb2e8f9f7 68 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
<> 144:ef7eb2e8f9f7 69 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
<> 144:ef7eb2e8f9f7 70 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
<> 144:ef7eb2e8f9f7 71 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
<> 144:ef7eb2e8f9f7 72 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
<> 144:ef7eb2e8f9f7 73 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
<> 144:ef7eb2e8f9f7 74 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
<> 144:ef7eb2e8f9f7 75 *
<> 144:ef7eb2e8f9f7 76 ******************************************************************************
<> 144:ef7eb2e8f9f7 77 */
<> 144:ef7eb2e8f9f7 78
<> 144:ef7eb2e8f9f7 79 /* Includes ------------------------------------------------------------------*/
<> 144:ef7eb2e8f9f7 80 #include "stm32f7xx_hal.h"
<> 144:ef7eb2e8f9f7 81
<> 144:ef7eb2e8f9f7 82 /** @addtogroup STM32F7xx_HAL_Driver
<> 144:ef7eb2e8f9f7 83 * @{
<> 144:ef7eb2e8f9f7 84 */
<> 144:ef7eb2e8f9f7 85
<> 144:ef7eb2e8f9f7 86 /** @defgroup CEC CEC
<> 144:ef7eb2e8f9f7 87 * @brief HAL CEC module driver
<> 144:ef7eb2e8f9f7 88 * @{
<> 144:ef7eb2e8f9f7 89 */
<> 144:ef7eb2e8f9f7 90 #ifdef HAL_CEC_MODULE_ENABLED
<> 144:ef7eb2e8f9f7 91
<> 144:ef7eb2e8f9f7 92 /* Private typedef -----------------------------------------------------------*/
<> 144:ef7eb2e8f9f7 93 /* Private define ------------------------------------------------------------*/
<> 144:ef7eb2e8f9f7 94 /** @defgroup CEC_Private_Constants CEC Private Constants
<> 144:ef7eb2e8f9f7 95 * @{
<> 144:ef7eb2e8f9f7 96 */
<> 144:ef7eb2e8f9f7 97 /**
<> 144:ef7eb2e8f9f7 98 * @}
<> 144:ef7eb2e8f9f7 99 */
<> 144:ef7eb2e8f9f7 100
<> 144:ef7eb2e8f9f7 101 /* Private macro -------------------------------------------------------------*/
<> 144:ef7eb2e8f9f7 102 /* Private variables ---------------------------------------------------------*/
<> 144:ef7eb2e8f9f7 103 /* Private function prototypes -----------------------------------------------*/
<> 144:ef7eb2e8f9f7 104 /** @defgroup CEC_Private_Functions CEC Private Functions
<> 144:ef7eb2e8f9f7 105 * @{
<> 144:ef7eb2e8f9f7 106 */
<> 144:ef7eb2e8f9f7 107 /**
<> 144:ef7eb2e8f9f7 108 * @}
<> 144:ef7eb2e8f9f7 109 */
<> 144:ef7eb2e8f9f7 110
<> 144:ef7eb2e8f9f7 111 /* Exported functions ---------------------------------------------------------*/
<> 144:ef7eb2e8f9f7 112
<> 144:ef7eb2e8f9f7 113 /** @defgroup CEC_Exported_Functions CEC Exported Functions
<> 144:ef7eb2e8f9f7 114 * @{
<> 144:ef7eb2e8f9f7 115 */
<> 144:ef7eb2e8f9f7 116
<> 144:ef7eb2e8f9f7 117 /** @defgroup CEC_Exported_Functions_Group1 Initialization and de-initialization functions
<> 144:ef7eb2e8f9f7 118 * @brief Initialization and Configuration functions
<> 144:ef7eb2e8f9f7 119 *
<> 144:ef7eb2e8f9f7 120 @verbatim
<> 144:ef7eb2e8f9f7 121 ===============================================================================
<> 144:ef7eb2e8f9f7 122 ##### Initialization and Configuration functions #####
<> 144:ef7eb2e8f9f7 123 ===============================================================================
<> 144:ef7eb2e8f9f7 124 [..]
<> 144:ef7eb2e8f9f7 125 This subsection provides a set of functions allowing to initialize the CEC
<> 144:ef7eb2e8f9f7 126 (+) The following parameters need to be configured:
<> 144:ef7eb2e8f9f7 127 (++) SignalFreeTime
<> 144:ef7eb2e8f9f7 128 (++) Tolerance
<> 144:ef7eb2e8f9f7 129 (++) BRERxStop (RX stopped or not upon Bit Rising Error)
<> 144:ef7eb2e8f9f7 130 (++) BREErrorBitGen (Error-Bit generation in case of Bit Rising Error)
<> 144:ef7eb2e8f9f7 131 (++) LBPEErrorBitGen (Error-Bit generation in case of Long Bit Period Error)
<> 144:ef7eb2e8f9f7 132 (++) BroadcastMsgNoErrorBitGen (Error-bit generation in case of broadcast message error)
<> 144:ef7eb2e8f9f7 133 (++) SignalFreeTimeOption (SFT Timer start definition)
<> 144:ef7eb2e8f9f7 134 (++) OwnAddress (CEC device address)
<> 144:ef7eb2e8f9f7 135 (++) ListenMode
<> 144:ef7eb2e8f9f7 136
<> 144:ef7eb2e8f9f7 137 @endverbatim
<> 144:ef7eb2e8f9f7 138 * @{
<> 144:ef7eb2e8f9f7 139 */
<> 144:ef7eb2e8f9f7 140
<> 144:ef7eb2e8f9f7 141 /**
<> 144:ef7eb2e8f9f7 142 * @brief Initializes the CEC mode according to the specified
<> 144:ef7eb2e8f9f7 143 * parameters in the CEC_InitTypeDef and creates the associated handle .
<> 144:ef7eb2e8f9f7 144 * @param hcec: CEC handle
<> 144:ef7eb2e8f9f7 145 * @retval HAL status
<> 144:ef7eb2e8f9f7 146 */
<> 144:ef7eb2e8f9f7 147 HAL_StatusTypeDef HAL_CEC_Init(CEC_HandleTypeDef *hcec)
<> 144:ef7eb2e8f9f7 148 {
<> 144:ef7eb2e8f9f7 149 /* Check the CEC handle allocation */
<> 144:ef7eb2e8f9f7 150 if((hcec == NULL) ||(hcec->Init.RxBuffer == NULL))
<> 144:ef7eb2e8f9f7 151 {
<> 144:ef7eb2e8f9f7 152 return HAL_ERROR;
<> 144:ef7eb2e8f9f7 153 }
<> 144:ef7eb2e8f9f7 154
<> 144:ef7eb2e8f9f7 155 /* Check the parameters */
<> 144:ef7eb2e8f9f7 156 assert_param(IS_CEC_ALL_INSTANCE(hcec->Instance));
<> 144:ef7eb2e8f9f7 157 assert_param(IS_CEC_SIGNALFREETIME(hcec->Init.SignalFreeTime));
<> 144:ef7eb2e8f9f7 158 assert_param(IS_CEC_TOLERANCE(hcec->Init.Tolerance));
<> 144:ef7eb2e8f9f7 159 assert_param(IS_CEC_BRERXSTOP(hcec->Init.BRERxStop));
<> 144:ef7eb2e8f9f7 160 assert_param(IS_CEC_BREERRORBITGEN(hcec->Init.BREErrorBitGen));
<> 144:ef7eb2e8f9f7 161 assert_param(IS_CEC_LBPEERRORBITGEN(hcec->Init.LBPEErrorBitGen));
<> 144:ef7eb2e8f9f7 162 assert_param(IS_CEC_BROADCASTERROR_NO_ERRORBIT_GENERATION(hcec->Init.BroadcastMsgNoErrorBitGen));
<> 144:ef7eb2e8f9f7 163 assert_param(IS_CEC_SFTOP(hcec->Init.SignalFreeTimeOption));
<> 144:ef7eb2e8f9f7 164 assert_param(IS_CEC_LISTENING_MODE(hcec->Init.ListenMode));
<> 144:ef7eb2e8f9f7 165 assert_param(IS_CEC_OWN_ADDRESS(hcec->Init.OwnAddress));
<> 144:ef7eb2e8f9f7 166
<> 144:ef7eb2e8f9f7 167 if(hcec->gState == HAL_CEC_STATE_RESET)
<> 144:ef7eb2e8f9f7 168 {
<> 144:ef7eb2e8f9f7 169 /* Allocate lock resource and initialize it */
<> 144:ef7eb2e8f9f7 170 hcec->Lock = HAL_UNLOCKED;
<> 144:ef7eb2e8f9f7 171 /* Init the low level hardware : GPIO, CLOCK */
<> 144:ef7eb2e8f9f7 172 HAL_CEC_MspInit(hcec);
<> 144:ef7eb2e8f9f7 173 }
<> 144:ef7eb2e8f9f7 174 hcec->gState = HAL_CEC_STATE_BUSY;
<> 144:ef7eb2e8f9f7 175
<> 144:ef7eb2e8f9f7 176 /* Disable the Peripheral */
<> 144:ef7eb2e8f9f7 177 __HAL_CEC_DISABLE(hcec);
<> 144:ef7eb2e8f9f7 178
<> 144:ef7eb2e8f9f7 179 /* Write to CEC Control Register */
<> 144:ef7eb2e8f9f7 180 hcec->Instance->CFGR = hcec->Init.SignalFreeTime | hcec->Init.Tolerance | hcec->Init.BRERxStop|\
<> 144:ef7eb2e8f9f7 181 hcec->Init.BREErrorBitGen | hcec->Init.LBPEErrorBitGen | hcec->Init.BroadcastMsgNoErrorBitGen |\
<> 144:ef7eb2e8f9f7 182 hcec->Init.SignalFreeTimeOption |((uint32_t)(hcec->Init.OwnAddress)<<16U) |\
<> 144:ef7eb2e8f9f7 183 hcec->Init.ListenMode;
<> 144:ef7eb2e8f9f7 184
<> 144:ef7eb2e8f9f7 185 /* Enable the following CEC Transmission/Reception interrupts as
<> 144:ef7eb2e8f9f7 186 * well as the following CEC Transmission/Reception Errors interrupts
<> 144:ef7eb2e8f9f7 187 * Rx Byte Received IT
<> 144:ef7eb2e8f9f7 188 * End of Reception IT
<> 144:ef7eb2e8f9f7 189 * Rx overrun
<> 144:ef7eb2e8f9f7 190 * Rx bit rising error
<> 144:ef7eb2e8f9f7 191 * Rx short bit period error
<> 144:ef7eb2e8f9f7 192 * Rx long bit period error
<> 144:ef7eb2e8f9f7 193 * Rx missing acknowledge
<> 144:ef7eb2e8f9f7 194 * Tx Byte Request IT
<> 144:ef7eb2e8f9f7 195 * End of Transmission IT
<> 144:ef7eb2e8f9f7 196 * Tx Missing Acknowledge IT
<> 144:ef7eb2e8f9f7 197 * Tx-Error IT
<> 144:ef7eb2e8f9f7 198 * Tx-Buffer Underrun IT
<> 144:ef7eb2e8f9f7 199 * Tx arbitration lost */
<> 144:ef7eb2e8f9f7 200 __HAL_CEC_ENABLE_IT(hcec, CEC_IT_RXBR|CEC_IT_RXEND|CEC_IER_RX_ALL_ERR|CEC_IT_TXBR|CEC_IT_TXEND|CEC_IER_TX_ALL_ERR);
<> 144:ef7eb2e8f9f7 201
<> 144:ef7eb2e8f9f7 202 /* Enable the CEC Peripheral */
<> 144:ef7eb2e8f9f7 203 __HAL_CEC_ENABLE(hcec);
<> 144:ef7eb2e8f9f7 204
<> 144:ef7eb2e8f9f7 205 hcec->ErrorCode = HAL_CEC_ERROR_NONE;
<> 144:ef7eb2e8f9f7 206 hcec->gState = HAL_CEC_STATE_READY;
<> 144:ef7eb2e8f9f7 207 hcec->RxState = HAL_CEC_STATE_READY;
<> 144:ef7eb2e8f9f7 208
<> 144:ef7eb2e8f9f7 209 return HAL_OK;
<> 144:ef7eb2e8f9f7 210 }
<> 144:ef7eb2e8f9f7 211
<> 144:ef7eb2e8f9f7 212 /**
<> 144:ef7eb2e8f9f7 213 * @brief DeInitializes the CEC peripheral
<> 144:ef7eb2e8f9f7 214 * @param hcec: CEC handle
<> 144:ef7eb2e8f9f7 215 * @retval HAL status
<> 144:ef7eb2e8f9f7 216 */
<> 144:ef7eb2e8f9f7 217 HAL_StatusTypeDef HAL_CEC_DeInit(CEC_HandleTypeDef *hcec)
<> 144:ef7eb2e8f9f7 218 {
<> 144:ef7eb2e8f9f7 219 /* Check the CEC handle allocation */
<> 144:ef7eb2e8f9f7 220 if(hcec == NULL)
<> 144:ef7eb2e8f9f7 221 {
<> 144:ef7eb2e8f9f7 222 return HAL_ERROR;
<> 144:ef7eb2e8f9f7 223 }
<> 144:ef7eb2e8f9f7 224
<> 144:ef7eb2e8f9f7 225 /* Check the parameters */
<> 144:ef7eb2e8f9f7 226 assert_param(IS_CEC_ALL_INSTANCE(hcec->Instance));
<> 144:ef7eb2e8f9f7 227
<> 144:ef7eb2e8f9f7 228 hcec->gState = HAL_CEC_STATE_BUSY;
<> 144:ef7eb2e8f9f7 229
<> 144:ef7eb2e8f9f7 230 /* DeInit the low level hardware */
<> 144:ef7eb2e8f9f7 231 HAL_CEC_MspDeInit(hcec);
<> 144:ef7eb2e8f9f7 232
<> 144:ef7eb2e8f9f7 233 /* Disable the Peripheral */
<> 144:ef7eb2e8f9f7 234 __HAL_CEC_DISABLE(hcec);
<> 144:ef7eb2e8f9f7 235
<> 144:ef7eb2e8f9f7 236 /* Clear Flags */
<> 144:ef7eb2e8f9f7 237 __HAL_CEC_CLEAR_FLAG(hcec,CEC_FLAG_TXEND|CEC_FLAG_TXBR|CEC_FLAG_RXBR|CEC_FLAG_RXEND|CEC_ISR_ALL_ERROR);
<> 144:ef7eb2e8f9f7 238
<> 144:ef7eb2e8f9f7 239 /* Disable the following CEC Transmission/Reception interrupts as
<> 144:ef7eb2e8f9f7 240 * well as the following CEC Transmission/Reception Errors interrupts
<> 144:ef7eb2e8f9f7 241 * Rx Byte Received IT
<> 144:ef7eb2e8f9f7 242 * End of Reception IT
<> 144:ef7eb2e8f9f7 243 * Rx overrun
<> 144:ef7eb2e8f9f7 244 * Rx bit rising error
<> 144:ef7eb2e8f9f7 245 * Rx short bit period error
<> 144:ef7eb2e8f9f7 246 * Rx long bit period error
<> 144:ef7eb2e8f9f7 247 * Rx missing acknowledge
<> 144:ef7eb2e8f9f7 248 * Tx Byte Request IT
<> 144:ef7eb2e8f9f7 249 * End of Transmission IT
<> 144:ef7eb2e8f9f7 250 * Tx Missing Acknowledge IT
<> 144:ef7eb2e8f9f7 251 * Tx-Error IT
<> 144:ef7eb2e8f9f7 252 * Tx-Buffer Underrun IT
<> 144:ef7eb2e8f9f7 253 * Tx arbitration lost */
<> 144:ef7eb2e8f9f7 254 __HAL_CEC_DISABLE_IT(hcec, CEC_IT_RXBR|CEC_IT_RXEND|CEC_IER_RX_ALL_ERR|CEC_IT_TXBR|CEC_IT_TXEND|CEC_IER_TX_ALL_ERR);
<> 144:ef7eb2e8f9f7 255
<> 144:ef7eb2e8f9f7 256 hcec->ErrorCode = HAL_CEC_ERROR_NONE;
<> 144:ef7eb2e8f9f7 257 hcec->gState = HAL_CEC_STATE_RESET;
<> 144:ef7eb2e8f9f7 258 hcec->RxState = HAL_CEC_STATE_RESET;
<> 144:ef7eb2e8f9f7 259
<> 144:ef7eb2e8f9f7 260 /* Process Unlock */
<> 144:ef7eb2e8f9f7 261 __HAL_UNLOCK(hcec);
<> 144:ef7eb2e8f9f7 262
<> 144:ef7eb2e8f9f7 263 return HAL_OK;
<> 144:ef7eb2e8f9f7 264 }
<> 144:ef7eb2e8f9f7 265
<> 144:ef7eb2e8f9f7 266 /**
<> 144:ef7eb2e8f9f7 267 * @brief Initializes the Own Address of the CEC device
<> 144:ef7eb2e8f9f7 268 * @param hcec: CEC handle
<> 144:ef7eb2e8f9f7 269 * @param CEC_OwnAddress: The CEC own address.
<> 144:ef7eb2e8f9f7 270 * @retval HAL status
<> 144:ef7eb2e8f9f7 271 */
<> 144:ef7eb2e8f9f7 272 HAL_StatusTypeDef HAL_CEC_SetDeviceAddress(CEC_HandleTypeDef *hcec, uint16_t CEC_OwnAddress)
<> 144:ef7eb2e8f9f7 273 {
<> 144:ef7eb2e8f9f7 274 /* Check the parameters */
<> 144:ef7eb2e8f9f7 275 assert_param(IS_CEC_OWN_ADDRESS(CEC_OwnAddress));
<> 144:ef7eb2e8f9f7 276
<> 144:ef7eb2e8f9f7 277 if ((hcec->gState == HAL_CEC_STATE_READY) && (hcec->RxState == HAL_CEC_STATE_READY))
<> 144:ef7eb2e8f9f7 278 {
<> 144:ef7eb2e8f9f7 279 /* Process Locked */
<> 144:ef7eb2e8f9f7 280 __HAL_LOCK(hcec);
<> 144:ef7eb2e8f9f7 281
<> 144:ef7eb2e8f9f7 282 hcec->gState = HAL_CEC_STATE_BUSY;
<> 144:ef7eb2e8f9f7 283
<> 144:ef7eb2e8f9f7 284 /* Disable the Peripheral */
<> 144:ef7eb2e8f9f7 285 __HAL_CEC_DISABLE(hcec);
<> 144:ef7eb2e8f9f7 286
<> 144:ef7eb2e8f9f7 287 if(CEC_OwnAddress != CEC_OWN_ADDRESS_NONE)
<> 144:ef7eb2e8f9f7 288 {
<> 144:ef7eb2e8f9f7 289 hcec->Instance->CFGR |= ((uint32_t)CEC_OwnAddress<<16);
<> 144:ef7eb2e8f9f7 290 }
<> 144:ef7eb2e8f9f7 291 else
<> 144:ef7eb2e8f9f7 292 {
<> 144:ef7eb2e8f9f7 293 hcec->Instance->CFGR &= ~(CEC_CFGR_OAR);
<> 144:ef7eb2e8f9f7 294 }
<> 144:ef7eb2e8f9f7 295
<> 144:ef7eb2e8f9f7 296 hcec->gState = HAL_CEC_STATE_READY;
<> 144:ef7eb2e8f9f7 297 hcec->ErrorCode = HAL_CEC_ERROR_NONE;
<> 144:ef7eb2e8f9f7 298
<> 144:ef7eb2e8f9f7 299 /* Process Unlocked */
<> 144:ef7eb2e8f9f7 300 __HAL_UNLOCK(hcec);
<> 144:ef7eb2e8f9f7 301
<> 144:ef7eb2e8f9f7 302 /* Enable the Peripheral */
<> 144:ef7eb2e8f9f7 303 __HAL_CEC_ENABLE(hcec);
<> 144:ef7eb2e8f9f7 304
<> 144:ef7eb2e8f9f7 305 return HAL_OK;
<> 144:ef7eb2e8f9f7 306 }
<> 144:ef7eb2e8f9f7 307 else
<> 144:ef7eb2e8f9f7 308 {
<> 144:ef7eb2e8f9f7 309 return HAL_BUSY;
<> 144:ef7eb2e8f9f7 310 }
<> 144:ef7eb2e8f9f7 311 }
<> 144:ef7eb2e8f9f7 312
<> 144:ef7eb2e8f9f7 313 /**
<> 144:ef7eb2e8f9f7 314 * @brief CEC MSP Init
<> 144:ef7eb2e8f9f7 315 * @param hcec: CEC handle
<> 144:ef7eb2e8f9f7 316 * @retval None
<> 144:ef7eb2e8f9f7 317 */
<> 144:ef7eb2e8f9f7 318 __weak void HAL_CEC_MspInit(CEC_HandleTypeDef *hcec)
<> 144:ef7eb2e8f9f7 319 {
<> 144:ef7eb2e8f9f7 320 /* Prevent unused argument(s) compilation warning */
<> 144:ef7eb2e8f9f7 321 UNUSED(hcec);
<> 144:ef7eb2e8f9f7 322 /* NOTE : This function should not be modified, when the callback is needed,
<> 144:ef7eb2e8f9f7 323 the HAL_CEC_MspInit can be implemented in the user file
<> 144:ef7eb2e8f9f7 324 */
<> 144:ef7eb2e8f9f7 325 }
<> 144:ef7eb2e8f9f7 326
<> 144:ef7eb2e8f9f7 327 /**
<> 144:ef7eb2e8f9f7 328 * @brief CEC MSP DeInit
<> 144:ef7eb2e8f9f7 329 * @param hcec: CEC handle
<> 144:ef7eb2e8f9f7 330 * @retval None
<> 144:ef7eb2e8f9f7 331 */
<> 144:ef7eb2e8f9f7 332 __weak void HAL_CEC_MspDeInit(CEC_HandleTypeDef *hcec)
<> 144:ef7eb2e8f9f7 333 {
<> 144:ef7eb2e8f9f7 334 /* Prevent unused argument(s) compilation warning */
<> 144:ef7eb2e8f9f7 335 UNUSED(hcec);
<> 144:ef7eb2e8f9f7 336 /* NOTE : This function should not be modified, when the callback is needed,
<> 144:ef7eb2e8f9f7 337 the HAL_CEC_MspDeInit can be implemented in the user file
<> 144:ef7eb2e8f9f7 338 */
<> 144:ef7eb2e8f9f7 339 }
<> 144:ef7eb2e8f9f7 340
<> 144:ef7eb2e8f9f7 341 /**
<> 144:ef7eb2e8f9f7 342 * @}
<> 144:ef7eb2e8f9f7 343 */
<> 144:ef7eb2e8f9f7 344
<> 144:ef7eb2e8f9f7 345 /** @defgroup CEC_Exported_Functions_Group2 Input and Output operation functions
<> 144:ef7eb2e8f9f7 346 * @brief CEC Transmit/Receive functions
<> 144:ef7eb2e8f9f7 347 *
<> 144:ef7eb2e8f9f7 348 @verbatim
<> 144:ef7eb2e8f9f7 349 ===============================================================================
<> 144:ef7eb2e8f9f7 350 ##### IO operation functions #####
<> 144:ef7eb2e8f9f7 351 ===============================================================================
<> 144:ef7eb2e8f9f7 352 This subsection provides a set of functions allowing to manage the CEC data transfers.
<> 144:ef7eb2e8f9f7 353
<> 144:ef7eb2e8f9f7 354 (#) The CEC handle must contain the initiator (TX side) and the destination (RX side)
<> 144:ef7eb2e8f9f7 355 logical addresses (4-bit long addresses, 0xF for broadcast messages destination)
<> 144:ef7eb2e8f9f7 356
<> 144:ef7eb2e8f9f7 357 (#) The communication is performed using Interrupts.
<> 144:ef7eb2e8f9f7 358 These API's return the HAL status.
<> 144:ef7eb2e8f9f7 359 The end of the data processing will be indicated through the
<> 144:ef7eb2e8f9f7 360 dedicated CEC IRQ when using Interrupt mode.
<> 144:ef7eb2e8f9f7 361 The HAL_CEC_TxCpltCallback(), HAL_CEC_RxCpltCallback() user callbacks
<> 144:ef7eb2e8f9f7 362 will be executed respectively at the end of the transmit or Receive process
<> 144:ef7eb2e8f9f7 363 The HAL_CEC_ErrorCallback() user callback will be executed when a communication
<> 144:ef7eb2e8f9f7 364 error is detected
<> 144:ef7eb2e8f9f7 365
<> 144:ef7eb2e8f9f7 366 (#) API's with Interrupt are :
<> 144:ef7eb2e8f9f7 367 (+) HAL_CEC_Transmit_IT()
<> 144:ef7eb2e8f9f7 368 (+) HAL_CEC_IRQHandler()
<> 144:ef7eb2e8f9f7 369
<> 144:ef7eb2e8f9f7 370 (#) A set of User Callbacks are provided:
<> 144:ef7eb2e8f9f7 371 (+) HAL_CEC_TxCpltCallback()
<> 144:ef7eb2e8f9f7 372 (+) HAL_CEC_RxCpltCallback()
<> 144:ef7eb2e8f9f7 373 (+) HAL_CEC_ErrorCallback()
<> 144:ef7eb2e8f9f7 374
<> 144:ef7eb2e8f9f7 375 @endverbatim
<> 144:ef7eb2e8f9f7 376 * @{
<> 144:ef7eb2e8f9f7 377 */
<> 144:ef7eb2e8f9f7 378
<> 144:ef7eb2e8f9f7 379 /**
<> 144:ef7eb2e8f9f7 380 * @brief Send data in interrupt mode
<> 144:ef7eb2e8f9f7 381 * @param hcec: CEC handle
<> 144:ef7eb2e8f9f7 382 * @param InitiatorAddress: Initiator address
<> 144:ef7eb2e8f9f7 383 * @param DestinationAddress: destination logical address
<> 144:ef7eb2e8f9f7 384 * @param pData: pointer to input byte data buffer
<> 144:ef7eb2e8f9f7 385 * @param Size: amount of data to be sent in bytes (without counting the header).
<> 144:ef7eb2e8f9f7 386 * 0 means only the header is sent (ping operation).
<> 144:ef7eb2e8f9f7 387 * Maximum TX size is 15 bytes (1 opcode and up to 14 operands).
<> 144:ef7eb2e8f9f7 388 * @retval HAL status
<> 144:ef7eb2e8f9f7 389 */
<> 144:ef7eb2e8f9f7 390 HAL_StatusTypeDef HAL_CEC_Transmit_IT(CEC_HandleTypeDef *hcec, uint8_t InitiatorAddress,uint8_t DestinationAddress, uint8_t *pData, uint32_t Size)
<> 144:ef7eb2e8f9f7 391 {
<> 144:ef7eb2e8f9f7 392 /* if the IP isn't already busy and if there is no previous transmission
<> 144:ef7eb2e8f9f7 393 already pending due to arbitration lost */
<> 144:ef7eb2e8f9f7 394 if (hcec->gState == HAL_CEC_STATE_READY)
<> 144:ef7eb2e8f9f7 395 {
<> 144:ef7eb2e8f9f7 396 if((pData == NULL ) && (Size > 0))
<> 144:ef7eb2e8f9f7 397 {
<> 144:ef7eb2e8f9f7 398 return HAL_ERROR;
<> 144:ef7eb2e8f9f7 399 }
<> 144:ef7eb2e8f9f7 400
<> 144:ef7eb2e8f9f7 401 assert_param(IS_CEC_ADDRESS(DestinationAddress));
<> 144:ef7eb2e8f9f7 402 assert_param(IS_CEC_ADDRESS(InitiatorAddress));
<> 144:ef7eb2e8f9f7 403 assert_param(IS_CEC_MSGSIZE(Size));
<> 144:ef7eb2e8f9f7 404
<> 144:ef7eb2e8f9f7 405 /* Process Locked */
<> 144:ef7eb2e8f9f7 406 __HAL_LOCK(hcec);
<> 144:ef7eb2e8f9f7 407 hcec->pTxBuffPtr = pData;
<> 144:ef7eb2e8f9f7 408 hcec->gState = HAL_CEC_STATE_BUSY_TX;
<> 144:ef7eb2e8f9f7 409 hcec->ErrorCode = HAL_CEC_ERROR_NONE;
<> 144:ef7eb2e8f9f7 410
<> 144:ef7eb2e8f9f7 411 /* initialize the number of bytes to send,
<> 144:ef7eb2e8f9f7 412 * 0 means only one header is sent (ping operation) */
<> 144:ef7eb2e8f9f7 413 hcec->TxXferCount = Size;
<> 144:ef7eb2e8f9f7 414
<> 144:ef7eb2e8f9f7 415 /* in case of no payload (Size = 0), sender is only pinging the system;
<> 144:ef7eb2e8f9f7 416 Set TX End of Message (TXEOM) bit, must be set before writing data to TXDR */
<> 144:ef7eb2e8f9f7 417 if (Size == 0)
<> 144:ef7eb2e8f9f7 418 {
<> 144:ef7eb2e8f9f7 419 __HAL_CEC_LAST_BYTE_TX_SET(hcec);
<> 144:ef7eb2e8f9f7 420 }
<> 144:ef7eb2e8f9f7 421 /* send header block */
<> 144:ef7eb2e8f9f7 422 hcec->Instance->TXDR = ((uint8_t)(InitiatorAddress << CEC_INITIATOR_LSB_POS) |(uint8_t) DestinationAddress);
<> 144:ef7eb2e8f9f7 423 /* Set TX Start of Message (TXSOM) bit */
<> 144:ef7eb2e8f9f7 424 __HAL_CEC_FIRST_BYTE_TX_SET(hcec);
<> 144:ef7eb2e8f9f7 425
<> 144:ef7eb2e8f9f7 426 /* Process Unlocked */
<> 144:ef7eb2e8f9f7 427 __HAL_UNLOCK(hcec);
<> 144:ef7eb2e8f9f7 428
<> 144:ef7eb2e8f9f7 429 return HAL_OK;
<> 144:ef7eb2e8f9f7 430
<> 144:ef7eb2e8f9f7 431 }
<> 144:ef7eb2e8f9f7 432 else
<> 144:ef7eb2e8f9f7 433 {
<> 144:ef7eb2e8f9f7 434 return HAL_BUSY;
<> 144:ef7eb2e8f9f7 435 }
<> 144:ef7eb2e8f9f7 436 }
<> 144:ef7eb2e8f9f7 437
<> 144:ef7eb2e8f9f7 438 /**
<> 144:ef7eb2e8f9f7 439 * @brief Get size of the received frame.
<> 144:ef7eb2e8f9f7 440 * @param hcec: CEC handle
<> 144:ef7eb2e8f9f7 441 * @retval Frame size
<> 144:ef7eb2e8f9f7 442 */
<> 144:ef7eb2e8f9f7 443 uint32_t HAL_CEC_GetLastReceivedFrameSize(CEC_HandleTypeDef *hcec)
<> 144:ef7eb2e8f9f7 444 {
<> 144:ef7eb2e8f9f7 445 return hcec->RxXferSize;
<> 144:ef7eb2e8f9f7 446 }
<> 144:ef7eb2e8f9f7 447
<> 144:ef7eb2e8f9f7 448 /**
<> 144:ef7eb2e8f9f7 449 * @brief Change Rx Buffer.
<> 144:ef7eb2e8f9f7 450 * @param hcec: CEC handle
<> 144:ef7eb2e8f9f7 451 * @param Rxbuffer: Rx Buffer
<> 144:ef7eb2e8f9f7 452 * @note This function can be called only inside the HAL_CEC_RxCpltCallback()
<> 144:ef7eb2e8f9f7 453 * @retval Frame size
<> 144:ef7eb2e8f9f7 454 */
<> 144:ef7eb2e8f9f7 455 void HAL_CEC_ChangeRxBuffer(CEC_HandleTypeDef *hcec, uint8_t* Rxbuffer)
<> 144:ef7eb2e8f9f7 456 {
<> 144:ef7eb2e8f9f7 457 hcec->Init.RxBuffer = Rxbuffer;
<> 144:ef7eb2e8f9f7 458 }
<> 144:ef7eb2e8f9f7 459
<> 144:ef7eb2e8f9f7 460 /**
<> 144:ef7eb2e8f9f7 461 * @brief This function handles CEC interrupt requests.
<> 144:ef7eb2e8f9f7 462 * @param hcec: CEC handle
<> 144:ef7eb2e8f9f7 463 * @retval None
<> 144:ef7eb2e8f9f7 464 */
<> 144:ef7eb2e8f9f7 465 void HAL_CEC_IRQHandler(CEC_HandleTypeDef *hcec)
<> 144:ef7eb2e8f9f7 466 {
<> 144:ef7eb2e8f9f7 467
<> 144:ef7eb2e8f9f7 468 /* save interrupts register for further error or interrupts handling purposes */
<> 144:ef7eb2e8f9f7 469 uint32_t reg = 0;
<> 144:ef7eb2e8f9f7 470 reg = hcec->Instance->ISR;
<> 144:ef7eb2e8f9f7 471
<> 144:ef7eb2e8f9f7 472
<> 144:ef7eb2e8f9f7 473 /* ----------------------------Arbitration Lost Management----------------------------------*/
<> 144:ef7eb2e8f9f7 474 /* CEC TX arbitration error interrupt occurred --------------------------------------*/
<> 144:ef7eb2e8f9f7 475 if((reg & CEC_FLAG_ARBLST) != RESET)
<> 144:ef7eb2e8f9f7 476 {
<> 144:ef7eb2e8f9f7 477 hcec->ErrorCode = HAL_CEC_ERROR_ARBLST;
<> 144:ef7eb2e8f9f7 478 __HAL_CEC_CLEAR_FLAG(hcec, CEC_FLAG_ARBLST);
<> 144:ef7eb2e8f9f7 479 }
<> 144:ef7eb2e8f9f7 480
<> 144:ef7eb2e8f9f7 481 /* ----------------------------Rx Management----------------------------------*/
<> 144:ef7eb2e8f9f7 482 /* CEC RX byte received interrupt ---------------------------------------------------*/
<> 144:ef7eb2e8f9f7 483 if((reg & CEC_FLAG_RXBR) != RESET)
<> 144:ef7eb2e8f9f7 484 {
<> 144:ef7eb2e8f9f7 485 /* reception is starting */
<> 144:ef7eb2e8f9f7 486 hcec->RxState = HAL_CEC_STATE_BUSY_RX;
<> 144:ef7eb2e8f9f7 487 hcec->RxXferSize++;
<> 144:ef7eb2e8f9f7 488 /* read received byte */
<> 144:ef7eb2e8f9f7 489 *hcec->Init.RxBuffer++ = hcec->Instance->RXDR;
<> 144:ef7eb2e8f9f7 490 __HAL_CEC_CLEAR_FLAG(hcec, CEC_FLAG_RXBR);
<> 144:ef7eb2e8f9f7 491 }
<> 144:ef7eb2e8f9f7 492
<> 144:ef7eb2e8f9f7 493 /* CEC RX end received interrupt ---------------------------------------------------*/
<> 144:ef7eb2e8f9f7 494 if((reg & CEC_FLAG_RXEND) != RESET)
<> 144:ef7eb2e8f9f7 495 {
<> 144:ef7eb2e8f9f7 496 /* clear IT */
<> 144:ef7eb2e8f9f7 497 __HAL_CEC_CLEAR_FLAG(hcec, CEC_FLAG_RXEND);
<> 144:ef7eb2e8f9f7 498
<> 144:ef7eb2e8f9f7 499 /* Rx process is completed, restore hcec->RxState to Ready */
<> 144:ef7eb2e8f9f7 500 hcec->RxState = HAL_CEC_STATE_READY;
<> 144:ef7eb2e8f9f7 501 hcec->ErrorCode = HAL_CEC_ERROR_NONE;
<> 144:ef7eb2e8f9f7 502 hcec->Init.RxBuffer-=hcec->RxXferSize;
<> 144:ef7eb2e8f9f7 503 HAL_CEC_RxCpltCallback(hcec, hcec->RxXferSize);
<> 144:ef7eb2e8f9f7 504 hcec->RxXferSize = 0;
<> 144:ef7eb2e8f9f7 505 }
<> 144:ef7eb2e8f9f7 506
<> 144:ef7eb2e8f9f7 507 /* ----------------------------Tx Management----------------------------------*/
<> 144:ef7eb2e8f9f7 508 /* CEC TX byte request interrupt ------------------------------------------------*/
<> 144:ef7eb2e8f9f7 509 if((reg & CEC_FLAG_TXBR) != RESET)
<> 144:ef7eb2e8f9f7 510 {
<> 144:ef7eb2e8f9f7 511 if (hcec->TxXferCount == 0)
<> 144:ef7eb2e8f9f7 512 {
<> 144:ef7eb2e8f9f7 513 /* if this is the last byte transmission, set TX End of Message (TXEOM) bit */
<> 144:ef7eb2e8f9f7 514 __HAL_CEC_LAST_BYTE_TX_SET(hcec);
<> 144:ef7eb2e8f9f7 515 hcec->Instance->TXDR = *hcec->pTxBuffPtr++;
<> 144:ef7eb2e8f9f7 516 }
<> 144:ef7eb2e8f9f7 517 else
<> 144:ef7eb2e8f9f7 518 {
<> 144:ef7eb2e8f9f7 519 hcec->Instance->TXDR = *hcec->pTxBuffPtr++;
<> 144:ef7eb2e8f9f7 520 hcec->TxXferCount--;
<> 144:ef7eb2e8f9f7 521 }
<> 144:ef7eb2e8f9f7 522 /* clear Tx-Byte request flag */
<> 144:ef7eb2e8f9f7 523 __HAL_CEC_CLEAR_FLAG(hcec,CEC_FLAG_TXBR);
<> 144:ef7eb2e8f9f7 524 }
<> 144:ef7eb2e8f9f7 525
<> 144:ef7eb2e8f9f7 526 /* CEC TX end interrupt ------------------------------------------------*/
<> 144:ef7eb2e8f9f7 527 if((reg & CEC_FLAG_TXEND) != RESET)
<> 144:ef7eb2e8f9f7 528 {
<> 144:ef7eb2e8f9f7 529 __HAL_CEC_CLEAR_FLAG(hcec, CEC_FLAG_TXEND);
<> 144:ef7eb2e8f9f7 530
<> 144:ef7eb2e8f9f7 531 /* Tx process is ended, restore hcec->gState to Ready */
<> 144:ef7eb2e8f9f7 532 hcec->gState = HAL_CEC_STATE_READY;
<> 144:ef7eb2e8f9f7 533 /* Call the Process Unlocked before calling the Tx call back API to give the possibility to
<> 144:ef7eb2e8f9f7 534 start again the Transmission under the Tx call back API */
<> 144:ef7eb2e8f9f7 535 __HAL_UNLOCK(hcec);
<> 144:ef7eb2e8f9f7 536 hcec->ErrorCode = HAL_CEC_ERROR_NONE;
<> 144:ef7eb2e8f9f7 537 HAL_CEC_TxCpltCallback(hcec);
<> 144:ef7eb2e8f9f7 538 }
<> 144:ef7eb2e8f9f7 539
<> 144:ef7eb2e8f9f7 540 /* ----------------------------Rx/Tx Error Management----------------------------------*/
<> 144:ef7eb2e8f9f7 541 if ((reg & (CEC_ISR_RXOVR|CEC_ISR_BRE|CEC_ISR_SBPE|CEC_ISR_LBPE|CEC_ISR_RXACKE|CEC_ISR_TXUDR|CEC_ISR_TXERR|CEC_ISR_TXACKE)) != 0)
<> 144:ef7eb2e8f9f7 542 {
<> 144:ef7eb2e8f9f7 543 hcec->ErrorCode = reg;
<> 144:ef7eb2e8f9f7 544 __HAL_CEC_CLEAR_FLAG(hcec, HAL_CEC_ERROR_RXOVR|HAL_CEC_ERROR_BRE|CEC_FLAG_LBPE|CEC_FLAG_SBPE|HAL_CEC_ERROR_RXACKE|HAL_CEC_ERROR_TXUDR|HAL_CEC_ERROR_TXERR|HAL_CEC_ERROR_TXACKE);
<> 144:ef7eb2e8f9f7 545
<> 144:ef7eb2e8f9f7 546
<> 144:ef7eb2e8f9f7 547 if((reg & (CEC_ISR_RXOVR|CEC_ISR_BRE|CEC_ISR_SBPE|CEC_ISR_LBPE|CEC_ISR_RXACKE)) != RESET)
<> 144:ef7eb2e8f9f7 548 {
<> 144:ef7eb2e8f9f7 549 hcec->Init.RxBuffer-=hcec->RxXferSize;
<> 144:ef7eb2e8f9f7 550 hcec->RxXferSize = 0;
<> 144:ef7eb2e8f9f7 551 hcec->RxState = HAL_CEC_STATE_READY;
<> 144:ef7eb2e8f9f7 552 }
<> 144:ef7eb2e8f9f7 553 else if (((reg & (CEC_ISR_TXUDR|CEC_ISR_TXERR|CEC_ISR_TXACKE)) != RESET) && ((reg & CEC_ISR_ARBLST) == RESET))
<> 144:ef7eb2e8f9f7 554 {
<> 144:ef7eb2e8f9f7 555 /* Set the CEC state ready to be able to start again the process */
<> 144:ef7eb2e8f9f7 556 hcec->gState = HAL_CEC_STATE_READY;
<> 144:ef7eb2e8f9f7 557 }
<> 144:ef7eb2e8f9f7 558
<> 144:ef7eb2e8f9f7 559 /* Error Call Back */
<> 144:ef7eb2e8f9f7 560 HAL_CEC_ErrorCallback(hcec);
<> 144:ef7eb2e8f9f7 561 }
<> 144:ef7eb2e8f9f7 562
<> 144:ef7eb2e8f9f7 563 }
<> 144:ef7eb2e8f9f7 564
<> 144:ef7eb2e8f9f7 565 /**
<> 144:ef7eb2e8f9f7 566 * @brief Tx Transfer completed callback
<> 144:ef7eb2e8f9f7 567 * @param hcec: CEC handle
<> 144:ef7eb2e8f9f7 568 * @retval None
<> 144:ef7eb2e8f9f7 569 */
<> 144:ef7eb2e8f9f7 570 __weak void HAL_CEC_TxCpltCallback(CEC_HandleTypeDef *hcec)
<> 144:ef7eb2e8f9f7 571 {
<> 144:ef7eb2e8f9f7 572 /* Prevent unused argument(s) compilation warning */
<> 144:ef7eb2e8f9f7 573 UNUSED(hcec);
<> 144:ef7eb2e8f9f7 574 /* NOTE : This function should not be modified, when the callback is needed,
<> 144:ef7eb2e8f9f7 575 the HAL_CEC_TxCpltCallback can be implemented in the user file
<> 144:ef7eb2e8f9f7 576 */
<> 144:ef7eb2e8f9f7 577 }
<> 144:ef7eb2e8f9f7 578
<> 144:ef7eb2e8f9f7 579 /**
<> 144:ef7eb2e8f9f7 580 * @brief Rx Transfer completed callback
<> 144:ef7eb2e8f9f7 581 * @param hcec: CEC handle
<> 144:ef7eb2e8f9f7 582 * @param RxFrameSize: Size of frame
<> 144:ef7eb2e8f9f7 583 * @retval None
<> 144:ef7eb2e8f9f7 584 */
<> 144:ef7eb2e8f9f7 585 __weak void HAL_CEC_RxCpltCallback(CEC_HandleTypeDef *hcec, uint32_t RxFrameSize)
<> 144:ef7eb2e8f9f7 586 {
<> 144:ef7eb2e8f9f7 587 /* Prevent unused argument(s) compilation warning */
<> 144:ef7eb2e8f9f7 588 UNUSED(hcec);
<> 144:ef7eb2e8f9f7 589 UNUSED(RxFrameSize);
<> 144:ef7eb2e8f9f7 590 /* NOTE : This function should not be modified, when the callback is needed,
<> 144:ef7eb2e8f9f7 591 the HAL_CEC_RxCpltCallback can be implemented in the user file
<> 144:ef7eb2e8f9f7 592 */
<> 144:ef7eb2e8f9f7 593 }
<> 144:ef7eb2e8f9f7 594
<> 144:ef7eb2e8f9f7 595 /**
<> 144:ef7eb2e8f9f7 596 * @brief CEC error callbacks
<> 144:ef7eb2e8f9f7 597 * @param hcec: CEC handle
<> 144:ef7eb2e8f9f7 598 * @retval None
<> 144:ef7eb2e8f9f7 599 */
<> 144:ef7eb2e8f9f7 600 __weak void HAL_CEC_ErrorCallback(CEC_HandleTypeDef *hcec)
<> 144:ef7eb2e8f9f7 601 {
<> 144:ef7eb2e8f9f7 602 /* Prevent unused argument(s) compilation warning */
<> 144:ef7eb2e8f9f7 603 UNUSED(hcec);
<> 144:ef7eb2e8f9f7 604 /* NOTE : This function should not be modified, when the callback is needed,
<> 144:ef7eb2e8f9f7 605 the HAL_CEC_ErrorCallback can be implemented in the user file
<> 144:ef7eb2e8f9f7 606 */
<> 144:ef7eb2e8f9f7 607 }
<> 144:ef7eb2e8f9f7 608 /**
<> 144:ef7eb2e8f9f7 609 * @}
<> 144:ef7eb2e8f9f7 610 */
<> 144:ef7eb2e8f9f7 611
<> 144:ef7eb2e8f9f7 612 /** @defgroup CEC_Exported_Functions_Group3 Peripheral Control function
<> 144:ef7eb2e8f9f7 613 * @brief CEC control functions
<> 144:ef7eb2e8f9f7 614 *
<> 144:ef7eb2e8f9f7 615 @verbatim
<> 144:ef7eb2e8f9f7 616 ===============================================================================
<> 144:ef7eb2e8f9f7 617 ##### Peripheral Control function #####
<> 144:ef7eb2e8f9f7 618 ===============================================================================
<> 144:ef7eb2e8f9f7 619 [..]
<> 144:ef7eb2e8f9f7 620 This subsection provides a set of functions allowing to control the CEC.
<> 144:ef7eb2e8f9f7 621 (+) HAL_CEC_GetState() API can be helpful to check in run-time the state of the CEC peripheral.
<> 144:ef7eb2e8f9f7 622 (+) HAL_CEC_GetError() API can be helpful to check in run-time the error of the CEC peripheral.
<> 144:ef7eb2e8f9f7 623 @endverbatim
<> 144:ef7eb2e8f9f7 624 * @{
<> 144:ef7eb2e8f9f7 625 */
<> 144:ef7eb2e8f9f7 626 /**
<> 144:ef7eb2e8f9f7 627 * @brief return the CEC state
<> 144:ef7eb2e8f9f7 628 * @param hcec: pointer to a CEC_HandleTypeDef structure that contains
<> 144:ef7eb2e8f9f7 629 * the configuration information for the specified CEC module.
<> 144:ef7eb2e8f9f7 630 * @retval HAL state
<> 144:ef7eb2e8f9f7 631 */
<> 144:ef7eb2e8f9f7 632 HAL_CEC_StateTypeDef HAL_CEC_GetState(CEC_HandleTypeDef *hcec)
<> 144:ef7eb2e8f9f7 633 {
<> 144:ef7eb2e8f9f7 634 uint32_t temp1= 0x00U, temp2 = 0x00U;
<> 144:ef7eb2e8f9f7 635 temp1 = hcec->gState;
<> 144:ef7eb2e8f9f7 636 temp2 = hcec->RxState;
<> 144:ef7eb2e8f9f7 637
<> 144:ef7eb2e8f9f7 638 return (HAL_CEC_StateTypeDef)(temp1 | temp2);
<> 144:ef7eb2e8f9f7 639 }
<> 144:ef7eb2e8f9f7 640
<> 144:ef7eb2e8f9f7 641 /**
<> 144:ef7eb2e8f9f7 642 * @brief Return the CEC error code
<> 144:ef7eb2e8f9f7 643 * @param hcec : pointer to a CEC_HandleTypeDef structure that contains
<> 144:ef7eb2e8f9f7 644 * the configuration information for the specified CEC.
<> 144:ef7eb2e8f9f7 645 * @retval CEC Error Code
<> 144:ef7eb2e8f9f7 646 */
<> 144:ef7eb2e8f9f7 647 uint32_t HAL_CEC_GetError(CEC_HandleTypeDef *hcec)
<> 144:ef7eb2e8f9f7 648 {
<> 144:ef7eb2e8f9f7 649 return hcec->ErrorCode;
<> 144:ef7eb2e8f9f7 650 }
<> 144:ef7eb2e8f9f7 651
<> 144:ef7eb2e8f9f7 652 /**
<> 144:ef7eb2e8f9f7 653 * @}
<> 144:ef7eb2e8f9f7 654 */
<> 144:ef7eb2e8f9f7 655
<> 144:ef7eb2e8f9f7 656 /**
<> 144:ef7eb2e8f9f7 657 * @}
<> 144:ef7eb2e8f9f7 658 */
<> 144:ef7eb2e8f9f7 659 #endif /* HAL_CEC_MODULE_ENABLED */
<> 144:ef7eb2e8f9f7 660 /**
<> 144:ef7eb2e8f9f7 661 * @}
<> 144:ef7eb2e8f9f7 662 */
<> 144:ef7eb2e8f9f7 663
<> 144:ef7eb2e8f9f7 664 /**
<> 144:ef7eb2e8f9f7 665 * @}
<> 144:ef7eb2e8f9f7 666 */
<> 144:ef7eb2e8f9f7 667
<> 144:ef7eb2e8f9f7 668 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/