DSO138_SourceCodes_v037.rar
[DSO138] / Libraries / STM32F10x_StdPeriph_Driver / inc / stm32f10x_cec.h
1 /**\r
2   ******************************************************************************\r
3   * @file    stm32f10x_cec.h\r
4   * @author  MCD Application Team\r
5   * @version V3.3.0\r
6   * @date    04/16/2010\r
7   * @brief   This file contains all the functions prototypes for the CEC firmware \r
8   *          library.\r
9   ******************************************************************************\r
10   * @copy\r
11   *\r
12   * THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS\r
13   * WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE\r
14   * TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY\r
15   * DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING\r
16   * FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE\r
17   * CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.\r
18   *\r
19   * <h2><center>&copy; COPYRIGHT 2010 STMicroelectronics</center></h2>\r
20   */ \r
21 \r
22 /* Define to prevent recursive inclusion -------------------------------------*/\r
23 #ifndef __STM32F10x_CEC_H\r
24 #define __STM32F10x_CEC_H\r
25 \r
26 #ifdef __cplusplus\r
27  extern "C" {\r
28 #endif\r
29 \r
30 /* Includes ------------------------------------------------------------------*/\r
31 #include "stm32f10x.h"\r
32 \r
33 /** @addtogroup STM32F10x_StdPeriph_Driver\r
34   * @{\r
35   */\r
36 \r
37 /** @addtogroup CEC\r
38   * @{\r
39   */\r
40   \r
41 \r
42 /** @defgroup CEC_Exported_Types\r
43   * @{\r
44   */\r
45    \r
46 /** \r
47   * @brief  CEC Init structure definition  \r
48   */ \r
49 typedef struct\r
50 {\r
51   uint16_t CEC_BitTimingMode; /*!< Configures the CEC Bit Timing Error Mode. \r
52                                This parameter can be a value of @ref CEC_BitTiming_Mode */\r
53   uint16_t CEC_BitPeriodMode; /*!< Configures the CEC Bit Period Error Mode. \r
54                                This parameter can be a value of @ref CEC_BitPeriod_Mode */\r
55 }CEC_InitTypeDef;\r
56 \r
57 /**\r
58   * @}\r
59   */\r
60 \r
61 /** @defgroup CEC_Exported_Constants\r
62   * @{\r
63   */ \r
64   \r
65 /** @defgroup CEC_BitTiming_Mode \r
66   * @{\r
67   */ \r
68 #define CEC_BitTimingStdMode                    ((uint16_t)0x00) /*!< Bit timing error Standard Mode */\r
69 #define CEC_BitTimingErrFreeMode                CEC_CFGR_BTEM   /*!< Bit timing error Free Mode */\r
70 \r
71 #define IS_CEC_BIT_TIMING_ERROR_MODE(MODE) (((MODE) == CEC_BitTimingStdMode) || \\r
72                                             ((MODE) == CEC_BitTimingErrFreeMode))\r
73 /**\r
74   * @}\r
75   */\r
76 \r
77 /** @defgroup CEC_BitPeriod_Mode \r
78   * @{\r
79   */ \r
80 #define CEC_BitPeriodStdMode                    ((uint16_t)0x00) /*!< Bit period error Standard Mode */\r
81 #define CEC_BitPeriodFlexibleMode                CEC_CFGR_BPEM   /*!< Bit period error Flexible Mode */\r
82 \r
83 #define IS_CEC_BIT_PERIOD_ERROR_MODE(MODE) (((MODE) == CEC_BitPeriodStdMode) || \\r
84                                             ((MODE) == CEC_BitPeriodFlexibleMode))\r
85 /**\r
86   * @}\r
87   */ \r
88 \r
89 \r
90 /** @defgroup CEC_interrupts_definition \r
91   * @{\r
92   */ \r
93 #define CEC_IT_TERR                              CEC_CSR_TERR\r
94 #define CEC_IT_TBTRF                             CEC_CSR_TBTRF\r
95 #define CEC_IT_RERR                              CEC_CSR_RERR\r
96 #define CEC_IT_RBTF                              CEC_CSR_RBTF\r
97 #define IS_CEC_GET_IT(IT) (((IT) == CEC_IT_TERR) || ((IT) == CEC_IT_TBTRF) || \\r
98                            ((IT) == CEC_IT_RERR) || ((IT) == CEC_IT_RBTF))\r
99 /**\r
100   * @}\r
101   */ \r
102 \r
103 \r
104 /** @defgroup CEC_Own_Addres \r
105   * @{\r
106   */ \r
107 #define IS_CEC_ADDRESS(ADDRESS) ((ADDRESS) < 0x10)\r
108 /**\r
109   * @}\r
110   */ \r
111 \r
112 /** @defgroup CEC_Prescaler \r
113   * @{\r
114   */ \r
115 #define IS_CEC_PRESCALER(PRESCALER) ((PRESCALER) <= 0x3FFF)\r
116 \r
117 /**\r
118   * @}\r
119   */\r
120 \r
121 /** @defgroup CEC_flags_definition \r
122   * @{\r
123   */\r
124    \r
125 /** \r
126   * @brief  ESR register flags  \r
127   */ \r
128 #define CEC_FLAG_BTE                            ((uint32_t)0x10010000)\r
129 #define CEC_FLAG_BPE                            ((uint32_t)0x10020000)\r
130 #define CEC_FLAG_RBTFE                          ((uint32_t)0x10040000)\r
131 #define CEC_FLAG_SBE                            ((uint32_t)0x10080000)\r
132 #define CEC_FLAG_ACKE                           ((uint32_t)0x10100000)\r
133 #define CEC_FLAG_LINE                           ((uint32_t)0x10200000)\r
134 #define CEC_FLAG_TBTFE                          ((uint32_t)0x10400000)\r
135 \r
136 /** \r
137   * @brief  CSR register flags  \r
138   */ \r
139 #define CEC_FLAG_TEOM                           ((uint32_t)0x00000002)  \r
140 #define CEC_FLAG_TERR                           ((uint32_t)0x00000004)\r
141 #define CEC_FLAG_TBTRF                          ((uint32_t)0x00000008)\r
142 #define CEC_FLAG_RSOM                           ((uint32_t)0x00000010)\r
143 #define CEC_FLAG_REOM                           ((uint32_t)0x00000020)\r
144 #define CEC_FLAG_RERR                           ((uint32_t)0x00000040)\r
145 #define CEC_FLAG_RBTF                           ((uint32_t)0x00000080)\r
146 \r
147 #define IS_CEC_CLEAR_FLAG(FLAG) ((((FLAG) & (uint32_t)0xFFFFFF03) == 0x00) && ((FLAG) != 0x00))\r
148                                \r
149 #define IS_CEC_GET_FLAG(FLAG) (((FLAG) == CEC_FLAG_BTE) || ((FLAG) == CEC_FLAG_BPE) || \\r
150                                ((FLAG) == CEC_FLAG_RBTFE) || ((FLAG)== CEC_FLAG_SBE) || \\r
151                                ((FLAG) == CEC_FLAG_ACKE) || ((FLAG) == CEC_FLAG_LINE) || \\r
152                                ((FLAG) == CEC_FLAG_TBTFE) || ((FLAG) == CEC_FLAG_TEOM) || \\r
153                                ((FLAG) == CEC_FLAG_TERR) || ((FLAG) == CEC_FLAG_TBTRF) || \\r
154                                ((FLAG) == CEC_FLAG_RSOM) || ((FLAG) == CEC_FLAG_REOM) || \\r
155                                ((FLAG) == CEC_FLAG_RERR) || ((FLAG) == CEC_FLAG_RBTF))\r
156 \r
157 /**\r
158   * @}\r
159   */ \r
160 \r
161 /**\r
162   * @}\r
163   */ \r
164 \r
165 /** @defgroup CEC_Exported_Macros\r
166   * @{\r
167   */\r
168  \r
169 /**\r
170   * @}\r
171   */\r
172 \r
173 /** @defgroup CEC_Exported_Functions\r
174   * @{\r
175   */ \r
176 void CEC_DeInit(void);\r
177 void CEC_Init(CEC_InitTypeDef* CEC_InitStruct);\r
178 void CEC_Cmd(FunctionalState NewState);\r
179 void CEC_ITConfig(FunctionalState NewState);\r
180 void CEC_OwnAddressConfig(uint8_t CEC_OwnAddress);\r
181 void CEC_SetPrescaler(uint16_t CEC_Prescaler);\r
182 void CEC_SendDataByte(uint8_t Data);\r
183 uint8_t CEC_ReceiveDataByte(void);\r
184 void CEC_StartOfMessage(void);\r
185 void CEC_EndOfMessageCmd(FunctionalState NewState);\r
186 FlagStatus CEC_GetFlagStatus(uint32_t CEC_FLAG);\r
187 void CEC_ClearFlag(uint32_t CEC_FLAG);\r
188 ITStatus CEC_GetITStatus(uint8_t CEC_IT);\r
189 void CEC_ClearITPendingBit(uint16_t CEC_IT);\r
190 \r
191 #ifdef __cplusplus\r
192 }\r
193 #endif\r
194 \r
195 #endif /* __STM32F10x_CEC_H */\r
196 \r
197 /**\r
198   * @}\r
199   */ \r
200 \r
201 /**\r
202   * @}\r
203   */ \r
204 \r
205 /**\r
206   * @}\r
207   */ \r
208 \r
209 /******************* (C) COPYRIGHT 2010 STMicroelectronics *****END OF FILE****/\r