9#ifndef STSXYTERMESSAGE_H
10#define STSXYTERMESSAGE_H
75static constexpr uint16_t kusPosNotHitFlag = 31;
76static constexpr uint16_t kusPosLinkIndex = 22;
78static constexpr uint16_t kusPosHitChannel = 15;
79static constexpr uint16_t kusPosHitAdc = 10;
80static constexpr uint16_t kusPosHitTsOver = 9;
81static constexpr uint16_t kusPosHitTs = 1;
82static constexpr uint16_t kusPosHitEmFlag = 0;
84static constexpr uint16_t kusPosSubtype = 29;
86static constexpr uint16_t kusPosTsMsbVal = 0;
88static constexpr uint16_t kusPosEpochVal = 0;
90static constexpr uint16_t kusPosStatLinkId = 20;
91static constexpr uint16_t kusPosStatSxTs = 14;
92static constexpr uint16_t kusPosStatStatus = 10;
93static constexpr uint16_t kusPosStatDpbTs = 1;
94static constexpr uint16_t kusPosStatCpFlag = 0;
96static constexpr uint16_t kusPosEmptyFlag = 28;
97static constexpr uint16_t kusPosMsErrType = 1;
98static constexpr uint16_t kusPosMsErrFlag = 0;
101static constexpr uint16_t kusLenNotHitFlag = 1;
102static constexpr uint16_t kusLenLinkIndex = 9;
104static constexpr uint16_t kusLenHitChannel = 7;
105static constexpr uint16_t kusLenHitAdc = 5;
106static constexpr uint16_t kusLenHitTsFull = 9;
107static constexpr uint16_t kusLenHitTsOver = 0;
108static constexpr uint16_t kusLenHitTs = 9;
109static constexpr uint16_t kusLenHitEmFlag = 1;
111static constexpr uint16_t kusLenSubtype = 2;
113static constexpr uint16_t kusLenTsMsbVal = 22;
114static constexpr uint16_t kusLenTsMsbValBinning = 29;
116static constexpr uint16_t kusLenEpochVal = 29;
118static constexpr uint16_t kusLenStatLinkId = 9;
119static constexpr uint16_t kusLenStatSxTs = 6;
120static constexpr uint16_t kusLenStatStatus = 4;
121static constexpr uint16_t kusLenStatDpbTs = 9;
122static constexpr uint16_t kusLenStatCpFlag = 1;
124static constexpr uint16_t kusLenEmptyFlag = 1;
125static constexpr uint16_t kusLenMsErrType = 4;
126static constexpr uint16_t kusLenMsErrFlag = 1;
129static constexpr MessField kFieldLinkIndex(kusPosLinkIndex, kusLenLinkIndex);
130static constexpr MessField kFieldNotHitFlag(kusPosNotHitFlag, kusLenNotHitFlag);
132static constexpr MessField kFieldHitChannel(kusPosHitChannel, kusLenHitChannel);
133static constexpr MessField kFieldHitAdc(kusPosHitAdc, kusLenHitAdc);
134static constexpr MessField kFieldHitTsFull(kusPosHitTs, kusLenHitTsFull);
135static constexpr MessField kFieldHitTsOver(kusPosHitTsOver, kusLenHitTsOver);
136static constexpr MessField kFieldHitTs(kusPosHitTs, kusLenHitTs);
137static constexpr MessField kFieldHitEmFlag(kusPosHitEmFlag, kusLenHitEmFlag);
139static constexpr MessField kFieldSubtype(kusPosSubtype, kusLenSubtype);
141static constexpr MessField kFieldTsMsbVal(kusPosTsMsbVal, kusLenTsMsbVal);
142static constexpr MessField kFieldTsMsbValBinning(kusPosTsMsbVal, kusLenTsMsbValBinning);
144static constexpr MessField kFieldEpochVal(kusPosEpochVal, kusLenEpochVal);
146static constexpr MessField kFieldStatLinkId(kusPosStatLinkId, kusLenStatLinkId);
147static constexpr MessField kFieldStatSxTs(kusPosStatSxTs, kusLenStatSxTs);
148static constexpr MessField kFieldStatStatus(kusPosStatStatus, kusLenStatStatus);
149static constexpr MessField kFieldStatDpbTs(kusPosStatDpbTs, kusLenStatDpbTs);
150static constexpr MessField kFieldStatCpFlag(kusPosStatCpFlag, kusLenStatCpFlag);
152static constexpr MessField kFieldEmptyFlag(kusPosEmptyFlag, kusLenEmptyFlag);
153static constexpr MessField kFieldMsErrFlag(kusPosMsErrFlag, kusLenMsErrFlag);
154static constexpr MessField kFieldMsErrType(kusPosMsErrType, kusLenMsErrType);
157static constexpr uint32_t kuHitNbAdcBins = (0 < kusLenHitAdc ? 1 << kusLenHitAdc : 0);
158static constexpr uint32_t kuHitNbTsBins = (0 < kusLenHitTs ? 1 << kusLenHitTs : 0);
159static constexpr uint32_t kuHitNbOverBins = (0 < kusLenHitTsOver ? 1 << kusLenHitTsOver : 0);
160static constexpr uint32_t kuTsMsbNbTsBins = (0 < kusLenTsMsbVal ? 1 << kusLenTsMsbVal : 0);
161static constexpr uint64_t kulTsCycleNbBins =
162 static_cast<uint64_t
>(kuTsMsbNbTsBins) *
static_cast<uint64_t
>(kuHitNbTsBins);
163static constexpr uint16_t kusMaskTsMsbOver = (1 << kusLenHitTsOver) - 1;
164static constexpr uint32_t kulClockCycleNom = 25;
165static constexpr uint32_t kulClockCycleDen = 8;
166static constexpr double kdClockCycleNs =
static_cast<double>(kulClockCycleNom) / kulClockCycleDen;
169static constexpr uint32_t kuHitNbTsBinsBinning = 1 << 10;
170static constexpr uint32_t kuTsMsbNbTsBinsBinning = 1 << kusLenTsMsbValBinning;
171static constexpr uint64_t kulTsCycleNbBinsBinning =
172 static_cast<uint64_t
>(kuTsMsbNbTsBinsBinning) *
static_cast<uint64_t
>(kuHitNbTsBinsBinning);
209 inline uint32_t
GetField(uint32_t uShift, uint32_t uLen)
const
211 return (
fuData >> uShift) & (((
static_cast<uint32_t
>(1)) << uLen) - 1);
214 inline uint8_t
GetBit(uint32_t uShift)
const {
return (
fuData >> uShift) & 1; }
216 inline uint32_t
GetFieldBE(uint32_t uShift, uint32_t uLen)
const
218 return (
DataBE() >> uShift) & (((
static_cast<uint32_t
>(1)) << uLen) - 1);
220 inline uint8_t
GetBitBE(uint32_t uShift)
const {
return (
DataBE() >> uShift) & 1; }
223 return ((
fuData & 0x000000FF) << 24) + ((
fuData & 0x0000FF00) << 8) + ((
fuData >> 8) & 0x0000FF00)
224 + ((
fuData >> 24) & 0x000000FF);
228 inline void SetField(uint32_t uShift, uint32_t uLen, uint32_t uValue)
230 fuData = (
fuData & ~((((
static_cast<uint32_t
>(1)) << uLen) - 1) << uShift))
231 | ((
static_cast<uint64_t
>(uValue)) << uShift);
234 inline void SetBit(uint32_t uShift, uint8_t uValue)
236 fuData = uValue ? (
fuData | ((
static_cast<uint32_t
>(1)) << uShift))
237 : (
fuData & ~((
static_cast<uint32_t
>(1)) << uShift));
262 return !
GetFlag(kFieldNotHitFlag)
293 return ((
static_cast<uint16_t
>(
GetBit(30)) << 9) +
GetField(kFieldHitTs));
408 bool bBinning =
true)
const;
uint16_t GetLinkIndex() const
For all data: Returns the (global) index of the eLink on which the message was received (n bit field)
bool IsCpFlagOn() const
For Status data: Returns the CP flag from ACK frame (1 bit field)
uint32_t GetTsMsbValBinning() const
For TS MSB data: Returns the TS MSB 29 bit field)
bool IsTsMsb() const
Check if the message if a Ts_Msb.
void SetHitTimeOver(uint16_t usVal)
For Hit data: Sets timestamp overlap bits (2 bits field, overlap with 2 LSBs of TS_MSB message)
bool IsDummy() const
Check if the message if a Dummy Hit Message.
uint8_t GetBitBE(MessField field) const
void SetField(MessField field, uint32_t uValue)
Message(uint32_t uDataIn)
bool IsMsErrorFlagOn() const
For End of MS data: Returns the MS error flag (1 bit field)
void SetTsMsbVal(uint32_t uVal)
For TS MSB data: Sets the TS MSB (22 bit field)
uint16_t GetHitTimeFull() const
For Hit data: Returns Full timestamp (10 bit field including 2 bits overlap)
uint16_t GetStatusLink() const
For Status data: Returns the Link Inedx (9 bit field)
uint32_t GetTsMsbVal() const
For TS MSB data: Returns the TS MSB 22 bit field)
uint16_t GetHitAdc() const
For Hit data: Returns ADC value (5 bit field)
void SetHitTimeFull(uint16_t usVal)
For Hit data: Sets Full timestamp (10 bit field including 2 bits overlap)
uint32_t GetField(MessField field) const
void assign(const Message &src)
uint16_t GetLinkIndexHitBinning() const
void SetHitAdc(uint16_t usVal)
For Hit data: Sets ADC value (5 bit field)
static std::string PrintMessType(MessType type)
bool GetFlag(MessField field) const
void SetHitChannel(uint16_t usVal)
For Hit data: Sets StsXYTER channel number (7 bit field)
uint16_t GetHitTimeBinning() const
uint16_t GetStatusStatus() const
For Status data: Returns the Status field from ACK frame (4 bit field)
void SetCpFlag(bool bVal)
For Status data: Sets the Status (1 bit field)
void SetEmptyMsgFlag(bool bVal)
For Empty/End of MS data data: Sets the Empty message flag (1 bit field)
uint8_t GetBit(uint32_t uShift) const
MessSubType GetSubType() const
For non-Hit data: Returns subtype (2 bit field)
void SetStatusLink(uint16_t usVal)
For Status data: Sets the Status (9 bit field)
Message(const Message &src)
void SetHitMissEvtsFlag(bool bVal)
For Hit data: Sets Missed event flag (1 bit field)
Message & operator=(const Message &src)
void SetBit(uint32_t uShift, uint8_t uValue)
void SetMsErrorType(uint16_t usVal)
For End of MS data: Sets the MS error type field (2 bit field)
uint8_t GetBit(MessField field) const
uint32_t GetFieldBE(uint32_t uShift, uint32_t uLen) const
void SetStatusDpbTs(uint16_t usVal)
For Status data: Sets the Status (9 bit field)
void SetEpochVal(uint32_t uVal)
For Epoch data: Sets the Epoch (29 bit field)
void SetData(uint32_t uValue)
uint32_t GetEpochVal() const
For Epoch data: Returns the Epoch (29 bit field)
uint16_t GetHitChannel() const
For Hit data: Returns StsXYTER channel number (7 bit field)
bool IsHit() const
Check if the message if a Hit Message.
uint32_t GetField(uint32_t uShift, uint32_t uLen) const
void SetStatusStatus(uint16_t usVal)
For Status data: Sets the Status (4 bit field)
void SetMsErrorFlag(bool bVal)
For End of MS data data: Sets the MS Error flag (1 bit field)
void SetHitTime(uint16_t usVal)
For Hit data: Sets Full timestamp (8 bit field, 2 MSB bits overlap removed)
MessType GetMessType() const
Returns the message type, see enum MessType.
bool IsEmptyMsg() const
For Empty/End of MS data: Check if this is an empty message (1 bit field)
bool PrintMess(std::ostream &os, MessagePrintMask ctrl=MessagePrintMask::msg_print_Human, bool bBinning=true) const
uint16_t GetMsErrorType() const
For End of MS data: Returns the MS error type field (2 bit field)
uint16_t GetStatusSxTs() const
For Status data: Returns the SMX TS from ACK frame (6 bit field)
uint32_t GetFieldBE(MessField field) const
uint16_t GetHitTime() const
For Hit data: Returns timestamp (8 bit field, 2 MSB bits overlap removed)
uint16_t GetHitTimeOver() const
For Hit data: Returns timestamp overlap bits (2 bits field, overlap with 2 LSBs of TS_MSB message)
uint16_t GetStatusDpbTs() const
For Status data: Returns the DPB TS when frame received (9 bit field)
void SetBit(MessField field, uint8_t ucValue)
uint8_t GetBitBE(uint32_t uShift) const
void SetStatusSxTs(uint16_t usVal)
For Status data: Sets the Status (6 bit field)
bool IsHitMissedEvts() const
For Hit data: Returns Missed event flag (1 bit field)
void SetField(uint32_t uShift, uint32_t uLen, uint32_t uValue)
#define ENABLE_BITMASK_OPERATORS(x)
MsErrorFlags
MS error flags.
MessagePrintMask
Printout control.
MessSubType
Non-hit Message sub-types.
uint16_t fusLen
Start bit index.
constexpr MessField(uint16_t usPos, uint16_t usLen)
Field length.