1 /***************************************************************************//**
2  * @file
3  * @brief EFM32HG_AES register and bit field definitions
4  *******************************************************************************
5  * # License
6  * <b>Copyright 2022 Silicon Laboratories Inc. www.silabs.com</b>
7  *******************************************************************************
8  *
9  * SPDX-License-Identifier: Zlib
10  *
11  * The licensor of this software is Silicon Laboratories Inc.
12  *
13  * This software is provided 'as-is', without any express or implied
14  * warranty. In no event will the authors be held liable for any damages
15  * arising from the use of this software.
16  *
17  * Permission is granted to anyone to use this software for any purpose,
18  * including commercial applications, and to alter it and redistribute it
19  * freely, subject to the following restrictions:
20  *
21  * 1. The origin of this software must not be misrepresented; you must not
22  *    claim that you wrote the original software. If you use this software
23  *    in a product, an acknowledgment in the product documentation would be
24  *    appreciated but is not required.
25  * 2. Altered source versions must be plainly marked as such, and must not be
26  *    misrepresented as being the original software.
27  * 3. This notice may not be removed or altered from any source distribution.
28  *
29  ******************************************************************************/
30 
31 #if defined(__ICCARM__)
32 #pragma system_include       /* Treat file as system include file. */
33 #elif defined(__ARMCC_VERSION) && (__ARMCC_VERSION >= 6010050)
34 #pragma clang system_header  /* Treat file as system include file. */
35 #endif
36 
37 /***************************************************************************//**
38  * @addtogroup Parts
39  * @{
40  ******************************************************************************/
41 /***************************************************************************//**
42  * @defgroup EFM32HG_AES
43  * @{
44  * @brief EFM32HG_AES Register Declaration
45  ******************************************************************************/
46 typedef struct {
47   __IOM uint32_t CTRL;          /**< Control Register  */
48   __IOM uint32_t CMD;           /**< Command Register  */
49   __IM uint32_t  STATUS;        /**< Status Register  */
50   __IOM uint32_t IEN;           /**< Interrupt Enable Register  */
51   __IM uint32_t  IF;            /**< Interrupt Flag Register  */
52   __IOM uint32_t IFS;           /**< Interrupt Flag Set Register  */
53   __IOM uint32_t IFC;           /**< Interrupt Flag Clear Register  */
54   __IOM uint32_t DATA;          /**< DATA Register  */
55   __IOM uint32_t XORDATA;       /**< XORDATA Register  */
56   uint32_t       RESERVED0[3U]; /**< Reserved for future use **/
57   __IOM uint32_t KEYLA;         /**< KEY Low Register  */
58   __IOM uint32_t KEYLB;         /**< KEY Low Register  */
59   __IOM uint32_t KEYLC;         /**< KEY Low Register  */
60   __IOM uint32_t KEYLD;         /**< KEY Low Register  */
61 } AES_TypeDef;                  /**< AES Register Declaration *//** @} */
62 
63 /***************************************************************************//**
64  * @defgroup EFM32HG_AES_BitFields
65  * @{
66  ******************************************************************************/
67 
68 /* Bit fields for AES CTRL */
69 #define _AES_CTRL_RESETVALUE            0x00000000UL                       /**< Default value for AES_CTRL */
70 #define _AES_CTRL_MASK                  0x00000071UL                       /**< Mask for AES_CTRL */
71 #define AES_CTRL_DECRYPT                (0x1UL << 0)                       /**< Decryption/Encryption Mode */
72 #define _AES_CTRL_DECRYPT_SHIFT         0                                  /**< Shift value for AES_DECRYPT */
73 #define _AES_CTRL_DECRYPT_MASK          0x1UL                              /**< Bit mask for AES_DECRYPT */
74 #define _AES_CTRL_DECRYPT_DEFAULT       0x00000000UL                       /**< Mode DEFAULT for AES_CTRL */
75 #define AES_CTRL_DECRYPT_DEFAULT        (_AES_CTRL_DECRYPT_DEFAULT << 0)   /**< Shifted mode DEFAULT for AES_CTRL */
76 #define AES_CTRL_DATASTART              (0x1UL << 4)                       /**< AES_DATA Write Start */
77 #define _AES_CTRL_DATASTART_SHIFT       4                                  /**< Shift value for AES_DATASTART */
78 #define _AES_CTRL_DATASTART_MASK        0x10UL                             /**< Bit mask for AES_DATASTART */
79 #define _AES_CTRL_DATASTART_DEFAULT     0x00000000UL                       /**< Mode DEFAULT for AES_CTRL */
80 #define AES_CTRL_DATASTART_DEFAULT      (_AES_CTRL_DATASTART_DEFAULT << 4) /**< Shifted mode DEFAULT for AES_CTRL */
81 #define AES_CTRL_XORSTART               (0x1UL << 5)                       /**< AES_XORDATA Write Start */
82 #define _AES_CTRL_XORSTART_SHIFT        5                                  /**< Shift value for AES_XORSTART */
83 #define _AES_CTRL_XORSTART_MASK         0x20UL                             /**< Bit mask for AES_XORSTART */
84 #define _AES_CTRL_XORSTART_DEFAULT      0x00000000UL                       /**< Mode DEFAULT for AES_CTRL */
85 #define AES_CTRL_XORSTART_DEFAULT       (_AES_CTRL_XORSTART_DEFAULT << 5)  /**< Shifted mode DEFAULT for AES_CTRL */
86 #define AES_CTRL_BYTEORDER              (0x1UL << 6)                       /**< Configure byte order in data and key registers */
87 #define _AES_CTRL_BYTEORDER_SHIFT       6                                  /**< Shift value for AES_BYTEORDER */
88 #define _AES_CTRL_BYTEORDER_MASK        0x40UL                             /**< Bit mask for AES_BYTEORDER */
89 #define _AES_CTRL_BYTEORDER_DEFAULT     0x00000000UL                       /**< Mode DEFAULT for AES_CTRL */
90 #define AES_CTRL_BYTEORDER_DEFAULT      (_AES_CTRL_BYTEORDER_DEFAULT << 6) /**< Shifted mode DEFAULT for AES_CTRL */
91 
92 /* Bit fields for AES CMD */
93 #define _AES_CMD_RESETVALUE             0x00000000UL                  /**< Default value for AES_CMD */
94 #define _AES_CMD_MASK                   0x00000003UL                  /**< Mask for AES_CMD */
95 #define AES_CMD_START                   (0x1UL << 0)                  /**< Encryption/Decryption Start */
96 #define _AES_CMD_START_SHIFT            0                             /**< Shift value for AES_START */
97 #define _AES_CMD_START_MASK             0x1UL                         /**< Bit mask for AES_START */
98 #define _AES_CMD_START_DEFAULT          0x00000000UL                  /**< Mode DEFAULT for AES_CMD */
99 #define AES_CMD_START_DEFAULT           (_AES_CMD_START_DEFAULT << 0) /**< Shifted mode DEFAULT for AES_CMD */
100 #define AES_CMD_STOP                    (0x1UL << 1)                  /**< Encryption/Decryption Stop */
101 #define _AES_CMD_STOP_SHIFT             1                             /**< Shift value for AES_STOP */
102 #define _AES_CMD_STOP_MASK              0x2UL                         /**< Bit mask for AES_STOP */
103 #define _AES_CMD_STOP_DEFAULT           0x00000000UL                  /**< Mode DEFAULT for AES_CMD */
104 #define AES_CMD_STOP_DEFAULT            (_AES_CMD_STOP_DEFAULT << 1)  /**< Shifted mode DEFAULT for AES_CMD */
105 
106 /* Bit fields for AES STATUS */
107 #define _AES_STATUS_RESETVALUE          0x00000000UL                       /**< Default value for AES_STATUS */
108 #define _AES_STATUS_MASK                0x00000001UL                       /**< Mask for AES_STATUS */
109 #define AES_STATUS_RUNNING              (0x1UL << 0)                       /**< AES Running */
110 #define _AES_STATUS_RUNNING_SHIFT       0                                  /**< Shift value for AES_RUNNING */
111 #define _AES_STATUS_RUNNING_MASK        0x1UL                              /**< Bit mask for AES_RUNNING */
112 #define _AES_STATUS_RUNNING_DEFAULT     0x00000000UL                       /**< Mode DEFAULT for AES_STATUS */
113 #define AES_STATUS_RUNNING_DEFAULT      (_AES_STATUS_RUNNING_DEFAULT << 0) /**< Shifted mode DEFAULT for AES_STATUS */
114 
115 /* Bit fields for AES IEN */
116 #define _AES_IEN_RESETVALUE             0x00000000UL                 /**< Default value for AES_IEN */
117 #define _AES_IEN_MASK                   0x00000001UL                 /**< Mask for AES_IEN */
118 #define AES_IEN_DONE                    (0x1UL << 0)                 /**< Encryption/Decryption Done Interrupt Enable */
119 #define _AES_IEN_DONE_SHIFT             0                            /**< Shift value for AES_DONE */
120 #define _AES_IEN_DONE_MASK              0x1UL                        /**< Bit mask for AES_DONE */
121 #define _AES_IEN_DONE_DEFAULT           0x00000000UL                 /**< Mode DEFAULT for AES_IEN */
122 #define AES_IEN_DONE_DEFAULT            (_AES_IEN_DONE_DEFAULT << 0) /**< Shifted mode DEFAULT for AES_IEN */
123 
124 /* Bit fields for AES IF */
125 #define _AES_IF_RESETVALUE              0x00000000UL                /**< Default value for AES_IF */
126 #define _AES_IF_MASK                    0x00000001UL                /**< Mask for AES_IF */
127 #define AES_IF_DONE                     (0x1UL << 0)                /**< Encryption/Decryption Done Interrupt Flag */
128 #define _AES_IF_DONE_SHIFT              0                           /**< Shift value for AES_DONE */
129 #define _AES_IF_DONE_MASK               0x1UL                       /**< Bit mask for AES_DONE */
130 #define _AES_IF_DONE_DEFAULT            0x00000000UL                /**< Mode DEFAULT for AES_IF */
131 #define AES_IF_DONE_DEFAULT             (_AES_IF_DONE_DEFAULT << 0) /**< Shifted mode DEFAULT for AES_IF */
132 
133 /* Bit fields for AES IFS */
134 #define _AES_IFS_RESETVALUE             0x00000000UL                 /**< Default value for AES_IFS */
135 #define _AES_IFS_MASK                   0x00000001UL                 /**< Mask for AES_IFS */
136 #define AES_IFS_DONE                    (0x1UL << 0)                 /**< Encryption/Decryption Done Interrupt Flag Set */
137 #define _AES_IFS_DONE_SHIFT             0                            /**< Shift value for AES_DONE */
138 #define _AES_IFS_DONE_MASK              0x1UL                        /**< Bit mask for AES_DONE */
139 #define _AES_IFS_DONE_DEFAULT           0x00000000UL                 /**< Mode DEFAULT for AES_IFS */
140 #define AES_IFS_DONE_DEFAULT            (_AES_IFS_DONE_DEFAULT << 0) /**< Shifted mode DEFAULT for AES_IFS */
141 
142 /* Bit fields for AES IFC */
143 #define _AES_IFC_RESETVALUE             0x00000000UL                 /**< Default value for AES_IFC */
144 #define _AES_IFC_MASK                   0x00000001UL                 /**< Mask for AES_IFC */
145 #define AES_IFC_DONE                    (0x1UL << 0)                 /**< Encryption/Decryption Done Interrupt Flag Clear */
146 #define _AES_IFC_DONE_SHIFT             0                            /**< Shift value for AES_DONE */
147 #define _AES_IFC_DONE_MASK              0x1UL                        /**< Bit mask for AES_DONE */
148 #define _AES_IFC_DONE_DEFAULT           0x00000000UL                 /**< Mode DEFAULT for AES_IFC */
149 #define AES_IFC_DONE_DEFAULT            (_AES_IFC_DONE_DEFAULT << 0) /**< Shifted mode DEFAULT for AES_IFC */
150 
151 /* Bit fields for AES DATA */
152 #define _AES_DATA_RESETVALUE            0x00000000UL                  /**< Default value for AES_DATA */
153 #define _AES_DATA_MASK                  0xFFFFFFFFUL                  /**< Mask for AES_DATA */
154 #define _AES_DATA_DATA_SHIFT            0                             /**< Shift value for AES_DATA */
155 #define _AES_DATA_DATA_MASK             0xFFFFFFFFUL                  /**< Bit mask for AES_DATA */
156 #define _AES_DATA_DATA_DEFAULT          0x00000000UL                  /**< Mode DEFAULT for AES_DATA */
157 #define AES_DATA_DATA_DEFAULT           (_AES_DATA_DATA_DEFAULT << 0) /**< Shifted mode DEFAULT for AES_DATA */
158 
159 /* Bit fields for AES XORDATA */
160 #define _AES_XORDATA_RESETVALUE         0x00000000UL                        /**< Default value for AES_XORDATA */
161 #define _AES_XORDATA_MASK               0xFFFFFFFFUL                        /**< Mask for AES_XORDATA */
162 #define _AES_XORDATA_XORDATA_SHIFT      0                                   /**< Shift value for AES_XORDATA */
163 #define _AES_XORDATA_XORDATA_MASK       0xFFFFFFFFUL                        /**< Bit mask for AES_XORDATA */
164 #define _AES_XORDATA_XORDATA_DEFAULT    0x00000000UL                        /**< Mode DEFAULT for AES_XORDATA */
165 #define AES_XORDATA_XORDATA_DEFAULT     (_AES_XORDATA_XORDATA_DEFAULT << 0) /**< Shifted mode DEFAULT for AES_XORDATA */
166 
167 /* Bit fields for AES KEYLA */
168 #define _AES_KEYLA_RESETVALUE           0x00000000UL                    /**< Default value for AES_KEYLA */
169 #define _AES_KEYLA_MASK                 0xFFFFFFFFUL                    /**< Mask for AES_KEYLA */
170 #define _AES_KEYLA_KEYLA_SHIFT          0                               /**< Shift value for AES_KEYLA */
171 #define _AES_KEYLA_KEYLA_MASK           0xFFFFFFFFUL                    /**< Bit mask for AES_KEYLA */
172 #define _AES_KEYLA_KEYLA_DEFAULT        0x00000000UL                    /**< Mode DEFAULT for AES_KEYLA */
173 #define AES_KEYLA_KEYLA_DEFAULT         (_AES_KEYLA_KEYLA_DEFAULT << 0) /**< Shifted mode DEFAULT for AES_KEYLA */
174 
175 /* Bit fields for AES KEYLB */
176 #define _AES_KEYLB_RESETVALUE           0x00000000UL                    /**< Default value for AES_KEYLB */
177 #define _AES_KEYLB_MASK                 0xFFFFFFFFUL                    /**< Mask for AES_KEYLB */
178 #define _AES_KEYLB_KEYLB_SHIFT          0                               /**< Shift value for AES_KEYLB */
179 #define _AES_KEYLB_KEYLB_MASK           0xFFFFFFFFUL                    /**< Bit mask for AES_KEYLB */
180 #define _AES_KEYLB_KEYLB_DEFAULT        0x00000000UL                    /**< Mode DEFAULT for AES_KEYLB */
181 #define AES_KEYLB_KEYLB_DEFAULT         (_AES_KEYLB_KEYLB_DEFAULT << 0) /**< Shifted mode DEFAULT for AES_KEYLB */
182 
183 /* Bit fields for AES KEYLC */
184 #define _AES_KEYLC_RESETVALUE           0x00000000UL                    /**< Default value for AES_KEYLC */
185 #define _AES_KEYLC_MASK                 0xFFFFFFFFUL                    /**< Mask for AES_KEYLC */
186 #define _AES_KEYLC_KEYLC_SHIFT          0                               /**< Shift value for AES_KEYLC */
187 #define _AES_KEYLC_KEYLC_MASK           0xFFFFFFFFUL                    /**< Bit mask for AES_KEYLC */
188 #define _AES_KEYLC_KEYLC_DEFAULT        0x00000000UL                    /**< Mode DEFAULT for AES_KEYLC */
189 #define AES_KEYLC_KEYLC_DEFAULT         (_AES_KEYLC_KEYLC_DEFAULT << 0) /**< Shifted mode DEFAULT for AES_KEYLC */
190 
191 /* Bit fields for AES KEYLD */
192 #define _AES_KEYLD_RESETVALUE           0x00000000UL                    /**< Default value for AES_KEYLD */
193 #define _AES_KEYLD_MASK                 0xFFFFFFFFUL                    /**< Mask for AES_KEYLD */
194 #define _AES_KEYLD_KEYLD_SHIFT          0                               /**< Shift value for AES_KEYLD */
195 #define _AES_KEYLD_KEYLD_MASK           0xFFFFFFFFUL                    /**< Bit mask for AES_KEYLD */
196 #define _AES_KEYLD_KEYLD_DEFAULT        0x00000000UL                    /**< Mode DEFAULT for AES_KEYLD */
197 #define AES_KEYLD_KEYLD_DEFAULT         (_AES_KEYLD_KEYLD_DEFAULT << 0) /**< Shifted mode DEFAULT for AES_KEYLD */
198 
199 /** @} End of group EFM32HG_AES */
200 /** @} End of group Parts */
201