10 #define RAWHEADER_V2_H
14 #include <rawdata/switch_basf2_standalone.h>
166 MAGIC_WORD = 0x7F7F0000,
167 MAGIC_MASK = 0xFFFF0000,
169 FORMAT_VERSION__MASK = 0x0000FF00,
170 FORMAT_VERSION_SHIFT = 8
174 EXP_MASK = 0xFFC00000,
176 RUNNO_MASK = 0x003FFF00,
178 SUBRUNNO_MASK = 0x000000FF
182 RAWHEADER_NWORDS = 12
186 HDR_NWORDS_MASK = 0x000000FF
192 POS_VERSION_HDRNWORDS = 1,
195 POS_TTCTIME_TRGTYPE = 4,
198 POS_TRUNC_MASK_DATATYPE = 7,
199 POS_OFFSET_1ST_FINESSE = 8,
200 POS_OFFSET_2ND_FINESSE = 9,
201 POS_OFFSET_3RD_FINESSE = 10,
202 POS_OFFSET_4TH_FINESSE = 11,
222 TTCTIME_MASK = 0x7FFFFFF0,
230 B2LINK_PACKET_CRC_ERROR = 0x1,
231 B2LINK_EVENT_CRC_ERROR = 0x2
247 B2FATAL(
"m_buffer is NULL. Exiting...");
254 B2FATAL(
"m_buffer is NULL. Data is corrupted or header info has not yet filled. Exiting...");
277 m_buffer[ POS_NODE_ID ] = (int)node_id;
283 m_buffer[ POS_TRUNC_MASK_DATATYPE ] =
284 (data_type & 0x7FFFFFFF) | (
m_buffer[ POS_TRUNC_MASK_DATATYPE ] & 0x80000000);
291 m_buffer[ POS_TRUNC_MASK_DATATYPE ] = (trunc_mask << 31) | (
m_buffer[ POS_TRUNC_MASK_DATATYPE ] & 0x7FFFFFFF);
304 m_buffer[ POS_OFFSET_1ST_FINESSE ] = offset_1st_FINESSE;
310 m_buffer[ POS_OFFSET_2ND_FINESSE ] = offset_2nd_FINESSE;
316 m_buffer[ POS_OFFSET_3RD_FINESSE ] = offset_3rd_FINESSE;
322 m_buffer[ POS_OFFSET_4TH_FINESSE ] = offset_4th_FINESSE;
336 m_buffer[ POS_TTCTIME_TRGTYPE ] = word1;
345 memcpy(&(
m_buffer[ POS_EXP_RUN_NO ]), (
char*)exprun_buf,
sizeof(
int) * 1);
365 return RAWHEADER_NWORDS;
371 return (((
unsigned int)(
m_buffer[ POS_EXP_RUN_NO ]) & EXP_MASK)
379 return (((
unsigned int)(
m_buffer[ POS_EXP_RUN_NO ]) & RUNNO_MASK)
386 return (
m_buffer[ POS_EXP_RUN_NO ] & SUBRUNNO_MASK);
392 return ((
unsigned int)(
m_buffer[ POS_EXP_RUN_NO ]));
405 return (
unsigned int)
m_buffer[ POS_NODE_ID ];
411 return (
m_buffer[ POS_TRUNC_MASK_DATATYPE ] & 0x7FFFFFFF);
417 return (
m_buffer[ POS_TRUNC_MASK_DATATYPE ] >> 23) & 0x1;
423 return (
unsigned int)(
m_buffer[ POS_TRUNC_MASK_DATATYPE ]);
429 m_buffer[ POS_TRUNC_MASK_DATATYPE ] |= (int)error_bit_flag;
437 if ((temp_err_flag & B2LINK_PACKET_CRC_ERROR) == 0) {
447 if ((temp_err_flag & B2LINK_EVENT_CRC_ERROR) == 0) {
456 return m_buffer[ POS_OFFSET_1ST_FINESSE ];
462 return m_buffer[ POS_OFFSET_2ND_FINESSE ];
468 return m_buffer[ POS_OFFSET_3RD_FINESSE ];
474 return m_buffer[ POS_OFFSET_4TH_FINESSE ];
486 return (
unsigned int)(
m_buffer[ POS_TTCTIME_TRGTYPE ]);
504 return (
unsigned int)(
m_buffer[ POS_TTUTIME ]);
510 tv->tv_usec = (int)(((
double)
GetTTCtime()) / 127.216);
int GetNwords()
set contents of header
void SetTruncMask(int trunc_mask)
set contents of header
unsigned int GetEveNo()
get restart #(8bit)
int GetOffset1stFINESSE()
get contents of header
int GetPacketCRCError()
Get Packet CRC error flag.
void AddErrorBitFlag(unsigned int error_bit_flag)
Add Detected Error bitflag.
int GetTTCtime()
get contents of header
void SetOffset4thFINESSE(int offset_4th_FINESSE)
set contents of header
void GetTTTimeVal(struct timeval *tv)
get contents of header
void SetFTSW2Words(unsigned int word1, unsigned int word2)
Set values of FTSW info( trigger timing)
int GetSubRunNo()
get run # (14bit)
int GetHdrNwords()
get contents of header
void SetOffset2ndFINESSE(int offset_2nd_FINESSE)
set contents of header
int GetDataType()
get contents of header
void CheckSetBuffer()
initialize header
unsigned int GetTTUtime()
get contents of header
void CheckGetBuffer()
check if m_buffer exists
int GetTRGType()
get TRGType
void SetEveNo(unsigned int eve_no)
set contents of header
unsigned int GetNodeID()
get contents of header
void SetDataType(int data_type)
set contents of header
void SetNodeID(unsigned int node_id)
set contents of header
int GetRunNo()
get contents of header
void SetOffset1stFINESSE(int offset_1st_FINESSE)
set contents of header
void SetNwords(int nwords)
set contents of header
int GetTruncMask()
get contents of header
int GetOffset4thFINESSE()
get contents of header
unsigned int GetErrorBitFlag()
get contents of header
int GetEventCRCError()
Get Detected Error bitflag.
void SetOffset3rdFINESSE(int offset_3rd_FINESSE)
set contents of header
unsigned int GetTTCtimeTRGType()
get contents of header
unsigned int GetExpRunSubrun()
get contents of header
void SetExpRunNumber(int *exprun_buf)
Set a word consists of exp #, run # and subrun #.
int GetExpNo()
get a run/exp number combined word
int GetOffset2ndFINESSE()
get contents of header
int GetOffset3rdFINESSE()
get contents of header
Abstract base class for different kinds of events.