StRoot
1
Main Page
Related Pages
Modules
Namespaces
Classes
Files
Examples
File List
File Members
•
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Friends
Groups
Pages
RTS
trg
include
trgDataDefs_47.h
1
#ifndef TRG_DATA_DEFS
2
#define TRG_DATA_DEFS
3
/******
4
*
5
* Layout of new Trigger Data Block
6
*
7
* J.M. Nelson 30 January 2009
8
*
9
* Notes: The event descriptor will describe data from either
10
* the Mk1 or Mk2 TCUs. The variable TCU_Mark will be 1 for Mk1
11
* and 2 for the Mk2 TCU. Variables not used by one or other of the
12
* TCUs will be zero.
13
*
14
* The data block structure will always begin with a 4 character
15
* name, followed by the byte-count of data following. The structure of
16
* data will depend on the configuration of particular crates.
17
*
18
* Note: PrePost data will only be available on local trigger disks and
19
* will not be present in event files.
20
*
21
* 8Dec16: JMN changed FORMAT_VERSION
22
* 3Oct17: je - removed DAQ10k TPCpreMask from MIX added EPDlayer# to BBC
23
* 6Dec18: je - modified BBCBlock structure for added EPD DSMs
24
* 4Jan19: JMN removed redundant info from BBCBlock
25
* 12Oct21: JMN and JE: remove FPD[8] from L1_DSM_Data and
26
* FPDEastNSLayer1[8] from MIXBlock
27
* Updated FORMAT_VERSION to 47
28
*
29
******************************************************************************/
30
#define FORMAT_VERSION 0x21101247
/* Format: yymmddvv */
31
#define MAX_TRG_BLK_SIZE 122896
/* Current total: 113.25k bytes for pre/post non-zero suppressed data. Allow 120k */
32
#define MAX_OFFLEN 20
/* Depends on the number of crates in the system */
33
34
#define ADD_BIT_PREPILEUP 0
/* pileup present */
35
#define ADD_BIT_POSTPILEUP 1
36
#define ADD_BIT_FORCE 5
/* Force store of this event */
37
#define ADD_BIT_L2_5 6
/* Level 2.5 abort */
38
#define ADD_BIT_SIM 7
/* Simulated event - used by DAQ */
39
40
/* Event Descriptor Data Structures */
41
42
#pragma pack(1)
43
44
typedef
struct
{
45
char
name[3];
/* Contains EVD */
46
char
TrgDataFmtVer;
/* Exception for use by DAQ (LS byte of FORMAT_VERSION) */
47
int
length;
/* Byte count of data that follows */
48
unsigned
int
bunchXing_hi;
49
unsigned
int
bunchXing_lo;
/* Two parts of RHIC bunch crossing number */
50
unsigned
short
actionWdDetectorBitMask;
/* from Fifo 1 */
51
unsigned
char
actionWdTrgCommand;
/* from Fifo 1 */
52
unsigned
char
actionWdDaqCommand;
/* from Fifo 1 */
53
unsigned
short
TrgToken;
/* from Fifo 2 */
54
unsigned
short
addBits;
/* used by trigger/daq: bit 5=Force store; bit 6=L2.5 abort; bit 7=1 is fake data */
55
unsigned
short
DSMInput;
/* only for use with Mk1 TCU. 0 if Mk2 TCU is used */
56
unsigned
short
externalBusy;
/* from Fifo 9 (Fifo 3 Mk1 TCU) */
57
unsigned
short
internalBusy;
/* from Fifo 9 (Mk2 TCU) */
58
59
60
#ifndef __linux
61
unsigned
int
tcuCtrBunch;
62
#else
63
union
{
64
struct
{
65
unsigned
short
physicsWord;
/* Fifo 4 Mk1 TCU. 0 if Mk2 TCU is used */
66
unsigned
short
TriggerWord;
/* Fifo 5 Mk1 TCU. 0 if Mk2 TCU is used */
67
};
68
struct
{
69
unsigned
short
trgDetMask;
// After 11/8/16
70
unsigned
short
tcuCtrBunch_hi;
// After 11/8/16
71
};
72
unsigned
int
tcuCtrBunch;
73
};
74
#endif
75
76
unsigned
short
DSMAddress;
/* from Fifo 10 (Fifo 6 Mk1 TCU) */
77
78
unsigned
short
TCU_Mark;
/* TCU_Mark Mk1=1 Mk2=2 */
79
unsigned
short
npre;
// (crate_mask & 0xfff) << 4 | npre (after 11/8/16)
80
81
unsigned
short
npost;
// (crate_mask & 0xfff000)>>8| npost (after 11/8/16)
82
unsigned
short
res1;
// (crate_mask & 0xff000000)>>20 | res1&0xf (after 11/8/16)
83
}
EvtDescData
;
84
85
#pragma pack()
86
87
/* L1 DSM data structures */
88
89
typedef
struct
{
90
char
name[4];
/* Contains L1DS */
91
int
length;
/* Byte count of data that follows */
92
unsigned
short
TOF[8];
/* TOF and MTD data */
93
unsigned
short
VTX[8];
/* Separate VPD, ZDC and BBC DSMs have been replaced with this one */
94
unsigned
short
EMC[8];
/* Contents of 1 EMC IB - results of separate BEMC and EEMC DSMs */
95
unsigned
short
TPCMask[8];
/* TPC mask for DAQ10K */
96
unsigned
short
BCdata[16];
/* Contents of 2 Bunch Crossing DSMs IB's */
97
unsigned
short
specialTriggers[8];
/* Contents of 1 Special Trigger DSM - all the special trigger requests */
98
unsigned
short
lastDSM[8];
/* Contents of last DSM IB - results of all DSM trees */
99
}
L1_DSM_Data
;
100
101
/* Trigger Summary Data Structures */
102
103
typedef
struct
{
104
char
name[4];
/* Contains TSUM */
105
int
length;
/* Byte count of data that follows */
106
unsigned
int
L1Sum[2];
/* L1 Summary */
107
unsigned
int
L2Sum[2];
/* L2 Summary */
108
unsigned
int
L1Result[32];
/* Result from L1 CPU */
109
unsigned
int
L2Result[64];
/* Result from L2 CPU */
110
unsigned
int
C2Result[64];
/* Result from last algorithm */
111
unsigned
int
LocalClocks[32];
/* localClock values from RCC2*/
112
}
TrgSumData
;
113
114
typedef
struct
{
115
char
name[4];
116
int
length;
/* Byte count of data that follows */
117
unsigned
int
data
[1];
/* NB: this definition is generic but would vary depending on actual data */
118
}
DataBlock
;
119
120
typedef
struct
{
121
char
name[4];
/* Contains BBC */
122
int
length;
/* Byte count of data that follows */
123
unsigned
short
BBClayer1[8];
/* BBC-small layer1 DSM feeding VT201 DSM */
124
unsigned
short
EPDlayer1a[8];
/* layer1 DSM feeding QT32C TAC info to VT201 DSM */
125
unsigned
short
ZDClayer1[8];
/* layer1 ZDC DSM that feeds the VT201 DSM */
126
unsigned
short
VPD[8];
/* layer1 VPD DSM feeding ADC & TAC values to VT201*/
127
unsigned
short
EPDlayer0t[16];
/* layer0 EPD DSM feeding east & west TAC to EP101 */
128
}
BBCBlock
;
129
130
131
typedef
struct
{
132
char
name[4];
/* Contains MIX */
133
int
length;
/* Byte count of data that follows */
134
unsigned
char
MTD_P2PLayer1[16];
/* Data from MTD and PP2PP */
135
unsigned
short
TOFLayer1[8];
/* This is TOF Layer 1 */
136
unsigned
short
TOF[48];
/* TOF data */
137
/* unsigned short TPCpreMask[24]; */
/* EMC, MTD, & TOF TPC Grid Masks je-removed starting run 18 */
138
}
MIXBlock
;
139
140
typedef
struct
{
141
char
name[4];
142
int
length;
/* Byte count of data that follows */
143
int
dataLoss;
/* Byte count of data truncated due to buffer limitations */
144
unsigned
int
data
[1];
/* NB: this definition is generic but would vary depending on actual data */
145
}
QTBlock
;
146
147
typedef
struct
{
148
char
name[4];
149
int
length;
150
unsigned
char
BEMCEast[240];
/* 15 DSMs covering the East half of BEMC */
151
}
BEastBlock
;
152
153
typedef
struct
{
154
char
name[4];
155
int
length;
156
unsigned
char
BEMCWest[240];
/* 15 DSMs covering the West half of BEMC */
157
}
BWestBlock
;
158
159
typedef
struct
{
160
char
name[4];
161
int
length;
162
unsigned
short
BEMClayer1[48];
/* 6 DSMs for BEMC at layer1 */
163
unsigned
short
EEMClayer1[16];
/* 2 DSMs for EEMC at layer1 */
164
unsigned
char
EEMC[144];
/* 9 DSMs for EEMC at layer0 */
165
}
BELayerBlock
;
166
167
typedef
struct
{
168
char
name[4];
169
int
length;
170
unsigned
char
FMS[256];
/* 16 DSMs for FMS */
171
}
FMSBlock
;
172
173
typedef
struct
{
174
int
offset;
/* Offset (in bytes) from the start of Trigger block to data */
175
int
length;
/* Length (in bytes) of data */
176
}
TrgOfflen
;
177
178
typedef
struct
{
179
int
FormatVersion;
/* Trigger Data Definition Version yymmddvv */
180
int
totalTriggerLength;
/* Total length (bytes) of complete Trigger Block */
181
int
eventNumber;
/* Event number in this run */
182
TrgOfflen
EventDesc_ofl;
/* Offset/length pair to Event Descriptor */
183
TrgOfflen
L1_DSM_ofl;
/* Offset/length pair to L1 DSM Data */
184
TrgOfflen
Summary_ofl;
/* Offset/length pair to Summary Data */
185
TrgOfflen
MainX[MAX_OFFLEN];
/* Offset/length pairs for main crossing */
186
int
PrePostList[10];
/* Offsets to offset/length pairs to Pre and Post crossing */
187
int
raw_data[MAX_TRG_BLK_SIZE/4];
/* Storage for raw data */
188
}
TriggerDataBlk
;
189
190
191
192
// jml - 9/12/11
193
//
194
// These are the data blocks transferred from L1 --> L2 via stp
195
// Back engineered and relabled.
196
// Originally there were multiple instances of these structures in a very confusing set of
197
// of local directories and trgStructures.h etc... Many structs were not consistent
198
//
199
// The 2011 nomenclature is just to differentiate between these structs and the obsolete ones. The
200
// underlying format does not change in 2011
201
202
// These are the datum that L1 creates...
203
typedef
struct
{
204
EvtDescData
EvtDesc;
/* L1 Event Descriptor Data */
205
L1_DSM_Data
L1_DSM;
/* L1 DSM Data */
206
TrgSumData
TrgSum;
/* Summary data */
207
}
L1DataType2011
;
208
209
// This is the specialized L1 version of the dsmMemcpy2Buf packet
210
// which is shipped L1-->L2 Note that the size is 876 bytes which is not 8 byte aligned
211
// The start of this buffer has to be 8 byte aligned for STP sends, however...
212
typedef
struct
{
213
int
src_nodeId;
/* Source nodeId */
214
int
cur_token;
215
int
Npre;
216
int
Npost;
217
unsigned
int
localClock;
/* Local RCC2 clock */
218
int
numGroup;
/* Number of DSMs in first group */
219
int
numDSM;
/* Total number of DSMs */
220
int
byteCount;
/* Ensure alignment of long long */
221
222
//long long dsmData[RAW_MAX_LEN*11/8]; /* Make this 8-byte aligned */
223
L1DataType2011
l1Data;
// This is the true format of the "dsmData" for L1
224
}
L1_Data_Block2011
;
225
226
// This structure is for internal use in L1. This structure has a length that is 8-byte
227
// aligned so that elements of an array remain 8 byte aligned.
228
typedef
struct
{
229
L1_Data_Block2011
l1;
230
unsigned
int
currentBusy;
// keep padded though!
231
// UINT32 pad;
232
}
L1_Data_Storage2011
;
233
234
#endif
235
L1DataType2011
Definition:
trgDataDefs_40.h:169
L1_DSM_Data
Definition:
trgDataDefs_40.h:58
QTBlock
Definition:
trgCrateDefs.h:69
DataBlock
Definition:
trgDataDefs_40.h:82
L1_Data_Block2011
Definition:
trgDataDefs_40.h:178
BWestBlock
Definition:
trgCrateDefs.h:43
BEastBlock
Definition:
trgCrateDefs.h:37
EvtDescData
Definition:
trgStructures-Jan2002.h:150
TrgSumData
Definition:
trgStructures-Jan2002.h:178
FMSBlock
Definition:
trgCrateDefs.h:57
TriggerDataBlk
Definition:
trgDataDefs_40.h:143
TrgOfflen
Definition:
trgDataDefs_40.h:138
BELayerBlock
Definition:
trgCrateDefs.h:49
MIXBlock
Definition:
trgCrateDefs.h:27
BBCBlock
Definition:
trgCrateDefs.h:19
L1_Data_Storage2011
Definition:
trgDataDefs_40.h:194
data
Definition:
PMD_Reader.hh:62
Generated by
1.8.5