summaryrefslogtreecommitdiff
path: root/chip/max32660/flc_regs.h
blob: a484763c0b2c015bca9afa18bb557608d2166b14 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
/* Copyright 2019 The Chromium OS Authors. All rights reserved.
 * Use of this source code is governed by a BSD-style license that can be
 * found in the LICENSE file.
 */

/* MAX32660 Registers, Bit Masks and Bit Positions for the FLC Peripheral Module
 */

#ifndef _FLC_REGS_H_
#define _FLC_REGS_H_

/* **** Includes **** */
#include <stdint.h>

#ifdef __cplusplus
extern "C" {
#endif

/*
    If types are not defined elsewhere (CMSIS) define them here
*/
#ifndef __IO
#define __IO volatile
#endif
#ifndef __I
#define __I volatile const
#endif
#ifndef __O
#define __O volatile
#endif
#ifndef __R
#define __R volatile const
#endif

/* **** Definitions **** */

/**
 * Registers, Bit Masks and Bit Positions for the FLC Peripheral
 * Module.
 */

/**
 * Structure type to access the FLC Registers.
 */
typedef struct {
	__IO uint32_t addr;   /**< <tt>\b 0x00:<\tt> FLC ADDR Register */
	__IO uint32_t clkdiv; /**< <tt>\b 0x04:<\tt> FLC CLKDIV Register */
	__IO uint32_t cn;     /**< <tt>\b 0x08:<\tt> FLC CN Register */
	__R uint32_t rsv_0xc_0x23[6];
	__IO uint32_t intr; /**< <tt>\b 0x024:<\tt> FLC INTR Register */
	__R uint32_t rsv_0x28_0x2f[2];
	__IO uint32_t data[4]; /**< <tt>\b 0x30:<\tt> FLC DATA Register */
	__O uint32_t acntl;    /**< <tt>\b 0x40:<\tt> FLC ACNTL Register */
} mxc_flc_regs_t;

/* Register offsets for module FLC */
/**
 * FLC Peripheral Register Offsets from the FLC Base Peripheral
 * Address.
 */
#define MXC_R_FLC_ADDR                                                         \
	((uint32_t)0x00000000UL) /**< Offset from FLC Base Address: <tt>       \
				    0x0x000 */
#define MXC_R_FLC_CLKDIV                                                       \
	((uint32_t)0x00000004UL) /**< Offset from FLC Base Address: <tt>       \
				    0x0x004 */
#define MXC_R_FLC_CN                                                           \
	((uint32_t)0x00000008UL) /**< Offset from FLC Base Address: <tt>       \
				    0x0x008 */
#define MXC_R_FLC_INTR                                                         \
	((uint32_t)0x00000024UL) /**< Offset from FLC Base Address: <tt>       \
				    0x0x024 */
#define MXC_R_FLC_DATA                                                         \
	((uint32_t)0x00000030UL) /**< Offset from FLC Base Address: <tt>       \
				    0x0x030 */
#define MXC_R_FLC_ACNTL                                                        \
	((uint32_t)0x00000040UL) /**< Offset from FLC Base Address: <tt>       \
				    0x0x040 */

/**
 * Flash Write Address.
 */
#define MXC_F_FLC_ADDR_ADDR_POS 0 /**< ADDR_ADDR Position */
#define MXC_F_FLC_ADDR_ADDR                                                    \
	((uint32_t)(0xFFFFFFFFUL                                               \
		    << MXC_F_FLC_ADDR_ADDR_POS)) /**< ADDR_ADDR Mask */

/**
 * Flash Clock Divide. The clock (PLL0) is divided by this value to
 * generate a 1 MHz clock for Flash controller.
 */
#define MXC_F_FLC_CLKDIV_CLKDIV_POS 0 /**< CLKDIV_CLKDIV Position */
#define MXC_F_FLC_CLKDIV_CLKDIV                                                \
	((uint32_t)(                                                           \
		0xFFUL                                                         \
		<< MXC_F_FLC_CLKDIV_CLKDIV_POS)) /**< CLKDIV_CLKDIV Mask */

/**
 * Flash Control Register.
 */
#define MXC_F_FLC_CN_WR_POS 0 /**< CN_WR Position */
#define MXC_F_FLC_CN_WR                                                        \
	((uint32_t)(0x1UL << MXC_F_FLC_CN_WR_POS)) /**< CN_WR Mask */
#define MXC_V_FLC_CN_WR_COMPLETE                                               \
	((uint32_t)0x0UL) /**< CN_WR_COMPLETE Value                            \
			   */
#define MXC_S_FLC_CN_WR_COMPLETE                                               \
	(MXC_V_FLC_CN_WR_COMPLETE                                              \
	 << MXC_F_FLC_CN_WR_POS)		/**< CN_WR_COMPLETE Setting */
#define MXC_V_FLC_CN_WR_START ((uint32_t)0x1UL) /**< CN_WR_START Value */
#define MXC_S_FLC_CN_WR_START                                                  \
	(MXC_V_FLC_CN_WR_START                                                 \
	 << MXC_F_FLC_CN_WR_POS) /**< CN_WR_START Setting */

#define MXC_F_FLC_CN_ME_POS 1 /**< CN_ME Position */
#define MXC_F_FLC_CN_ME                                                        \
	((uint32_t)(0x1UL << MXC_F_FLC_CN_ME_POS)) /**< CN_ME Mask */

#define MXC_F_FLC_CN_PGE_POS 2 /**< CN_PGE Position */
#define MXC_F_FLC_CN_PGE                                                       \
	((uint32_t)(0x1UL << MXC_F_FLC_CN_PGE_POS)) /**< CN_PGE Mask */

#define MXC_F_FLC_CN_WDTH_POS 4 /**< CN_WDTH Position */
#define MXC_F_FLC_CN_WDTH                                                      \
	((uint32_t)(0x1UL << MXC_F_FLC_CN_WDTH_POS)) /**< CN_WDTH Mask */
#define MXC_V_FLC_CN_WDTH_SIZE128                                              \
	((uint32_t)0x0UL) /**< CN_WDTH_SIZE128 Value */
#define MXC_S_FLC_CN_WDTH_SIZE128                                              \
	(MXC_V_FLC_CN_WDTH_SIZE128                                             \
	 << MXC_F_FLC_CN_WDTH_POS) /**< CN_WDTH_SIZE128 Setting */
#define MXC_V_FLC_CN_WDTH_SIZE32                                               \
	((uint32_t)0x1UL) /**< CN_WDTH_SIZE32 Value                            \
			   */
#define MXC_S_FLC_CN_WDTH_SIZE32                                               \
	(MXC_V_FLC_CN_WDTH_SIZE32                                              \
	 << MXC_F_FLC_CN_WDTH_POS) /**< CN_WDTH_SIZE32 Setting */

#define MXC_F_FLC_CN_ERASE_CODE_POS 8 /**< CN_ERASE_CODE Position */
#define MXC_F_FLC_CN_ERASE_CODE                                                \
	((uint32_t)(                                                           \
		0xFFUL                                                         \
		<< MXC_F_FLC_CN_ERASE_CODE_POS)) /**< CN_ERASE_CODE Mask */
#define MXC_V_FLC_CN_ERASE_CODE_NOP                                            \
	((uint32_t)0x0UL) /**< CN_ERASE_CODE_NOP Value */
#define MXC_S_FLC_CN_ERASE_CODE_NOP                                            \
	(MXC_V_FLC_CN_ERASE_CODE_NOP                                           \
	 << MXC_F_FLC_CN_ERASE_CODE_POS) /**< CN_ERASE_CODE_NOP Setting */
#define MXC_V_FLC_CN_ERASE_CODE_ERASEPAGE                                      \
	((uint32_t)0x55UL) /**< CN_ERASE_CODE_ERASEPAGE Value */
#define MXC_S_FLC_CN_ERASE_CODE_ERASEPAGE                                      \
	(MXC_V_FLC_CN_ERASE_CODE_ERASEPAGE                                     \
	 << MXC_F_FLC_CN_ERASE_CODE_POS) /**< CN_ERASE_CODE_ERASEPAGE Setting  \
					  */
#define MXC_V_FLC_CN_ERASE_CODE_ERASEALL                                       \
	((uint32_t)0xAAUL) /**< CN_ERASE_CODE_ERASEALL Value */
#define MXC_S_FLC_CN_ERASE_CODE_ERASEALL                                       \
	(MXC_V_FLC_CN_ERASE_CODE_ERASEALL                                      \
	 << MXC_F_FLC_CN_ERASE_CODE_POS) /**< CN_ERASE_CODE_ERASEALL Setting   \
					  */

#define MXC_F_FLC_CN_PEND_POS 24 /**< CN_PEND Position */
#define MXC_F_FLC_CN_PEND                                                      \
	((uint32_t)(0x1UL << MXC_F_FLC_CN_PEND_POS)) /**< CN_PEND Mask */
#define MXC_V_FLC_CN_PEND_IDLE ((uint32_t)0x0UL)     /**< CN_PEND_IDLE Value */
#define MXC_S_FLC_CN_PEND_IDLE                                                 \
	(MXC_V_FLC_CN_PEND_IDLE                                                \
	 << MXC_F_FLC_CN_PEND_POS)		 /**< CN_PEND_IDLE Setting */
#define MXC_V_FLC_CN_PEND_BUSY ((uint32_t)0x1UL) /**< CN_PEND_BUSY Value */
#define MXC_S_FLC_CN_PEND_BUSY                                                 \
	(MXC_V_FLC_CN_PEND_BUSY                                                \
	 << MXC_F_FLC_CN_PEND_POS) /**< CN_PEND_BUSY Setting */

#define MXC_F_FLC_CN_LVE_POS 25 /**< CN_LVE Position */
#define MXC_F_FLC_CN_LVE                                                       \
	((uint32_t)(0x1UL << MXC_F_FLC_CN_LVE_POS)) /**< CN_LVE Mask */
#define MXC_V_FLC_CN_LVE_DIS ((uint32_t)0x0UL)      /**< CN_LVE_DIS Value */
#define MXC_S_FLC_CN_LVE_DIS                                                   \
	(MXC_V_FLC_CN_LVE_DIS                                                  \
	 << MXC_F_FLC_CN_LVE_POS)	     /**< CN_LVE_DIS Setting */
#define MXC_V_FLC_CN_LVE_EN ((uint32_t)0x1UL) /**< CN_LVE_EN Value */
#define MXC_S_FLC_CN_LVE_EN                                                    \
	(MXC_V_FLC_CN_LVE_EN << MXC_F_FLC_CN_LVE_POS) /**< CN_LVE_EN Setting   \
						       */

#define MXC_F_FLC_CN_BRST_POS 27 /**< CN_BRST Position */
#define MXC_F_FLC_CN_BRST                                                      \
	((uint32_t)(0x1UL << MXC_F_FLC_CN_BRST_POS)) /**< CN_BRST Mask */
#define MXC_V_FLC_CN_BRST_DISABLE                                              \
	((uint32_t)0x0UL) /**< CN_BRST_DISABLE Value */
#define MXC_S_FLC_CN_BRST_DISABLE                                              \
	(MXC_V_FLC_CN_BRST_DISABLE                                             \
	 << MXC_F_FLC_CN_BRST_POS) /**< CN_BRST_DISABLE Setting */
#define MXC_V_FLC_CN_BRST_ENABLE                                               \
	((uint32_t)0x1UL) /**< CN_BRST_ENABLE Value                            \
			   */
#define MXC_S_FLC_CN_BRST_ENABLE                                               \
	(MXC_V_FLC_CN_BRST_ENABLE                                              \
	 << MXC_F_FLC_CN_BRST_POS) /**< CN_BRST_ENABLE Setting */

#define MXC_F_FLC_CN_UNLOCK_POS 28 /**< CN_UNLOCK Position */
#define MXC_F_FLC_CN_UNLOCK                                                    \
	((uint32_t)(0xFUL << MXC_F_FLC_CN_UNLOCK_POS)) /**< CN_UNLOCK Mask */
#define MXC_V_FLC_CN_UNLOCK_UNLOCKED                                           \
	((uint32_t)0x2UL) /**< CN_UNLOCK_UNLOCKED Value */
#define MXC_S_FLC_CN_UNLOCK_UNLOCKED                                           \
	(MXC_V_FLC_CN_UNLOCK_UNLOCKED                                          \
	 << MXC_F_FLC_CN_UNLOCK_POS) /**< CN_UNLOCK_UNLOCKED Setting */

/**
 * Flash Interrupt Register.
 */
#define MXC_F_FLC_INTR_DONE_POS 0 /**< INTR_DONE Position */
#define MXC_F_FLC_INTR_DONE                                                    \
	((uint32_t)(0x1UL << MXC_F_FLC_INTR_DONE_POS)) /**< INTR_DONE Mask */
#define MXC_V_FLC_INTR_DONE_INACTIVE                                           \
	((uint32_t)0x0UL) /**< INTR_DONE_INACTIVE Value */
#define MXC_S_FLC_INTR_DONE_INACTIVE                                           \
	(MXC_V_FLC_INTR_DONE_INACTIVE                                          \
	 << MXC_F_FLC_INTR_DONE_POS) /**< INTR_DONE_INACTIVE Setting */
#define MXC_V_FLC_INTR_DONE_PENDING                                            \
	((uint32_t)0x1UL) /**< INTR_DONE_PENDING Value */
#define MXC_S_FLC_INTR_DONE_PENDING                                            \
	(MXC_V_FLC_INTR_DONE_PENDING                                           \
	 << MXC_F_FLC_INTR_DONE_POS) /**< INTR_DONE_PENDING Setting */

#define MXC_F_FLC_INTR_AF_POS 1 /**< INTR_AF Position */
#define MXC_F_FLC_INTR_AF                                                      \
	((uint32_t)(0x1UL << MXC_F_FLC_INTR_AF_POS)) /**< INTR_AF Mask */
#define MXC_V_FLC_INTR_AF_NOERROR                                              \
	((uint32_t)0x0UL) /**< INTR_AF_NOERROR Value */
#define MXC_S_FLC_INTR_AF_NOERROR                                              \
	(MXC_V_FLC_INTR_AF_NOERROR                                             \
	 << MXC_F_FLC_INTR_AF_POS) /**< INTR_AF_NOERROR Setting */
#define MXC_V_FLC_INTR_AF_ERROR ((uint32_t)0x1UL) /**< INTR_AF_ERROR Value */
#define MXC_S_FLC_INTR_AF_ERROR                                                \
	(MXC_V_FLC_INTR_AF_ERROR                                               \
	 << MXC_F_FLC_INTR_AF_POS) /**< INTR_AF_ERROR Setting */

#define MXC_F_FLC_INTR_DONEIE_POS 8 /**< INTR_DONEIE Position */
#define MXC_F_FLC_INTR_DONEIE                                                  \
	((uint32_t)(                                                           \
		0x1UL << MXC_F_FLC_INTR_DONEIE_POS)) /**< INTR_DONEIE Mask */
#define MXC_V_FLC_INTR_DONEIE_DISABLE                                          \
	((uint32_t)0x0UL) /**< INTR_DONEIE_DISABLE Value */
#define MXC_S_FLC_INTR_DONEIE_DISABLE                                          \
	(MXC_V_FLC_INTR_DONEIE_DISABLE                                         \
	 << MXC_F_FLC_INTR_DONEIE_POS) /**< INTR_DONEIE_DISABLE Setting */
#define MXC_V_FLC_INTR_DONEIE_ENABLE                                           \
	((uint32_t)0x1UL) /**< INTR_DONEIE_ENABLE Value */
#define MXC_S_FLC_INTR_DONEIE_ENABLE                                           \
	(MXC_V_FLC_INTR_DONEIE_ENABLE                                          \
	 << MXC_F_FLC_INTR_DONEIE_POS) /**< INTR_DONEIE_ENABLE Setting */

#define MXC_F_FLC_INTR_AFIE_POS 9 /**< INTR_AFIE Position */
#define MXC_F_FLC_INTR_AFIE                                                    \
	((uint32_t)(0x1UL << MXC_F_FLC_INTR_AFIE_POS)) /**< INTR_AFIE Mask */

/**
 * Flash Write Data.
 */
#define MXC_F_FLC_DATA_DATA_POS 0 /**< DATA_DATA Position */
#define MXC_F_FLC_DATA_DATA                                                    \
	((uint32_t)(0xFFFFFFFFUL                                               \
		    << MXC_F_FLC_DATA_DATA_POS)) /**< DATA_DATA Mask */

/**
 * Access Control Register. Writing the ACNTL register with the
 * following values in the order shown, allows read and write access to the
 * system and user Information block: pflc-acntl = 0x3a7f5ca3; pflc-acntl =
 * 0xa1e34f20; pflc-acntl = 0x9608b2c1. When unlocked, a write of any word will
 * disable access to system and user information block. Readback of this
 * register is always zero.
 */
#define MXC_F_FLC_ACNTL_ACNTL_POS 0 /**< ACNTL_ACNTL Position */
#define MXC_F_FLC_ACNTL_ACNTL                                                  \
	((uint32_t)(0xFFFFFFFFUL                                               \
		    << MXC_F_FLC_ACNTL_ACNTL_POS)) /**< ACNTL_ACNTL Mask */

#ifdef __cplusplus
}
#endif

#endif /* _FLC_REGS_H_ */