MAX32650 Peripheral Driver API
Peripheral Driver API for the MAX32650
All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Modules Pages
trng_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_MAX32650_INCLUDE_TRNG_REGS_H_
29#define LIBRARIES_CMSIS_DEVICE_MAXIM_MAX32650_INCLUDE_TRNG_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 ctrl;
78 __I uint32_t data;
80
81/* Register offsets for module TRNG */
88#define MXC_R_TRNG_CTRL ((uint32_t)0x00000000UL)
89#define MXC_R_TRNG_DATA ((uint32_t)0x00000004UL)
98#define MXC_F_TRNG_CTRL_RNG_IE_POS 2
99#define MXC_F_TRNG_CTRL_RNG_IE ((uint32_t)(0x1UL << MXC_F_TRNG_CTRL_RNG_IE_POS))
100#define MXC_V_TRNG_CTRL_RNG_IE_DIS ((uint32_t)0x0UL)
101#define MXC_S_TRNG_CTRL_RNG_IE_DIS (MXC_V_TRNG_CTRL_RNG_IE_DIS << MXC_F_TRNG_CTRL_RNG_IE_POS)
102#define MXC_V_TRNG_CTRL_RNG_IE_EN ((uint32_t)0x1UL)
103#define MXC_S_TRNG_CTRL_RNG_IE_EN (MXC_V_TRNG_CTRL_RNG_IE_EN << MXC_F_TRNG_CTRL_RNG_IE_POS)
105#define MXC_F_TRNG_CTRL_RNG_ISC_POS 3
106#define MXC_F_TRNG_CTRL_RNG_ISC ((uint32_t)(0x1UL << MXC_F_TRNG_CTRL_RNG_ISC_POS))
107#define MXC_V_TRNG_CTRL_RNG_ISC_CLEAR ((uint32_t)0x1UL)
108#define MXC_S_TRNG_CTRL_RNG_ISC_CLEAR (MXC_V_TRNG_CTRL_RNG_ISC_CLEAR << MXC_F_TRNG_CTRL_RNG_ISC_POS)
110#define MXC_F_TRNG_CTRL_RNG_I4S_POS 4
111#define MXC_F_TRNG_CTRL_RNG_I4S ((uint32_t)(0x1UL << MXC_F_TRNG_CTRL_RNG_I4S_POS))
112#define MXC_V_TRNG_CTRL_RNG_I4S_NOT_READY ((uint32_t)0x0UL)
113#define MXC_S_TRNG_CTRL_RNG_I4S_NOT_READY (MXC_V_TRNG_CTRL_RNG_I4S_NOT_READY << MXC_F_TRNG_CTRL_RNG_I4S_POS)
114#define MXC_V_TRNG_CTRL_RNG_I4S_READY ((uint32_t)0x1UL)
115#define MXC_S_TRNG_CTRL_RNG_I4S_READY (MXC_V_TRNG_CTRL_RNG_I4S_READY << MXC_F_TRNG_CTRL_RNG_I4S_POS)
117#define MXC_F_TRNG_CTRL_RNG_IS_POS 5
118#define MXC_F_TRNG_CTRL_RNG_IS ((uint32_t)(0x1UL << MXC_F_TRNG_CTRL_RNG_IS_POS))
119#define MXC_V_TRNG_CTRL_RNG_IS_NOT_READY ((uint32_t)0x0UL)
120#define MXC_S_TRNG_CTRL_RNG_IS_NOT_READY (MXC_V_TRNG_CTRL_RNG_IS_NOT_READY << MXC_F_TRNG_CTRL_RNG_IS_POS)
121#define MXC_V_TRNG_CTRL_RNG_IS_READY ((uint32_t)0x1UL)
122#define MXC_S_TRNG_CTRL_RNG_IS_READY (MXC_V_TRNG_CTRL_RNG_IS_READY << MXC_F_TRNG_CTRL_RNG_IS_POS)
124#define MXC_F_TRNG_CTRL_AESKG_POS 6
125#define MXC_F_TRNG_CTRL_AESKG ((uint32_t)(0x1UL << MXC_F_TRNG_CTRL_AESKG_POS))
136#define MXC_F_TRNG_DATA_DATA_POS 0
137#define MXC_F_TRNG_DATA_DATA ((uint32_t)(0xFFFFFFFFUL << MXC_F_TRNG_DATA_DATA_POS))
141#ifdef __cplusplus
142}
143#endif
144
145#endif // LIBRARIES_CMSIS_DEVICE_MAXIM_MAX32650_INCLUDE_TRNG_REGS_H_
__I uint32_t data
Definition: trng_regs.h:78
__IO uint32_t ctrl
Definition: trng_regs.h:77
Definition: trng_regs.h:76