]> git.uio.no Git - u/mrichter/AliRoot.git/blame - TRD/AliTRDtrapConfig.cxx
Choice of injected/pure, BB cut not applied to MC, typo corrected
[u/mrichter/AliRoot.git] / TRD / AliTRDtrapConfig.cxx
CommitLineData
36dc3337 1/**************************************************************************
2 * Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
3 * *
4 * Author: The ALICE Off-line Project. *
5 * Contributors are mentioned in the code where appropriate. *
6 * *
7 * Permission to use, copy, modify and distribute this software and its *
8 * documentation strictly for non-commercial purposes is hereby granted *
9 * without fee, provided that the above copyright notice appears in all *
10 * copies and that both the copyright notice and this permission notice *
11 * appear in the supporting documentation. The authors make no claims *
12 * about the suitability of this software for any purpose. It is *
13 * provided "as is" without express or implied warranty. *
14 **************************************************************************/
15
16////////////////////////////////////////////////////////////////////////////
17// //
18// TRAP config //
19// //
20// Author: J. Klein (Jochen.Klein@cern.ch) //
21// //
22////////////////////////////////////////////////////////////////////////////
23
ce4786b9 24#include "AliLog.h"
25
26#include "AliTRDgeometry.h"
27#include "AliTRDfeeParam.h"
28#include "AliTRDtrapConfig.h"
5e86ff99 29#include "AliTRDtrapConfigHandler.h"
ce4786b9 30
31#include <fstream>
32#include <iostream>
33#include <iomanip>
34
35ClassImp(AliTRDtrapConfig)
36
37AliTRDtrapConfig* AliTRDtrapConfig::fgInstance = 0x0;
38const Int_t AliTRDtrapConfig::fgkMaxMcm = AliTRDfeeParam::GetNmcmRob() + 2;
39const Int_t AliTRDtrapConfig::fgkDmemStartAddress = 0xc000;
40
5f006bd7 41AliTRDtrapConfig::AliTRDtrapConfig() :
8ea391e3 42 TObject(), fScaleQ0(0), fScaleQ1(0)
ce4786b9 43{
44 // default constructor, initializing array of TRAP registers
45
46 // Name Address Nbits Reset Value
47 fRegs[kSML0] = SimpleReg_t("SML0", 0x0A00, 15, 0x4050 ); // Global state machine
48 fRegs[kSML1] = SimpleReg_t("SML1", 0x0A01, 15, 0x4200 );
49 fRegs[kSML2] = SimpleReg_t("SML2", 0x0A02, 15, 0x4384 );
50 fRegs[kSMMODE] = SimpleReg_t("SMMODE", 0x0A03, 16, 0xF0E2 );
51 fRegs[kNITM0] = SimpleReg_t("NITM0", 0x0A08, 14, 0x3FFF );
52 fRegs[kNITM1] = SimpleReg_t("NITM1", 0x0A09, 14, 0x3FFF );
53 fRegs[kNITM2] = SimpleReg_t("NITM2", 0x0A0A, 14, 0x3FFF );
54 fRegs[kNIP4D] = SimpleReg_t("NIP4D", 0x0A0B, 7, 0x7F );
55 fRegs[kCPU0CLK] = SimpleReg_t("CPU0CLK", 0x0A20, 5, 0x07 );
56 fRegs[kCPU1CLK] = SimpleReg_t("CPU1CLK", 0x0A22, 5, 0x07 );
57 fRegs[kCPU2CLK] = SimpleReg_t("CPU2CLK", 0x0A24, 5, 0x07 );
58 fRegs[kCPU3CLK] = SimpleReg_t("CPU3CLK", 0x0A26, 5, 0x07 );
59 fRegs[kNICLK] = SimpleReg_t("NICLK", 0x0A28, 5, 0x07 );
60 fRegs[kFILCLK] = SimpleReg_t("FILCLK", 0x0A2A, 5, 0x07 );
61 fRegs[kPRECLK] = SimpleReg_t("PRECLK", 0x0A2C, 5, 0x07 );
62 fRegs[kADCEN] = SimpleReg_t("ADCEN", 0x0A2E, 5, 0x07 );
63 fRegs[kNIODE] = SimpleReg_t("NIODE", 0x0A30, 5, 0x07 );
64 fRegs[kNIOCE] = SimpleReg_t("NIOCE", 0x0A32, 6, 0x21 ); // bit 5 is status bit (read-only)!
65 fRegs[kNIIDE] = SimpleReg_t("NIIDE", 0x0A34, 5, 0x07 );
66 fRegs[kNIICE] = SimpleReg_t("NIICE", 0x0A36, 5, 0x07 );
67 fRegs[kARBTIM] = SimpleReg_t("ARBTIM", 0x0A3F, 4, 0x0 ); // Arbiter
68 fRegs[kIA0IRQ0] = SimpleReg_t("IA0IRQ0", 0x0B00, 12, 0x000 ); // IVT of CPU0
69 fRegs[kIA0IRQ1] = SimpleReg_t("IA0IRQ1", 0x0B01, 12, 0x000 );
70 fRegs[kIA0IRQ2] = SimpleReg_t("IA0IRQ2", 0x0B02, 12, 0x000 );
71 fRegs[kIA0IRQ3] = SimpleReg_t("IA0IRQ3", 0x0B03, 12, 0x000 );
72 fRegs[kIA0IRQ4] = SimpleReg_t("IA0IRQ4", 0x0B04, 12, 0x000 );
73 fRegs[kIA0IRQ5] = SimpleReg_t("IA0IRQ5", 0x0B05, 12, 0x000 );
74 fRegs[kIA0IRQ6] = SimpleReg_t("IA0IRQ6", 0x0B06, 12, 0x000 );
75 fRegs[kIA0IRQ7] = SimpleReg_t("IA0IRQ7", 0x0B07, 12, 0x000 );
76 fRegs[kIA0IRQ8] = SimpleReg_t("IA0IRQ8", 0x0B08, 12, 0x000 );
77 fRegs[kIA0IRQ9] = SimpleReg_t("IA0IRQ9", 0x0B09, 12, 0x000 );
78 fRegs[kIA0IRQA] = SimpleReg_t("IA0IRQA", 0x0B0A, 12, 0x000 );
79 fRegs[kIA0IRQB] = SimpleReg_t("IA0IRQB", 0x0B0B, 12, 0x000 );
80 fRegs[kIA0IRQC] = SimpleReg_t("IA0IRQC", 0x0B0C, 12, 0x000 );
81 fRegs[kIRQSW0] = SimpleReg_t("IRQSW0", 0x0B0D, 13, 0x1FFF );
82 fRegs[kIRQHW0] = SimpleReg_t("IRQHW0", 0x0B0E, 13, 0x0000 );
83 fRegs[kIRQHL0] = SimpleReg_t("IRQHL0", 0x0B0F, 13, 0x0000 );
84 fRegs[kIA1IRQ0] = SimpleReg_t("IA1IRQ0", 0x0B20, 12, 0x000 ); // IVT of CPU1
85 fRegs[kIA1IRQ1] = SimpleReg_t("IA1IRQ1", 0x0B21, 12, 0x000 );
86 fRegs[kIA1IRQ2] = SimpleReg_t("IA1IRQ2", 0x0B22, 12, 0x000 );
87 fRegs[kIA1IRQ3] = SimpleReg_t("IA1IRQ3", 0x0B23, 12, 0x000 );
88 fRegs[kIA1IRQ4] = SimpleReg_t("IA1IRQ4", 0x0B24, 12, 0x000 );
89 fRegs[kIA1IRQ5] = SimpleReg_t("IA1IRQ5", 0x0B25, 12, 0x000 );
90 fRegs[kIA1IRQ6] = SimpleReg_t("IA1IRQ6", 0x0B26, 12, 0x000 );
91 fRegs[kIA1IRQ7] = SimpleReg_t("IA1IRQ7", 0x0B27, 12, 0x000 );
92 fRegs[kIA1IRQ8] = SimpleReg_t("IA1IRQ8", 0x0B28, 12, 0x000 );
93 fRegs[kIA1IRQ9] = SimpleReg_t("IA1IRQ9", 0x0B29, 12, 0x000 );
94 fRegs[kIA1IRQA] = SimpleReg_t("IA1IRQA", 0x0B2A, 12, 0x000 );
95 fRegs[kIA1IRQB] = SimpleReg_t("IA1IRQB", 0x0B2B, 12, 0x000 );
96 fRegs[kIA1IRQC] = SimpleReg_t("IA1IRQC", 0x0B2C, 12, 0x000 );
97 fRegs[kIRQSW1] = SimpleReg_t("IRQSW1", 0x0B2D, 13, 0x1FFF );
98 fRegs[kIRQHW1] = SimpleReg_t("IRQHW1", 0x0B2E, 13, 0x0000 );
99 fRegs[kIRQHL1] = SimpleReg_t("IRQHL1", 0x0B2F, 13, 0x0000 );
100 fRegs[kIA2IRQ0] = SimpleReg_t("IA2IRQ0", 0x0B40, 12, 0x000 ); // IVT of CPU2
101 fRegs[kIA2IRQ1] = SimpleReg_t("IA2IRQ1", 0x0B41, 12, 0x000 );
102 fRegs[kIA2IRQ2] = SimpleReg_t("IA2IRQ2", 0x0B42, 12, 0x000 );
103 fRegs[kIA2IRQ3] = SimpleReg_t("IA2IRQ3", 0x0B43, 12, 0x000 );
104 fRegs[kIA2IRQ4] = SimpleReg_t("IA2IRQ4", 0x0B44, 12, 0x000 );
105 fRegs[kIA2IRQ5] = SimpleReg_t("IA2IRQ5", 0x0B45, 12, 0x000 );
106 fRegs[kIA2IRQ6] = SimpleReg_t("IA2IRQ6", 0x0B46, 12, 0x000 );
107 fRegs[kIA2IRQ7] = SimpleReg_t("IA2IRQ7", 0x0B47, 12, 0x000 );
108 fRegs[kIA2IRQ8] = SimpleReg_t("IA2IRQ8", 0x0B48, 12, 0x000 );
109 fRegs[kIA2IRQ9] = SimpleReg_t("IA2IRQ9", 0x0B49, 12, 0x000 );
110 fRegs[kIA2IRQA] = SimpleReg_t("IA2IRQA", 0x0B4A, 12, 0x000 );
111 fRegs[kIA2IRQB] = SimpleReg_t("IA2IRQB", 0x0B4B, 12, 0x000 );
112 fRegs[kIA2IRQC] = SimpleReg_t("IA2IRQC", 0x0B4C, 12, 0x000 );
113 fRegs[kIRQSW2] = SimpleReg_t("IRQSW2", 0x0B4D, 13, 0x1FFF );
114 fRegs[kIRQHW2] = SimpleReg_t("IRQHW2", 0x0B4E, 13, 0x0000 );
115 fRegs[kIRQHL2] = SimpleReg_t("IRQHL2", 0x0B4F, 13, 0x0000 );
116 fRegs[kIA3IRQ0] = SimpleReg_t("IA3IRQ0", 0x0B60, 12, 0x000 ); // IVT of CPU3
117 fRegs[kIA3IRQ1] = SimpleReg_t("IA3IRQ1", 0x0B61, 12, 0x000 );
118 fRegs[kIA3IRQ2] = SimpleReg_t("IA3IRQ2", 0x0B62, 12, 0x000 );
119 fRegs[kIA3IRQ3] = SimpleReg_t("IA3IRQ3", 0x0B63, 12, 0x000 );
120 fRegs[kIA3IRQ4] = SimpleReg_t("IA3IRQ4", 0x0B64, 12, 0x000 );
121 fRegs[kIA3IRQ5] = SimpleReg_t("IA3IRQ5", 0x0B65, 12, 0x000 );
122 fRegs[kIA3IRQ6] = SimpleReg_t("IA3IRQ6", 0x0B66, 12, 0x000 );
123 fRegs[kIA3IRQ7] = SimpleReg_t("IA3IRQ7", 0x0B67, 12, 0x000 );
124 fRegs[kIA3IRQ8] = SimpleReg_t("IA3IRQ8", 0x0B68, 12, 0x000 );
125 fRegs[kIA3IRQ9] = SimpleReg_t("IA3IRQ9", 0x0B69, 12, 0x000 );
126 fRegs[kIA3IRQA] = SimpleReg_t("IA3IRQA", 0x0B6A, 12, 0x000 );
127 fRegs[kIA3IRQB] = SimpleReg_t("IA3IRQB", 0x0B6B, 12, 0x000 );
128 fRegs[kIA3IRQC] = SimpleReg_t("IA3IRQC", 0x0B6C, 12, 0x000 );
129 fRegs[kIRQSW3] = SimpleReg_t("IRQSW3", 0x0B6D, 13, 0x1FFF );
130 fRegs[kIRQHW3] = SimpleReg_t("IRQHW3", 0x0B6E, 13, 0x0000 );
131 fRegs[kIRQHL3] = SimpleReg_t("IRQHL3", 0x0B6F, 13, 0x0000 );
132 fRegs[kCTGDINI] = SimpleReg_t("CTGDINI", 0x0B80, 32, 0x00000000 ); // Global Counter/Timer
133 fRegs[kCTGCTRL] = SimpleReg_t("CTGCTRL", 0x0B81, 12, 0xE3F );
134 fRegs[kC08CPU0] = SimpleReg_t("C08CPU0", 0x0C00, 32, 0x00000000 ); // CPU constants
135 fRegs[kC09CPU0] = SimpleReg_t("C09CPU0", 0x0C01, 32, 0x00000000 );
136 fRegs[kC10CPU0] = SimpleReg_t("C10CPU0", 0x0C02, 32, 0x00000000 );
137 fRegs[kC11CPU0] = SimpleReg_t("C11CPU0", 0x0C03, 32, 0x00000000 );
138 fRegs[kC12CPUA] = SimpleReg_t("C12CPUA", 0x0C04, 32, 0x00000000 );
139 fRegs[kC13CPUA] = SimpleReg_t("C13CPUA", 0x0C05, 32, 0x00000000 );
140 fRegs[kC14CPUA] = SimpleReg_t("C14CPUA", 0x0C06, 32, 0x00000000 );
141 fRegs[kC15CPUA] = SimpleReg_t("C15CPUA", 0x0C07, 32, 0x00000000 );
142 fRegs[kC08CPU1] = SimpleReg_t("C08CPU1", 0x0C08, 32, 0x00000000 );
143 fRegs[kC09CPU1] = SimpleReg_t("C09CPU1", 0x0C09, 32, 0x00000000 );
144 fRegs[kC10CPU1] = SimpleReg_t("C10CPU1", 0x0C0A, 32, 0x00000000 );
145 fRegs[kC11CPU1] = SimpleReg_t("C11CPU1", 0x0C0B, 32, 0x00000000 );
146 fRegs[kC08CPU2] = SimpleReg_t("C08CPU2", 0x0C10, 32, 0x00000000 );
147 fRegs[kC09CPU2] = SimpleReg_t("C09CPU2", 0x0C11, 32, 0x00000000 );
148 fRegs[kC10CPU2] = SimpleReg_t("C10CPU2", 0x0C12, 32, 0x00000000 );
149 fRegs[kC11CPU2] = SimpleReg_t("C11CPU2", 0x0C13, 32, 0x00000000 );
150 fRegs[kC08CPU3] = SimpleReg_t("C08CPU3", 0x0C18, 32, 0x00000000 );
151 fRegs[kC09CPU3] = SimpleReg_t("C09CPU3", 0x0C19, 32, 0x00000000 );
152 fRegs[kC10CPU3] = SimpleReg_t("C10CPU3", 0x0C1A, 32, 0x00000000 );
153 fRegs[kC11CPU3] = SimpleReg_t("C11CPU3", 0x0C1B, 32, 0x00000000 );
154 fRegs[kNMOD] = SimpleReg_t("NMOD", 0x0D40, 6, 0x08 ); // NI interface
155 fRegs[kNDLY] = SimpleReg_t("NDLY", 0x0D41, 30, 0x24924924 );
156 fRegs[kNED] = SimpleReg_t("NED", 0x0D42, 16, 0xA240 );
157 fRegs[kNTRO] = SimpleReg_t("NTRO", 0x0D43, 18, 0x3FFFC );
158 fRegs[kNRRO] = SimpleReg_t("NRRO", 0x0D44, 18, 0x3FFFC );
159 fRegs[kNES] = SimpleReg_t("NES", 0x0D45, 32, 0x00000000 );
160 fRegs[kNTP] = SimpleReg_t("NTP", 0x0D46, 32, 0x0000FFFF );
161 fRegs[kNBND] = SimpleReg_t("NBND", 0x0D47, 16, 0x6020 );
162 fRegs[kNP0] = SimpleReg_t("NP0", 0x0D48, 11, 0x44C );
163 fRegs[kNP1] = SimpleReg_t("NP1", 0x0D49, 11, 0x44C );
164 fRegs[kNP2] = SimpleReg_t("NP2", 0x0D4A, 11, 0x44C );
165 fRegs[kNP3] = SimpleReg_t("NP3", 0x0D4B, 11, 0x44C );
166 fRegs[kNCUT] = SimpleReg_t("NCUT", 0x0D4C, 32, 0xFFFFFFFF );
167 fRegs[kTPPT0] = SimpleReg_t("TPPT0", 0x3000, 7, 0x01 ); // Filter and Preprocessor
168 fRegs[kTPFS] = SimpleReg_t("TPFS", 0x3001, 7, 0x05 );
169 fRegs[kTPFE] = SimpleReg_t("TPFE", 0x3002, 7, 0x14 );
170 fRegs[kTPPGR] = SimpleReg_t("TPPGR", 0x3003, 7, 0x15 );
171 fRegs[kTPPAE] = SimpleReg_t("TPPAE", 0x3004, 7, 0x1E );
172 fRegs[kTPQS0] = SimpleReg_t("TPQS0", 0x3005, 7, 0x00 );
173 fRegs[kTPQE0] = SimpleReg_t("TPQE0", 0x3006, 7, 0x0A );
174 fRegs[kTPQS1] = SimpleReg_t("TPQS1", 0x3007, 7, 0x0B );
175 fRegs[kTPQE1] = SimpleReg_t("TPQE1", 0x3008, 7, 0x14 );
176 fRegs[kEBD] = SimpleReg_t("EBD", 0x3009, 3, 0x0 );
177 fRegs[kEBAQA] = SimpleReg_t("EBAQA", 0x300A, 7, 0x00 );
178 fRegs[kEBSIA] = SimpleReg_t("EBSIA", 0x300B, 7, 0x20 );
179 fRegs[kEBSF] = SimpleReg_t("EBSF", 0x300C, 1, 0x1 );
180 fRegs[kEBSIM] = SimpleReg_t("EBSIM", 0x300D, 1, 0x1 );
181 fRegs[kEBPP] = SimpleReg_t("EBPP", 0x300E, 1, 0x1 );
182 fRegs[kEBPC] = SimpleReg_t("EBPC", 0x300F, 1, 0x1 );
183 fRegs[kEBIS] = SimpleReg_t("EBIS", 0x3014, 10, 0x005 );
184 fRegs[kEBIT] = SimpleReg_t("EBIT", 0x3015, 12, 0x028 );
185 fRegs[kEBIL] = SimpleReg_t("EBIL", 0x3016, 8, 0xF0 );
186 fRegs[kEBIN] = SimpleReg_t("EBIN", 0x3017, 1, 0x1 );
187 fRegs[kFLBY] = SimpleReg_t("FLBY", 0x3018, 1, 0x0 );
188 fRegs[kFPBY] = SimpleReg_t("FPBY", 0x3019, 1, 0x0 );
189 fRegs[kFGBY] = SimpleReg_t("FGBY", 0x301A, 1, 0x0 );
190 fRegs[kFTBY] = SimpleReg_t("FTBY", 0x301B, 1, 0x0 );
191 fRegs[kFCBY] = SimpleReg_t("FCBY", 0x301C, 1, 0x0 );
192 fRegs[kFPTC] = SimpleReg_t("FPTC", 0x3020, 2, 0x3 );
193 fRegs[kFPNP] = SimpleReg_t("FPNP", 0x3021, 9, 0x078 );
194 fRegs[kFPCL] = SimpleReg_t("FPCL", 0x3022, 1, 0x1 );
195 fRegs[kFGTA] = SimpleReg_t("FGTA", 0x3028, 12, 0x014 );
196 fRegs[kFGTB] = SimpleReg_t("FGTB", 0x3029, 12, 0x80C );
197 fRegs[kFGCL] = SimpleReg_t("FGCL", 0x302A, 1, 0x1 );
198 fRegs[kFTAL] = SimpleReg_t("FTAL", 0x3030, 10, 0x0F6 );
199 fRegs[kFTLL] = SimpleReg_t("FTLL", 0x3031, 9, 0x11D );
200 fRegs[kFTLS] = SimpleReg_t("FTLS", 0x3032, 9, 0x0D3 );
201 fRegs[kFCW1] = SimpleReg_t("FCW1", 0x3038, 8, 0x1E );
202 fRegs[kFCW2] = SimpleReg_t("FCW2", 0x3039, 8, 0xD4 );
203 fRegs[kFCW3] = SimpleReg_t("FCW3", 0x303A, 8, 0xE6 );
204 fRegs[kFCW4] = SimpleReg_t("FCW4", 0x303B, 8, 0x4A );
205 fRegs[kFCW5] = SimpleReg_t("FCW5", 0x303C, 8, 0xEF );
206 fRegs[kTPFP] = SimpleReg_t("TPFP", 0x3040, 9, 0x037 );
207 fRegs[kTPHT] = SimpleReg_t("TPHT", 0x3041, 14, 0x00A0 );
208 fRegs[kTPVT] = SimpleReg_t("TPVT", 0x3042, 6, 0x00 );
209 fRegs[kTPVBY] = SimpleReg_t("TPVBY", 0x3043, 1, 0x0 );
210 fRegs[kTPCT] = SimpleReg_t("TPCT", 0x3044, 5, 0x08 );
211 fRegs[kTPCL] = SimpleReg_t("TPCL", 0x3045, 5, 0x01 );
212 fRegs[kTPCBY] = SimpleReg_t("TPCBY", 0x3046, 1, 0x1 );
213 fRegs[kTPD] = SimpleReg_t("TPD", 0x3047, 4, 0xF );
214 fRegs[kTPCI0] = SimpleReg_t("TPCI0", 0x3048, 5, 0x00 );
215 fRegs[kTPCI1] = SimpleReg_t("TPCI1", 0x3049, 5, 0x00 );
216 fRegs[kTPCI2] = SimpleReg_t("TPCI2", 0x304A, 5, 0x00 );
217 fRegs[kTPCI3] = SimpleReg_t("TPCI3", 0x304B, 5, 0x00 );
218 fRegs[kADCMSK] = SimpleReg_t("ADCMSK", 0x3050, 21, 0x1FFFFF );
219 fRegs[kADCINB] = SimpleReg_t("ADCINB", 0x3051, 2, 0x2 );
220 fRegs[kADCDAC] = SimpleReg_t("ADCDAC", 0x3052, 5, 0x10 );
221 fRegs[kADCPAR] = SimpleReg_t("ADCPAR", 0x3053, 18, 0x195EF );
222 fRegs[kADCTST] = SimpleReg_t("ADCTST", 0x3054, 2, 0x0 );
223 fRegs[kSADCAZ] = SimpleReg_t("SADCAZ", 0x3055, 1, 0x1 );
224 fRegs[kFGF0] = SimpleReg_t("FGF0", 0x3080, 9, 0x000 );
225 fRegs[kFGF1] = SimpleReg_t("FGF1", 0x3081, 9, 0x000 );
226 fRegs[kFGF2] = SimpleReg_t("FGF2", 0x3082, 9, 0x000 );
227 fRegs[kFGF3] = SimpleReg_t("FGF3", 0x3083, 9, 0x000 );
228 fRegs[kFGF4] = SimpleReg_t("FGF4", 0x3084, 9, 0x000 );
229 fRegs[kFGF5] = SimpleReg_t("FGF5", 0x3085, 9, 0x000 );
230 fRegs[kFGF6] = SimpleReg_t("FGF6", 0x3086, 9, 0x000 );
231 fRegs[kFGF7] = SimpleReg_t("FGF7", 0x3087, 9, 0x000 );
232 fRegs[kFGF8] = SimpleReg_t("FGF8", 0x3088, 9, 0x000 );
233 fRegs[kFGF9] = SimpleReg_t("FGF9", 0x3089, 9, 0x000 );
234 fRegs[kFGF10] = SimpleReg_t("FGF10", 0x308A, 9, 0x000 );
235 fRegs[kFGF11] = SimpleReg_t("FGF11", 0x308B, 9, 0x000 );
236 fRegs[kFGF12] = SimpleReg_t("FGF12", 0x308C, 9, 0x000 );
237 fRegs[kFGF13] = SimpleReg_t("FGF13", 0x308D, 9, 0x000 );
238 fRegs[kFGF14] = SimpleReg_t("FGF14", 0x308E, 9, 0x000 );
239 fRegs[kFGF15] = SimpleReg_t("FGF15", 0x308F, 9, 0x000 );
240 fRegs[kFGF16] = SimpleReg_t("FGF16", 0x3090, 9, 0x000 );
241 fRegs[kFGF17] = SimpleReg_t("FGF17", 0x3091, 9, 0x000 );
242 fRegs[kFGF18] = SimpleReg_t("FGF18", 0x3092, 9, 0x000 );
243 fRegs[kFGF19] = SimpleReg_t("FGF19", 0x3093, 9, 0x000 );
244 fRegs[kFGF20] = SimpleReg_t("FGF20", 0x3094, 9, 0x000 );
245 fRegs[kFGA0] = SimpleReg_t("FGA0", 0x30A0, 6, 0x00 );
246 fRegs[kFGA1] = SimpleReg_t("FGA1", 0x30A1, 6, 0x00 );
247 fRegs[kFGA2] = SimpleReg_t("FGA2", 0x30A2, 6, 0x00 );
248 fRegs[kFGA3] = SimpleReg_t("FGA3", 0x30A3, 6, 0x00 );
249 fRegs[kFGA4] = SimpleReg_t("FGA4", 0x30A4, 6, 0x00 );
250 fRegs[kFGA5] = SimpleReg_t("FGA5", 0x30A5, 6, 0x00 );
251 fRegs[kFGA6] = SimpleReg_t("FGA6", 0x30A6, 6, 0x00 );
252 fRegs[kFGA7] = SimpleReg_t("FGA7", 0x30A7, 6, 0x00 );
253 fRegs[kFGA8] = SimpleReg_t("FGA8", 0x30A8, 6, 0x00 );
254 fRegs[kFGA9] = SimpleReg_t("FGA9", 0x30A9, 6, 0x00 );
255 fRegs[kFGA10] = SimpleReg_t("FGA10", 0x30AA, 6, 0x00 );
256 fRegs[kFGA11] = SimpleReg_t("FGA11", 0x30AB, 6, 0x00 );
257 fRegs[kFGA12] = SimpleReg_t("FGA12", 0x30AC, 6, 0x00 );
258 fRegs[kFGA13] = SimpleReg_t("FGA13", 0x30AD, 6, 0x00 );
259 fRegs[kFGA14] = SimpleReg_t("FGA14", 0x30AE, 6, 0x00 );
260 fRegs[kFGA15] = SimpleReg_t("FGA15", 0x30AF, 6, 0x00 );
261 fRegs[kFGA16] = SimpleReg_t("FGA16", 0x30B0, 6, 0x00 );
262 fRegs[kFGA17] = SimpleReg_t("FGA17", 0x30B1, 6, 0x00 );
263 fRegs[kFGA18] = SimpleReg_t("FGA18", 0x30B2, 6, 0x00 );
264 fRegs[kFGA19] = SimpleReg_t("FGA19", 0x30B3, 6, 0x00 );
265 fRegs[kFGA20] = SimpleReg_t("FGA20", 0x30B4, 6, 0x00 );
266 fRegs[kFLL00] = SimpleReg_t("FLL00", 0x3100, 6, 0x00 ); // non-linearity table, 64 x 6 bits
267 fRegs[kFLL01] = SimpleReg_t("FLL01", 0x3101, 6, 0x00 );
268 fRegs[kFLL02] = SimpleReg_t("FLL02", 0x3102, 6, 0x00 );
269 fRegs[kFLL03] = SimpleReg_t("FLL03", 0x3103, 6, 0x00 );
270 fRegs[kFLL04] = SimpleReg_t("FLL04", 0x3104, 6, 0x00 );
271 fRegs[kFLL05] = SimpleReg_t("FLL05", 0x3105, 6, 0x00 );
272 fRegs[kFLL06] = SimpleReg_t("FLL06", 0x3106, 6, 0x00 );
273 fRegs[kFLL07] = SimpleReg_t("FLL07", 0x3107, 6, 0x00 );
274 fRegs[kFLL08] = SimpleReg_t("FLL08", 0x3108, 6, 0x00 );
275 fRegs[kFLL09] = SimpleReg_t("FLL09", 0x3109, 6, 0x00 );
276 fRegs[kFLL0A] = SimpleReg_t("FLL0A", 0x310A, 6, 0x00 );
277 fRegs[kFLL0B] = SimpleReg_t("FLL0B", 0x310B, 6, 0x00 );
278 fRegs[kFLL0C] = SimpleReg_t("FLL0C", 0x310C, 6, 0x00 );
279 fRegs[kFLL0D] = SimpleReg_t("FLL0D", 0x310D, 6, 0x00 );
280 fRegs[kFLL0E] = SimpleReg_t("FLL0E", 0x310E, 6, 0x00 );
281 fRegs[kFLL0F] = SimpleReg_t("FLL0F", 0x310F, 6, 0x00 );
282 fRegs[kFLL10] = SimpleReg_t("FLL10", 0x3110, 6, 0x00 );
283 fRegs[kFLL11] = SimpleReg_t("FLL11", 0x3111, 6, 0x00 );
284 fRegs[kFLL12] = SimpleReg_t("FLL12", 0x3112, 6, 0x00 );
285 fRegs[kFLL13] = SimpleReg_t("FLL13", 0x3113, 6, 0x00 );
286 fRegs[kFLL14] = SimpleReg_t("FLL14", 0x3114, 6, 0x00 );
287 fRegs[kFLL15] = SimpleReg_t("FLL15", 0x3115, 6, 0x00 );
288 fRegs[kFLL16] = SimpleReg_t("FLL16", 0x3116, 6, 0x00 );
289 fRegs[kFLL17] = SimpleReg_t("FLL17", 0x3117, 6, 0x00 );
290 fRegs[kFLL18] = SimpleReg_t("FLL18", 0x3118, 6, 0x00 );
291 fRegs[kFLL19] = SimpleReg_t("FLL19", 0x3119, 6, 0x00 );
292 fRegs[kFLL1A] = SimpleReg_t("FLL1A", 0x311A, 6, 0x00 );
293 fRegs[kFLL1B] = SimpleReg_t("FLL1B", 0x311B, 6, 0x00 );
294 fRegs[kFLL1C] = SimpleReg_t("FLL1C", 0x311C, 6, 0x00 );
295 fRegs[kFLL1D] = SimpleReg_t("FLL1D", 0x311D, 6, 0x00 );
296 fRegs[kFLL1E] = SimpleReg_t("FLL1E", 0x311E, 6, 0x00 );
297 fRegs[kFLL1F] = SimpleReg_t("FLL1F", 0x311F, 6, 0x00 );
298 fRegs[kFLL20] = SimpleReg_t("FLL20", 0x3120, 6, 0x00 );
299 fRegs[kFLL21] = SimpleReg_t("FLL21", 0x3121, 6, 0x00 );
300 fRegs[kFLL22] = SimpleReg_t("FLL22", 0x3122, 6, 0x00 );
301 fRegs[kFLL23] = SimpleReg_t("FLL23", 0x3123, 6, 0x00 );
302 fRegs[kFLL24] = SimpleReg_t("FLL24", 0x3124, 6, 0x00 );
303 fRegs[kFLL25] = SimpleReg_t("FLL25", 0x3125, 6, 0x00 );
304 fRegs[kFLL26] = SimpleReg_t("FLL26", 0x3126, 6, 0x00 );
305 fRegs[kFLL27] = SimpleReg_t("FLL27", 0x3127, 6, 0x00 );
306 fRegs[kFLL28] = SimpleReg_t("FLL28", 0x3128, 6, 0x00 );
307 fRegs[kFLL29] = SimpleReg_t("FLL29", 0x3129, 6, 0x00 );
308 fRegs[kFLL2A] = SimpleReg_t("FLL2A", 0x312A, 6, 0x00 );
309 fRegs[kFLL2B] = SimpleReg_t("FLL2B", 0x312B, 6, 0x00 );
310 fRegs[kFLL2C] = SimpleReg_t("FLL2C", 0x312C, 6, 0x00 );
311 fRegs[kFLL2D] = SimpleReg_t("FLL2D", 0x312D, 6, 0x00 );
312 fRegs[kFLL2E] = SimpleReg_t("FLL2E", 0x312E, 6, 0x00 );
313 fRegs[kFLL2F] = SimpleReg_t("FLL2F", 0x312F, 6, 0x00 );
314 fRegs[kFLL30] = SimpleReg_t("FLL30", 0x3130, 6, 0x00 );
315 fRegs[kFLL31] = SimpleReg_t("FLL31", 0x3131, 6, 0x00 );
316 fRegs[kFLL32] = SimpleReg_t("FLL32", 0x3132, 6, 0x00 );
317 fRegs[kFLL33] = SimpleReg_t("FLL33", 0x3133, 6, 0x00 );
318 fRegs[kFLL34] = SimpleReg_t("FLL34", 0x3134, 6, 0x00 );
319 fRegs[kFLL35] = SimpleReg_t("FLL35", 0x3135, 6, 0x00 );
320 fRegs[kFLL36] = SimpleReg_t("FLL36", 0x3136, 6, 0x00 );
321 fRegs[kFLL37] = SimpleReg_t("FLL37", 0x3137, 6, 0x00 );
322 fRegs[kFLL38] = SimpleReg_t("FLL38", 0x3138, 6, 0x00 );
323 fRegs[kFLL39] = SimpleReg_t("FLL39", 0x3139, 6, 0x00 );
324 fRegs[kFLL3A] = SimpleReg_t("FLL3A", 0x313A, 6, 0x00 );
325 fRegs[kFLL3B] = SimpleReg_t("FLL3B", 0x313B, 6, 0x00 );
326 fRegs[kFLL3C] = SimpleReg_t("FLL3C", 0x313C, 6, 0x00 );
327 fRegs[kFLL3D] = SimpleReg_t("FLL3D", 0x313D, 6, 0x00 );
328 fRegs[kFLL3E] = SimpleReg_t("FLL3E", 0x313E, 6, 0x00 );
329 fRegs[kFLL3F] = SimpleReg_t("FLL3F", 0x313F, 6, 0x00 );
330 fRegs[kPASADEL] = SimpleReg_t("PASADEL", 0x3158, 8, 0xFF ); // end of non-lin table
331 fRegs[kPASAPHA] = SimpleReg_t("PASAPHA", 0x3159, 6, 0x3F );
332 fRegs[kPASAPRA] = SimpleReg_t("PASAPRA", 0x315A, 6, 0x0F );
333 fRegs[kPASADAC] = SimpleReg_t("PASADAC", 0x315B, 8, 0x80 );
334 fRegs[kPASACHM] = SimpleReg_t("PASACHM", 0x315C, 19, 0x7FFFF );
335 fRegs[kPASASTL] = SimpleReg_t("PASASTL", 0x315D, 8, 0xFF );
336 fRegs[kPASAPR1] = SimpleReg_t("PASAPR1", 0x315E, 1, 0x0 );
337 fRegs[kPASAPR0] = SimpleReg_t("PASAPR0", 0x315F, 1, 0x0 );
338 fRegs[kSADCTRG] = SimpleReg_t("SADCTRG", 0x3161, 1, 0x0 );
339 fRegs[kSADCRUN] = SimpleReg_t("SADCRUN", 0x3162, 1, 0x0 );
340 fRegs[kSADCPWR] = SimpleReg_t("SADCPWR", 0x3163, 3, 0x7 );
341 fRegs[kL0TSIM] = SimpleReg_t("L0TSIM", 0x3165, 14, 0x0050 );
342 fRegs[kSADCEC] = SimpleReg_t("SADCEC", 0x3166, 7, 0x00 );
343 fRegs[kSADCMC] = SimpleReg_t("SADCMC", 0x3170, 8, 0xC0 );
344 fRegs[kSADCOC] = SimpleReg_t("SADCOC", 0x3171, 8, 0x19 );
345 fRegs[kSADCGTB] = SimpleReg_t("SADCGTB", 0x3172, 32, 0x37737700 );
346 fRegs[kSEBDEN] = SimpleReg_t("SEBDEN", 0x3178, 3, 0x0 );
347 fRegs[kSEBDOU] = SimpleReg_t("SEBDOU", 0x3179, 3, 0x0 );
348 fRegs[kTPL00] = SimpleReg_t("TPL00", 0x3180, 5, 0x00 ); // pos table, 128 x 5 bits
349 fRegs[kTPL01] = SimpleReg_t("TPL01", 0x3181, 5, 0x00 );
350 fRegs[kTPL02] = SimpleReg_t("TPL02", 0x3182, 5, 0x00 );
351 fRegs[kTPL03] = SimpleReg_t("TPL03", 0x3183, 5, 0x00 );
352 fRegs[kTPL04] = SimpleReg_t("TPL04", 0x3184, 5, 0x00 );
353 fRegs[kTPL05] = SimpleReg_t("TPL05", 0x3185, 5, 0x00 );
354 fRegs[kTPL06] = SimpleReg_t("TPL06", 0x3186, 5, 0x00 );
355 fRegs[kTPL07] = SimpleReg_t("TPL07", 0x3187, 5, 0x00 );
356 fRegs[kTPL08] = SimpleReg_t("TPL08", 0x3188, 5, 0x00 );
357 fRegs[kTPL09] = SimpleReg_t("TPL09", 0x3189, 5, 0x00 );
358 fRegs[kTPL0A] = SimpleReg_t("TPL0A", 0x318A, 5, 0x00 );
359 fRegs[kTPL0B] = SimpleReg_t("TPL0B", 0x318B, 5, 0x00 );
360 fRegs[kTPL0C] = SimpleReg_t("TPL0C", 0x318C, 5, 0x00 );
361 fRegs[kTPL0D] = SimpleReg_t("TPL0D", 0x318D, 5, 0x00 );
362 fRegs[kTPL0E] = SimpleReg_t("TPL0E", 0x318E, 5, 0x00 );
363 fRegs[kTPL0F] = SimpleReg_t("TPL0F", 0x318F, 5, 0x00 );
364 fRegs[kTPL10] = SimpleReg_t("TPL10", 0x3190, 5, 0x00 );
365 fRegs[kTPL11] = SimpleReg_t("TPL11", 0x3191, 5, 0x00 );
366 fRegs[kTPL12] = SimpleReg_t("TPL12", 0x3192, 5, 0x00 );
367 fRegs[kTPL13] = SimpleReg_t("TPL13", 0x3193, 5, 0x00 );
368 fRegs[kTPL14] = SimpleReg_t("TPL14", 0x3194, 5, 0x00 );
369 fRegs[kTPL15] = SimpleReg_t("TPL15", 0x3195, 5, 0x00 );
370 fRegs[kTPL16] = SimpleReg_t("TPL16", 0x3196, 5, 0x00 );
371 fRegs[kTPL17] = SimpleReg_t("TPL17", 0x3197, 5, 0x00 );
372 fRegs[kTPL18] = SimpleReg_t("TPL18", 0x3198, 5, 0x00 );
373 fRegs[kTPL19] = SimpleReg_t("TPL19", 0x3199, 5, 0x00 );
374 fRegs[kTPL1A] = SimpleReg_t("TPL1A", 0x319A, 5, 0x00 );
375 fRegs[kTPL1B] = SimpleReg_t("TPL1B", 0x319B, 5, 0x00 );
376 fRegs[kTPL1C] = SimpleReg_t("TPL1C", 0x319C, 5, 0x00 );
377 fRegs[kTPL1D] = SimpleReg_t("TPL1D", 0x319D, 5, 0x00 );
378 fRegs[kTPL1E] = SimpleReg_t("TPL1E", 0x319E, 5, 0x00 );
379 fRegs[kTPL1F] = SimpleReg_t("TPL1F", 0x319F, 5, 0x00 );
380 fRegs[kTPL20] = SimpleReg_t("TPL20", 0x31A0, 5, 0x00 );
381 fRegs[kTPL21] = SimpleReg_t("TPL21", 0x31A1, 5, 0x00 );
382 fRegs[kTPL22] = SimpleReg_t("TPL22", 0x31A2, 5, 0x00 );
383 fRegs[kTPL23] = SimpleReg_t("TPL23", 0x31A3, 5, 0x00 );
384 fRegs[kTPL24] = SimpleReg_t("TPL24", 0x31A4, 5, 0x00 );
385 fRegs[kTPL25] = SimpleReg_t("TPL25", 0x31A5, 5, 0x00 );
386 fRegs[kTPL26] = SimpleReg_t("TPL26", 0x31A6, 5, 0x00 );
387 fRegs[kTPL27] = SimpleReg_t("TPL27", 0x31A7, 5, 0x00 );
388 fRegs[kTPL28] = SimpleReg_t("TPL28", 0x31A8, 5, 0x00 );
389 fRegs[kTPL29] = SimpleReg_t("TPL29", 0x31A9, 5, 0x00 );
390 fRegs[kTPL2A] = SimpleReg_t("TPL2A", 0x31AA, 5, 0x00 );
391 fRegs[kTPL2B] = SimpleReg_t("TPL2B", 0x31AB, 5, 0x00 );
392 fRegs[kTPL2C] = SimpleReg_t("TPL2C", 0x31AC, 5, 0x00 );
393 fRegs[kTPL2D] = SimpleReg_t("TPL2D", 0x31AD, 5, 0x00 );
394 fRegs[kTPL2E] = SimpleReg_t("TPL2E", 0x31AE, 5, 0x00 );
395 fRegs[kTPL2F] = SimpleReg_t("TPL2F", 0x31AF, 5, 0x00 );
396 fRegs[kTPL30] = SimpleReg_t("TPL30", 0x31B0, 5, 0x00 );
397 fRegs[kTPL31] = SimpleReg_t("TPL31", 0x31B1, 5, 0x00 );
398 fRegs[kTPL32] = SimpleReg_t("TPL32", 0x31B2, 5, 0x00 );
399 fRegs[kTPL33] = SimpleReg_t("TPL33", 0x31B3, 5, 0x00 );
400 fRegs[kTPL34] = SimpleReg_t("TPL34", 0x31B4, 5, 0x00 );
401 fRegs[kTPL35] = SimpleReg_t("TPL35", 0x31B5, 5, 0x00 );
402 fRegs[kTPL36] = SimpleReg_t("TPL36", 0x31B6, 5, 0x00 );
403 fRegs[kTPL37] = SimpleReg_t("TPL37", 0x31B7, 5, 0x00 );
404 fRegs[kTPL38] = SimpleReg_t("TPL38", 0x31B8, 5, 0x00 );
405 fRegs[kTPL39] = SimpleReg_t("TPL39", 0x31B9, 5, 0x00 );
406 fRegs[kTPL3A] = SimpleReg_t("TPL3A", 0x31BA, 5, 0x00 );
407 fRegs[kTPL3B] = SimpleReg_t("TPL3B", 0x31BB, 5, 0x00 );
408 fRegs[kTPL3C] = SimpleReg_t("TPL3C", 0x31BC, 5, 0x00 );
409 fRegs[kTPL3D] = SimpleReg_t("TPL3D", 0x31BD, 5, 0x00 );
410 fRegs[kTPL3E] = SimpleReg_t("TPL3E", 0x31BE, 5, 0x00 );
411 fRegs[kTPL3F] = SimpleReg_t("TPL3F", 0x31BF, 5, 0x00 );
412 fRegs[kTPL40] = SimpleReg_t("TPL40", 0x31C0, 5, 0x00 );
413 fRegs[kTPL41] = SimpleReg_t("TPL41", 0x31C1, 5, 0x00 );
414 fRegs[kTPL42] = SimpleReg_t("TPL42", 0x31C2, 5, 0x00 );
415 fRegs[kTPL43] = SimpleReg_t("TPL43", 0x31C3, 5, 0x00 );
416 fRegs[kTPL44] = SimpleReg_t("TPL44", 0x31C4, 5, 0x00 );
417 fRegs[kTPL45] = SimpleReg_t("TPL45", 0x31C5, 5, 0x00 );
418 fRegs[kTPL46] = SimpleReg_t("TPL46", 0x31C6, 5, 0x00 );
419 fRegs[kTPL47] = SimpleReg_t("TPL47", 0x31C7, 5, 0x00 );
420 fRegs[kTPL48] = SimpleReg_t("TPL48", 0x31C8, 5, 0x00 );
421 fRegs[kTPL49] = SimpleReg_t("TPL49", 0x31C9, 5, 0x00 );
422 fRegs[kTPL4A] = SimpleReg_t("TPL4A", 0x31CA, 5, 0x00 );
423 fRegs[kTPL4B] = SimpleReg_t("TPL4B", 0x31CB, 5, 0x00 );
424 fRegs[kTPL4C] = SimpleReg_t("TPL4C", 0x31CC, 5, 0x00 );
425 fRegs[kTPL4D] = SimpleReg_t("TPL4D", 0x31CD, 5, 0x00 );
426 fRegs[kTPL4E] = SimpleReg_t("TPL4E", 0x31CE, 5, 0x00 );
427 fRegs[kTPL4F] = SimpleReg_t("TPL4F", 0x31CF, 5, 0x00 );
428 fRegs[kTPL50] = SimpleReg_t("TPL50", 0x31D0, 5, 0x00 );
429 fRegs[kTPL51] = SimpleReg_t("TPL51", 0x31D1, 5, 0x00 );
430 fRegs[kTPL52] = SimpleReg_t("TPL52", 0x31D2, 5, 0x00 );
431 fRegs[kTPL53] = SimpleReg_t("TPL53", 0x31D3, 5, 0x00 );
432 fRegs[kTPL54] = SimpleReg_t("TPL54", 0x31D4, 5, 0x00 );
433 fRegs[kTPL55] = SimpleReg_t("TPL55", 0x31D5, 5, 0x00 );
434 fRegs[kTPL56] = SimpleReg_t("TPL56", 0x31D6, 5, 0x00 );
435 fRegs[kTPL57] = SimpleReg_t("TPL57", 0x31D7, 5, 0x00 );
436 fRegs[kTPL58] = SimpleReg_t("TPL58", 0x31D8, 5, 0x00 );
437 fRegs[kTPL59] = SimpleReg_t("TPL59", 0x31D9, 5, 0x00 );
438 fRegs[kTPL5A] = SimpleReg_t("TPL5A", 0x31DA, 5, 0x00 );
439 fRegs[kTPL5B] = SimpleReg_t("TPL5B", 0x31DB, 5, 0x00 );
440 fRegs[kTPL5C] = SimpleReg_t("TPL5C", 0x31DC, 5, 0x00 );
441 fRegs[kTPL5D] = SimpleReg_t("TPL5D", 0x31DD, 5, 0x00 );
442 fRegs[kTPL5E] = SimpleReg_t("TPL5E", 0x31DE, 5, 0x00 );
443 fRegs[kTPL5F] = SimpleReg_t("TPL5F", 0x31DF, 5, 0x00 );
444 fRegs[kTPL60] = SimpleReg_t("TPL60", 0x31E0, 5, 0x00 );
445 fRegs[kTPL61] = SimpleReg_t("TPL61", 0x31E1, 5, 0x00 );
446 fRegs[kTPL62] = SimpleReg_t("TPL62", 0x31E2, 5, 0x00 );
447 fRegs[kTPL63] = SimpleReg_t("TPL63", 0x31E3, 5, 0x00 );
448 fRegs[kTPL64] = SimpleReg_t("TPL64", 0x31E4, 5, 0x00 );
449 fRegs[kTPL65] = SimpleReg_t("TPL65", 0x31E5, 5, 0x00 );
450 fRegs[kTPL66] = SimpleReg_t("TPL66", 0x31E6, 5, 0x00 );
451 fRegs[kTPL67] = SimpleReg_t("TPL67", 0x31E7, 5, 0x00 );
452 fRegs[kTPL68] = SimpleReg_t("TPL68", 0x31E8, 5, 0x00 );
453 fRegs[kTPL69] = SimpleReg_t("TPL69", 0x31E9, 5, 0x00 );
454 fRegs[kTPL6A] = SimpleReg_t("TPL6A", 0x31EA, 5, 0x00 );
455 fRegs[kTPL6B] = SimpleReg_t("TPL6B", 0x31EB, 5, 0x00 );
456 fRegs[kTPL6C] = SimpleReg_t("TPL6C", 0x31EC, 5, 0x00 );
457 fRegs[kTPL6D] = SimpleReg_t("TPL6D", 0x31ED, 5, 0x00 );
458 fRegs[kTPL6E] = SimpleReg_t("TPL6E", 0x31EE, 5, 0x00 );
459 fRegs[kTPL6F] = SimpleReg_t("TPL6F", 0x31EF, 5, 0x00 );
460 fRegs[kTPL70] = SimpleReg_t("TPL70", 0x31F0, 5, 0x00 );
461 fRegs[kTPL71] = SimpleReg_t("TPL71", 0x31F1, 5, 0x00 );
462 fRegs[kTPL72] = SimpleReg_t("TPL72", 0x31F2, 5, 0x00 );
463 fRegs[kTPL73] = SimpleReg_t("TPL73", 0x31F3, 5, 0x00 );
464 fRegs[kTPL74] = SimpleReg_t("TPL74", 0x31F4, 5, 0x00 );
465 fRegs[kTPL75] = SimpleReg_t("TPL75", 0x31F5, 5, 0x00 );
466 fRegs[kTPL76] = SimpleReg_t("TPL76", 0x31F6, 5, 0x00 );
467 fRegs[kTPL77] = SimpleReg_t("TPL77", 0x31F7, 5, 0x00 );
468 fRegs[kTPL78] = SimpleReg_t("TPL78", 0x31F8, 5, 0x00 );
469 fRegs[kTPL79] = SimpleReg_t("TPL79", 0x31F9, 5, 0x00 );
470 fRegs[kTPL7A] = SimpleReg_t("TPL7A", 0x31FA, 5, 0x00 );
471 fRegs[kTPL7B] = SimpleReg_t("TPL7B", 0x31FB, 5, 0x00 );
472 fRegs[kTPL7C] = SimpleReg_t("TPL7C", 0x31FC, 5, 0x00 );
473 fRegs[kTPL7D] = SimpleReg_t("TPL7D", 0x31FD, 5, 0x00 );
474 fRegs[kTPL7E] = SimpleReg_t("TPL7E", 0x31FE, 5, 0x00 );
475 fRegs[kTPL7F] = SimpleReg_t("TPL7F", 0x31FF, 5, 0x00 );
476 fRegs[kMEMRW] = SimpleReg_t("MEMRW", 0xD000, 7, 0x79 ); // end of pos table
477 fRegs[kMEMCOR] = SimpleReg_t("MEMCOR", 0xD001, 9, 0x000 );
478 fRegs[kDMDELA] = SimpleReg_t("DMDELA", 0xD002, 4, 0x8 );
479 fRegs[kDMDELS] = SimpleReg_t("DMDELS", 0xD003, 4, 0x8 );
480
8ea391e3 481
482
483 for(Int_t iAddr = 0; iAddr < fgkDmemWords; iAddr++) {
5f006bd7 484
8ea391e3 485 if(iAddr == fgkDmemAddrDeflCorr - fgkDmemStartAddress) {
486 fDmem[iAddr] = new UInt_t[fgkDmemSizeSmIndividual];
487 fDmemDepth[iAddr] = fgkDmemSizeSmIndividual;
488 }
489
490 else if(iAddr == fgkDmemAddrNdrift - fgkDmemStartAddress) {
491 fDmem[iAddr] = new UInt_t[fgkDmemSizeSmRocIndividual];
492 fDmemDepth[iAddr] = fgkDmemSizeSmRocIndividual;
493 }
494
495 else if(iAddr >= fgkDmemAddrDeflCutStart-fgkDmemStartAddress && iAddr <= fgkDmemAddrDeflCutEnd-fgkDmemStartAddress) {
5f006bd7 496 fDmem[iAddr] = new UInt_t[fgkDmemSizeSmIndividual];
8ea391e3 497 fDmemDepth[iAddr] = fgkDmemSizeSmIndividual;
498 }
499
500 else if(iAddr >= fgkDmemAddrTrackletStart-fgkDmemStartAddress && iAddr <= fgkDmemAddrTrackletEnd-fgkDmemStartAddress) {
501 fDmem[iAddr] = new UInt_t[fgkDmemSizeTotalIndividual];
502 fDmemDepth[iAddr] = fgkDmemSizeTotalIndividual;
503 }
504
505 else if(iAddr >= fgkDmemAddrLUTStart-fgkDmemStartAddress && iAddr <= fgkDmemAddrLUTEnd-fgkDmemStartAddress) {
506 fDmem[iAddr] = new UInt_t; // same value for all MCMs
507 fDmemDepth[iAddr] = fgkDmemSizeUniform;
508 }
509
510 else if(iAddr == fgkDmemAddrLUTcor0-fgkDmemStartAddress) {
5f006bd7 511 fDmem[iAddr] = new UInt_t[fgkDmemSizeSmIndividual];
8ea391e3 512 fDmemDepth[iAddr] = fgkDmemSizeSmIndividual;
513 }
514
515 else if(iAddr == fgkDmemAddrLUTcor1-fgkDmemStartAddress) {
5f006bd7 516 fDmem[iAddr] = new UInt_t[fgkDmemSizeSmIndividual];
8ea391e3 517 fDmemDepth[iAddr] = fgkDmemSizeSmIndividual;
518 }
5f006bd7 519
8ea391e3 520 else if(iAddr == fgkDmemAddrLUTnbins-fgkDmemStartAddress) {
521 fDmem[iAddr] = new UInt_t; // same value for all MCMs
522 fDmemDepth[iAddr] = fgkDmemSizeUniform;
523 }
524
525 else if(iAddr == fgkDmemAddrLUTLength-fgkDmemStartAddress) {
526 fDmem[iAddr] = new UInt_t; // same value for all MCMs
527 fDmemDepth[iAddr] = fgkDmemSizeUniform;
528 }
529
530 else {
531 fDmem[iAddr] = NULL;
532 fDmemDepth[iAddr] = fgkDmemSizeEmpty;
533 }
5f006bd7 534
051af255 535 }
536
ce4786b9 537 InitRegs();
8ea391e3 538 ResetDmem();
ce4786b9 539}
540
541
542AliTRDtrapConfig* AliTRDtrapConfig::Instance()
543{
544 // return a pointer to an instance of this class
545
546 if (!fgInstance) {
547 fgInstance = new AliTRDtrapConfig();
5e86ff99 548 AliTRDtrapConfigHandler cfgHandler;
549 cfgHandler.LoadConfig();
ce4786b9 550 }
551
552 return fgInstance;
553}
554
555
051af255 556AliTRDtrapConfig::~AliTRDtrapConfig()
557{
8ea391e3 558 for(Int_t iAddr = 0; iAddr < fgkDmemWords; iAddr++) {
559 if(iAddr == fgkDmemAddrDeflCorr - fgkDmemStartAddress)
560 delete [] fDmem[iAddr];
561
562 else if(iAddr == fgkDmemAddrNdrift - fgkDmemStartAddress)
563 delete [] fDmem[iAddr];
564
565 else if(iAddr >= fgkDmemAddrDeflCutStart-fgkDmemStartAddress && iAddr <= fgkDmemAddrDeflCutEnd-fgkDmemStartAddress)
566 delete [] fDmem[iAddr];
567
568 else if(iAddr >= fgkDmemAddrTrackletStart-fgkDmemStartAddress && iAddr <= fgkDmemAddrTrackletEnd-fgkDmemStartAddress)
569 delete [] fDmem[iAddr];
570
571 else if(iAddr >= fgkDmemAddrLUTStart-fgkDmemStartAddress && iAddr <= fgkDmemAddrLUTEnd-fgkDmemStartAddress)
572 delete fDmem[iAddr];
573
574 else if(iAddr == fgkDmemAddrLUTcor0-fgkDmemStartAddress)
575 delete [] fDmem[iAddr];
576
577 else if(iAddr == fgkDmemAddrLUTcor1-fgkDmemStartAddress)
578 delete [] fDmem[iAddr];
5f006bd7 579
8ea391e3 580 else if(iAddr == fgkDmemAddrLUTnbins-fgkDmemStartAddress)
581 delete fDmem[iAddr];
582
583 else if(iAddr == fgkDmemAddrLUTLength-fgkDmemStartAddress)
584 delete fDmem[iAddr];
051af255 585 }
586}
587
588
8ea391e3 589void AliTRDtrapConfig::InitRegs()
ce4786b9 590{
591 // Reset the content of all TRAP registers to the reset values (see TRAP User Manual)
592
593 for (Int_t iReg = 0; iReg < kLastReg; iReg++) {
594
595 fRegisterValue[iReg].individualValue = 0x0;
596
597 fRegisterValue[iReg].globalValue = GetRegResetValue((TrapReg_t) iReg);
598 fRegisterValue[iReg].state = RegValue_t::kGlobal;
599 }
600}
601
602
8ea391e3 603void AliTRDtrapConfig::ResetRegs()
ce4786b9 604{
605 // Reset the content of all TRAP registers to the reset values (see TRAP User Manual)
606
607 for (Int_t iReg = 0; iReg < kLastReg; iReg++) {
608 if(fRegisterValue[iReg].state == RegValue_t::kIndividual) {
609 if (fRegisterValue[iReg].individualValue) {
610 delete [] fRegisterValue[iReg].individualValue;
611 fRegisterValue[iReg].individualValue = 0x0;
612 }
613 }
614
615 fRegisterValue[iReg].globalValue = GetRegResetValue((TrapReg_t) iReg);
616 fRegisterValue[iReg].state = RegValue_t::kGlobal;
617 // printf("%-8s: 0x%08x\n", GetRegName((TrapReg_t) iReg), fRegisterValue[iReg].globalValue);
618 }
619}
620
621
8ea391e3 622void AliTRDtrapConfig::ResetDmem()
623{
624 for(Int_t iAddr = 0; iAddr < fgkDmemWords; iAddr++) {
625 if(fDmemDepth[iAddr] == 0)
626 continue;
627 for(Int_t j=0; j < fDmemDepth[iAddr]; j++) {
628 fDmem[iAddr][j]=0;
629 }
630 }
631}
632
633
634Int_t AliTRDtrapConfig::GetTrapReg(TrapReg_t reg, Int_t det, Int_t rob, Int_t mcm) const
ce4786b9 635{
5f006bd7 636 // get the value of an individual TRAP register
ce4786b9 637 // if it is individual for TRAPs a valid TRAP has to be specified
638
639 if ((reg < 0) || (reg >= kLastReg)) {
640 AliError("Non-existing register requested");
54d34aac 641 return 0;
ce4786b9 642 }
643 else {
644 if (fRegisterValue[reg].state == RegValue_t::kGlobal) {
645 return fRegisterValue[reg].globalValue;
646 }
647 else if (fRegisterValue[reg].state == RegValue_t::kIndividual) {
5f006bd7 648 if((det >= 0 && det < AliTRDgeometry::Ndet()) &&
649 (rob >= 0 && rob < AliTRDfeeParam::GetNrobC1()) &&
ce4786b9 650 (mcm >= 0 && mcm < fgkMaxMcm)) {
651 return fRegisterValue[reg].individualValue[det*AliTRDfeeParam::GetNrobC1()*fgkMaxMcm + rob*fgkMaxMcm + mcm];
652 }
653 else {
654 AliError("Invalid MCM specified or register is individual");
637666cd 655 return 0;
ce4786b9 656 }
657 }
658 else { // should never be reached
659 AliError("MCM register status neither kGlobal nor kIndividual");
637666cd 660 return 0;
ce4786b9 661 }
662 }
ce4786b9 663}
664
665
666Bool_t AliTRDtrapConfig::SetTrapReg(TrapReg_t reg, Int_t value)
667{
668 // set a global value for the given TRAP register,
669 // i.e. the same value for all TRAPs
670
671 if (fRegisterValue[reg].state == RegValue_t::kGlobal) {
672 fRegisterValue[reg].globalValue = value;
673 return kTRUE;
674 }
675 else {
51380642 676 AliError(Form("Register %s has individual values", AliTRDtrapConfig::GetRegName(reg)));
ce4786b9 677 }
678 return kFALSE;
679}
680
681
682Bool_t AliTRDtrapConfig::SetTrapReg(TrapReg_t reg, Int_t value, Int_t det)
683{
684 // set a global value for the given TRAP register,
685 // i.e. the same value for all TRAPs
686
759042e7 687 if( (det>=0 && det<AliTRDgeometry::Ndet())) {
688 if (fRegisterValue[reg].state == RegValue_t::kGlobal) {
689 Int_t defaultValue = fRegisterValue[reg].globalValue;
690
691 fRegisterValue[reg].state = RegValue_t::kIndividual;
692 fRegisterValue[reg].individualValue = new Int_t[AliTRDgeometry::Ndet()*AliTRDfeeParam::GetNrobC1()*fgkMaxMcm];
693
694 for(Int_t i = 0; i < AliTRDgeometry::Ndet()*AliTRDfeeParam::GetNrobC1()*fgkMaxMcm; i++)
695 fRegisterValue[reg].individualValue[i] = defaultValue; // set the requested register of all MCMs to the value previously stored
696
697 for(Int_t rob=0; rob<AliTRDfeeParam::GetNrobC1(); rob++) {
698 for(Int_t mcm=0; mcm<fgkMaxMcm; mcm++)
699 fRegisterValue[reg].individualValue[det*AliTRDfeeParam::GetNrobC1()*fgkMaxMcm + rob*fgkMaxMcm + mcm] = value;
700 }
701 }
702 else if (fRegisterValue[reg].state == RegValue_t::kIndividual) {
5f006bd7 703 // if the register is in idividual mode but a broadcast is requested, the selected register is
ce4786b9 704 // set to value for all MCMs on the chamber
705
759042e7 706 for(Int_t rob=0; rob<AliTRDfeeParam::GetNrobC1(); rob++) {
707 for(Int_t mcm=0; mcm<fgkMaxMcm; mcm++)
708 fRegisterValue[reg].individualValue[det*AliTRDfeeParam::GetNrobC1()*fgkMaxMcm + rob*fgkMaxMcm + mcm] = value;
ce4786b9 709 }
759042e7 710 }
711 else { // should never be reached
ce4786b9 712 AliError("MCM register status neither kGlobal nor kIndividual");
713 return kFALSE;
759042e7 714 }
715 }
716 else {
717 AliError(Form("Invalid detector number: %i\n", det));
718 return kFALSE;
719 }
5f006bd7 720
759042e7 721 return kFALSE;
ce4786b9 722}
723
724
725Bool_t AliTRDtrapConfig::SetTrapReg(TrapReg_t reg, Int_t value, Int_t det, Int_t rob, Int_t mcm)
726{
5f006bd7 727 // set the value for the given TRAP register of an individual MCM
ce4786b9 728
5f006bd7 729 //std::cout << "-- reg: 0x" << std::hex << fRegs[reg].addr <<
051af255 730 //std::dec << ", data " << value << ", det " << det << ", rob " << rob << ", mcm " << mcm << std::endl;
ce4786b9 731
5f006bd7 732 if( (det >= 0 && det < AliTRDgeometry::Ndet()) &&
733 (rob >= 0 && rob < AliTRDfeeParam::GetNrobC1()) &&
ce4786b9 734 (mcm >= 0 && mcm < fgkMaxMcm) ) {
735 if (fRegisterValue[reg].state == RegValue_t::kGlobal) {
736 Int_t defaultValue = fRegisterValue[reg].globalValue;
5f006bd7 737
ce4786b9 738 fRegisterValue[reg].state = RegValue_t::kIndividual;
739 fRegisterValue[reg].individualValue = new Int_t[AliTRDgeometry::Ndet()*AliTRDfeeParam::GetNrobC1()*fgkMaxMcm];
740
741 for(Int_t i = 0; i < AliTRDgeometry::Ndet()*AliTRDfeeParam::GetNrobC1()*fgkMaxMcm; i++)
742 fRegisterValue[reg].individualValue[i] = defaultValue; // set the requested register of all MCMs to the value previously stored
743
744 fRegisterValue[reg].individualValue[det*AliTRDfeeParam::GetNrobC1()*fgkMaxMcm + rob*fgkMaxMcm + mcm] = value;
745 }
746 else if (fRegisterValue[reg].state == RegValue_t::kIndividual) {
747 fRegisterValue[reg].individualValue[det*AliTRDfeeParam::GetNrobC1()*fgkMaxMcm + rob*fgkMaxMcm + mcm] = value;
748 }
749 else { // should never be reached
750 AliError("MCM register status neither kGlobal nor kIndividual");
751 return kFALSE;
752 }
753 }
754 else {
8ea391e3 755 AliError(Form("Invalid value for det, ROB or MCM selected: %i, %i, %i", det, rob, mcm));
ce4786b9 756 return kFALSE;
757 }
758
759 return kTRUE;
760}
761
762
8ea391e3 763UInt_t AliTRDtrapConfig::Peek(Int_t addr, Int_t det, Int_t rob, Int_t mcm) const
ce4786b9 764{
765 // reading from given address
ce4786b9 766
5f006bd7 767 if ( (addr >= fgkDmemStartAddress) &&
ce4786b9 768 (addr < (fgkDmemStartAddress + fgkDmemWords)) ) {
8ea391e3 769 return GetDmemUnsigned(addr, det, rob, mcm);
ce4786b9 770 }
771 else {
772 TrapReg_t mcmReg = GetRegByAddress(addr);
773 if ( mcmReg >= 0 && mcmReg < kLastReg) {
8ea391e3 774 return (UInt_t) GetTrapReg(mcmReg, det, rob, mcm);
ce4786b9 775 }
776 }
777
b17aded9 778 return 0;
ce4786b9 779}
780
781
8ea391e3 782Bool_t AliTRDtrapConfig::Poke(Int_t addr, UInt_t value, Int_t det, Int_t rob, Int_t mcm)
ce4786b9 783{
784 // writing to given address
ce4786b9 785
5f006bd7 786 if ( (addr >= fgkDmemStartAddress) &&
ce4786b9 787 (addr < (fgkDmemStartAddress + fgkDmemWords)) ) {
051af255 788 AliDebug(2, Form("DMEM 0x%08x : %i", addr, value));
789 SetDmem(addr, value, det, rob, mcm);
ce4786b9 790 return kTRUE;
791 }
792 else {
793 TrapReg_t mcmReg = GetRegByAddress(addr);
794 if ( mcmReg >= 0 && mcmReg < kLastReg) {
051af255 795 AliDebug(2, Form("Register: %s : %i\n", GetRegName(mcmReg), value));
8ea391e3 796 SetTrapReg(mcmReg, (UInt_t) value, det, rob, mcm);
ce4786b9 797 return kTRUE;
798 }
799 }
5f006bd7 800
ce4786b9 801 return kFALSE;
802}
803
804
051af255 805Bool_t AliTRDtrapConfig::SetDmem(Int_t addr, UInt_t value)
ce4786b9 806{
5f006bd7 807 // Set the content of the given DMEM address
59f78ad5 808
8ea391e3 809 addr = addr - fgkDmemStartAddress;
ce4786b9 810
8ea391e3 811 if(addr < 0 || addr >= fgkDmemWords) {
5ac2e3b1 812 AliError(Form("No DMEM address: 0x%08x", addr+fgkDmemStartAddress));
8ea391e3 813 return kFALSE;
814 }
815
816 switch(fDmemDepth[addr]) {
817 case fgkDmemSizeEmpty:
5ac2e3b1 818 AliDebug(4, Form("DMEM address %i not active", addr));
8ea391e3 819 return kFALSE;
820 break;
821 case fgkDmemSizeUniform:
822 if(fDmem[addr][0]!=0)
823 AliDebug(5, Form("Warning: Setting new value to DMEM 0x%08x", addr+fgkDmemStartAddress));
824
825 fDmem[addr][0] = value;
826 break;
827 case fgkDmemSizeSmIndividual:
828 for(Int_t i=0; i<fgkDmemSizeSmIndividual; i++) {
829 if(fDmem[addr][i]!=0)
830 AliDebug(5, Form("Warning: Setting new value to DMEM 0x%08x", addr+fgkDmemStartAddress));
831
832 fDmem[addr][i]=value;
051af255 833 }
8ea391e3 834 break;
835 case fgkDmemSizeTotalIndividual:
836 for(Int_t i=0; i<fgkDmemSizeTotalIndividual; i++) {
837 if(fDmem[addr][i]!=0)
838 AliDebug(5, Form("Warning: Setting new value to DMEM 0x%08x", addr+fgkDmemStartAddress));
839
840 fDmem[addr][i]=value;
051af255 841 }
8ea391e3 842 break;
843 case fgkDmemSizeSmRocIndividual:
844 for(Int_t i=0; i<fgkDmemSizeSmRocIndividual; i++) {
845 if(fDmem[addr][i]!=0)
846 AliDebug(5, Form("Warning: Setting new value to DMEM 0x%08x", addr+fgkDmemStartAddress));
847
848 fDmem[addr][i]=value;
ce4786b9 849 }
8ea391e3 850 break;
851 default:
852 AliError(Form("Invalid selection type"));
853 break;
854 }
051af255 855
8ea391e3 856 return kTRUE;
ce4786b9 857}
858
859
8ea391e3 860Bool_t AliTRDtrapConfig::SetDmem(Int_t addr, UInt_t value, Int_t det, Int_t rob, Int_t mcm)
ce4786b9 861{
5f006bd7 862 // Set the content of the given DMEM address
59f78ad5 863
8ea391e3 864 addr = addr - fgkDmemStartAddress;
865 Int_t roc = det%30;
866 Int_t loc;
5f006bd7 867
8ea391e3 868 if(addr < 0 || addr >= fgkDmemWords) {
869 AliError(Form("No DMEM address: 0x%08x", addr+fgkDmemStartAddress));
870 return kFALSE;
871 }
872
873 Int_t detFactor=8*16;
874 Int_t robFactor=16;
051af255 875
8ea391e3 876 switch(fDmemDepth[addr]) {
877 case fgkDmemSizeEmpty:
5ac2e3b1 878 AliDebug(4, Form("DMEM address 0x%08x not active", addr+fgkDmemStartAddress));
8ea391e3 879 return kFALSE;
880 break;
881 case fgkDmemSizeUniform:
882 if(fDmem[addr][0]!=0)
883 AliDebug(5, Form("Warning: Setting new value to DMEM 0x%08x", addr+fgkDmemStartAddress));
884
885 fDmem[addr][0] = value;
886 break;
887 case fgkDmemSizeSmIndividual:
888 loc = detFactor*roc + robFactor*rob + mcm;
889 if(loc < fgkDmemSizeSmIndividual) {
890 if(fDmem[addr][loc]!=0)
891 AliDebug(5, Form("Warning: Setting new value to DMEM 0x%08x", addr+fgkDmemStartAddress));
892
893 fDmem[addr][loc] = value;
051af255 894 }
8ea391e3 895 else {
896 AliError(Form("DMEM sub-address %i out of scope", loc));
897 return kFALSE;
051af255 898 }
8ea391e3 899 break;
900 case fgkDmemSizeTotalIndividual:
901 loc = detFactor*det + robFactor*rob + mcm;
902 if(loc < fgkDmemSizeTotalIndividual) {
903 if(fDmem[addr][loc]!=0)
904 AliDebug(5, Form("Warning: Setting new value to DMEM 0x%08x", addr+fgkDmemStartAddress));
5f006bd7 905
8ea391e3 906 fDmem[addr][loc]=value;
051af255 907 }
8ea391e3 908 else {
909 AliError(Form("DMEM sub-address %i out of scope", loc));
910 return kFALSE;
911 }
912 break;
913 case fgkDmemSizeSmRocIndividual:
914 if(det < fgkDmemSizeSmRocIndividual) {
915 if(fDmem[addr][det]!=0)
916 AliDebug(5, Form("Warning: Setting new value to DMEM 0x%08x", addr+fgkDmemStartAddress));
051af255 917
8ea391e3 918 fDmem[addr][det]=value;
919 }
920 else {
921 AliError(Form("DMEM sub-address %i out of scope", det));
922 return kFALSE;
923 }
5f006bd7 924
8ea391e3 925 break;
926 default:
927 AliError(Form("Invalid selection type"));
928 return kFALSE;
929 break;
930 }
5f006bd7 931
8ea391e3 932 return kTRUE;
ce4786b9 933}
934
935
8ea391e3 936UInt_t AliTRDtrapConfig::GetDmemUnsigned(Int_t addr) const
ce4786b9 937{
8ea391e3 938 addr = addr - fgkDmemStartAddress;
5ac2e3b1 939 if(addr < 0 || addr >= fgkDmemWords) {
8ea391e3 940 AliError(Form("No DMEM address: 0x%08x", addr+fgkDmemStartAddress));
941 return 0;
942 }
051af255 943
8ea391e3 944 if(fDmemDepth[addr] == fgkDmemSizeUniform)
945 return fDmem[addr][0];
946 else {
947 AliError(Form("No global DMEM value at 0x%08x", addr+fgkDmemStartAddress));
948 return 0;
949 }
950 return 0;
ce4786b9 951}
952
8ea391e3 953UInt_t AliTRDtrapConfig::GetDmemUnsigned(Int_t addr, Int_t det, Int_t rob, Int_t mcm) const
ce4786b9 954{
8ea391e3 955 addr = addr - fgkDmemStartAddress;
956 Int_t roc = det%30;
957 Int_t loc;
5f006bd7 958
8ea391e3 959 if(addr < 0 || addr >= fgkDmemWords) {
960 AliError(Form("No DMEM address: 0x%08x", addr+fgkDmemStartAddress));
961 return 0;
962 }
59f78ad5 963
8ea391e3 964 Int_t detFactor=8*16;
965 Int_t robFactor=16;
966
967 switch(fDmemDepth[addr]) {
968 case fgkDmemSizeEmpty:
5ac2e3b1 969 AliDebug(4, Form("DMEM address 0x%08x not active", addr+fgkDmemStartAddress));
8ea391e3 970 return 0;
971 break;
972 case fgkDmemSizeUniform:
973 return fDmem[addr][0];
974 break;
975 case fgkDmemSizeSmIndividual:
976 loc = detFactor*roc + robFactor*rob + mcm;
977 if(loc < fgkDmemSizeSmIndividual) {
978 return fDmem[addr][loc];
979 }
980 else {
981 AliError(Form("DMEM sub-address %i out of scope", loc));
982 return 0;
983 }
984 break;
985 case fgkDmemSizeTotalIndividual:
986 loc = detFactor*det + robFactor*rob + mcm;
987 if(loc < fgkDmemSizeTotalIndividual) {
988 return fDmem[addr][loc];
989 }
990 else {
991 AliError(Form("DMEM sub-address %i out of scope", loc));
992 return 0;
993 }
994 break;
995 case fgkDmemSizeSmRocIndividual:
996 if(det < fgkDmemSizeSmRocIndividual) {
997 return fDmem[addr][det];
998 }
999 else {
1000 AliError(Form("DMEM sub-address %i out of scope", det));
1001 return 0;
1002 }
1003 break;
1004 default:
1005 AliError(Form("Invalid selection type"));
1006 return 0;
1007 break;
1008 }
5f006bd7 1009
8ea391e3 1010 return 0;
ce4786b9 1011}
1012
1013
5f006bd7 1014Bool_t AliTRDtrapConfig::ReadPackedConfig(Int_t hc, UInt_t *data, Int_t size)
ce4786b9 1015{
59f78ad5 1016 // Read the packed configuration from the passed memory block
1017 //
5f006bd7 1018 // To be used to retrieve the TRAP configuration from the
1019 // configuration as sent in the raw data.
59f78ad5 1020
051af255 1021 AliDebug(1, "Reading packed configuration");
1022
1023 Int_t det = hc/2;
1024
ce4786b9 1025 Int_t idx = 0;
1026 Int_t err = 0;
59f78ad5 1027 Int_t step, bwidth, nwords, exitFlag, bitcnt;
5f006bd7 1028
ce4786b9 1029 UShort_t caddr;
59f78ad5 1030 UInt_t dat, msk, header, dataHi;
5f006bd7 1031
051af255 1032 while (idx < size && *data != 0x00000000) {
5f006bd7 1033
051af255 1034 Int_t rob = (*data >> 28) & 0x7;
1035 Int_t mcm = (*data >> 24) & 0xf;
1036
1037 AliDebug(1, Form("Config of det. %3i MCM %i:%02i (0x%08x)", det, rob, mcm, *data));
ce4786b9 1038 data++;
5f006bd7 1039
051af255 1040 while (idx < size && *data != 0x00000000) {
5f006bd7 1041
051af255 1042 header = *data;
1043 data++;
1044 idx++;
5f006bd7 1045
051af255 1046 AliDebug(5, Form("read: 0x%08x", header));
5f006bd7 1047
8ea391e3 1048 if (header & 0x01) // single data
051af255 1049 {
5f006bd7 1050 dat = (header >> 2) & 0xFFFF; // 16 bit data
1051 caddr = (header >> 18) & 0x3FFF; // 14 bit address
1052
8ea391e3 1053 if (caddr != 0x1FFF) // temp!!! because the end marker was wrong
051af255 1054 {
8ea391e3 1055 if (header & 0x02) // check if > 16 bits
051af255 1056 {
1057 dataHi = *data;
1058 AliDebug(5, Form("read: 0x%08x", dataHi));
1059 data++;
1060 idx++;
1061 err += ((dataHi ^ (dat | 1)) & 0xFFFF) != 0;
1062 dat = (dataHi & 0xFFFF0000) | dat;
1063 }
1064 AliDebug(5, Form("addr=0x%04x (%s) data=0x%08x\n", caddr, GetRegName(GetRegByAddress(caddr)), dat));
1065 if ( ! Poke(caddr, dat, det, rob, mcm) )
1066 AliDebug(5, Form("(single-write): non-existing address 0x%04x containing 0x%08x\n", caddr, header));
1067 if (idx > size)
1068 {
1069 AliDebug(5, Form("(single-write): no more data, missing end marker\n"));
1070 return -err;
1071 }
1072 }
1073 else
1074 {
1075 AliDebug(5, Form("(single-write): address 0x%04x => old endmarker?\n", caddr));
1076 return err;
1077 }
1078 }
5f006bd7 1079
1080 else // block of data
051af255 1081 {
1082 step = (header >> 1) & 0x0003;
1083 bwidth = ((header >> 3) & 0x001F) + 1;
1084 nwords = (header >> 8) & 0x00FF;
1085 caddr = (header >> 16) & 0xFFFF;
1086 exitFlag = (step == 0) || (step == 3) || (nwords == 0);
5f006bd7 1087
1088 if (exitFlag)
051af255 1089 break;
5f006bd7 1090
051af255 1091 switch (bwidth)
1092 {
1093 case 15:
1094 case 10:
1095 case 7:
1096 case 6:
1097 case 5:
1098 {
1099 msk = (1 << bwidth) - 1;
1100 bitcnt = 0;
1101 while (nwords > 0)
1102 {
1103 nwords--;
1104 bitcnt -= bwidth;
1105 if (bitcnt < 0)
1106 {
1107 header = *data;
1108 AliDebug(5, Form("read 0x%08x", header));
1109 data++;
1110 idx++;
1111 err += (header & 1);
1112 header = header >> 1;
1113 bitcnt = 31 - bwidth;
1114 }
1115 AliDebug(5, Form("addr=0x%04x (%s) data=0x%08x\n", caddr, GetRegName(GetRegByAddress(caddr)), header & msk));
1116 if ( ! Poke(caddr, header & msk, det, rob, mcm) )
1117 AliDebug(5, Form("(single-write): non-existing address 0x%04x containing 0x%08x\n", caddr, header));
5f006bd7 1118
051af255 1119 caddr += step;
1120 header = header >> bwidth;
1121 if (idx >= size)
1122 {
1123 AliDebug(5, Form("(block-write): no end marker! %d words read\n", idx));
1124 return -err;
1125 }
1126 }
1127 break;
5f006bd7 1128 } // end case 5-15
051af255 1129 case 31:
1130 {
1131 while (nwords > 0)
1132 {
1133 header = *data;
1134 AliDebug(5, Form("read 0x%08x", header));
1135 data++;
1136 idx++;
1137 nwords--;
1138 err += (header & 1);
5f006bd7 1139
051af255 1140 AliDebug(5, Form("addr=0x%04x (%s) data=0x%08x", caddr, GetRegName(GetRegByAddress(caddr)), header >> 1));
1141 if ( ! Poke(caddr, header >> 1, det, rob, mcm) )
1142 AliDebug(5, Form("(single-write): non-existing address 0x%04x containing 0x%08x\n", caddr, header));
5f006bd7 1143
051af255 1144 caddr += step;
1145 if (idx >= size)
1146 {
1147 AliDebug(5, Form("no end marker! %d words read", idx));
1148 return -err;
1149 }
1150 }
1151 break;
1152 }
1153 default: return err;
5f006bd7 1154 } // end switch
8ea391e3 1155 } // end block case
051af255 1156 }
8ea391e3 1157 } // end while
ce4786b9 1158 AliDebug(5, Form("no end marker! %d words read", idx));
5f006bd7 1159 return -err; // only if the max length of the block reached!
ce4786b9 1160}
1161
1162
8ea391e3 1163Bool_t AliTRDtrapConfig::PrintTrapReg(TrapReg_t reg, Int_t det, Int_t rob, Int_t mcm) const
ce4786b9 1164{
1165 // print the value stored in the given register
1166 // if it is individual a valid MCM has to be specified
1167
1168 if (fRegisterValue[reg].state == RegValue_t::kGlobal) {
759042e7 1169 printf("%10s (%2i bits) at 0x%04x is 0x%08x and resets to: 0x%08x (currently global mode)\n",
ce4786b9 1170 GetRegName((TrapReg_t) reg),
1171 GetRegNBits((TrapReg_t) reg),
1172 GetRegAddress((TrapReg_t) reg),
1173 fRegisterValue[reg].globalValue,
1174 GetRegResetValue((TrapReg_t) reg));
1175 }
1176 else if (fRegisterValue[reg].state == RegValue_t::kIndividual) {
5f006bd7 1177 if((det >= 0 && det < AliTRDgeometry::Ndet()) &&
1178 (rob >= 0 && rob < AliTRDfeeParam::GetNrobC1()) &&
ce4786b9 1179 (mcm >= 0 && mcm < fgkMaxMcm)) {
759042e7 1180 printf("%10s (%2i bits) at 0x%04x is 0x%08x and resets to: 0x%08x (currently individual mode)\n",
ce4786b9 1181 GetRegName((TrapReg_t) reg),
1182 GetRegNBits((TrapReg_t) reg),
1183 GetRegAddress((TrapReg_t) reg),
1184 fRegisterValue[reg].individualValue[det*AliTRDfeeParam::GetNrobC1()*fgkMaxMcm + rob*fgkMaxMcm + mcm],
1185 GetRegResetValue((TrapReg_t) reg));
1186 }
1187 else {
1188 AliError("Register value is MCM-specific: Invalid detector, ROB or MCM requested");
1189 return kFALSE;
1190 }
1191 }
1192 else { // should never be reached
1193 AliError("MCM register status neither kGlobal nor kIndividual");
1194 return kFALSE;
1195 }
1196 return kTRUE;
1197}
1198
1199
8ea391e3 1200Bool_t AliTRDtrapConfig::PrintTrapAddr(Int_t addr, Int_t det, Int_t rob, Int_t mcm) const
ce4786b9 1201{
1202 // print the value stored at the given address in the MCM chip
1203 TrapReg_t reg = GetRegByAddress(addr);
1204 if (reg >= 0 && reg < kLastReg) {
1205 return PrintTrapReg(reg, det, rob, mcm);
1206 }
1207 else {
1208 AliError(Form("There is no register at address 0x%08x in the simulator", addr));
1209 return kFALSE;
1210 }
1211}
1212
1213
1214Bool_t AliTRDtrapConfig::AddValues(UInt_t det, UInt_t cmd, UInt_t extali, Int_t addr, UInt_t data)
1215{
1216 // transfer the informations provided by LoadConfig to the internal class variables
1217
1218 if(cmd != fgkScsnCmdWrite) {
1219 AliError(Form("Invalid command received: %i", cmd));
1220 return kFALSE;
1221 }
1222
1223 TrapReg_t mcmReg = GetRegByAddress(addr);
1224 Int_t rocType = AliTRDgeometry::GetStack(det) == 2 ? 0 : 1;
1225
8ea391e3 1226 static const int mcmListSize=40; // 40 is more or less arbitrary
1227 Int_t mcmList[mcmListSize];
1228
ce4786b9 1229 // configuration registers
1230 if(mcmReg >= 0 && mcmReg < kLastReg) {
5f006bd7 1231
ce4786b9 1232 for(Int_t linkPair=0; linkPair<fgkMaxLinkPairs; linkPair++) {
8ea391e3 1233 if(AliTRDfeeParam::ExtAliToAli(extali, linkPair, rocType, mcmList, mcmListSize)!=0) {
1234 Int_t i=0;
1235 while(mcmList[i] != -1 && i<mcmListSize) {
759042e7 1236 if(mcmList[i]==127) {
1237 AliDebug(1, Form("broadcast write to %s: 0x%08x",
1238 GetRegName((TrapReg_t) mcmReg), data));
ce4786b9 1239 SetTrapReg( (TrapReg_t) mcmReg, data, det);
759042e7 1240 }
1241 else {
1242 AliDebug(1, Form("individual write to %s (%i, %i): 0x%08x",
1243 GetRegName((TrapReg_t) mcmReg), (mcmList[i]>>7), (mcmList[i]&0x7F), data));
1244 SetTrapReg( (TrapReg_t) mcmReg, data, det, (mcmList[i]>>7)&0x7, (mcmList[i]&0x7F));
1245 }
ce4786b9 1246 i++;
1247 }
1248 }
1249 }
1250 return kTRUE;
1251 }
1252 // DMEM
5f006bd7 1253 else if ( (addr >= fgkDmemStartAddress) &&
ce4786b9 1254 (addr < (fgkDmemStartAddress + fgkDmemWords))) {
1255 for(Int_t linkPair=0; linkPair<fgkMaxLinkPairs; linkPair++) {
8ea391e3 1256 if(AliTRDfeeParam::ExtAliToAli(extali, linkPair, rocType, mcmList, mcmListSize)!=0) {
ce4786b9 1257 Int_t i=0;
8ea391e3 1258 while(mcmList[i] != -1 && i < mcmListSize) {
1259 if(mcmList[i] == 127)
1260 SetDmem(addr, data, det, 0, 127);
ce4786b9 1261 else
8ea391e3 1262 SetDmem(addr, data, det, mcmList[i] >> 7, mcmList[i] & 0x7f);
ce4786b9 1263 i++;
1264 }
1265 }
1266 }
1267 return kTRUE;
1268 }
5f006bd7 1269 else
ce4786b9 1270 return kFALSE;
1271}
1272
1273
8ea391e3 1274AliTRDtrapConfig::TrapReg_t AliTRDtrapConfig::GetRegByAddress(Int_t address) const
ce4786b9 1275{
8ea391e3 1276 // get register by its address
1277 // used for reading of configuration data as sent to real FEE
ce4786b9 1278
8ea391e3 1279 TrapReg_t mcmReg = kLastReg;
1280 Int_t reg = 0;
1281 do {
1282 if(fRegs[reg].fAddr == address)
1283 mcmReg = (TrapReg_t) reg;
1284 reg++;
1285 } while (mcmReg == kLastReg && reg < kLastReg);
ce4786b9 1286
8ea391e3 1287 return mcmReg;
ce4786b9 1288}
1289
1290
8ea391e3 1291void AliTRDtrapConfig::PrintMemDatx(ostream &os, Int_t addr) const
ce4786b9 1292{
8ea391e3 1293 PrintMemDatx(os, addr, 0, 0, 127);
ce4786b9 1294}
1295
8ea391e3 1296void AliTRDtrapConfig::PrintMemDatx(ostream &os, Int_t addr, Int_t det, Int_t rob, Int_t mcm) const
ce4786b9 1297{
8ea391e3 1298 if(addr < fgkDmemStartAddress || addr >= fgkDmemStartAddress+fgkDmemWords) {
1299 AliError(Form("Invalid DMEM address 0x%08x!", addr));
1300 return;
1301 }
1302 PrintDatx(os, addr, GetDmemUnsigned(addr, det, rob, mcm), rob, mcm);
1303}
1304
ce4786b9 1305
8ea391e3 1306void AliTRDtrapConfig::PrintMemDatx(ostream &os, TrapReg_t reg) const
1307{
1308 PrintMemDatx(os, reg, 0, 0, 127);
ce4786b9 1309}
1310
1311
8ea391e3 1312void AliTRDtrapConfig::PrintMemDatx(ostream &os, TrapReg_t reg, Int_t det, Int_t rob, Int_t mcm) const
ce4786b9 1313{
8ea391e3 1314 if(reg>= kLastReg) {
1315 AliError(Form("Invalid register %i!", reg));
1316 return;
1317 }
1318 PrintDatx(os, GetRegAddress(reg), GetTrapReg(reg, det, rob, mcm), rob, mcm);
1319}
36dc3337 1320
ce4786b9 1321
8ea391e3 1322void AliTRDtrapConfig::PrintDatx(ostream &os, UInt_t addr, UInt_t data, Int_t rob, Int_t mcm) const
1323{
5f006bd7 1324 os << std::setw(5) << 10
8ea391e3 1325 << std::setw(8) << addr
1326 << std::setw(12) << data;
1327 if(mcm==127)
1328 os << std::setw(8) << 127;
1329 else
1330 os << std::setw(8) << AliTRDfeeParam::AliToExtAli(rob, mcm);
5f006bd7 1331
8ea391e3 1332 os << std::endl;
ce4786b9 1333}