MAX32690 Peripheral Driver API
Peripheral Driver API for the MAX32690
All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Modules Pages
mcr_regs.h
Go to the documentation of this file.
1
8/******************************************************************************
9 *
10 * Copyright (C) 2022-2023 Maxim Integrated Products, Inc. (now owned by
11 * Analog Devices, Inc.),
12 * Copyright (C) 2023-2024 Analog Devices, Inc.
13 *
14 * Licensed under the Apache License, Version 2.0 (the "License");
15 * you may not use this file except in compliance with the License.
16 * You may obtain a copy of the License at
17 *
18 * http://www.apache.org/licenses/LICENSE-2.0
19 *
20 * Unless required by applicable law or agreed to in writing, software
21 * distributed under the License is distributed on an "AS IS" BASIS,
22 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
23 * See the License for the specific language governing permissions and
24 * limitations under the License.
25 *
26 ******************************************************************************/
27
28#ifndef LIBRARIES_CMSIS_DEVICE_MAXIM_MAX32690_INCLUDE_MCR_REGS_H_
29#define LIBRARIES_CMSIS_DEVICE_MAXIM_MAX32690_INCLUDE_MCR_REGS_H_
30
31/* **** Includes **** */
32#include <stdint.h>
33
34#ifdef __cplusplus
35extern "C" {
36#endif
37
38#if defined (__ICCARM__)
39 #pragma system_include
40#endif
41
42#if defined (__CC_ARM)
43 #pragma anon_unions
44#endif
46/*
47 If types are not defined elsewhere (CMSIS) define them here
48*/
49#ifndef __IO
50#define __IO volatile
51#endif
52#ifndef __I
53#define __I volatile const
54#endif
55#ifndef __O
56#define __O volatile
57#endif
58#ifndef __R
59#define __R volatile const
60#endif
62
63/* **** Definitions **** */
64
76typedef struct {
77 __IO uint32_t eccen;
78 __IO uint32_t ipo_mtrim;
79 __IO uint32_t outen;
80 __IO uint32_t cmp_ctrl;
81 __IO uint32_t ctrl;
82 __R uint32_t rsv_0x14_0x1f[3];
83 __IO uint32_t gpio4_ctrl;
84 __R uint32_t rsv_0x24_0x3f[7];
85 __IO uint32_t cwd0;
86 __IO uint32_t cwd1;
87 __R uint32_t rsv_0x48_0x4f[2];
88 __IO uint32_t adccfg0;
89 __IO uint32_t adccfg1;
90 __IO uint32_t adccfg2;
91 __R uint32_t rsv_0x5c;
92 __IO uint32_t ldoctrl;
94
95/* Register offsets for module MCR */
102#define MXC_R_MCR_ECCEN ((uint32_t)0x00000000UL)
103#define MXC_R_MCR_IPO_MTRIM ((uint32_t)0x00000004UL)
104#define MXC_R_MCR_OUTEN ((uint32_t)0x00000008UL)
105#define MXC_R_MCR_CMP_CTRL ((uint32_t)0x0000000CUL)
106#define MXC_R_MCR_CTRL ((uint32_t)0x00000010UL)
107#define MXC_R_MCR_GPIO4_CTRL ((uint32_t)0x00000020UL)
108#define MXC_R_MCR_CWD0 ((uint32_t)0x00000040UL)
109#define MXC_R_MCR_CWD1 ((uint32_t)0x00000044UL)
110#define MXC_R_MCR_ADCCFG0 ((uint32_t)0x00000050UL)
111#define MXC_R_MCR_ADCCFG1 ((uint32_t)0x00000054UL)
112#define MXC_R_MCR_ADCCFG2 ((uint32_t)0x00000058UL)
113#define MXC_R_MCR_LDOCTRL ((uint32_t)0x00000060UL)
122#define MXC_F_MCR_ECCEN_RAM0_POS 0
123#define MXC_F_MCR_ECCEN_RAM0 ((uint32_t)(0x1UL << MXC_F_MCR_ECCEN_RAM0_POS))
125#define MXC_F_MCR_ECCEN_RAM1_POS 1
126#define MXC_F_MCR_ECCEN_RAM1 ((uint32_t)(0x1UL << MXC_F_MCR_ECCEN_RAM1_POS))
128#define MXC_F_MCR_ECCEN_RAM2_POS 2
129#define MXC_F_MCR_ECCEN_RAM2 ((uint32_t)(0x1UL << MXC_F_MCR_ECCEN_RAM2_POS))
131#define MXC_F_MCR_ECCEN_RAM3_POS 3
132#define MXC_F_MCR_ECCEN_RAM3 ((uint32_t)(0x1UL << MXC_F_MCR_ECCEN_RAM3_POS))
134#define MXC_F_MCR_ECCEN_RAM4_POS 4
135#define MXC_F_MCR_ECCEN_RAM4 ((uint32_t)(0x1UL << MXC_F_MCR_ECCEN_RAM4_POS))
137#define MXC_F_MCR_ECCEN_RAM5_POS 5
138#define MXC_F_MCR_ECCEN_RAM5 ((uint32_t)(0x1UL << MXC_F_MCR_ECCEN_RAM5_POS))
140#define MXC_F_MCR_ECCEN_RAM6_POS 6
141#define MXC_F_MCR_ECCEN_RAM6 ((uint32_t)(0x1UL << MXC_F_MCR_ECCEN_RAM6_POS))
143#define MXC_F_MCR_ECCEN_ICACHE0_POS 8
144#define MXC_F_MCR_ECCEN_ICACHE0 ((uint32_t)(0x1UL << MXC_F_MCR_ECCEN_ICACHE0_POS))
146#define MXC_F_MCR_ECCEN_ICACHEXIP_POS 10
147#define MXC_F_MCR_ECCEN_ICACHEXIP ((uint32_t)(0x1UL << MXC_F_MCR_ECCEN_ICACHEXIP_POS))
157#define MXC_F_MCR_IPO_MTRIM_MTRIM_POS 0
158#define MXC_F_MCR_IPO_MTRIM_MTRIM ((uint32_t)(0xFFUL << MXC_F_MCR_IPO_MTRIM_MTRIM_POS))
160#define MXC_F_MCR_IPO_MTRIM_TRIM_RANGE_POS 8
161#define MXC_F_MCR_IPO_MTRIM_TRIM_RANGE ((uint32_t)(0x1UL << MXC_F_MCR_IPO_MTRIM_TRIM_RANGE_POS))
171#define MXC_F_MCR_OUTEN_SQWOUT_EN_POS 0
172#define MXC_F_MCR_OUTEN_SQWOUT_EN ((uint32_t)(0x1UL << MXC_F_MCR_OUTEN_SQWOUT_EN_POS))
174#define MXC_F_MCR_OUTEN_PDOWN_OUT_EN_POS 1
175#define MXC_F_MCR_OUTEN_PDOWN_OUT_EN ((uint32_t)(0x1UL << MXC_F_MCR_OUTEN_PDOWN_OUT_EN_POS))
185#define MXC_F_MCR_CMP_CTRL_EN_POS 0
186#define MXC_F_MCR_CMP_CTRL_EN ((uint32_t)(0x1UL << MXC_F_MCR_CMP_CTRL_EN_POS))
188#define MXC_F_MCR_CMP_CTRL_POL_POS 5
189#define MXC_F_MCR_CMP_CTRL_POL ((uint32_t)(0x1UL << MXC_F_MCR_CMP_CTRL_POL_POS))
191#define MXC_F_MCR_CMP_CTRL_INT_EN_POS 6
192#define MXC_F_MCR_CMP_CTRL_INT_EN ((uint32_t)(0x1UL << MXC_F_MCR_CMP_CTRL_INT_EN_POS))
194#define MXC_F_MCR_CMP_CTRL_OUT_POS 14
195#define MXC_F_MCR_CMP_CTRL_OUT ((uint32_t)(0x1UL << MXC_F_MCR_CMP_CTRL_OUT_POS))
197#define MXC_F_MCR_CMP_CTRL_INT_FL_POS 15
198#define MXC_F_MCR_CMP_CTRL_INT_FL ((uint32_t)(0x1UL << MXC_F_MCR_CMP_CTRL_INT_FL_POS))
208#define MXC_F_MCR_CTRL_CMPHYST_POS 0
209#define MXC_F_MCR_CTRL_CMPHYST ((uint32_t)(0x3UL << MXC_F_MCR_CTRL_CMPHYST_POS))
211#define MXC_F_MCR_CTRL_INRO_EN_POS 2
212#define MXC_F_MCR_CTRL_INRO_EN ((uint32_t)(0x1UL << MXC_F_MCR_CTRL_INRO_EN_POS))
214#define MXC_F_MCR_CTRL_ERTCO_EN_POS 3
215#define MXC_F_MCR_CTRL_ERTCO_EN ((uint32_t)(0x1UL << MXC_F_MCR_CTRL_ERTCO_EN_POS))
217#define MXC_F_MCR_CTRL_IBRO_EN_POS 4
218#define MXC_F_MCR_CTRL_IBRO_EN ((uint32_t)(0x1UL << MXC_F_MCR_CTRL_IBRO_EN_POS))
220#define MXC_F_MCR_CTRL_RSTNP1M_POS 9
221#define MXC_F_MCR_CTRL_RSTNP1M ((uint32_t)(0x1UL << MXC_F_MCR_CTRL_RSTNP1M_POS))
223#define MXC_F_MCR_CTRL_RSTNVDDIOHSEL_POS 10
224#define MXC_F_MCR_CTRL_RSTNVDDIOHSEL ((uint32_t)(0x1UL << MXC_F_MCR_CTRL_RSTNVDDIOHSEL_POS))
234#define MXC_F_MCR_GPIO4_CTRL_P40_DO_POS 0
235#define MXC_F_MCR_GPIO4_CTRL_P40_DO ((uint32_t)(0x1UL << MXC_F_MCR_GPIO4_CTRL_P40_DO_POS))
237#define MXC_F_MCR_GPIO4_CTRL_P40_OE_POS 1
238#define MXC_F_MCR_GPIO4_CTRL_P40_OE ((uint32_t)(0x1UL << MXC_F_MCR_GPIO4_CTRL_P40_OE_POS))
240#define MXC_F_MCR_GPIO4_CTRL_P40_PE_POS 2
241#define MXC_F_MCR_GPIO4_CTRL_P40_PE ((uint32_t)(0x1UL << MXC_F_MCR_GPIO4_CTRL_P40_PE_POS))
243#define MXC_F_MCR_GPIO4_CTRL_P40_IN_POS 3
244#define MXC_F_MCR_GPIO4_CTRL_P40_IN ((uint32_t)(0x1UL << MXC_F_MCR_GPIO4_CTRL_P40_IN_POS))
246#define MXC_F_MCR_GPIO4_CTRL_P41_DO_POS 4
247#define MXC_F_MCR_GPIO4_CTRL_P41_DO ((uint32_t)(0x1UL << MXC_F_MCR_GPIO4_CTRL_P41_DO_POS))
249#define MXC_F_MCR_GPIO4_CTRL_P41_OE_POS 5
250#define MXC_F_MCR_GPIO4_CTRL_P41_OE ((uint32_t)(0x1UL << MXC_F_MCR_GPIO4_CTRL_P41_OE_POS))
252#define MXC_F_MCR_GPIO4_CTRL_P41_PE_POS 6
253#define MXC_F_MCR_GPIO4_CTRL_P41_PE ((uint32_t)(0x1UL << MXC_F_MCR_GPIO4_CTRL_P41_PE_POS))
255#define MXC_F_MCR_GPIO4_CTRL_P41_IN_POS 7
256#define MXC_F_MCR_GPIO4_CTRL_P41_IN ((uint32_t)(0x1UL << MXC_F_MCR_GPIO4_CTRL_P41_IN_POS))
266#define MXC_F_MCR_CWD0_DATA_POS 0
267#define MXC_F_MCR_CWD0_DATA ((uint32_t)(0xFFFFFFFFUL << MXC_F_MCR_CWD0_DATA_POS))
277#define MXC_F_MCR_CWD1_DATA_POS 0
278#define MXC_F_MCR_CWD1_DATA ((uint32_t)(0xFFFFFFFFUL << MXC_F_MCR_CWD1_DATA_POS))
288#define MXC_F_MCR_ADCCFG0_LP_5K_DIS_POS 0
289#define MXC_F_MCR_ADCCFG0_LP_5K_DIS ((uint32_t)(0x1UL << MXC_F_MCR_ADCCFG0_LP_5K_DIS_POS))
291#define MXC_F_MCR_ADCCFG0_LP_50K_DIS_POS 1
292#define MXC_F_MCR_ADCCFG0_LP_50K_DIS ((uint32_t)(0x1UL << MXC_F_MCR_ADCCFG0_LP_50K_DIS_POS))
294#define MXC_F_MCR_ADCCFG0_EXT_REF_POS 2
295#define MXC_F_MCR_ADCCFG0_EXT_REF ((uint32_t)(0x1UL << MXC_F_MCR_ADCCFG0_EXT_REF_POS))
297#define MXC_F_MCR_ADCCFG0_REF_SEL_POS 3
298#define MXC_F_MCR_ADCCFG0_REF_SEL ((uint32_t)(0x1UL << MXC_F_MCR_ADCCFG0_REF_SEL_POS))
308#define MXC_F_MCR_ADCCFG1_CHX_PU_DYN_POS 0
309#define MXC_F_MCR_ADCCFG1_CHX_PU_DYN ((uint32_t)(0x1FFFUL << MXC_F_MCR_ADCCFG1_CHX_PU_DYN_POS))
319#define MXC_F_MCR_ADCCFG2_CH0_POS 0
320#define MXC_F_MCR_ADCCFG2_CH0 ((uint32_t)(0x3UL << MXC_F_MCR_ADCCFG2_CH0_POS))
321#define MXC_V_MCR_ADCCFG2_CH0_DIV1 ((uint32_t)0x0UL)
322#define MXC_S_MCR_ADCCFG2_CH0_DIV1 (MXC_V_MCR_ADCCFG2_CH0_DIV1 << MXC_F_MCR_ADCCFG2_CH0_POS)
323#define MXC_V_MCR_ADCCFG2_CH0_DIV2_5K ((uint32_t)0x1UL)
324#define MXC_S_MCR_ADCCFG2_CH0_DIV2_5K (MXC_V_MCR_ADCCFG2_CH0_DIV2_5K << MXC_F_MCR_ADCCFG2_CH0_POS)
325#define MXC_V_MCR_ADCCFG2_CH0_DIV2_50K ((uint32_t)0x2UL)
326#define MXC_S_MCR_ADCCFG2_CH0_DIV2_50K (MXC_V_MCR_ADCCFG2_CH0_DIV2_50K << MXC_F_MCR_ADCCFG2_CH0_POS)
328#define MXC_F_MCR_ADCCFG2_CH1_POS 2
329#define MXC_F_MCR_ADCCFG2_CH1 ((uint32_t)(0x3UL << MXC_F_MCR_ADCCFG2_CH1_POS))
331#define MXC_F_MCR_ADCCFG2_CH2_POS 4
332#define MXC_F_MCR_ADCCFG2_CH2 ((uint32_t)(0x3UL << MXC_F_MCR_ADCCFG2_CH2_POS))
334#define MXC_F_MCR_ADCCFG2_CH3_POS 6
335#define MXC_F_MCR_ADCCFG2_CH3 ((uint32_t)(0x3UL << MXC_F_MCR_ADCCFG2_CH3_POS))
337#define MXC_F_MCR_ADCCFG2_CH4_POS 8
338#define MXC_F_MCR_ADCCFG2_CH4 ((uint32_t)(0x3UL << MXC_F_MCR_ADCCFG2_CH4_POS))
340#define MXC_F_MCR_ADCCFG2_CH5_POS 10
341#define MXC_F_MCR_ADCCFG2_CH5 ((uint32_t)(0x3UL << MXC_F_MCR_ADCCFG2_CH5_POS))
343#define MXC_F_MCR_ADCCFG2_CH6_POS 12
344#define MXC_F_MCR_ADCCFG2_CH6 ((uint32_t)(0x3UL << MXC_F_MCR_ADCCFG2_CH6_POS))
346#define MXC_F_MCR_ADCCFG2_CH7_POS 14
347#define MXC_F_MCR_ADCCFG2_CH7 ((uint32_t)(0x3UL << MXC_F_MCR_ADCCFG2_CH7_POS))
357#define MXC_F_MCR_LDOCTRL_0P9EN_POS 0
358#define MXC_F_MCR_LDOCTRL_0P9EN ((uint32_t)(0x1UL << MXC_F_MCR_LDOCTRL_0P9EN_POS))
360#define MXC_F_MCR_LDOCTRL_2P5EN_POS 1
361#define MXC_F_MCR_LDOCTRL_2P5EN ((uint32_t)(0x1UL << MXC_F_MCR_LDOCTRL_2P5EN_POS))
365#ifdef __cplusplus
366}
367#endif
368
369#endif // LIBRARIES_CMSIS_DEVICE_MAXIM_MAX32690_INCLUDE_MCR_REGS_H_
__IO uint32_t adccfg0
Definition: mcr_regs.h:88
__IO uint32_t gpio4_ctrl
Definition: mcr_regs.h:83
__IO uint32_t cwd1
Definition: mcr_regs.h:86
__IO uint32_t ctrl
Definition: mcr_regs.h:81
__IO uint32_t adccfg2
Definition: mcr_regs.h:90
__IO uint32_t outen
Definition: mcr_regs.h:79
__IO uint32_t ldoctrl
Definition: mcr_regs.h:92
__IO uint32_t cmp_ctrl
Definition: mcr_regs.h:80
__IO uint32_t cwd0
Definition: mcr_regs.h:85
__IO uint32_t ipo_mtrim
Definition: mcr_regs.h:78
__IO uint32_t eccen
Definition: mcr_regs.h:77
__IO uint32_t adccfg1
Definition: mcr_regs.h:89
Definition: mcr_regs.h:76