Software APIs
clkmgr_regs.h
Go to the documentation of this file.
1/**
2 * @file
3 * @brief Generated register defines for clkmgr
4 */
5
6// Copyright information found in source file:
7// Copyright lowRISC contributors (OpenTitan project).
8
9// Licensing information found in source file:
10// Licensed under the Apache License, Version 2.0, see LICENSE for details.
11// SPDX-License-Identifier: Apache-2.0
12
13#ifndef _CLKMGR_REG_DEFS_
14#define _CLKMGR_REG_DEFS_
15
16#ifdef __cplusplus
17extern "C" {
18#endif
19// Number of clock groups
20#define CLKMGR_PARAM_NUM_GROUPS 7
21
22// Number of SW gateable clocks
23#define CLKMGR_PARAM_NUM_SW_GATEABLE_CLOCKS 1
24
25// Number of hintable clocks
26#define CLKMGR_PARAM_NUM_HINTABLE_CLOCKS 4
27
28// Number of alerts
29#define CLKMGR_PARAM_NUM_ALERTS 2
30
31// Register width
32#define CLKMGR_PARAM_REG_WIDTH 32
33
34// Alert Test Register
35#define CLKMGR_ALERT_TEST_REG_OFFSET 0x0
36#define CLKMGR_ALERT_TEST_REG_RESVAL 0x0u
37#define CLKMGR_ALERT_TEST_RECOV_FAULT_BIT 0
38#define CLKMGR_ALERT_TEST_FATAL_FAULT_BIT 1
39
40// Jitter write enable
41#define CLKMGR_JITTER_REGWEN_REG_OFFSET 0x10
42#define CLKMGR_JITTER_REGWEN_REG_RESVAL 0x1u
43#define CLKMGR_JITTER_REGWEN_EN_BIT 0
44
45// Enable jittery clock
46#define CLKMGR_JITTER_ENABLE_REG_OFFSET 0x14
47#define CLKMGR_JITTER_ENABLE_REG_RESVAL 0x9u
48#define CLKMGR_JITTER_ENABLE_VAL_MASK 0xfu
49#define CLKMGR_JITTER_ENABLE_VAL_OFFSET 0
50#define CLKMGR_JITTER_ENABLE_VAL_FIELD \
51 ((bitfield_field32_t) { .mask = CLKMGR_JITTER_ENABLE_VAL_MASK, .index = CLKMGR_JITTER_ENABLE_VAL_OFFSET })
52
53// Clock enable for software gateable clocks.
54#define CLKMGR_CLK_ENABLES_REG_OFFSET 0x18
55#define CLKMGR_CLK_ENABLES_REG_RESVAL 0x1u
56#define CLKMGR_CLK_ENABLES_CLK_IO_PERI_EN_BIT 0
57
58// Clock hint for software gateable transactional clocks during active mode.
59#define CLKMGR_CLK_HINTS_REG_OFFSET 0x1c
60#define CLKMGR_CLK_HINTS_REG_RESVAL 0xfu
61#define CLKMGR_CLK_HINTS_CLK_MAIN_AES_HINT_BIT 0
62#define CLKMGR_CLK_HINTS_CLK_MAIN_HMAC_HINT_BIT 1
63#define CLKMGR_CLK_HINTS_CLK_MAIN_KMAC_HINT_BIT 2
64#define CLKMGR_CLK_HINTS_CLK_MAIN_OTBN_HINT_BIT 3
65
66// Since the final state of !!CLK_HINTS is not always determined by software,
67#define CLKMGR_CLK_HINTS_STATUS_REG_OFFSET 0x20
68#define CLKMGR_CLK_HINTS_STATUS_REG_RESVAL 0xfu
69#define CLKMGR_CLK_HINTS_STATUS_CLK_MAIN_AES_VAL_BIT 0
70#define CLKMGR_CLK_HINTS_STATUS_CLK_MAIN_HMAC_VAL_BIT 1
71#define CLKMGR_CLK_HINTS_STATUS_CLK_MAIN_KMAC_VAL_BIT 2
72#define CLKMGR_CLK_HINTS_STATUS_CLK_MAIN_OTBN_VAL_BIT 3
73
74// Measurement control write enable
75#define CLKMGR_MEASURE_CTRL_REGWEN_REG_OFFSET 0x24
76#define CLKMGR_MEASURE_CTRL_REGWEN_REG_RESVAL 0x1u
77#define CLKMGR_MEASURE_CTRL_REGWEN_EN_BIT 0
78
79// Enable for measurement control
80#define CLKMGR_IO_MEAS_CTRL_EN_REG_OFFSET 0x28
81#define CLKMGR_IO_MEAS_CTRL_EN_REG_RESVAL 0x9u
82#define CLKMGR_IO_MEAS_CTRL_EN_EN_MASK 0xfu
83#define CLKMGR_IO_MEAS_CTRL_EN_EN_OFFSET 0
84#define CLKMGR_IO_MEAS_CTRL_EN_EN_FIELD \
85 ((bitfield_field32_t) { .mask = CLKMGR_IO_MEAS_CTRL_EN_EN_MASK, .index = CLKMGR_IO_MEAS_CTRL_EN_EN_OFFSET })
86
87// Configuration controls for io measurement.
88#define CLKMGR_IO_MEAS_CTRL_SHADOWED_REG_OFFSET 0x2c
89#define CLKMGR_IO_MEAS_CTRL_SHADOWED_REG_RESVAL 0xec8au
90#define CLKMGR_IO_MEAS_CTRL_SHADOWED_HI_MASK 0x1ffu
91#define CLKMGR_IO_MEAS_CTRL_SHADOWED_HI_OFFSET 0
92#define CLKMGR_IO_MEAS_CTRL_SHADOWED_HI_FIELD \
93 ((bitfield_field32_t) { .mask = CLKMGR_IO_MEAS_CTRL_SHADOWED_HI_MASK, .index = CLKMGR_IO_MEAS_CTRL_SHADOWED_HI_OFFSET })
94#define CLKMGR_IO_MEAS_CTRL_SHADOWED_LO_MASK 0x1ffu
95#define CLKMGR_IO_MEAS_CTRL_SHADOWED_LO_OFFSET 9
96#define CLKMGR_IO_MEAS_CTRL_SHADOWED_LO_FIELD \
97 ((bitfield_field32_t) { .mask = CLKMGR_IO_MEAS_CTRL_SHADOWED_LO_MASK, .index = CLKMGR_IO_MEAS_CTRL_SHADOWED_LO_OFFSET })
98
99// Enable for measurement control
100#define CLKMGR_MAIN_MEAS_CTRL_EN_REG_OFFSET 0x30
101#define CLKMGR_MAIN_MEAS_CTRL_EN_REG_RESVAL 0x9u
102#define CLKMGR_MAIN_MEAS_CTRL_EN_EN_MASK 0xfu
103#define CLKMGR_MAIN_MEAS_CTRL_EN_EN_OFFSET 0
104#define CLKMGR_MAIN_MEAS_CTRL_EN_EN_FIELD \
105 ((bitfield_field32_t) { .mask = CLKMGR_MAIN_MEAS_CTRL_EN_EN_MASK, .index = CLKMGR_MAIN_MEAS_CTRL_EN_EN_OFFSET })
106
107// Configuration controls for main measurement.
108#define CLKMGR_MAIN_MEAS_CTRL_SHADOWED_REG_OFFSET 0x34
109#define CLKMGR_MAIN_MEAS_CTRL_SHADOWED_REG_RESVAL 0xec8au
110#define CLKMGR_MAIN_MEAS_CTRL_SHADOWED_HI_MASK 0x1ffu
111#define CLKMGR_MAIN_MEAS_CTRL_SHADOWED_HI_OFFSET 0
112#define CLKMGR_MAIN_MEAS_CTRL_SHADOWED_HI_FIELD \
113 ((bitfield_field32_t) { .mask = CLKMGR_MAIN_MEAS_CTRL_SHADOWED_HI_MASK, .index = CLKMGR_MAIN_MEAS_CTRL_SHADOWED_HI_OFFSET })
114#define CLKMGR_MAIN_MEAS_CTRL_SHADOWED_LO_MASK 0x1ffu
115#define CLKMGR_MAIN_MEAS_CTRL_SHADOWED_LO_OFFSET 9
116#define CLKMGR_MAIN_MEAS_CTRL_SHADOWED_LO_FIELD \
117 ((bitfield_field32_t) { .mask = CLKMGR_MAIN_MEAS_CTRL_SHADOWED_LO_MASK, .index = CLKMGR_MAIN_MEAS_CTRL_SHADOWED_LO_OFFSET })
118
119// Recoverable Error code
120#define CLKMGR_RECOV_ERR_CODE_REG_OFFSET 0x38
121#define CLKMGR_RECOV_ERR_CODE_REG_RESVAL 0x0u
122#define CLKMGR_RECOV_ERR_CODE_SHADOW_UPDATE_ERR_BIT 0
123#define CLKMGR_RECOV_ERR_CODE_IO_MEASURE_ERR_BIT 1
124#define CLKMGR_RECOV_ERR_CODE_MAIN_MEASURE_ERR_BIT 2
125#define CLKMGR_RECOV_ERR_CODE_IO_TIMEOUT_ERR_BIT 3
126#define CLKMGR_RECOV_ERR_CODE_MAIN_TIMEOUT_ERR_BIT 4
127
128// Error code
129#define CLKMGR_FATAL_ERR_CODE_REG_OFFSET 0x3c
130#define CLKMGR_FATAL_ERR_CODE_REG_RESVAL 0x0u
131#define CLKMGR_FATAL_ERR_CODE_REG_INTG_BIT 0
132#define CLKMGR_FATAL_ERR_CODE_IDLE_CNT_BIT 1
133#define CLKMGR_FATAL_ERR_CODE_SHADOW_STORAGE_ERR_BIT 2
134
135#ifdef __cplusplus
136} // extern "C"
137#endif
138#endif // _CLKMGR_REG_DEFS_
139// End generated register defines for clkmgr