MAX32670 Peripheral Driver API
Peripheral Driver API for the MAX32670
All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Modules Pages
icc_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_MAX32670_INCLUDE_ICC_REGS_H_
29#define LIBRARIES_CMSIS_DEVICE_MAXIM_MAX32670_INCLUDE_ICC_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 __I uint32_t info;
78 __I uint32_t sz;
79 __R uint32_t rsv_0x8_0xff[62];
80 __IO uint32_t ctrl;
81 __R uint32_t rsv_0x104_0x6ff[383];
82 __IO uint32_t invalidate;
84
85/* Register offsets for module ICC */
92#define MXC_R_ICC_INFO ((uint32_t)0x00000000UL)
93#define MXC_R_ICC_SZ ((uint32_t)0x00000004UL)
94#define MXC_R_ICC_CTRL ((uint32_t)0x00000100UL)
95#define MXC_R_ICC_INVALIDATE ((uint32_t)0x00000700UL)
104#define MXC_F_ICC_INFO_RELNUM_POS 0
105#define MXC_F_ICC_INFO_RELNUM ((uint32_t)(0x3FUL << MXC_F_ICC_INFO_RELNUM_POS))
107#define MXC_F_ICC_INFO_PARTNUM_POS 6
108#define MXC_F_ICC_INFO_PARTNUM ((uint32_t)(0xFUL << MXC_F_ICC_INFO_PARTNUM_POS))
110#define MXC_F_ICC_INFO_ID_POS 10
111#define MXC_F_ICC_INFO_ID ((uint32_t)(0x3FUL << MXC_F_ICC_INFO_ID_POS))
121#define MXC_F_ICC_SZ_CCH_POS 0
122#define MXC_F_ICC_SZ_CCH ((uint32_t)(0xFFFFUL << MXC_F_ICC_SZ_CCH_POS))
124#define MXC_F_ICC_SZ_MEM_POS 16
125#define MXC_F_ICC_SZ_MEM ((uint32_t)(0xFFFFUL << MXC_F_ICC_SZ_MEM_POS))
135#define MXC_F_ICC_CTRL_EN_POS 0
136#define MXC_F_ICC_CTRL_EN ((uint32_t)(0x1UL << MXC_F_ICC_CTRL_EN_POS))
138#define MXC_F_ICC_CTRL_RDY_POS 16
139#define MXC_F_ICC_CTRL_RDY ((uint32_t)(0x1UL << MXC_F_ICC_CTRL_RDY_POS))
149#define MXC_F_ICC_INVALIDATE_INVALID_POS 0
150#define MXC_F_ICC_INVALIDATE_INVALID ((uint32_t)(0xFFFFFFFFUL << MXC_F_ICC_INVALIDATE_INVALID_POS))
154#ifdef __cplusplus
155}
156#endif
157
158#endif // LIBRARIES_CMSIS_DEVICE_MAXIM_MAX32670_INCLUDE_ICC_REGS_H_
__I uint32_t sz
Definition: icc_regs.h:78
__I uint32_t info
Definition: icc_regs.h:77
__IO uint32_t ctrl
Definition: icc_regs.h:80
__IO uint32_t invalidate
Definition: icc_regs.h:82
Definition: icc_regs.h:76