Blame view

RIOT/cpu/cc26x0/include/cc26x0_vims.h 9.77 KB
a752c7ab   elopes   add first test an...
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
  /*
   * Copyright (C) 2016 Leon George
   *
   * This file is subject to the terms and conditions of the GNU Lesser
   * General Public License v2.1. See the file LICENSE in the top level
   * directory for more details.
   */
  
  /**
   * @ingroup         cpu_cc26x0_definitions
   * @{
   *
   * @file
   * @brief           CC26x0 VIMS register definitions
   */
  
  #ifndef CC26X0_VIMS_H
  #define CC26X0_VIMS_H
  
  #ifdef __cplusplus
  extern "C" {
  #endif
  
  /**
   * FLASH registers
   */
  typedef struct {
      reg32_t __reserved1[7]; /**< meh */
      reg32_t STAT; /**< FMC and efuse status */
      reg32_t CTL; /**< config */
      reg32_t __reserved2; /**< meh */
      reg32_t SYSCODE_START; /**< syscode start address offset config */
      reg32_t FLASH_SIZE; /**< flash size config */
      reg32_t __reserved3[3]; /**< meh */
      reg32_t FWLOCK; /**< firmware lock */
      reg32_t FWFLAG; /**< firmware flags */
      reg32_t __reserved4[0x3EF]; /**< meh */
      reg32_t EFUSE; /**< efuse instruction */
      reg32_t EFUSEADDR; /**< efuse address */
      reg32_t DATAUPPER; /**< efuse data - upper */
      reg32_t DATALOWER; /**< efuse data - lower */
      reg32_t EFUSECFG; /**< OCP sysconf */
      reg32_t EFUSESTAT; /**< system status */
      reg32_t ACC; /**< arbitrary instruction cound */
      reg32_t BOUNDARY; /**< boundary test register to drive I/O */
      reg32_t EFUSEFLAG; /**< efuse key loaded flag */
      reg32_t EFUSEKEY; /**< efuse key */
      reg32_t EFUSERELEASE; /**< efuese release */
      reg32_t EFUSEPINS; /**< efuse pins */
      reg32_t EFUSECRA; /**< efuse column repair address */
      reg32_t EFUSEREAD; /**< efuse read */
      reg32_t EFUSEPROGRAM; /**< efuse program */
      reg32_t EFUSEERROR; /**< efuse error */
      reg32_t SINGLEBIT; /**< single-bit error status */
      reg32_t TWOBIT; /**< two-bit error status */
      reg32_t SELFTESTCYC; /**< self-test cycles */
      reg32_t SELFTESTSIGN; /**< self-test signature */
      reg32_t __reserved5[0x3ec]; /**< meh */
      reg32_t FRDCTL; /**< FMC read control */
      reg32_t FSPRD; /**< FMC read margin control */
      reg32_t FEDACCTL1; /**< FMC error correction control 1 */
      reg32_t __reserved6[4]; /**< meh */
      reg32_t FEDACSTAT; /**< FMC error status */
      reg32_t __reserved7[4]; /**< meh */
      reg32_t FBPROT; /**< FMC bank protection */
      reg32_t FBSE; /**< FMC sector enable */
      reg32_t FBBUSY; /**< FMC bank busy */
      reg32_t FBAC; /**< FMC bank access control */
      reg32_t FBFALLBACK; /**< FMC bank fallback power */
      reg32_t FBPRDY; /**< FMC bank/pump ready */
      reg32_t FPAC1; /**< FMC pump access control 1 */
      reg32_t FPAC2; /**< FMC pump access control 2 */
      reg32_t FMAC; /**< FMC module access control */
      reg32_t FMSTAT; /**< FMC module status */
      reg32_t __reserved8[3]; /**< meh */
      reg32_t FLOCK; /**< FMC flash lock */
      reg32_t __reserved9[6]; /**< meh */
      reg32_t FVREADCT; /**< FMC VREADCT trim */
      reg32_t FVHVCT1; /**< FMC VHVCT1 trim */
      reg32_t FVHVCT2; /**< FMC VHVCT2 trim */
      reg32_t FVHVCT3; /**< FMC VHVCT3 trim */
      reg32_t FVNVCT; /**< FMC VNVCT trim */
      reg32_t FVSLP; /**< FMC VSL_P trim */
      reg32_t FVWLCT; /**< FMC VWLCT trim */
      reg32_t FEFUSECTL; /**< FMC efuse control */
      reg32_t FEFUSESTAT; /**< FMC efuse status */
      reg32_t FEFUSEDATA; /**< FMC efuse data */
      reg32_t FSEQPMP; /**< FMC sequential pump information */
      reg32_t __reserved10[21]; /**< meh */
      reg32_t FBSTROBES; /**< FMC bank signal strobe */
      reg32_t FPSTROBES; /**< FMC pump signal strobe */
      reg32_t FBMODE; /**< FMC bank and pump mode */
      reg32_t FTCR; /**< FMC test command control */
      reg32_t FADDR; /**< FMC bank address */
      reg32_t __reserved11[2]; /**< meh */
      reg32_t FTCTL; /**< FMC test control */
      reg32_t FWPWRITE0; /**< FMC flash wide programming write data 0 */
      reg32_t FWPWRITE1; /**< FMC flash wide programming write data 1 */
      reg32_t FWPWRITE2; /**< FMC flash wide programming write data 2 */
      reg32_t FWPWRITE3; /**< FMC flash wide programming write data 3 */
      reg32_t FWPWRITE4; /**< FMC flash wide programming write data 4 */
      reg32_t FWPWRITE5; /**< FMC flash wide programming write data 5 */
      reg32_t FWPWRITE6; /**< FMC flash wide programming write data 6 */
      reg32_t FWPWRITE7; /**< FMC flash wide programming write data 7 */
      reg32_t FWPWRITE_ECC; /**< FMC flash wide programming ECC */
      reg32_t FSWSTAT; /**< FMC software interface status */
      reg32_t __reserved12[0x2E]; /**< meh */
      reg32_t FSM_GLBCTL; /**< FMC FSM global controll */
      reg32_t FSM_STATE; /**< FMC FSM state status */
      reg32_t FSM_STAT; /**< FMC FSM status */
      reg32_t FSM_CMD; /**< FMC FSM command */
      reg32_t FSM_PE_OSU; /**< FMC FSM program/erase operation setup */
      reg32_t FSM_VSTAT; /**< FMC FSM voltage status setup */
      reg32_t FSM_PE_VSU; /**< FMC FSM program/erase verify setup */
      reg32_t FSM_CMP_VSU; /**< FMC FSM compare verify setup */
      reg32_t FSM_EX_VAL; /**< FMC FSM EXECUTEZ to valid data */
      reg32_t FSM_RD_H; /**< FMC FSM read mode hold */
      reg32_t FSM_P_OH; /**< FMC FSM program hold */
      reg32_t FSM_ERA_OH; /**< FMC FSM erase operation hold */
      reg32_t FSM_SAV_PPUL; /**< FMC FSM saved program pulses */
      reg32_t FSM_PE_VH; /**< FMC FSM program/erase verify hold */
      reg32_t __reserved13[2]; /**< meh */
      reg32_t FSM_PRG_PW; /**< FMC FSM program pulse width */
      reg32_t FSM_ERA_PW; /**< FMC FSM erase pulse width */
      reg32_t __reserved14[3]; /**< meh */
      reg32_t FSM_SAV_ERA_PUL; /**< FMC FSM saved erased pulses */
      reg32_t FSM_TIMER; /**< FMC FSM timer */
      reg32_t FSM_MODE; /**< FMC FSM MODE */
      reg32_t FSM_PGM; /**< FMC FSM program bits */
      reg32_t FSM_ERA; /**< FMC FSM erase bits */
      reg32_t FSM_PRG_PUL; /**< FMC FSM maximum programming pulses */
      reg32_t FSM_ERA_PUL; /**< FMC FSM maximum erase pulses */
      reg32_t FSM_STEP_SIZE; /**< FMC FSM EC step size */
      reg32_t FSM_PUL_CNTR; /**< FMC FSM pulse counter */
      reg32_t FSM_EC_STEP_HEIGHT; /**< FMC FSM EC step height */
      reg32_t FSM_ST_MACHINE; /**< FMC FSM ST MACHINE */
      reg32_t FSM_FLES; /**< FMC FSM FLES memory control bits */
      reg32_t __reserved15; /**< meh */
      reg32_t FSM_WR_ENA; /**< FMC FSM register write enable */
      reg32_t FSM_ACC_PP; /**< FMC FSM accumulate program pulses */
      reg32_t FSM_ACC_EP; /**< FMC FSM accumulate erase pulses */
      reg32_t __reserved16[3]; /**< meh */
      reg32_t FSM_ADDR; /**< FMC FSM address */
      reg32_t FSM_SECTOR; /**< FMC sectors erased */
      reg32_t FMC_REV_ID; /**< FMC revision identification */
      reg32_t FSM_ERR_ADDR; /**< FSM error address */
      reg32_t FSM_PGM_MAXPUL; /**< FMC FSM maximum program pulse */
      reg32_t FSM_EXECUTE; /**< FMC FSM command execute */
      reg32_t __reserved17[2]; /**< meh */
      reg32_t FSM_SECTOR1; /**< FMC FSM sector erased 1 */
      reg32_t FSM_SECTOR2; /**< FMC FSM sector erased 2 */
      reg32_t __reserved18[6]; /**< meh */
      reg32_t FSM_BSLE0; /**< FMC FSM bank sector lock erase 0 */
      reg32_t FSM_BSLE1; /**< FMC FSM bank sector lock erase 1 */
      reg32_t __reserved19[2]; /**< meh */
      reg32_t FSM_BSLP0; /**< FMC FSM bank sector lock program 0 */
      reg32_t FSM_BSLP1; /**< FMC FSM bank sector lock program 1 */
      reg32_t __reserved20[0x42]; /**< meh */
      reg32_t FCFG_BANK; /**< FMC flash configuration bank */
      reg32_t FCFG_WRAPPER; /**< FMC flash wrapper configuration */
      reg32_t FCFG_BNK_TYPE; /**< FMC flash bank type */
      reg32_t __reserved21; /**< meh */
      reg32_t FCFG_B0_START; /**< FMC flash bank 0 starting address */
      reg32_t FCFG_B1_START; /**< FMC flash bank 1 starting address */
      reg32_t FCFG_B2_START; /**< FMC flash bank 2 starting address */
      reg32_t FCFG_B3_START; /**< FMC flash bank 3 starting address */
      reg32_t FCFG_B4_START; /**< FMC flash bank 4 starting address */
      reg32_t FCFG_B5_START; /**< FMC flash bank 5 starting address */
      reg32_t FCFG_B6_START; /**< FMC flash bank 6 starting address */
      reg32_t FCFG_B7_START; /**< FMC flash bank 7 starting address */
      reg32_t FCFG_B0_SSIZE0; /**< FMC flash bank 0 sector size */
  } flash_regs_t;
  
  /** @ingroup cpu_specific_peripheral_memory_map
    * @{
    */
  #define FLASH_BASEADDR                           0x40030000 /**< base address of FLASH memory */
  /*@}*/
  
  #define FLASH                                ((flash_regs_t *)(FLASH_BASEADDR + 0x4)) /**< FLASH register bank */
  
  
  /**
   * VIMS registers
   */
  typedef struct {
      reg32_t STAT; /**< status */
      reg32_t CTL; /**< control */
  } vims_regs_t;
  
  /** @ingroup cpu_specific_peripheral_memory_map
    * @{
    */
  #define VIMS_BASE                           0x40034000 /**< base address of VIMS memory */
  /*@}*/
  
  #define VIMS                                ((vims_regs_t *)(VIMS_BASE + 0x4)) /**< VIMS register bank */
  
  /**
   * @brief   VIMS register values
   * @{
   */
  #define VIMS_CTL_STATS_CLR                  0x80000000
  #define VIMS_CTL_STATS_CLR_m                0x80000000
  
  #define VIMS_CTL_STATS_EN                   0x40000000
  #define VIMS_CTL_STATS_EN_m                 0x40000000
  
  #define VIMS_CTL_DYN_CG_EN                  0x20000000
  #define VIMS_CTL_DYN_CG_EN_m                0x20000000
  
  #define VIMS_CTL_IDCODE_LB_DIS              0x00000020
  #define VIMS_CTL_IDCODE_LB_DIS_m            0x00000020
  
  #define VIMS_CTL_SYSBUS_LB_DIS              0x00000010
  #define VIMS_CTL_SYSBUS_LB_DIS_m            0x00000010
  
  #define VIMS_CTL_ARB_CFG                    0x00000008
  #define VIMS_CTL_ARB_CFG_m                  0x00000008
  
  #define VIMS_CTL_PREF_EN                    0x00000004
  #define VIMS_CTL_PREF_EN_m                  0x00000004
  
  #define VIMS_CTL_MODE_GPRAM                 0x00000000
  #define VIMS_CTL_MODE_CACHE                 0x00000001
  #define VIMS_CTL_MODE_SPLIT                 0x00000002
  #define VIMS_CTL_MODE_OFF                   0x00000003
  #define VIMS_CTL_MODE_m                     0x00000003
  /** @} */
  
  #ifdef __cplusplus
  }
  #endif
  
  #endif /* CC26X0_VIMS_H */
  
  /*@}*/