/
pedestal_scan.py
215 lines (195 loc) · 9.14 KB
/
pedestal_scan.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
import larpix
import larpix.io
import network
from base import pacman_base
from base import asic_base
from base import ana_base
from base import utility_base
import argparse
import time
import json
import shutil
_default_LRS=False
_default_file_prefix=None
_default_disable_logger=False
_default_verbose=False
_default_disabled_json=None
_default_generate=False
_default_runtime=300
_default_file_count=1
_default_periodic_trigger_cycles=50000
_default_periodic_reset_cycles=409600
_default_vref_dac=223
_default_vcm_dac=68
_default_ref_current_trim=0
_default_tx_diff=0
_default_tx_slice=15
_default_r_term=2
_default_i_rx=8
_current_dir_='/home/daq/PACMANv1rev4/commission/'
_destination_dir_='/data/LArPix/Module2_Nov2022/TPC12/'
#_io_group_pacman_tile={2:[3]}
#_io_group_pacman_tile_={9:[1]}
#_io_group_pacman_tile_={1:[1]}
#_io_group_pacman_tile_={1:list(range(1,9,1))}
#_io_group_pacman_tile_={2:list(range(1,9,1))}
_io_group_pacman_tile_={1:list(range(1,9,1)), 2:list(range(1,9,1))}
_pacman_version_='v1rev4'
_asic_version_='2b'
def main(LRS=_default_LRS, \
file_prefix=_default_file_prefix, \
disable_logger=_default_disable_logger, \
verbose=_default_verbose, \
disabled_json=_default_disabled_json, \
generate=_default_generate, \
runtime=_default_runtime, \
file_count=_default_file_count, \
periodic_trigger_cycles=_default_periodic_trigger_cycles, \
periodic_reset_cycles=_default_periodic_reset_cycles, \
vref_dac=_default_vref_dac, \
vcm_dac=_default_vcm_dac, \
ref_current_trim=_default_ref_current_trim, \
tx_diff=_default_tx_diff, \
tx_slice=_default_tx_slice, \
r_term=_default_r_term, \
i_rx=_default_i_rx, \
**kwargs):
c, io = network.main(file_prefix=file_prefix, \
disable_logger=disable_logger, \
verbose=verbose, ref_current_trim=ref_current_trim,\
tx_diff=tx_diff, tx_slice=tx_slice, r_term=r_term,\
i_rx=i_rx)
if disable_logger==False:
now=time.strftime("%Y_%m_%d_%H_%M_%Z")
if file_prefix!=None: fname=file_prefix+'-pedestal-config-'+now+'.h5'
else: fname='pedestal-config-'+now+'.h5'
c.logger = larpix.logger.HDF5Logger(filename=fname)
print('filename: ', c.logger.filename)
c.logger.enable()
iog_ioc={}
for chip_key in c.chips:
pair = (chip_key.io_group, chip_key.io_channel)
if pair not in iog_ioc: iog_ioc[pair]=[]
iog_ioc[pair].append(chip_key)
for g_c in iog_ioc.keys():
ok, diff=asic_base.enable_pedestal_config_by_io_channel(c, io, \
iog_ioc[g_c],\
vref_dac, vcm_dac, \
periodic_trigger_cycles, \
periodic_reset_cycles)
if not ok:
for key in diff.keys():
print('MISCONFIGURED ASIC: ',key)
print('*****WARNING: Pedestal triggering error(s).*****\n')
print('Pedestal config setup on IO group ', g_c[0],\
' and IO channel ',g_c[1])
disabled=dict()
if disabled_json!=None:
with open(disabled_json,'r') as f: disabled=json.load(f)
iog_list=[]
for key in iog_ioc.keys():
if key[0] not in iog_list: iog_list.append(key[0])
diff_slice=[(0,15),(0,8),(0,4),(0,2),(0,1),(4,1),(8,1),(12,1),(13,1),(15,1)]
for transmit in diff_slice:
print('TX diff: ',transmit[0],'\t TX slice: ', transmit[1])
c.logger.enable()
for chip_key in c.chips:
if chip_key.chip_id in [21,41,71,91]: continue
tx_us = c[chip_key].config.enable_piso_upstream
tx_ds = c[chip_key].config.enable_piso_downstream
tx=[0]*4
for i in range(4):
if tx_us[i]==1 or tx_ds[i]==1: tx[i]==1
registers_to_write=[]
for piso in range(len(tx)):
setattr(c[chip_key].config,f'i_tx_diff{piso}', transmit[0])
registers_to_write.append(c[chip_key].config.register_map[f'i_tx_diff{piso}'])
setattr(c[chip_key].config,f'tx_slices{piso}', transmit[1])
registers_to_write.append(c[chip_key].config.register_map[f'tx_slices{piso}'])
for reg in registers_to_write:
c.write_configuration(chip_key,reg)
c.write_configuration(chip_key,reg)
for iog in iog_list:
ok, diff=asic_base.enable_periodic_triggering(c, io, iog, disabled)
if not ok:
for key in diff.keys():
print('MISCONFIGURED ASIC: ',key)
print('\n\n*****WARNING: Pedestal triggering error(s).*****')
print('Pedestal triggering setup on IO group ',g_c[0])
if disable_logger==False:
c.logger.flush()
c.logger.disable()
c.reads=[]
ctr=0
while ctr<file_count:
print('TX diff: ',transmit[0],'\t TX slice: ', transmit[1])
for iog in _io_group_pacman_tile_.keys():
pacman_base.enable_pacman_uart_from_tile(io, iog, \
_io_group_pacman_tile_[iog])
filename = utility_base.data(c, runtime, False, \
file_prefix+'-txdiff'+str(transmit[0])+'-txslice'+str(transmit[1]), LRS)
shutil.move(_current_dir_+filename, _destination_dir_+filename)
for iog in _io_group_pacman_tile_.keys():
io.set_reg(0x18, 0, io_group=iog)
ctr+=1
for g_c in iog_ioc.keys():
ok, diff = asic_base.debug_disable_response_trigger_config_by_io_channel(c, io, \
iog_ioc[g_c])
if not ok:
print('MISCONFIGURED ASIC: ',key)
print('***** WARNING: channel mask(s) not disabled. *****\n')
shutil.move(_current_dir_+c.logger.filename, _destination_dir_+c.logger.filename)
for iog in _io_group_pacman_tile_.keys():
io.set_reg(0x18, 0, io_group=iog)
return c
if __name__=='__main__':
parser = argparse.ArgumentParser()
parser.add_argument('--LRS', default=_default_LRS, \
action='store_true', help='''To run LRS''')
parser.add_argument('--file_prefix', default=_default_file_prefix, \
type=str, help='''String prepended to file''')
parser.add_argument('--disable_logger', default=_default_disable_logger, \
action='store_true', help='''Disable logger''')
parser.add_argument('--verbose', default=_default_verbose, \
action='store_true', help='''Enable verbose mode''')
parser.add_argument('--disabled_json', default=_default_disabled_json, \
type=str, help='''JSON-formatted dict of disabled \
chip_key:[channel]''')
parser.add_argument('--generate', default=_default_generate, \
action='store_true', help='''Generate disabled list''')
parser.add_argument('--runtime', default=_default_runtime, \
type=int, help='''Runtime duration''')
parser.add_argument('--file_count', default=_default_file_count, \
type=int, help='''Number of output files to create''')
parser.add_argument('--periodic_trigger_cycles', \
default=_default_periodic_trigger_cycles, type=int, \
help='''Periodic trigger cycles [MCLK]''')
parser.add_argument('--periodic_reset_cycles', \
default=_default_periodic_reset_cycles, type=int, \
help='''Periodic reset cycles [MCLK]''')
parser.add_argument('--vref_dac', default=_default_vref_dac, type=int, \
help='''Vref DAC''')
parser.add_argument('--vcm_dac', default=_default_vcm_dac, type=int, \
help='''Vcm DAC''')
parser.add_argument('--ref_current_trim', \
default=_default_ref_current_trim, \
type=int, \
help='''Trim DAC for primary reference current''')
parser.add_argument('--tx_diff', \
default=_default_tx_diff, \
type=int, \
help='''Differential per-slice loop current DAC''')
parser.add_argument('--tx_slice', \
default=_default_tx_slice, \
type=int, \
help='''Slices enabled per transmitter DAC''')
parser.add_argument('--r_term', \
default=_default_r_term, \
type=int, \
help='''Receiver termination DAC''')
parser.add_argument('--i_rx', \
default=_default_i_rx, \
type=int, \
help='''Receiver bias current DAC''')
args=parser.parse_args()
c = main(**vars(args))