]> git.sur5r.net Git - freertos/blob - FreeRTOS/Demo/CORTEX_EFM32_Gecko_Starter_Kit_Simplicity_Studio/Source/SilLabs_Code/Device/SiliconLabs/EFM32WG/Include/efm32wg_rtc.h
e1c6187f80dd1329fa19712f5749c7737cf5b199
[freertos] / FreeRTOS / Demo / CORTEX_EFM32_Gecko_Starter_Kit_Simplicity_Studio / Source / SilLabs_Code / Device / SiliconLabs / EFM32WG / Include / efm32wg_rtc.h
1 /**************************************************************************//**\r
2  * @file efm32wg_rtc.h\r
3  * @brief EFM32WG_RTC register and bit field definitions\r
4  * @version 4.2.1\r
5  ******************************************************************************\r
6  * @section License\r
7  * <b>Copyright 2015 Silicon Laboratories, Inc. http://www.silabs.com</b>\r
8  ******************************************************************************\r
9  *\r
10  * Permission is granted to anyone to use this software for any purpose,\r
11  * including commercial applications, and to alter it and redistribute it\r
12  * freely, subject to the following restrictions:\r
13  *\r
14  * 1. The origin of this software must not be misrepresented; you must not\r
15  *    claim that you wrote the original software.@n\r
16  * 2. Altered source versions must be plainly marked as such, and must not be\r
17  *    misrepresented as being the original software.@n\r
18  * 3. This notice may not be removed or altered from any source distribution.\r
19  *\r
20  * DISCLAIMER OF WARRANTY/LIMITATION OF REMEDIES: Silicon Laboratories, Inc.\r
21  * has no obligation to support this Software. Silicon Laboratories, Inc. is\r
22  * providing the Software "AS IS", with no express or implied warranties of any\r
23  * kind, including, but not limited to, any implied warranties of\r
24  * merchantability or fitness for any particular purpose or warranties against\r
25  * infringement of any proprietary rights of a third party.\r
26  *\r
27  * Silicon Laboratories, Inc. will not be liable for any consequential,\r
28  * incidental, or special damages, or any other relief, or for any claim by\r
29  * any third party, arising from your use of this Software.\r
30  *\r
31  *****************************************************************************/\r
32 /**************************************************************************//**\r
33 * @addtogroup Parts\r
34 * @{\r
35 ******************************************************************************/\r
36 /**************************************************************************//**\r
37  * @defgroup EFM32WG_RTC\r
38  * @{\r
39  * @brief EFM32WG_RTC Register Declaration\r
40  *****************************************************************************/\r
41 typedef struct\r
42 {\r
43   __IO uint32_t CTRL;     /**< Control Register  */\r
44   __IO uint32_t CNT;      /**< Counter Value Register  */\r
45   __IO uint32_t COMP0;    /**< Compare Value Register 0  */\r
46   __IO uint32_t COMP1;    /**< Compare Value Register 1  */\r
47   __I uint32_t  IF;       /**< Interrupt Flag Register  */\r
48   __IO uint32_t IFS;      /**< Interrupt Flag Set Register  */\r
49   __IO uint32_t IFC;      /**< Interrupt Flag Clear Register  */\r
50   __IO uint32_t IEN;      /**< Interrupt Enable Register  */\r
51 \r
52   __IO uint32_t FREEZE;   /**< Freeze Register  */\r
53   __I uint32_t  SYNCBUSY; /**< Synchronization Busy Register  */\r
54 } RTC_TypeDef;            /** @} */\r
55 \r
56 /**************************************************************************//**\r
57  * @defgroup EFM32WG_RTC_BitFields\r
58  * @{\r
59  *****************************************************************************/\r
60 \r
61 /* Bit fields for RTC CTRL */\r
62 #define _RTC_CTRL_RESETVALUE             0x00000000UL                      /**< Default value for RTC_CTRL */\r
63 #define _RTC_CTRL_MASK                   0x00000007UL                      /**< Mask for RTC_CTRL */\r
64 #define RTC_CTRL_EN                      (0x1UL << 0)                      /**< RTC Enable */\r
65 #define _RTC_CTRL_EN_SHIFT               0                                 /**< Shift value for RTC_EN */\r
66 #define _RTC_CTRL_EN_MASK                0x1UL                             /**< Bit mask for RTC_EN */\r
67 #define _RTC_CTRL_EN_DEFAULT             0x00000000UL                      /**< Mode DEFAULT for RTC_CTRL */\r
68 #define RTC_CTRL_EN_DEFAULT              (_RTC_CTRL_EN_DEFAULT << 0)       /**< Shifted mode DEFAULT for RTC_CTRL */\r
69 #define RTC_CTRL_DEBUGRUN                (0x1UL << 1)                      /**< Debug Mode Run Enable */\r
70 #define _RTC_CTRL_DEBUGRUN_SHIFT         1                                 /**< Shift value for RTC_DEBUGRUN */\r
71 #define _RTC_CTRL_DEBUGRUN_MASK          0x2UL                             /**< Bit mask for RTC_DEBUGRUN */\r
72 #define _RTC_CTRL_DEBUGRUN_DEFAULT       0x00000000UL                      /**< Mode DEFAULT for RTC_CTRL */\r
73 #define RTC_CTRL_DEBUGRUN_DEFAULT        (_RTC_CTRL_DEBUGRUN_DEFAULT << 1) /**< Shifted mode DEFAULT for RTC_CTRL */\r
74 #define RTC_CTRL_COMP0TOP                (0x1UL << 2)                      /**< Compare Channel 0 is Top Value */\r
75 #define _RTC_CTRL_COMP0TOP_SHIFT         2                                 /**< Shift value for RTC_COMP0TOP */\r
76 #define _RTC_CTRL_COMP0TOP_MASK          0x4UL                             /**< Bit mask for RTC_COMP0TOP */\r
77 #define _RTC_CTRL_COMP0TOP_DEFAULT       0x00000000UL                      /**< Mode DEFAULT for RTC_CTRL */\r
78 #define _RTC_CTRL_COMP0TOP_DISABLE       0x00000000UL                      /**< Mode DISABLE for RTC_CTRL */\r
79 #define _RTC_CTRL_COMP0TOP_ENABLE        0x00000001UL                      /**< Mode ENABLE for RTC_CTRL */\r
80 #define RTC_CTRL_COMP0TOP_DEFAULT        (_RTC_CTRL_COMP0TOP_DEFAULT << 2) /**< Shifted mode DEFAULT for RTC_CTRL */\r
81 #define RTC_CTRL_COMP0TOP_DISABLE        (_RTC_CTRL_COMP0TOP_DISABLE << 2) /**< Shifted mode DISABLE for RTC_CTRL */\r
82 #define RTC_CTRL_COMP0TOP_ENABLE         (_RTC_CTRL_COMP0TOP_ENABLE << 2)  /**< Shifted mode ENABLE for RTC_CTRL */\r
83 \r
84 /* Bit fields for RTC CNT */\r
85 #define _RTC_CNT_RESETVALUE              0x00000000UL                /**< Default value for RTC_CNT */\r
86 #define _RTC_CNT_MASK                    0x00FFFFFFUL                /**< Mask for RTC_CNT */\r
87 #define _RTC_CNT_CNT_SHIFT               0                           /**< Shift value for RTC_CNT */\r
88 #define _RTC_CNT_CNT_MASK                0xFFFFFFUL                  /**< Bit mask for RTC_CNT */\r
89 #define _RTC_CNT_CNT_DEFAULT             0x00000000UL                /**< Mode DEFAULT for RTC_CNT */\r
90 #define RTC_CNT_CNT_DEFAULT              (_RTC_CNT_CNT_DEFAULT << 0) /**< Shifted mode DEFAULT for RTC_CNT */\r
91 \r
92 /* Bit fields for RTC COMP0 */\r
93 #define _RTC_COMP0_RESETVALUE            0x00000000UL                    /**< Default value for RTC_COMP0 */\r
94 #define _RTC_COMP0_MASK                  0x00FFFFFFUL                    /**< Mask for RTC_COMP0 */\r
95 #define _RTC_COMP0_COMP0_SHIFT           0                               /**< Shift value for RTC_COMP0 */\r
96 #define _RTC_COMP0_COMP0_MASK            0xFFFFFFUL                      /**< Bit mask for RTC_COMP0 */\r
97 #define _RTC_COMP0_COMP0_DEFAULT         0x00000000UL                    /**< Mode DEFAULT for RTC_COMP0 */\r
98 #define RTC_COMP0_COMP0_DEFAULT          (_RTC_COMP0_COMP0_DEFAULT << 0) /**< Shifted mode DEFAULT for RTC_COMP0 */\r
99 \r
100 /* Bit fields for RTC COMP1 */\r
101 #define _RTC_COMP1_RESETVALUE            0x00000000UL                    /**< Default value for RTC_COMP1 */\r
102 #define _RTC_COMP1_MASK                  0x00FFFFFFUL                    /**< Mask for RTC_COMP1 */\r
103 #define _RTC_COMP1_COMP1_SHIFT           0                               /**< Shift value for RTC_COMP1 */\r
104 #define _RTC_COMP1_COMP1_MASK            0xFFFFFFUL                      /**< Bit mask for RTC_COMP1 */\r
105 #define _RTC_COMP1_COMP1_DEFAULT         0x00000000UL                    /**< Mode DEFAULT for RTC_COMP1 */\r
106 #define RTC_COMP1_COMP1_DEFAULT          (_RTC_COMP1_COMP1_DEFAULT << 0) /**< Shifted mode DEFAULT for RTC_COMP1 */\r
107 \r
108 /* Bit fields for RTC IF */\r
109 #define _RTC_IF_RESETVALUE               0x00000000UL                 /**< Default value for RTC_IF */\r
110 #define _RTC_IF_MASK                     0x00000007UL                 /**< Mask for RTC_IF */\r
111 #define RTC_IF_OF                        (0x1UL << 0)                 /**< Overflow Interrupt Flag */\r
112 #define _RTC_IF_OF_SHIFT                 0                            /**< Shift value for RTC_OF */\r
113 #define _RTC_IF_OF_MASK                  0x1UL                        /**< Bit mask for RTC_OF */\r
114 #define _RTC_IF_OF_DEFAULT               0x00000000UL                 /**< Mode DEFAULT for RTC_IF */\r
115 #define RTC_IF_OF_DEFAULT                (_RTC_IF_OF_DEFAULT << 0)    /**< Shifted mode DEFAULT for RTC_IF */\r
116 #define RTC_IF_COMP0                     (0x1UL << 1)                 /**< Compare Match 0 Interrupt Flag */\r
117 #define _RTC_IF_COMP0_SHIFT              1                            /**< Shift value for RTC_COMP0 */\r
118 #define _RTC_IF_COMP0_MASK               0x2UL                        /**< Bit mask for RTC_COMP0 */\r
119 #define _RTC_IF_COMP0_DEFAULT            0x00000000UL                 /**< Mode DEFAULT for RTC_IF */\r
120 #define RTC_IF_COMP0_DEFAULT             (_RTC_IF_COMP0_DEFAULT << 1) /**< Shifted mode DEFAULT for RTC_IF */\r
121 #define RTC_IF_COMP1                     (0x1UL << 2)                 /**< Compare Match 1 Interrupt Flag */\r
122 #define _RTC_IF_COMP1_SHIFT              2                            /**< Shift value for RTC_COMP1 */\r
123 #define _RTC_IF_COMP1_MASK               0x4UL                        /**< Bit mask for RTC_COMP1 */\r
124 #define _RTC_IF_COMP1_DEFAULT            0x00000000UL                 /**< Mode DEFAULT for RTC_IF */\r
125 #define RTC_IF_COMP1_DEFAULT             (_RTC_IF_COMP1_DEFAULT << 2) /**< Shifted mode DEFAULT for RTC_IF */\r
126 \r
127 /* Bit fields for RTC IFS */\r
128 #define _RTC_IFS_RESETVALUE              0x00000000UL                  /**< Default value for RTC_IFS */\r
129 #define _RTC_IFS_MASK                    0x00000007UL                  /**< Mask for RTC_IFS */\r
130 #define RTC_IFS_OF                       (0x1UL << 0)                  /**< Set Overflow Interrupt Flag */\r
131 #define _RTC_IFS_OF_SHIFT                0                             /**< Shift value for RTC_OF */\r
132 #define _RTC_IFS_OF_MASK                 0x1UL                         /**< Bit mask for RTC_OF */\r
133 #define _RTC_IFS_OF_DEFAULT              0x00000000UL                  /**< Mode DEFAULT for RTC_IFS */\r
134 #define RTC_IFS_OF_DEFAULT               (_RTC_IFS_OF_DEFAULT << 0)    /**< Shifted mode DEFAULT for RTC_IFS */\r
135 #define RTC_IFS_COMP0                    (0x1UL << 1)                  /**< Set Compare match 0 Interrupt Flag */\r
136 #define _RTC_IFS_COMP0_SHIFT             1                             /**< Shift value for RTC_COMP0 */\r
137 #define _RTC_IFS_COMP0_MASK              0x2UL                         /**< Bit mask for RTC_COMP0 */\r
138 #define _RTC_IFS_COMP0_DEFAULT           0x00000000UL                  /**< Mode DEFAULT for RTC_IFS */\r
139 #define RTC_IFS_COMP0_DEFAULT            (_RTC_IFS_COMP0_DEFAULT << 1) /**< Shifted mode DEFAULT for RTC_IFS */\r
140 #define RTC_IFS_COMP1                    (0x1UL << 2)                  /**< Set Compare match 1 Interrupt Flag */\r
141 #define _RTC_IFS_COMP1_SHIFT             2                             /**< Shift value for RTC_COMP1 */\r
142 #define _RTC_IFS_COMP1_MASK              0x4UL                         /**< Bit mask for RTC_COMP1 */\r
143 #define _RTC_IFS_COMP1_DEFAULT           0x00000000UL                  /**< Mode DEFAULT for RTC_IFS */\r
144 #define RTC_IFS_COMP1_DEFAULT            (_RTC_IFS_COMP1_DEFAULT << 2) /**< Shifted mode DEFAULT for RTC_IFS */\r
145 \r
146 /* Bit fields for RTC IFC */\r
147 #define _RTC_IFC_RESETVALUE              0x00000000UL                  /**< Default value for RTC_IFC */\r
148 #define _RTC_IFC_MASK                    0x00000007UL                  /**< Mask for RTC_IFC */\r
149 #define RTC_IFC_OF                       (0x1UL << 0)                  /**< Clear Overflow Interrupt Flag */\r
150 #define _RTC_IFC_OF_SHIFT                0                             /**< Shift value for RTC_OF */\r
151 #define _RTC_IFC_OF_MASK                 0x1UL                         /**< Bit mask for RTC_OF */\r
152 #define _RTC_IFC_OF_DEFAULT              0x00000000UL                  /**< Mode DEFAULT for RTC_IFC */\r
153 #define RTC_IFC_OF_DEFAULT               (_RTC_IFC_OF_DEFAULT << 0)    /**< Shifted mode DEFAULT for RTC_IFC */\r
154 #define RTC_IFC_COMP0                    (0x1UL << 1)                  /**< Clear Compare match 0 Interrupt Flag */\r
155 #define _RTC_IFC_COMP0_SHIFT             1                             /**< Shift value for RTC_COMP0 */\r
156 #define _RTC_IFC_COMP0_MASK              0x2UL                         /**< Bit mask for RTC_COMP0 */\r
157 #define _RTC_IFC_COMP0_DEFAULT           0x00000000UL                  /**< Mode DEFAULT for RTC_IFC */\r
158 #define RTC_IFC_COMP0_DEFAULT            (_RTC_IFC_COMP0_DEFAULT << 1) /**< Shifted mode DEFAULT for RTC_IFC */\r
159 #define RTC_IFC_COMP1                    (0x1UL << 2)                  /**< Clear Compare match 1 Interrupt Flag */\r
160 #define _RTC_IFC_COMP1_SHIFT             2                             /**< Shift value for RTC_COMP1 */\r
161 #define _RTC_IFC_COMP1_MASK              0x4UL                         /**< Bit mask for RTC_COMP1 */\r
162 #define _RTC_IFC_COMP1_DEFAULT           0x00000000UL                  /**< Mode DEFAULT for RTC_IFC */\r
163 #define RTC_IFC_COMP1_DEFAULT            (_RTC_IFC_COMP1_DEFAULT << 2) /**< Shifted mode DEFAULT for RTC_IFC */\r
164 \r
165 /* Bit fields for RTC IEN */\r
166 #define _RTC_IEN_RESETVALUE              0x00000000UL                  /**< Default value for RTC_IEN */\r
167 #define _RTC_IEN_MASK                    0x00000007UL                  /**< Mask for RTC_IEN */\r
168 #define RTC_IEN_OF                       (0x1UL << 0)                  /**< Overflow Interrupt Enable */\r
169 #define _RTC_IEN_OF_SHIFT                0                             /**< Shift value for RTC_OF */\r
170 #define _RTC_IEN_OF_MASK                 0x1UL                         /**< Bit mask for RTC_OF */\r
171 #define _RTC_IEN_OF_DEFAULT              0x00000000UL                  /**< Mode DEFAULT for RTC_IEN */\r
172 #define RTC_IEN_OF_DEFAULT               (_RTC_IEN_OF_DEFAULT << 0)    /**< Shifted mode DEFAULT for RTC_IEN */\r
173 #define RTC_IEN_COMP0                    (0x1UL << 1)                  /**< Compare Match 0 Interrupt Enable */\r
174 #define _RTC_IEN_COMP0_SHIFT             1                             /**< Shift value for RTC_COMP0 */\r
175 #define _RTC_IEN_COMP0_MASK              0x2UL                         /**< Bit mask for RTC_COMP0 */\r
176 #define _RTC_IEN_COMP0_DEFAULT           0x00000000UL                  /**< Mode DEFAULT for RTC_IEN */\r
177 #define RTC_IEN_COMP0_DEFAULT            (_RTC_IEN_COMP0_DEFAULT << 1) /**< Shifted mode DEFAULT for RTC_IEN */\r
178 #define RTC_IEN_COMP1                    (0x1UL << 2)                  /**< Compare Match 1 Interrupt Enable */\r
179 #define _RTC_IEN_COMP1_SHIFT             2                             /**< Shift value for RTC_COMP1 */\r
180 #define _RTC_IEN_COMP1_MASK              0x4UL                         /**< Bit mask for RTC_COMP1 */\r
181 #define _RTC_IEN_COMP1_DEFAULT           0x00000000UL                  /**< Mode DEFAULT for RTC_IEN */\r
182 #define RTC_IEN_COMP1_DEFAULT            (_RTC_IEN_COMP1_DEFAULT << 2) /**< Shifted mode DEFAULT for RTC_IEN */\r
183 \r
184 /* Bit fields for RTC FREEZE */\r
185 #define _RTC_FREEZE_RESETVALUE           0x00000000UL                         /**< Default value for RTC_FREEZE */\r
186 #define _RTC_FREEZE_MASK                 0x00000001UL                         /**< Mask for RTC_FREEZE */\r
187 #define RTC_FREEZE_REGFREEZE             (0x1UL << 0)                         /**< Register Update Freeze */\r
188 #define _RTC_FREEZE_REGFREEZE_SHIFT      0                                    /**< Shift value for RTC_REGFREEZE */\r
189 #define _RTC_FREEZE_REGFREEZE_MASK       0x1UL                                /**< Bit mask for RTC_REGFREEZE */\r
190 #define _RTC_FREEZE_REGFREEZE_DEFAULT    0x00000000UL                         /**< Mode DEFAULT for RTC_FREEZE */\r
191 #define _RTC_FREEZE_REGFREEZE_UPDATE     0x00000000UL                         /**< Mode UPDATE for RTC_FREEZE */\r
192 #define _RTC_FREEZE_REGFREEZE_FREEZE     0x00000001UL                         /**< Mode FREEZE for RTC_FREEZE */\r
193 #define RTC_FREEZE_REGFREEZE_DEFAULT     (_RTC_FREEZE_REGFREEZE_DEFAULT << 0) /**< Shifted mode DEFAULT for RTC_FREEZE */\r
194 #define RTC_FREEZE_REGFREEZE_UPDATE      (_RTC_FREEZE_REGFREEZE_UPDATE << 0)  /**< Shifted mode UPDATE for RTC_FREEZE */\r
195 #define RTC_FREEZE_REGFREEZE_FREEZE      (_RTC_FREEZE_REGFREEZE_FREEZE << 0)  /**< Shifted mode FREEZE for RTC_FREEZE */\r
196 \r
197 /* Bit fields for RTC SYNCBUSY */\r
198 #define _RTC_SYNCBUSY_RESETVALUE         0x00000000UL                       /**< Default value for RTC_SYNCBUSY */\r
199 #define _RTC_SYNCBUSY_MASK               0x00000007UL                       /**< Mask for RTC_SYNCBUSY */\r
200 #define RTC_SYNCBUSY_CTRL                (0x1UL << 0)                       /**< CTRL Register Busy */\r
201 #define _RTC_SYNCBUSY_CTRL_SHIFT         0                                  /**< Shift value for RTC_CTRL */\r
202 #define _RTC_SYNCBUSY_CTRL_MASK          0x1UL                              /**< Bit mask for RTC_CTRL */\r
203 #define _RTC_SYNCBUSY_CTRL_DEFAULT       0x00000000UL                       /**< Mode DEFAULT for RTC_SYNCBUSY */\r
204 #define RTC_SYNCBUSY_CTRL_DEFAULT        (_RTC_SYNCBUSY_CTRL_DEFAULT << 0)  /**< Shifted mode DEFAULT for RTC_SYNCBUSY */\r
205 #define RTC_SYNCBUSY_COMP0               (0x1UL << 1)                       /**< COMP0 Register Busy */\r
206 #define _RTC_SYNCBUSY_COMP0_SHIFT        1                                  /**< Shift value for RTC_COMP0 */\r
207 #define _RTC_SYNCBUSY_COMP0_MASK         0x2UL                              /**< Bit mask for RTC_COMP0 */\r
208 #define _RTC_SYNCBUSY_COMP0_DEFAULT      0x00000000UL                       /**< Mode DEFAULT for RTC_SYNCBUSY */\r
209 #define RTC_SYNCBUSY_COMP0_DEFAULT       (_RTC_SYNCBUSY_COMP0_DEFAULT << 1) /**< Shifted mode DEFAULT for RTC_SYNCBUSY */\r
210 #define RTC_SYNCBUSY_COMP1               (0x1UL << 2)                       /**< COMP1 Register Busy */\r
211 #define _RTC_SYNCBUSY_COMP1_SHIFT        2                                  /**< Shift value for RTC_COMP1 */\r
212 #define _RTC_SYNCBUSY_COMP1_MASK         0x4UL                              /**< Bit mask for RTC_COMP1 */\r
213 #define _RTC_SYNCBUSY_COMP1_DEFAULT      0x00000000UL                       /**< Mode DEFAULT for RTC_SYNCBUSY */\r
214 #define RTC_SYNCBUSY_COMP1_DEFAULT       (_RTC_SYNCBUSY_COMP1_DEFAULT << 2) /**< Shifted mode DEFAULT for RTC_SYNCBUSY */\r
215 \r
216 /** @} End of group EFM32WG_RTC */\r
217 /** @} End of group Parts */\r
218 \r