This repository has been archived by the owner on Oct 14, 2022. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathcsrmap.py
333 lines (332 loc) · 13.6 KB
/
csrmap.py
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
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
csr_constants = {
'fast_a_iir_a_shift': 16,
'fast_a_iir_a_width': 18,
'fast_a_iir_a_interval': 1,
'fast_a_iir_a_latency': 2,
'fast_a_iir_a_order': 1,
'fast_a_iir_a_iterative': 0,
'fast_a_iir_b_shift': 23,
'fast_a_iir_b_width': 25,
'fast_a_iir_b_interval': 5,
'fast_a_iir_b_latency': 6,
'fast_a_iir_b_order': 2,
'fast_a_iir_b_iterative': 1,
'fast_a_iir_c_shift': 16,
'fast_a_iir_c_width': 18,
'fast_a_iir_c_interval': 1,
'fast_a_iir_c_latency': 2,
'fast_a_iir_c_order': 1,
'fast_a_iir_c_iterative': 0,
'fast_a_iir_d_shift': 16,
'fast_a_iir_d_width': 18,
'fast_a_iir_d_interval': 1,
'fast_a_iir_d_latency': 3,
'fast_a_iir_d_order': 2,
'fast_a_iir_d_iterative': 0,
'fast_a_iir_e_shift': 23,
'fast_a_iir_e_width': 25,
'fast_a_iir_e_interval': 5,
'fast_a_iir_e_latency': 6,
'fast_a_iir_e_order': 2,
'fast_a_iir_e_iterative': 1,
'fast_a_relock_shift': 16,
'fast_a_sweep_shift': 18,
'fast_b_iir_a_shift': 16,
'fast_b_iir_a_width': 18,
'fast_b_iir_a_interval': 1,
'fast_b_iir_a_latency': 2,
'fast_b_iir_a_order': 1,
'fast_b_iir_a_iterative': 0,
'fast_b_iir_b_shift': 23,
'fast_b_iir_b_width': 25,
'fast_b_iir_b_interval': 5,
'fast_b_iir_b_latency': 6,
'fast_b_iir_b_order': 2,
'fast_b_iir_b_iterative': 1,
'fast_b_iir_c_shift': 16,
'fast_b_iir_c_width': 18,
'fast_b_iir_c_interval': 1,
'fast_b_iir_c_latency': 2,
'fast_b_iir_c_order': 1,
'fast_b_iir_c_iterative': 0,
'fast_b_iir_d_shift': 16,
'fast_b_iir_d_width': 18,
'fast_b_iir_d_interval': 1,
'fast_b_iir_d_latency': 3,
'fast_b_iir_d_order': 2,
'fast_b_iir_d_iterative': 0,
'fast_b_iir_e_shift': 23,
'fast_b_iir_e_width': 25,
'fast_b_iir_e_interval': 5,
'fast_b_iir_e_latency': 6,
'fast_b_iir_e_order': 2,
'fast_b_iir_e_iterative': 1,
'fast_b_relock_shift': 16,
'fast_b_sweep_shift': 18,
'slow_a_iir_shift': 23,
'slow_a_iir_width': 25,
'slow_a_iir_interval': 75,
'slow_a_iir_latency': 6,
'slow_a_iir_order': 2,
'slow_a_iir_iterative': 1,
'slow_b_iir_shift': 23,
'slow_b_iir_width': 25,
'slow_b_iir_interval': 75,
'slow_b_iir_latency': 6,
'slow_b_iir_order': 2,
'slow_b_iir_iterative': 1,
'slow_c_iir_shift': 23,
'slow_c_iir_width': 25,
'slow_c_iir_interval': 75,
'slow_c_iir_latency': 6,
'slow_c_iir_order': 2,
'slow_c_iir_iterative': 1,
'slow_d_iir_shift': 23,
'slow_d_iir_width': 25,
'slow_d_iir_interval': 75,
'slow_d_iir_latency': 6,
'slow_d_iir_order': 2,
'slow_d_iir_iterative': 1,
}
csr = {
'dna_dna': (28, 0x000, 64, False),
'fast_a_x_tap': (0, 0x000, 2, True),
'fast_a_brk': (0, 0x001, 1, True),
'fast_a_y_tap': (0, 0x002, 2, True),
'fast_a_iir_a_z0': (0, 0x003, 27, True),
'fast_a_iir_a_a1': (0, 0x007, 18, True),
'fast_a_iir_a_b0': (0, 0x00a, 18, True),
'fast_a_iir_a_b1': (0, 0x00d, 18, True),
'fast_a_demod_delay': (0, 0x010, 14, True),
'fast_a_iir_b_z0': (0, 0x012, 38, True),
'fast_a_iir_b_a1': (0, 0x017, 25, True),
'fast_a_iir_b_a2': (0, 0x01b, 25, True),
'fast_a_iir_b_b0': (0, 0x01f, 25, True),
'fast_a_iir_b_b1': (0, 0x023, 25, True),
'fast_a_iir_b_b2': (0, 0x027, 25, True),
'fast_a_x_limit_min': (0, 0x02b, 25, True),
'fast_a_x_limit_max': (0, 0x02f, 25, True),
'fast_a_iir_c_z0': (0, 0x033, 27, True),
'fast_a_iir_c_a1': (0, 0x037, 18, True),
'fast_a_iir_c_b0': (0, 0x03a, 18, True),
'fast_a_iir_c_b1': (0, 0x03d, 18, True),
'fast_a_iir_d_z0': (0, 0x040, 27, True),
'fast_a_iir_d_a1': (0, 0x044, 18, True),
'fast_a_iir_d_a2': (0, 0x047, 18, True),
'fast_a_iir_d_b0': (0, 0x04a, 18, True),
'fast_a_iir_d_b1': (0, 0x04d, 18, True),
'fast_a_iir_d_b2': (0, 0x050, 18, True),
'fast_a_iir_e_z0': (0, 0x053, 38, True),
'fast_a_iir_e_a1': (0, 0x058, 25, True),
'fast_a_iir_e_a2': (0, 0x05c, 25, True),
'fast_a_iir_e_b0': (0, 0x060, 25, True),
'fast_a_iir_e_b1': (0, 0x064, 25, True),
'fast_a_iir_e_b2': (0, 0x068, 25, True),
'fast_a_relock_step': (0, 0x06c, 24, True),
'fast_a_relock_run': (0, 0x06f, 1, True),
'fast_a_relock_min': (0, 0x070, 15, True),
'fast_a_relock_max': (0, 0x072, 15, True),
'fast_a_sweep_step': (0, 0x074, 24, True),
'fast_a_sweep_min': (0, 0x077, 14, True),
'fast_a_sweep_max': (0, 0x079, 14, True),
'fast_a_sweep_run': (0, 0x07b, 1, True),
'fast_a_mod_amp': (0, 0x07c, 14, True),
'fast_a_mod_freq': (0, 0x07e, 32, True),
'fast_a_y_limit_min': (0, 0x082, 14, True),
'fast_a_y_limit_max': (0, 0x084, 14, True),
'fast_a_x_clr': (0, 0x086, 1, True),
'fast_a_x_max': (0, 0x087, 25, False),
'fast_a_x_min': (0, 0x08b, 25, False),
'fast_a_y_clr': (0, 0x08f, 1, True),
'fast_a_y_max': (0, 0x090, 25, False),
'fast_a_y_min': (0, 0x094, 25, False),
'fast_a_sweep_trigger_clr': (0, 0x098, 1, True),
'fast_a_sweep_trigger_max': (0, 0x099, 1, False),
'fast_a_sweep_trigger_min': (0, 0x09a, 1, False),
'fast_a_x_hold_en': (0, 0x09b, 27, True),
'fast_a_x_clear_en': (0, 0x09f, 27, True),
'fast_a_y_hold_en': (0, 0x0a3, 27, True),
'fast_a_y_clear_en': (0, 0x0a7, 27, True),
'fast_a_relock_en': (0, 0x0ab, 27, True),
'fast_a_dx_sel': (0, 0x0af, 5, True),
'fast_a_dy_sel': (0, 0x0b0, 5, True),
'fast_a_rx_sel': (0, 0x0b1, 5, True),
'fast_b_x_tap': (1, 0x000, 2, True),
'fast_b_brk': (1, 0x001, 1, True),
'fast_b_y_tap': (1, 0x002, 2, True),
'fast_b_iir_a_z0': (1, 0x003, 27, True),
'fast_b_iir_a_a1': (1, 0x007, 18, True),
'fast_b_iir_a_b0': (1, 0x00a, 18, True),
'fast_b_iir_a_b1': (1, 0x00d, 18, True),
'fast_b_demod_delay': (1, 0x010, 14, True),
'fast_b_iir_b_z0': (1, 0x012, 38, True),
'fast_b_iir_b_a1': (1, 0x017, 25, True),
'fast_b_iir_b_a2': (1, 0x01b, 25, True),
'fast_b_iir_b_b0': (1, 0x01f, 25, True),
'fast_b_iir_b_b1': (1, 0x023, 25, True),
'fast_b_iir_b_b2': (1, 0x027, 25, True),
'fast_b_x_limit_min': (1, 0x02b, 25, True),
'fast_b_x_limit_max': (1, 0x02f, 25, True),
'fast_b_iir_c_z0': (1, 0x033, 27, True),
'fast_b_iir_c_a1': (1, 0x037, 18, True),
'fast_b_iir_c_b0': (1, 0x03a, 18, True),
'fast_b_iir_c_b1': (1, 0x03d, 18, True),
'fast_b_iir_d_z0': (1, 0x040, 27, True),
'fast_b_iir_d_a1': (1, 0x044, 18, True),
'fast_b_iir_d_a2': (1, 0x047, 18, True),
'fast_b_iir_d_b0': (1, 0x04a, 18, True),
'fast_b_iir_d_b1': (1, 0x04d, 18, True),
'fast_b_iir_d_b2': (1, 0x050, 18, True),
'fast_b_iir_e_z0': (1, 0x053, 38, True),
'fast_b_iir_e_a1': (1, 0x058, 25, True),
'fast_b_iir_e_a2': (1, 0x05c, 25, True),
'fast_b_iir_e_b0': (1, 0x060, 25, True),
'fast_b_iir_e_b1': (1, 0x064, 25, True),
'fast_b_iir_e_b2': (1, 0x068, 25, True),
'fast_b_relock_step': (1, 0x06c, 24, True),
'fast_b_relock_run': (1, 0x06f, 1, True),
'fast_b_relock_min': (1, 0x070, 15, True),
'fast_b_relock_max': (1, 0x072, 15, True),
'fast_b_sweep_step': (1, 0x074, 24, True),
'fast_b_sweep_min': (1, 0x077, 14, True),
'fast_b_sweep_max': (1, 0x079, 14, True),
'fast_b_sweep_run': (1, 0x07b, 1, True),
'fast_b_mod_amp': (1, 0x07c, 14, True),
'fast_b_mod_freq': (1, 0x07e, 32, True),
'fast_b_y_limit_min': (1, 0x082, 14, True),
'fast_b_y_limit_max': (1, 0x084, 14, True),
'fast_b_x_clr': (1, 0x086, 1, True),
'fast_b_x_max': (1, 0x087, 25, False),
'fast_b_x_min': (1, 0x08b, 25, False),
'fast_b_y_clr': (1, 0x08f, 1, True),
'fast_b_y_max': (1, 0x090, 25, False),
'fast_b_y_min': (1, 0x094, 25, False),
'fast_b_sweep_trigger_clr': (1, 0x098, 1, True),
'fast_b_sweep_trigger_max': (1, 0x099, 1, False),
'fast_b_sweep_trigger_min': (1, 0x09a, 1, False),
'fast_b_x_hold_en': (1, 0x09b, 27, True),
'fast_b_x_clear_en': (1, 0x09f, 27, True),
'fast_b_y_hold_en': (1, 0x0a3, 27, True),
'fast_b_y_clear_en': (1, 0x0a7, 27, True),
'fast_b_relock_en': (1, 0x0ab, 27, True),
'fast_b_dx_sel': (1, 0x0af, 5, True),
'fast_b_dy_sel': (1, 0x0b0, 5, True),
'fast_b_rx_sel': (1, 0x0b1, 5, True),
'gpio_n_ins': (30, 0x000, 8, False),
'gpio_n_outs': (30, 0x001, 8, True),
'gpio_n_oes': (30, 0x002, 8, True),
'gpio_n_state': (30, 0x003, 27, False),
'gpio_n_state_clr': (30, 0x007, 1, True),
'gpio_n_do0_en': (30, 0x008, 27, True),
'gpio_n_do1_en': (30, 0x00c, 27, True),
'gpio_n_do2_en': (30, 0x010, 27, True),
'gpio_n_do3_en': (30, 0x014, 27, True),
'gpio_n_do4_en': (30, 0x018, 27, True),
'gpio_n_do5_en': (30, 0x01c, 27, True),
'gpio_n_do6_en': (30, 0x020, 27, True),
'gpio_n_do7_en': (30, 0x024, 27, True),
'gpio_p_ins': (31, 0x000, 8, False),
'gpio_p_outs': (31, 0x001, 8, True),
'gpio_p_oes': (31, 0x002, 8, True),
'noise_bits': (7, 0x000, 5, True),
'noise_y_clr': (7, 0x001, 1, True),
'noise_y_max': (7, 0x002, 25, False),
'noise_y_min': (7, 0x006, 25, False),
'scopegen_external_trigger': (6, 0x000, 2, True),
'scopegen_dac_a_clr': (6, 0x001, 1, True),
'scopegen_dac_a_max': (6, 0x002, 25, False),
'scopegen_dac_a_min': (6, 0x006, 25, False),
'scopegen_dac_b_clr': (6, 0x00a, 1, True),
'scopegen_dac_b_max': (6, 0x00b, 25, False),
'scopegen_dac_b_min': (6, 0x00f, 25, False),
'scopegen_adc_a_sel': (6, 0x013, 5, True),
'scopegen_adc_b_sel': (6, 0x014, 5, True),
'slow_a_brk': (2, 0x000, 1, True),
'slow_a_x_limit_min': (2, 0x001, 25, True),
'slow_a_x_limit_max': (2, 0x005, 25, True),
'slow_a_iir_z0': (2, 0x009, 38, True),
'slow_a_iir_a1': (2, 0x00e, 25, True),
'slow_a_iir_a2': (2, 0x012, 25, True),
'slow_a_iir_b0': (2, 0x016, 25, True),
'slow_a_iir_b1': (2, 0x01a, 25, True),
'slow_a_iir_b2': (2, 0x01e, 25, True),
'slow_a_y_limit_min': (2, 0x022, 16, True),
'slow_a_y_limit_max': (2, 0x024, 16, True),
'slow_a_x_clr': (2, 0x026, 1, True),
'slow_a_x_max': (2, 0x027, 25, False),
'slow_a_x_min': (2, 0x02b, 25, False),
'slow_a_y_clr': (2, 0x02f, 1, True),
'slow_a_y_max': (2, 0x030, 25, False),
'slow_a_y_min': (2, 0x034, 25, False),
'slow_a_hold_en': (2, 0x038, 27, True),
'slow_a_clear_en': (2, 0x03c, 27, True),
'slow_a_dx_sel': (2, 0x040, 5, True),
'slow_b_brk': (3, 0x000, 1, True),
'slow_b_x_limit_min': (3, 0x001, 25, True),
'slow_b_x_limit_max': (3, 0x005, 25, True),
'slow_b_iir_z0': (3, 0x009, 38, True),
'slow_b_iir_a1': (3, 0x00e, 25, True),
'slow_b_iir_a2': (3, 0x012, 25, True),
'slow_b_iir_b0': (3, 0x016, 25, True),
'slow_b_iir_b1': (3, 0x01a, 25, True),
'slow_b_iir_b2': (3, 0x01e, 25, True),
'slow_b_y_limit_min': (3, 0x022, 16, True),
'slow_b_y_limit_max': (3, 0x024, 16, True),
'slow_b_x_clr': (3, 0x026, 1, True),
'slow_b_x_max': (3, 0x027, 25, False),
'slow_b_x_min': (3, 0x02b, 25, False),
'slow_b_y_clr': (3, 0x02f, 1, True),
'slow_b_y_max': (3, 0x030, 25, False),
'slow_b_y_min': (3, 0x034, 25, False),
'slow_b_hold_en': (3, 0x038, 27, True),
'slow_b_clear_en': (3, 0x03c, 27, True),
'slow_b_dx_sel': (3, 0x040, 5, True),
'slow_c_brk': (4, 0x000, 1, True),
'slow_c_x_limit_min': (4, 0x001, 25, True),
'slow_c_x_limit_max': (4, 0x005, 25, True),
'slow_c_iir_z0': (4, 0x009, 38, True),
'slow_c_iir_a1': (4, 0x00e, 25, True),
'slow_c_iir_a2': (4, 0x012, 25, True),
'slow_c_iir_b0': (4, 0x016, 25, True),
'slow_c_iir_b1': (4, 0x01a, 25, True),
'slow_c_iir_b2': (4, 0x01e, 25, True),
'slow_c_y_limit_min': (4, 0x022, 16, True),
'slow_c_y_limit_max': (4, 0x024, 16, True),
'slow_c_x_clr': (4, 0x026, 1, True),
'slow_c_x_max': (4, 0x027, 25, False),
'slow_c_x_min': (4, 0x02b, 25, False),
'slow_c_y_clr': (4, 0x02f, 1, True),
'slow_c_y_max': (4, 0x030, 25, False),
'slow_c_y_min': (4, 0x034, 25, False),
'slow_c_hold_en': (4, 0x038, 27, True),
'slow_c_clear_en': (4, 0x03c, 27, True),
'slow_c_dx_sel': (4, 0x040, 5, True),
'slow_d_brk': (5, 0x000, 1, True),
'slow_d_x_limit_min': (5, 0x001, 25, True),
'slow_d_x_limit_max': (5, 0x005, 25, True),
'slow_d_iir_z0': (5, 0x009, 38, True),
'slow_d_iir_a1': (5, 0x00e, 25, True),
'slow_d_iir_a2': (5, 0x012, 25, True),
'slow_d_iir_b0': (5, 0x016, 25, True),
'slow_d_iir_b1': (5, 0x01a, 25, True),
'slow_d_iir_b2': (5, 0x01e, 25, True),
'slow_d_y_limit_min': (5, 0x022, 16, True),
'slow_d_y_limit_max': (5, 0x024, 16, True),
'slow_d_x_clr': (5, 0x026, 1, True),
'slow_d_x_max': (5, 0x027, 25, False),
'slow_d_x_min': (5, 0x02b, 25, False),
'slow_d_y_clr': (5, 0x02f, 1, True),
'slow_d_y_max': (5, 0x030, 25, False),
'slow_d_y_min': (5, 0x034, 25, False),
'slow_d_hold_en': (5, 0x038, 27, True),
'slow_d_clear_en': (5, 0x03c, 27, True),
'slow_d_dx_sel': (5, 0x040, 5, True),
'xadc_temp': (29, 0x000, 12, False),
'xadc_v': (29, 0x002, 12, False),
'xadc_a': (29, 0x004, 12, False),
'xadc_b': (29, 0x006, 12, False),
'xadc_c': (29, 0x008, 12, False),
'xadc_d': (29, 0x00a, 12, False),
}
states = ['force', 'di0', 'di1', 'di2', 'di3', 'di4', 'di5', 'di6', 'di7', 'fast_a_x_sat', 'fast_a_x_railed', 'fast_a_y_sat', 'fast_a_y_railed', 'fast_a_unlocked', 'fast_b_x_sat', 'fast_b_x_railed', 'fast_b_y_sat', 'fast_b_y_railed', 'fast_b_unlocked', 'slow_a_sat', 'slow_a_railed', 'slow_b_sat', 'slow_b_railed', 'slow_c_sat', 'slow_c_railed', 'slow_d_sat', 'slow_d_railed']
signals = ['zero', 'fast_a_x', 'fast_a_y', 'fast_a_sweep_trigger', 'fast_b_x', 'fast_b_y', 'fast_b_sweep_trigger', 'slow_a_x', 'slow_a_y', 'slow_b_x', 'slow_b_y', 'slow_c_x', 'slow_c_y', 'slow_d_x', 'slow_d_y', 'scopegen_dac_a', 'scopegen_dac_b', 'noise_y']