#include "AliITSRawStreamSPD.h"
#include "AliRawReader.h"
#include "AliLog.h"
ClassImp(AliITSRawStreamSPD)
const Int_t AliITSRawStreamSPD::fgkDDLModuleMap[kDDLsNumber][kModulesPerDDL] = {
{ 4, 5, 0, 1, 80, 81, 84, 85, 88, 89, 92, 93},
{12,13, 8, 9, 96, 97,100,101,104,105,108,109},
{20,21,16,17,112,113,116,117,120,121,124,125},
{28,29,24,25,128,129,132,133,136,137,140,141},
{36,37,32,33,144,145,148,149,152,153,156,157},
{44,45,40,41,160,161,164,165,168,169,172,173},
{52,53,48,49,176,177,180,181,184,185,188,189},
{60,61,56,57,192,193,196,197,200,201,204,205},
{68,69,64,65,208,209,212,213,216,217,220,221},
{76,77,72,73,224,225,228,229,232,233,236,237},
{ 7, 6, 3, 2, 83, 82, 87, 86, 91, 90, 95, 94},
{15,14,11,10, 99, 98,103,102,107,106,111,110},
{23,22,19,18,115,114,119,118,123,122,127,126},
{31,30,27,26,131,130,135,134,139,138,143,142},
{39,38,35,34,147,146,151,150,155,154,159,158},
{47,46,43,42,163,162,167,166,171,170,175,174},
{55,54,51,50,179,178,183,182,187,186,191,190},
{63,62,59,58,195,194,199,198,203,202,207,206},
{71,70,67,66,211,210,215,214,219,218,223,222},
{79,78,75,74,227,226,231,230,235,234,239,238}
};
AliITSRawStreamSPD::AliITSRawStreamSPD(AliRawReader* rawReader) :
AliITSRawStream(rawReader),
fEventCounter(-1),fChipAddr(0),fHalfStaveNr(0),fCol(0),fRow(0),fCalHeadLen(0),
fData(0),fOffset(0),fHitCount(0),
fDataChar1(0),fDataChar2(0),fDataChar3(0),fDataChar4(0),
fFirstWord(kTRUE),fPrevEventId(0xffffffff),
fEqPLBytesRead(0),fEqPLChipHeadersRead(0),fEqPLChipTrailersRead(0),
fHeaderOrTrailerReadLast(kFALSE),fExpectedHeaderTrailerCount(0),
fFillOutOfSynch(kFALSE),fDDLID(-1),fLastDDLID(-1),fAdvancedErrorLog(kFALSE),
fAdvLogger(NULL)
{
fRawReader->Reset();
fRawReader->Select("ITSSPD");
for (UInt_t iword=0; iword<kCalHeadLenMax; iword++) {
fCalHeadWord[iword]=0xffffffff;
}
for (UInt_t eq=0; eq<20; eq++) {
fActiveEq[eq]=kFALSE;
for (UInt_t hs=0; hs<6; hs++) {
fActiveHS[eq][hs]=kFALSE;
for (UInt_t chip=0; chip<10; chip++) {
fActiveChip[eq][hs][chip]=kFALSE;
fEventCounterFull[eq][hs][chip] = -1;
}
}
}
NewEvent();
}
AliITSRawStreamSPD::AliITSRawStreamSPD(const AliITSRawStreamSPD& rstream) :
AliITSRawStream(rstream.fRawReader),
fEventCounter(-1),fChipAddr(0),fHalfStaveNr(0),fCol(0),fRow(0),fCalHeadLen(0),
fData(0),fOffset(0),fHitCount(0),
fDataChar1(0),fDataChar2(0),fDataChar3(0),fDataChar4(0),
fFirstWord(kTRUE),fPrevEventId(0xffffffff),
fEqPLBytesRead(0),fEqPLChipHeadersRead(0),fEqPLChipTrailersRead(0),
fHeaderOrTrailerReadLast(kFALSE),fExpectedHeaderTrailerCount(0),
fFillOutOfSynch(kFALSE),fDDLID(-1),fLastDDLID(-1),fAdvancedErrorLog(kFALSE),
fAdvLogger(NULL)
{
AliError("Copy constructor should not be used.");
}
AliITSRawStreamSPD& AliITSRawStreamSPD::operator=(const AliITSRawStreamSPD& rstream) {
if (this!=&rstream) {}
AliError("Assignment opertator should not be used.");
return *this;
}
Bool_t AliITSRawStreamSPD::ReadNextShort() {
if (fFirstWord) {
Bool_t b1 = fRawReader->ReadNextChar(fDataChar1);
if (!b1) return kFALSE;
Bool_t b2, b3, b4;
b2 = fRawReader->ReadNextChar(fDataChar2);
b3 = fRawReader->ReadNextChar(fDataChar3);
b4 = fRawReader->ReadNextChar(fDataChar4);
if (!(b2 && b3 && b4)) {
return kFALSE;
}
fData = fDataChar3+(fDataChar4<<8);
const UInt_t *intPtr = fRawReader->GetEventId();
if (intPtr!=0) {
if (*intPtr!=fPrevEventId) {
NewEvent();
fPrevEventId=*intPtr;
}
}
fFirstWord=kFALSE;
}
else {
fFirstWord=kTRUE;
fData = fDataChar1+(fDataChar2<<8);
}
fEqPLBytesRead+=2;
return kTRUE;
}
Bool_t AliITSRawStreamSPD::ReadNextInt() {
if (fFirstWord) {
if (ReadNextShort() && ReadNextShort()) {
return kTRUE;
}
}
else {
if (ReadNextShort()) {
return kTRUE;
}
}
return kFALSE;
}
void AliITSRawStreamSPD::NewEvent() {
for (UInt_t eqId=0; eqId<20; eqId++) {
fCalHeadRead[eqId]=kFALSE;
}
fEventCounter = -1;
fDDLID = -1;
fLastDDLID = -1;
for (UInt_t eq=0; eq<20; eq++) {
for (UInt_t hs=0; hs<6; hs++) {
for (UInt_t chip=0; chip<10; chip++) {
fFastOrSignal[eq][hs][chip] = kFALSE;
}
}
}
}
Int_t AliITSRawStreamSPD::ReadCalibHeader() {
Int_t ddlID = fRawReader->GetDDLID();
if (ddlID==-1) {
if (!ReadNextShort()) return -1;
ddlID = fRawReader->GetDDLID();
if(ddlID<0){
AliError("fRawReader->GetDDLID() returns a negative value");
ddlID=0;
}
}
fEqPLBytesRead = 2;
fEqPLChipHeadersRead = 0;
fEqPLChipTrailersRead = 0;
fHeaderOrTrailerReadLast = kFALSE;
fFillOutOfSynch = kFALSE;
UInt_t statusBits = fRawReader->GetStatusBits();
if ((statusBits >> 5) & 1) {
TString errMess = "LinkRx Error Bit Set";
AliError(errMess.Data());
fRawReader->AddMajorErrorLog(kLinkRxDetectorFatalErr,errMess.Data());
if (fAdvancedErrorLog) fAdvLogger->ProcessError(kLinkRxDetectorFatalErr,ddlID,-1,-1,errMess.Data());
}
if ((statusBits >> 12) & 1) {
TString errMess = "TSM Trigger Error Bit Set";
AliError(errMess.Data());
fRawReader->AddMajorErrorLog(kTSMtriggerErr,errMess.Data());
if (fAdvancedErrorLog) fAdvLogger->ProcessError(kTSMtriggerErr,ddlID,-1,-1,errMess.Data());
}
if (fRawReader->TestBlockAttribute(7)) {
TString errMess = "High Multiplicity Event Flag Set";
AliError(errMess.Data());
fRawReader->AddMajorErrorLog(kHighMultiplicityFlag,errMess.Data());
if (fAdvancedErrorLog) fAdvLogger->ProcessError(kHighMultiplicityFlag,ddlID,-1,-1,errMess.Data());
}
fActiveEq[ddlID]=kTRUE;
fExpectedHeaderTrailerCount = 0;
for (UInt_t hs=0; hs<6; hs++) {
if (!fRawReader->TestBlockAttribute(hs)) {
fActiveHS[ddlID][hs]=kTRUE;
fExpectedHeaderTrailerCount+=10;
}
else {
fActiveHS[ddlID][hs]=kFALSE;
}
}
if (ddlID>=0 && ddlID<20) fCalHeadRead[ddlID]=kTRUE;
if (fRawReader->TestBlockAttribute(6)) {
if (ReadNextInt()) {
fCalHeadLen = fDataChar1+(fDataChar2<<8)+(fDataChar3<<16)+(fDataChar4<<24);
if (fCalHeadLen>kCalHeadLenMax) {
TString errMess = Form("Header length %d > max = %d",fCalHeadLen,kCalHeadLenMax);
AliError(errMess.Data());
fRawReader->AddMajorErrorLog(kCalHeaderLengthErr,errMess.Data());
if (fAdvancedErrorLog) fAdvLogger->ProcessError(kCalHeaderLengthErr,ddlID,-1,-1,errMess.Data());
return -1;
}
else {
for (UInt_t iword=0; iword<fCalHeadLen; iword++) {
if (ReadNextInt()) {
fCalHeadWord[iword] = fDataChar1+(fDataChar2<<8)+(fDataChar3<<16)+(fDataChar4<<24);
}
else {
TString errMess = "Header length problem";
AliError(errMess.Data());
fRawReader->AddMajorErrorLog(kCalHeaderLengthErr,errMess.Data());
if (fAdvancedErrorLog) fAdvLogger->ProcessError(kCalHeaderLengthErr,ddlID,-1,-1,errMess.Data());
return -1;
}
}
return fCalHeadLen;
}
}
}
return -1;
}
Bool_t AliITSRawStreamSPD::Next() {
fPrevModuleID = fModuleID;
while (ReadNextShort()) {
fLastDDLID = fDDLID;
fDDLID = fRawReader->GetDDLID();
if (fDDLID>=0 && fDDLID<20) {
if (!fCalHeadRead[fDDLID]) {
if (fLastDDLID!=-1) {
fEqPLBytesRead -= 2;
}
if (ReadCalibHeader()>=0) continue;
}
}
else {
TString errMess = Form("Error in DDL number (=%d) , setting it to 19",fDDLID);
AliError(errMess.Data());
fRawReader->AddMajorErrorLog(kDDLNumberErr,errMess.Data());
if (fAdvancedErrorLog) fAdvLogger->AddMessage(errMess.Data());
fDDLID=19;
}
Short_t hs = ((fData & 0x3800)>>11) ; Short_t chip=(fData & 0x000F);
if ((fData & 0xC000) == 0x4000) {
if (fHeaderOrTrailerReadLast) {
TString errMess = Form("Chip trailer missing - (eq,hs,chip) = (%d,%d,%d)",fDDLID,hs,chip);
AliError(errMess.Data());
fRawReader->AddMajorErrorLog(kTrailerMissingErr,errMess.Data());
if (fAdvancedErrorLog) fAdvLogger->ProcessError(kTrailerMissingErr,fLastDDLID,fEqPLBytesRead,fEqPLChipHeadersRead,errMess.Data());
}
fHeaderOrTrailerReadLast = kTRUE;
fEqPLChipHeadersRead++;
fHitCount = 0;
UShort_t eventCounter = (fData >> 4) & 0x007F;
if (fEventCounter < 0) {
fEventCounter = eventCounter;
}
else if (eventCounter != fEventCounter) {
TString errMess;
if (fEqPLChipHeadersRead==1) {
errMess = Form("Mismatching event counters between this equipment and the previous: %d != %d - (eq,hs,chip) = (%d,%d,%d)",
eventCounter,fEventCounter,fDDLID,hs,chip);
}
else {
errMess = Form("Mismatching event counters between this chip header and the previous: %d != %d - (eq,hs,chip) = (%d,%d,%d)",
eventCounter,fEventCounter,fDDLID,hs,chip);
}
fEventCounter = eventCounter;
AliError(errMess.Data());
fRawReader->AddMajorErrorLog(kEventCounterErr,errMess.Data());
if (fAdvancedErrorLog) fAdvLogger->ProcessError(kEventCounterErr,fDDLID,fEqPLBytesRead,fEqPLChipHeadersRead,errMess.Data());
}
fChipAddr = fData & 0x000F;
if (fChipAddr>9) {
TString errMess = Form("Overflow chip address %d - set to 0 (eq,hs) = (%d,%d)",fChipAddr,fDDLID,hs);
AliError(errMess.Data());
fRawReader->AddMajorErrorLog(kChipAddrErr,errMess.Data());
if (fAdvancedErrorLog) fAdvLogger->ProcessError(kChipAddrErr,fDDLID,fEqPLBytesRead,fEqPLChipHeadersRead,errMess.Data());
fChipAddr=0;
}
fHalfStaveNr = (fData & 0x3800)>>11;
if (fHalfStaveNr>5 || fRawReader->TestBlockAttribute(fHalfStaveNr)) {
TString errMess = Form("Half stave number error: %d - set to 0 - eq %d",fHalfStaveNr,fDDLID);
AliError(errMess.Data());
fRawReader->AddMajorErrorLog(kHSNumberErr,errMess.Data());
if (fAdvancedErrorLog) fAdvLogger->ProcessError(kHSNumberErr,fDDLID,fEqPLBytesRead,fEqPLChipHeadersRead,errMess.Data());
fHalfStaveNr=0;
}
fActiveChip[fDDLID][fHalfStaveNr][fChipAddr]=kTRUE;
fEventCounterFull[fDDLID][fHalfStaveNr][fChipAddr] = eventCounter;
fModuleID = GetOfflineModuleFromOnline(fDDLID,fHalfStaveNr,fChipAddr);
}
else if ((fData & 0xC000) == 0x0000) {
if ( (fEqPLBytesRead+fFillOutOfSynch*2)%4 != 0 ) {
TString errMess = Form("Fill word is missing - (eq,hs,chip) = (%d,%d,%d)",fDDLID,fHalfStaveNr,fChipAddr);
AliError(errMess.Data());
fRawReader->AddMajorErrorLog(kFillMissingErr,errMess.Data());
if (fAdvancedErrorLog) fAdvLogger->ProcessError(kFillMissingErr,fDDLID,fEqPLBytesRead,fEqPLChipHeadersRead,errMess.Data());
if (fFillOutOfSynch) fFillOutOfSynch = kFALSE;
else fFillOutOfSynch = kTRUE;
}
if (!fHeaderOrTrailerReadLast) {
TString errMess = Form("Trailer without previous header - (eq,hs,chip) = (%d,%d,%d)",fDDLID,fHalfStaveNr,fChipAddr);
AliError(errMess.Data());
fRawReader->AddMajorErrorLog(kTrailerWithoutHeaderErr,errMess.Data());
if (fAdvancedErrorLog) fAdvLogger->ProcessError(kTrailerWithoutHeaderErr,fLastDDLID,fEqPLBytesRead,fEqPLChipHeadersRead,errMess.Data());
}
fHeaderOrTrailerReadLast = kFALSE;
fEqPLChipTrailersRead++;
UShort_t hitCount = fData & 0x0FFF;
if (hitCount != fHitCount){
TString errMess = Form("Number of hits %d, while %d expected - (eq,hs,chip) = (%d,%d,%d)",fHitCount,hitCount,fDDLID,fHalfStaveNr,fChipAddr);
AliError(errMess.Data());
fRawReader->AddMajorErrorLog(kNumberHitsErr,errMess.Data());
if (fAdvancedErrorLog) fAdvLogger->ProcessError(kNumberHitsErr,fDDLID,fEqPLBytesRead,fEqPLChipHeadersRead,errMess.Data());
}
Bool_t errorBit = fData & 0x1000;
if (errorBit) {
TString errMess = Form("Trailer error bit set for chip (eq,hs,chip) = (%d,%d,%d)",fDDLID,fHalfStaveNr,fChipAddr);
AliError(errMess.Data());
fRawReader->AddMajorErrorLog(kTrailerErrorBitErr,errMess.Data());
if (fAdvancedErrorLog) fAdvLogger->ProcessError(kTrailerErrorBitErr,fDDLID,fEqPLBytesRead,fEqPLChipHeadersRead,errMess.Data());
}
Bool_t fastorBit = fData & 0x2000;
fFastOrSignal[fDDLID][fHalfStaveNr][fChipAddr] = fastorBit;
}
else if ((fData & 0xC000) == 0x8000) {
if (!fHeaderOrTrailerReadLast) {
TString errMess = Form("Chip header missing - (eq,hs,chip) = (%d,%d,%d)",fDDLID,fHalfStaveNr,fChipAddr);
AliError(errMess.Data());
fRawReader->AddMajorErrorLog(kHeaderMissingErr,errMess.Data());
if (fAdvancedErrorLog) fAdvLogger->ProcessError(kHeaderMissingErr,fDDLID,fEqPLBytesRead,fEqPLChipHeadersRead,errMess.Data());
fHeaderOrTrailerReadLast = kTRUE;
}
fHitCount++;
fCol = (fData & 0x001F);
fRow = (fData >> 5) & 0x00FF;
fCoord1 = GetOfflineColFromOnline(fDDLID,fHalfStaveNr,fChipAddr,fCol);
fCoord2 = GetOfflineRowFromOnline(fDDLID,fHalfStaveNr,fChipAddr,fRow);
return kTRUE;
}
else {
if ((fData & 0xC000) != 0xC000) {
TString errMess = Form("Wrong fill word! - (eq,hs,chip) = (%d,%d,%d)",fDDLID,fHalfStaveNr,fChipAddr);
AliError(errMess.Data());
fRawReader->AddMajorErrorLog(kWrongFillWordErr,errMess.Data());
if (fAdvancedErrorLog) fAdvLogger->ProcessError(kWrongFillWordErr,fDDLID,fEqPLBytesRead,fEqPLChipHeadersRead,errMess.Data());
}
if ( (fEqPLBytesRead+fFillOutOfSynch*2)%4 != 2 ) {
TString errMess = Form("Fill word is unexpected - (eq,hs,chip) = (%d,%d,%d)",fDDLID,fHalfStaveNr,fChipAddr);
AliError(errMess.Data());
fRawReader->AddMajorErrorLog(kFillUnexpectErr,errMess.Data());
if (fAdvancedErrorLog) fAdvLogger->ProcessError(kFillUnexpectErr,fDDLID,fEqPLBytesRead,fEqPLChipHeadersRead,errMess.Data());
if (fFillOutOfSynch) fFillOutOfSynch = kFALSE;
else fFillOutOfSynch = kTRUE;
}
}
}
if (fDDLID>=0 && fDDLID<20) {
}
return kFALSE;
}
void AliITSRawStreamSPD::CheckHeaderAndTrailerCount(Int_t ddlID) {
if (fEqPLChipHeadersRead != fExpectedHeaderTrailerCount) {
TString errMess = Form("Chip header count inconsistent %d != %d (expected) for ddl %d",
fEqPLChipHeadersRead,fExpectedHeaderTrailerCount,ddlID);
AliError(errMess.Data());
fRawReader->AddMajorErrorLog(kHeaderCountErr,errMess.Data());
if (fAdvancedErrorLog) fAdvLogger->ProcessError(kHeaderCountErr,ddlID,fEqPLBytesRead,fEqPLChipHeadersRead,errMess.Data());
}
if (fEqPLChipTrailersRead != fExpectedHeaderTrailerCount) {
TString errMess = Form("Chip trailer count inconsistent %d != %d (expected) for ddl %d",
fEqPLChipTrailersRead,fExpectedHeaderTrailerCount,ddlID);
AliError(errMess.Data());
fRawReader->AddMajorErrorLog(kHeaderCountErr,errMess.Data());
if (fAdvancedErrorLog) fAdvLogger->ProcessError(kHeaderCountErr,ddlID,fEqPLBytesRead,fEqPLChipHeadersRead,errMess.Data());
}
}
void AliITSRawStreamSPD::ActivateAdvancedErrorLog(Bool_t activate, AliITSRawStreamSPDErrorLog* advLogger) {
fAdvancedErrorLog=activate;
if (activate && advLogger!=NULL) {
fAdvLogger = advLogger;
}
if (fAdvLogger==NULL) {
fAdvancedErrorLog=kFALSE;
}
}
const Char_t* AliITSRawStreamSPD::GetErrorName(UInt_t errorCode) {
if (errorCode==kTotal) return "All Errors";
else if (errorCode==kHeaderMissingErr) return "Header Missing";
else if (errorCode==kTrailerMissingErr) return "Trailer Missing";
else if (errorCode==kTrailerWithoutHeaderErr) return "Trailer Unexpected";
else if (errorCode==kHeaderCountErr) return "Header Count Wrong";
else if (errorCode==kTrailerCountErr) return "Trailer Count Wrong";
else if (errorCode==kFillUnexpectErr) return "Fill Unexpected";
else if (errorCode==kFillMissingErr) return "Fill Missing";
else if (errorCode==kWrongFillWordErr) return "Fill Word Wrong";
else if (errorCode==kNumberHitsErr) return "Hit Count Wrong";
else if (errorCode==kEventCounterErr) return "Event Counter Error";
else if (errorCode==kDDLNumberErr) return "DDL Number Error";
else if (errorCode==kHSNumberErr) return "HS Number Error";
else if (errorCode==kChipAddrErr) return "Chip Address Error";
else if (errorCode==kCalHeaderLengthErr) return "Calib Header Length Error";
else if (errorCode==kAdvEventCounterErr) return "Event Counter Error (Adv)";
else if (errorCode==kAdvEventCounterOrderErr) return "Event Counter Jump Error (Adv)";
else if (errorCode==kTrailerErrorBitErr) return "Trailer Error Bit Set";
else if (errorCode==kLinkRxDetectorFatalErr) return "LinkRx/Detector Fatal Error Bit Set";
else if (errorCode==kTSMtriggerErr) return "TSM Trigger Error Bit Set";
else if (errorCode==kHighMultiplicityFlag) return "High Multiplicity Event Flag Set";
else return "";
}
Bool_t AliITSRawStreamSPD::GetFastOrSignal(UInt_t eq, UInt_t hs, UInt_t chip) {
if (eq>=20 || hs>=6 || chip>=10) {
TString errMess = Form("eq,hs,chip = %d,%d,%d out of bounds. Return kFALSE.",eq,hs,chip);
AliError(errMess.Data());
return kFALSE;
}
return fFastOrSignal[eq][hs][chip];
}
Bool_t AliITSRawStreamSPD::IsActiveEq(UInt_t eq) const {
if (eq>=20) {
TString errMess = Form("eq = %d out of bounds. Return kFALSE.",eq);
AliError(errMess.Data());
return kFALSE;
}
return fActiveEq[eq];
}
Bool_t AliITSRawStreamSPD::IsActiveHS(UInt_t eq, UInt_t hs) const {
if (eq>=20 || hs>=6) {
TString errMess = Form("eq,hs = %d,%d out of bounds. Return kFALSE.",eq,hs);
AliError(errMess.Data());
return kFALSE;
}
return fActiveHS[eq][hs];
}
Bool_t AliITSRawStreamSPD::IsActiveChip(UInt_t eq, UInt_t hs, UInt_t chip) const {
if (eq>=20 || hs>=6 || chip>=10) {
TString errMess = Form("eq,hs,chip = %d,%d,%d out of bounds. Return kFALSE.",eq,hs,chip);
AliError(errMess.Data());
return kFALSE;
}
return fActiveChip[eq][hs][chip];
}
Bool_t AliITSRawStreamSPD::GetHalfStavePresent(UInt_t hs) {
Int_t ddlID = fRawReader->GetDDLID();
if (ddlID==-1) {
AliWarning("DDL ID = -1. Cannot read block attributes. Return kFALSE.");
return kFALSE;
}
else {
if (hs>=6) {
AliWarning(Form("HS >= 6 requested (%d). Return kFALSE.",hs));
return kFALSE;
}
UChar_t attr = fRawReader->GetBlockAttributes();
if (((attr>>hs) & 0x01) == 0x01) {
return kFALSE;
}
else {
return kTRUE;
}
}
}
Bool_t AliITSRawStreamSPD::IsEventCounterFullConsistent() const {
Short_t reference = -1;
for (UInt_t eq=0; eq<20; eq++) {
if (IsActiveEq(eq)) {
for (UInt_t hs=0; hs<6; hs++) {
if (IsActiveHS(eq,hs)) {
for (UInt_t chip=0; chip<10; chip++) {
if (fEventCounterFull[eq][hs][chip]!=-1) {
if (reference==-1) reference = fEventCounterFull[eq][hs][chip];
if (fEventCounterFull[eq][hs][chip] != reference) return kFALSE;
}
}
}
}
}
}
return kTRUE;
}
Short_t AliITSRawStreamSPD::GetEventCounterFullEq(UInt_t eq) const {
if (eq>=20) {
TString errMess = Form("eq (%d) out of bounds",eq);
AliError(errMess.Data());
return -1;
}
if (IsActiveEq(eq)) {
for (UInt_t hs=0; hs<6; hs++) {
if (IsActiveHS(eq,hs)) {
for (UInt_t chip=0; chip<10; chip++) {
if (fEventCounterFull[eq][hs][chip]!=-1) {
return fEventCounterFull[eq][hs][chip];
}
}
}
}
}
return -1;
}
Short_t AliITSRawStreamSPD::GetEventCounterFullHS(UInt_t eq, UInt_t hs) const {
if (eq>=20 || hs>=6) {
TString errMess = Form("eq,hs (%d,%d) out of bounds",eq,hs);
AliError(errMess.Data());
return -1;
}
if (IsActiveEq(eq)) {
if (IsActiveHS(eq,hs)) {
for (UInt_t chip=0; chip<10; chip++) {
if (fEventCounterFull[eq][hs][chip]!=-1) {
return fEventCounterFull[eq][hs][chip];
}
}
}
}
return -1;
}
Short_t AliITSRawStreamSPD::GetEventCounterFullChip(UInt_t eq, UInt_t hs, UInt_t chip) const {
if (eq>=20 || hs>=6 || chip>=10) {
TString errMess = Form("eq,hs,chip (%d,%d,%d) out of bounds",eq,hs,chip);
AliError(errMess.Data());
return -1;
}
if (IsActiveEq(eq)) {
if (IsActiveHS(eq,hs)) {
if (IsActiveChip(eq,hs,chip)) {
return fEventCounterFull[eq][hs][chip];
}
}
}
return -1;
}
Int_t AliITSRawStreamSPD::GetHword(UInt_t index) {
if (index<kCalHeadLenMax) return fCalHeadWord[index];
else return 0;
}
Bool_t AliITSRawStreamSPD::GetHhalfStaveScanned(UInt_t hs) const {
if (hs<6) return (Bool_t)((fCalHeadWord[0]>>(6+hs)) & (0x00000001));
else return kFALSE;
}
Bool_t AliITSRawStreamSPD::GetHchipPresent(UInt_t hs, UInt_t chip) const {
if (hs<6 && chip<10) return ((( fCalHeadWord[hs/3+3]>>((hs%3)*10+chip)) & 0x00000001) == 1);
else return kFALSE;
}
UInt_t AliITSRawStreamSPD::GetHdacHigh(UInt_t hs) const {
if (hs<6) return (fCalHeadWord[hs/2+7]>>(24-16*(hs%2)) & 0x000000ff);
else return 0;
}
UInt_t AliITSRawStreamSPD::GetHdacLow(UInt_t hs) const {
if (hs<6) return (fCalHeadWord[hs/2+7]>>(16-16*(hs%2)) & 0x000000ff);
else return 0;
}
UInt_t AliITSRawStreamSPD::GetHTPAmp(UInt_t hs) const {
if (hs<6) return fCalHeadWord[hs+10];
else return 0;
}
Bool_t AliITSRawStreamSPD::GetHminTHchipPresent(UInt_t chip) const {
if (chip<10) return ((( fCalHeadWord[7]>>(16+chip)) & 0x00000001) == 1);
else return kFALSE;
}
UInt_t AliITSRawStreamSPD::GetFOHnumDacs() const {
return (fCalHeadLen-37)/2;
}
UInt_t AliITSRawStreamSPD::GetFOHdacIndex(UInt_t index) const {
if (index>=GetFOHnumDacs()) {
TString errMess = Form("Only %d DACs in this run, returning 0",GetFOHnumDacs());
AliError(errMess.Data());
return 0;
}
return fCalHeadWord[7+index*2];
}
UInt_t AliITSRawStreamSPD::GetFOHdacValue(UInt_t index) const {
if (index>=GetFOHnumDacs()) {
TString errMess = Form("Only %d DACs in this run, returning 0",GetFOHnumDacs());
AliError(errMess.Data());
return 0;
}
return fCalHeadWord[7+1+index*2];
}
UInt_t AliITSRawStreamSPD::GetFOHchipCount(UInt_t hs, UInt_t chip) const {
if (hs<6 && chip<10) {
if (chip%2==0) {
return ((fCalHeadWord[7 + GetFOHnumDacs()*2 + (hs*10 + chip)/2] >> 16) & 0x0000ffff);
}
else {
return (fCalHeadWord[7 + GetFOHnumDacs()*2 + (hs*10 + chip)/2] & 0x0000ffff);
}
}
else return 0;
}
Int_t AliITSRawStreamSPD::GetModuleNumber(UInt_t iDDL, UInt_t iModule) {
if (iDDL<20 && iModule<12) return fgkDDLModuleMap[iDDL][iModule];
else return 240;
}
Bool_t AliITSRawStreamSPD::OfflineToOnline(UInt_t module, UInt_t colM, UInt_t rowM, UInt_t& eq, UInt_t& hs, UInt_t& chip, UInt_t& col, UInt_t& row) {
eq = GetOnlineEqIdFromOffline(module);
hs = GetOnlineHSFromOffline(module);
chip = GetOnlineChipFromOffline(module,colM);
col = GetOnlineColFromOffline(module,colM);
row = GetOnlineRowFromOffline(module,rowM);
if (eq>=20 || hs>=6 || chip>=10 || col>=32 || row>=256) return kFALSE;
else return kTRUE;
}
Bool_t AliITSRawStreamSPD::OnlineToOffline(UInt_t eq, UInt_t hs, UInt_t chip, UInt_t col, UInt_t row, UInt_t& module, UInt_t& colM, UInt_t& rowM) {
module = GetOfflineModuleFromOnline(eq,hs,chip);
colM = GetOfflineColFromOnline(eq,hs,chip,col);
rowM = GetOfflineRowFromOnline(eq,hs,chip,row);
if (module>=240 || colM>=160 || rowM>=256) return kFALSE;
else return kTRUE;
}
UInt_t AliITSRawStreamSPD::GetOnlineEqIdFromOffline(UInt_t module) {
for (UInt_t eqId=0; eqId<20; eqId++) {
for (UInt_t iModule=0; iModule<12; iModule++) {
if (GetModuleNumber(eqId,iModule)==(Int_t)module) return eqId;
}
}
return 20;
}
UInt_t AliITSRawStreamSPD::GetOnlineHSFromOffline(UInt_t module) {
for (UInt_t eqId=0; eqId<20; eqId++) {
for (UInt_t iModule=0; iModule<12; iModule++) {
if (GetModuleNumber(eqId,iModule)==(Int_t)module) return iModule/2;
}
}
return 6;
}
UInt_t AliITSRawStreamSPD::GetOnlineChipFromOffline(UInt_t module, UInt_t colM) {
for (UInt_t eq=0; eq<20; eq++) {
for (UInt_t iModule=0; iModule<12; iModule++) {
if (GetModuleNumber(eq,iModule)==(Int_t)module) {
if (module<80) {
if (eq<10) {
return (159-colM)/32 + 5*(iModule%2);
}
else {
return colM/32 + 5*(iModule%2);
}
}
else if (module<240) {
if (eq<10) {
return colM/32 + 5*(iModule%2);
}
else {
return (159-colM)/32 + 5*(iModule%2);
}
}
}
}
}
return 10;
}
UInt_t AliITSRawStreamSPD::GetOnlineColFromOffline(UInt_t module, UInt_t colM) {
if (module<80) {
return colM%32;
}
else if (module<240) {
return colM%32;
}
return 32;
}
UInt_t AliITSRawStreamSPD::GetOnlineRowFromOffline(UInt_t module, UInt_t rowM) {
if (module<80) {
return (255-rowM);
}
else if (module<240) {
return (255-rowM);
}
return 256;
}
UInt_t AliITSRawStreamSPD::GetOfflineModuleFromOnline(UInt_t eqId, UInt_t hs, UInt_t chip) {
if (eqId<20 && hs<6 && chip<10) return fgkDDLModuleMap[eqId][hs*2+chip/5];
else return 240;
}
UInt_t AliITSRawStreamSPD::GetOfflineChipKeyFromOnline(UInt_t eqId, UInt_t hs, UInt_t chip) {
if (eqId<20 && hs<6 && chip<10) {
UInt_t module = GetOfflineModuleFromOnline(eqId,hs,chip);
UInt_t chipInModule = ( chip>4 ? chip-5 : chip );
if(eqId>9) chipInModule = 4 - chipInModule;
return (module*5 + chipInModule);
} else return 1200;
}
UInt_t AliITSRawStreamSPD::GetOfflineColFromOnline(UInt_t eqId, UInt_t hs, UInt_t chip, UInt_t col) {
if (eqId>=20 || hs>=6 || chip>=10 || col>=32) return 160;
UInt_t offset = 32 * (chip % 5);
if (hs<2) {
if (eqId<10) {
return 159 - (31-col + offset);
}
else {
return col + offset;
}
}
else {
if (eqId<10) {
return (col + offset);
}
else {
return 159 - (31-col + offset);
}
}
}
UInt_t AliITSRawStreamSPD::GetOfflineRowFromOnline(UInt_t eqId, UInt_t hs, UInt_t chip, UInt_t row) {
if (eqId>=20 || hs>=6 || chip>=10 || row>=256) return 256;
return 255-row;
}
AliITSRawStreamSPD.cxx:10 AliITSRawStreamSPD.cxx:11 AliITSRawStreamSPD.cxx:12 AliITSRawStreamSPD.cxx:13 AliITSRawStreamSPD.cxx:14 AliITSRawStreamSPD.cxx:15 AliITSRawStreamSPD.cxx:16 AliITSRawStreamSPD.cxx:17 AliITSRawStreamSPD.cxx:18 AliITSRawStreamSPD.cxx:19 AliITSRawStreamSPD.cxx:20 AliITSRawStreamSPD.cxx:21 AliITSRawStreamSPD.cxx:22 AliITSRawStreamSPD.cxx:23 AliITSRawStreamSPD.cxx:24 AliITSRawStreamSPD.cxx:25 AliITSRawStreamSPD.cxx:26 AliITSRawStreamSPD.cxx:27 AliITSRawStreamSPD.cxx:28 AliITSRawStreamSPD.cxx:29 AliITSRawStreamSPD.cxx:30 AliITSRawStreamSPD.cxx:31 AliITSRawStreamSPD.cxx:32 AliITSRawStreamSPD.cxx:33 AliITSRawStreamSPD.cxx:34 AliITSRawStreamSPD.cxx:35 AliITSRawStreamSPD.cxx:36 AliITSRawStreamSPD.cxx:37 AliITSRawStreamSPD.cxx:38 AliITSRawStreamSPD.cxx:39 AliITSRawStreamSPD.cxx:40 AliITSRawStreamSPD.cxx:41 AliITSRawStreamSPD.cxx:42 AliITSRawStreamSPD.cxx:43 AliITSRawStreamSPD.cxx:44 AliITSRawStreamSPD.cxx:45 AliITSRawStreamSPD.cxx:46 AliITSRawStreamSPD.cxx:47 AliITSRawStreamSPD.cxx:48 AliITSRawStreamSPD.cxx:49 AliITSRawStreamSPD.cxx:50 AliITSRawStreamSPD.cxx:51 AliITSRawStreamSPD.cxx:52 AliITSRawStreamSPD.cxx:53 AliITSRawStreamSPD.cxx:54 AliITSRawStreamSPD.cxx:55 AliITSRawStreamSPD.cxx:56 AliITSRawStreamSPD.cxx:57 AliITSRawStreamSPD.cxx:58 AliITSRawStreamSPD.cxx:59 AliITSRawStreamSPD.cxx:60 AliITSRawStreamSPD.cxx:61 AliITSRawStreamSPD.cxx:62 AliITSRawStreamSPD.cxx:63 AliITSRawStreamSPD.cxx:64 AliITSRawStreamSPD.cxx:65 AliITSRawStreamSPD.cxx:66 AliITSRawStreamSPD.cxx:67 AliITSRawStreamSPD.cxx:68 AliITSRawStreamSPD.cxx:69 AliITSRawStreamSPD.cxx:70 AliITSRawStreamSPD.cxx:71 AliITSRawStreamSPD.cxx:72 AliITSRawStreamSPD.cxx:73 AliITSRawStreamSPD.cxx:74 AliITSRawStreamSPD.cxx:75 AliITSRawStreamSPD.cxx:76 AliITSRawStreamSPD.cxx:77 AliITSRawStreamSPD.cxx:78 AliITSRawStreamSPD.cxx:79 AliITSRawStreamSPD.cxx:80 AliITSRawStreamSPD.cxx:81 AliITSRawStreamSPD.cxx:82 AliITSRawStreamSPD.cxx:83 AliITSRawStreamSPD.cxx:84 AliITSRawStreamSPD.cxx:85 AliITSRawStreamSPD.cxx:86 AliITSRawStreamSPD.cxx:87 AliITSRawStreamSPD.cxx:88 AliITSRawStreamSPD.cxx:89 AliITSRawStreamSPD.cxx:90 AliITSRawStreamSPD.cxx:91 AliITSRawStreamSPD.cxx:92 AliITSRawStreamSPD.cxx:93 AliITSRawStreamSPD.cxx:94 AliITSRawStreamSPD.cxx:95 AliITSRawStreamSPD.cxx:96 AliITSRawStreamSPD.cxx:97 AliITSRawStreamSPD.cxx:98 AliITSRawStreamSPD.cxx:99 AliITSRawStreamSPD.cxx:100 AliITSRawStreamSPD.cxx:101 AliITSRawStreamSPD.cxx:102 AliITSRawStreamSPD.cxx:103 AliITSRawStreamSPD.cxx:104 AliITSRawStreamSPD.cxx:105 AliITSRawStreamSPD.cxx:106 AliITSRawStreamSPD.cxx:107 AliITSRawStreamSPD.cxx:108 AliITSRawStreamSPD.cxx:109 AliITSRawStreamSPD.cxx:110 AliITSRawStreamSPD.cxx:111 AliITSRawStreamSPD.cxx:112 AliITSRawStreamSPD.cxx:113 AliITSRawStreamSPD.cxx:114 AliITSRawStreamSPD.cxx:115 AliITSRawStreamSPD.cxx:116 AliITSRawStreamSPD.cxx:117 AliITSRawStreamSPD.cxx:118 AliITSRawStreamSPD.cxx:119 AliITSRawStreamSPD.cxx:120 AliITSRawStreamSPD.cxx:121 AliITSRawStreamSPD.cxx:122 AliITSRawStreamSPD.cxx:123 AliITSRawStreamSPD.cxx:124 AliITSRawStreamSPD.cxx:125 AliITSRawStreamSPD.cxx:126 AliITSRawStreamSPD.cxx:127 AliITSRawStreamSPD.cxx:128 AliITSRawStreamSPD.cxx:129 AliITSRawStreamSPD.cxx:130 AliITSRawStreamSPD.cxx:131 AliITSRawStreamSPD.cxx:132 AliITSRawStreamSPD.cxx:133 AliITSRawStreamSPD.cxx:134 AliITSRawStreamSPD.cxx:135 AliITSRawStreamSPD.cxx:136 AliITSRawStreamSPD.cxx:137 AliITSRawStreamSPD.cxx:138 AliITSRawStreamSPD.cxx:139 AliITSRawStreamSPD.cxx:140 AliITSRawStreamSPD.cxx:141 AliITSRawStreamSPD.cxx:142 AliITSRawStreamSPD.cxx:143 AliITSRawStreamSPD.cxx:144 AliITSRawStreamSPD.cxx:145 AliITSRawStreamSPD.cxx:146 AliITSRawStreamSPD.cxx:147 AliITSRawStreamSPD.cxx:148 AliITSRawStreamSPD.cxx:149 AliITSRawStreamSPD.cxx:150 AliITSRawStreamSPD.cxx:151 AliITSRawStreamSPD.cxx:152 AliITSRawStreamSPD.cxx:153 AliITSRawStreamSPD.cxx:154 AliITSRawStreamSPD.cxx:155 AliITSRawStreamSPD.cxx:156 AliITSRawStreamSPD.cxx:157 AliITSRawStreamSPD.cxx:158 AliITSRawStreamSPD.cxx:159 AliITSRawStreamSPD.cxx:160 AliITSRawStreamSPD.cxx:161 AliITSRawStreamSPD.cxx:162 AliITSRawStreamSPD.cxx:163 AliITSRawStreamSPD.cxx:164 AliITSRawStreamSPD.cxx:165 AliITSRawStreamSPD.cxx:166 AliITSRawStreamSPD.cxx:167 AliITSRawStreamSPD.cxx:168 AliITSRawStreamSPD.cxx:169 AliITSRawStreamSPD.cxx:170 AliITSRawStreamSPD.cxx:171 AliITSRawStreamSPD.cxx:172 AliITSRawStreamSPD.cxx:173 AliITSRawStreamSPD.cxx:174 AliITSRawStreamSPD.cxx:175 AliITSRawStreamSPD.cxx:176 AliITSRawStreamSPD.cxx:177 AliITSRawStreamSPD.cxx:178 AliITSRawStreamSPD.cxx:179 AliITSRawStreamSPD.cxx:180 AliITSRawStreamSPD.cxx:181 AliITSRawStreamSPD.cxx:182 AliITSRawStreamSPD.cxx:183 AliITSRawStreamSPD.cxx:184 AliITSRawStreamSPD.cxx:185 AliITSRawStreamSPD.cxx:186 AliITSRawStreamSPD.cxx:187 AliITSRawStreamSPD.cxx:188 AliITSRawStreamSPD.cxx:189 AliITSRawStreamSPD.cxx:190 AliITSRawStreamSPD.cxx:191 AliITSRawStreamSPD.cxx:192 AliITSRawStreamSPD.cxx:193 AliITSRawStreamSPD.cxx:194 AliITSRawStreamSPD.cxx:195 AliITSRawStreamSPD.cxx:196 AliITSRawStreamSPD.cxx:197 AliITSRawStreamSPD.cxx:198 AliITSRawStreamSPD.cxx:199 AliITSRawStreamSPD.cxx:200 AliITSRawStreamSPD.cxx:201 AliITSRawStreamSPD.cxx:202 AliITSRawStreamSPD.cxx:203 AliITSRawStreamSPD.cxx:204 AliITSRawStreamSPD.cxx:205 AliITSRawStreamSPD.cxx:206 AliITSRawStreamSPD.cxx:207 AliITSRawStreamSPD.cxx:208 AliITSRawStreamSPD.cxx:209 AliITSRawStreamSPD.cxx:210 AliITSRawStreamSPD.cxx:211 AliITSRawStreamSPD.cxx:212 AliITSRawStreamSPD.cxx:213 AliITSRawStreamSPD.cxx:214 AliITSRawStreamSPD.cxx:215 AliITSRawStreamSPD.cxx:216 AliITSRawStreamSPD.cxx:217 AliITSRawStreamSPD.cxx:218 AliITSRawStreamSPD.cxx:219 AliITSRawStreamSPD.cxx:220 AliITSRawStreamSPD.cxx:221 AliITSRawStreamSPD.cxx:222 AliITSRawStreamSPD.cxx:223 AliITSRawStreamSPD.cxx:224 AliITSRawStreamSPD.cxx:225 AliITSRawStreamSPD.cxx:226 AliITSRawStreamSPD.cxx:227 AliITSRawStreamSPD.cxx:228 AliITSRawStreamSPD.cxx:229 AliITSRawStreamSPD.cxx:230 AliITSRawStreamSPD.cxx:231 AliITSRawStreamSPD.cxx:232 AliITSRawStreamSPD.cxx:233 AliITSRawStreamSPD.cxx:234 AliITSRawStreamSPD.cxx:235 AliITSRawStreamSPD.cxx:236 AliITSRawStreamSPD.cxx:237 AliITSRawStreamSPD.cxx:238 AliITSRawStreamSPD.cxx:239 AliITSRawStreamSPD.cxx:240 AliITSRawStreamSPD.cxx:241 AliITSRawStreamSPD.cxx:242 AliITSRawStreamSPD.cxx:243 AliITSRawStreamSPD.cxx:244 AliITSRawStreamSPD.cxx:245 AliITSRawStreamSPD.cxx:246 AliITSRawStreamSPD.cxx:247 AliITSRawStreamSPD.cxx:248 AliITSRawStreamSPD.cxx:249 AliITSRawStreamSPD.cxx:250 AliITSRawStreamSPD.cxx:251 AliITSRawStreamSPD.cxx:252 AliITSRawStreamSPD.cxx:253 AliITSRawStreamSPD.cxx:254 AliITSRawStreamSPD.cxx:255 AliITSRawStreamSPD.cxx:256 AliITSRawStreamSPD.cxx:257 AliITSRawStreamSPD.cxx:258 AliITSRawStreamSPD.cxx:259 AliITSRawStreamSPD.cxx:260 AliITSRawStreamSPD.cxx:261 AliITSRawStreamSPD.cxx:262 AliITSRawStreamSPD.cxx:263 AliITSRawStreamSPD.cxx:264 AliITSRawStreamSPD.cxx:265 AliITSRawStreamSPD.cxx:266 AliITSRawStreamSPD.cxx:267 AliITSRawStreamSPD.cxx:268 AliITSRawStreamSPD.cxx:269 AliITSRawStreamSPD.cxx:270 AliITSRawStreamSPD.cxx:271 AliITSRawStreamSPD.cxx:272 AliITSRawStreamSPD.cxx:273 AliITSRawStreamSPD.cxx:274 AliITSRawStreamSPD.cxx:275 AliITSRawStreamSPD.cxx:276 AliITSRawStreamSPD.cxx:277 AliITSRawStreamSPD.cxx:278 AliITSRawStreamSPD.cxx:279 AliITSRawStreamSPD.cxx:280 AliITSRawStreamSPD.cxx:281 AliITSRawStreamSPD.cxx:282 AliITSRawStreamSPD.cxx:283 AliITSRawStreamSPD.cxx:284 AliITSRawStreamSPD.cxx:285 AliITSRawStreamSPD.cxx:286 AliITSRawStreamSPD.cxx:287 AliITSRawStreamSPD.cxx:288 AliITSRawStreamSPD.cxx:289 AliITSRawStreamSPD.cxx:290 AliITSRawStreamSPD.cxx:291 AliITSRawStreamSPD.cxx:292 AliITSRawStreamSPD.cxx:293 AliITSRawStreamSPD.cxx:294 AliITSRawStreamSPD.cxx:295 AliITSRawStreamSPD.cxx:296 AliITSRawStreamSPD.cxx:297 AliITSRawStreamSPD.cxx:298 AliITSRawStreamSPD.cxx:299 AliITSRawStreamSPD.cxx:300 AliITSRawStreamSPD.cxx:301 AliITSRawStreamSPD.cxx:302 AliITSRawStreamSPD.cxx:303 AliITSRawStreamSPD.cxx:304 AliITSRawStreamSPD.cxx:305 AliITSRawStreamSPD.cxx:306 AliITSRawStreamSPD.cxx:307 AliITSRawStreamSPD.cxx:308 AliITSRawStreamSPD.cxx:309 AliITSRawStreamSPD.cxx:310 AliITSRawStreamSPD.cxx:311 AliITSRawStreamSPD.cxx:312 AliITSRawStreamSPD.cxx:313 AliITSRawStreamSPD.cxx:314 AliITSRawStreamSPD.cxx:315 AliITSRawStreamSPD.cxx:316 AliITSRawStreamSPD.cxx:317 AliITSRawStreamSPD.cxx:318 AliITSRawStreamSPD.cxx:319 AliITSRawStreamSPD.cxx:320 AliITSRawStreamSPD.cxx:321 AliITSRawStreamSPD.cxx:322 AliITSRawStreamSPD.cxx:323 AliITSRawStreamSPD.cxx:324 AliITSRawStreamSPD.cxx:325 AliITSRawStreamSPD.cxx:326 AliITSRawStreamSPD.cxx:327 AliITSRawStreamSPD.cxx:328 AliITSRawStreamSPD.cxx:329 AliITSRawStreamSPD.cxx:330 AliITSRawStreamSPD.cxx:331 AliITSRawStreamSPD.cxx:332 AliITSRawStreamSPD.cxx:333 AliITSRawStreamSPD.cxx:334 AliITSRawStreamSPD.cxx:335 AliITSRawStreamSPD.cxx:336 AliITSRawStreamSPD.cxx:337 AliITSRawStreamSPD.cxx:338 AliITSRawStreamSPD.cxx:339 AliITSRawStreamSPD.cxx:340 AliITSRawStreamSPD.cxx:341 AliITSRawStreamSPD.cxx:342 AliITSRawStreamSPD.cxx:343 AliITSRawStreamSPD.cxx:344 AliITSRawStreamSPD.cxx:345 AliITSRawStreamSPD.cxx:346 AliITSRawStreamSPD.cxx:347 AliITSRawStreamSPD.cxx:348 AliITSRawStreamSPD.cxx:349 AliITSRawStreamSPD.cxx:350 AliITSRawStreamSPD.cxx:351 AliITSRawStreamSPD.cxx:352 AliITSRawStreamSPD.cxx:353 AliITSRawStreamSPD.cxx:354 AliITSRawStreamSPD.cxx:355 AliITSRawStreamSPD.cxx:356 AliITSRawStreamSPD.cxx:357 AliITSRawStreamSPD.cxx:358 AliITSRawStreamSPD.cxx:359 AliITSRawStreamSPD.cxx:360 AliITSRawStreamSPD.cxx:361 AliITSRawStreamSPD.cxx:362 AliITSRawStreamSPD.cxx:363 AliITSRawStreamSPD.cxx:364 AliITSRawStreamSPD.cxx:365 AliITSRawStreamSPD.cxx:366 AliITSRawStreamSPD.cxx:367 AliITSRawStreamSPD.cxx:368 AliITSRawStreamSPD.cxx:369 AliITSRawStreamSPD.cxx:370 AliITSRawStreamSPD.cxx:371 AliITSRawStreamSPD.cxx:372 AliITSRawStreamSPD.cxx:373 AliITSRawStreamSPD.cxx:374 AliITSRawStreamSPD.cxx:375 AliITSRawStreamSPD.cxx:376 AliITSRawStreamSPD.cxx:377 AliITSRawStreamSPD.cxx:378 AliITSRawStreamSPD.cxx:379 AliITSRawStreamSPD.cxx:380 AliITSRawStreamSPD.cxx:381 AliITSRawStreamSPD.cxx:382 AliITSRawStreamSPD.cxx:383 AliITSRawStreamSPD.cxx:384 AliITSRawStreamSPD.cxx:385 AliITSRawStreamSPD.cxx:386 AliITSRawStreamSPD.cxx:387 AliITSRawStreamSPD.cxx:388 AliITSRawStreamSPD.cxx:389 AliITSRawStreamSPD.cxx:390 AliITSRawStreamSPD.cxx:391 AliITSRawStreamSPD.cxx:392 AliITSRawStreamSPD.cxx:393 AliITSRawStreamSPD.cxx:394 AliITSRawStreamSPD.cxx:395 AliITSRawStreamSPD.cxx:396 AliITSRawStreamSPD.cxx:397 AliITSRawStreamSPD.cxx:398 AliITSRawStreamSPD.cxx:399 AliITSRawStreamSPD.cxx:400 AliITSRawStreamSPD.cxx:401 AliITSRawStreamSPD.cxx:402 AliITSRawStreamSPD.cxx:403 AliITSRawStreamSPD.cxx:404 AliITSRawStreamSPD.cxx:405 AliITSRawStreamSPD.cxx:406 AliITSRawStreamSPD.cxx:407 AliITSRawStreamSPD.cxx:408 AliITSRawStreamSPD.cxx:409 AliITSRawStreamSPD.cxx:410 AliITSRawStreamSPD.cxx:411 AliITSRawStreamSPD.cxx:412 AliITSRawStreamSPD.cxx:413 AliITSRawStreamSPD.cxx:414 AliITSRawStreamSPD.cxx:415 AliITSRawStreamSPD.cxx:416 AliITSRawStreamSPD.cxx:417 AliITSRawStreamSPD.cxx:418 AliITSRawStreamSPD.cxx:419 AliITSRawStreamSPD.cxx:420 AliITSRawStreamSPD.cxx:421 AliITSRawStreamSPD.cxx:422 AliITSRawStreamSPD.cxx:423 AliITSRawStreamSPD.cxx:424 AliITSRawStreamSPD.cxx:425 AliITSRawStreamSPD.cxx:426 AliITSRawStreamSPD.cxx:427 AliITSRawStreamSPD.cxx:428 AliITSRawStreamSPD.cxx:429 AliITSRawStreamSPD.cxx:430 AliITSRawStreamSPD.cxx:431 AliITSRawStreamSPD.cxx:432 AliITSRawStreamSPD.cxx:433 AliITSRawStreamSPD.cxx:434 AliITSRawStreamSPD.cxx:435 AliITSRawStreamSPD.cxx:436 AliITSRawStreamSPD.cxx:437 AliITSRawStreamSPD.cxx:438 AliITSRawStreamSPD.cxx:439 AliITSRawStreamSPD.cxx:440 AliITSRawStreamSPD.cxx:441 AliITSRawStreamSPD.cxx:442 AliITSRawStreamSPD.cxx:443 AliITSRawStreamSPD.cxx:444 AliITSRawStreamSPD.cxx:445 AliITSRawStreamSPD.cxx:446 AliITSRawStreamSPD.cxx:447 AliITSRawStreamSPD.cxx:448 AliITSRawStreamSPD.cxx:449 AliITSRawStreamSPD.cxx:450 AliITSRawStreamSPD.cxx:451 AliITSRawStreamSPD.cxx:452 AliITSRawStreamSPD.cxx:453 AliITSRawStreamSPD.cxx:454 AliITSRawStreamSPD.cxx:455 AliITSRawStreamSPD.cxx:456 AliITSRawStreamSPD.cxx:457 AliITSRawStreamSPD.cxx:458 AliITSRawStreamSPD.cxx:459 AliITSRawStreamSPD.cxx:460 AliITSRawStreamSPD.cxx:461 AliITSRawStreamSPD.cxx:462 AliITSRawStreamSPD.cxx:463 AliITSRawStreamSPD.cxx:464 AliITSRawStreamSPD.cxx:465 AliITSRawStreamSPD.cxx:466 AliITSRawStreamSPD.cxx:467 AliITSRawStreamSPD.cxx:468 AliITSRawStreamSPD.cxx:469 AliITSRawStreamSPD.cxx:470 AliITSRawStreamSPD.cxx:471 AliITSRawStreamSPD.cxx:472 AliITSRawStreamSPD.cxx:473 AliITSRawStreamSPD.cxx:474 AliITSRawStreamSPD.cxx:475 AliITSRawStreamSPD.cxx:476 AliITSRawStreamSPD.cxx:477 AliITSRawStreamSPD.cxx:478 AliITSRawStreamSPD.cxx:479 AliITSRawStreamSPD.cxx:480 AliITSRawStreamSPD.cxx:481 AliITSRawStreamSPD.cxx:482 AliITSRawStreamSPD.cxx:483 AliITSRawStreamSPD.cxx:484 AliITSRawStreamSPD.cxx:485 AliITSRawStreamSPD.cxx:486 AliITSRawStreamSPD.cxx:487 AliITSRawStreamSPD.cxx:488 AliITSRawStreamSPD.cxx:489 AliITSRawStreamSPD.cxx:490 AliITSRawStreamSPD.cxx:491 AliITSRawStreamSPD.cxx:492 AliITSRawStreamSPD.cxx:493 AliITSRawStreamSPD.cxx:494 AliITSRawStreamSPD.cxx:495 AliITSRawStreamSPD.cxx:496 AliITSRawStreamSPD.cxx:497 AliITSRawStreamSPD.cxx:498 AliITSRawStreamSPD.cxx:499 AliITSRawStreamSPD.cxx:500 AliITSRawStreamSPD.cxx:501 AliITSRawStreamSPD.cxx:502 AliITSRawStreamSPD.cxx:503 AliITSRawStreamSPD.cxx:504 AliITSRawStreamSPD.cxx:505 AliITSRawStreamSPD.cxx:506 AliITSRawStreamSPD.cxx:507 AliITSRawStreamSPD.cxx:508 AliITSRawStreamSPD.cxx:509 AliITSRawStreamSPD.cxx:510 AliITSRawStreamSPD.cxx:511 AliITSRawStreamSPD.cxx:512 AliITSRawStreamSPD.cxx:513 AliITSRawStreamSPD.cxx:514 AliITSRawStreamSPD.cxx:515 AliITSRawStreamSPD.cxx:516 AliITSRawStreamSPD.cxx:517 AliITSRawStreamSPD.cxx:518 AliITSRawStreamSPD.cxx:519 AliITSRawStreamSPD.cxx:520 AliITSRawStreamSPD.cxx:521 AliITSRawStreamSPD.cxx:522 AliITSRawStreamSPD.cxx:523 AliITSRawStreamSPD.cxx:524 AliITSRawStreamSPD.cxx:525 AliITSRawStreamSPD.cxx:526 AliITSRawStreamSPD.cxx:527 AliITSRawStreamSPD.cxx:528 AliITSRawStreamSPD.cxx:529 AliITSRawStreamSPD.cxx:530 AliITSRawStreamSPD.cxx:531 AliITSRawStreamSPD.cxx:532 AliITSRawStreamSPD.cxx:533 AliITSRawStreamSPD.cxx:534 AliITSRawStreamSPD.cxx:535 AliITSRawStreamSPD.cxx:536 AliITSRawStreamSPD.cxx:537 AliITSRawStreamSPD.cxx:538 AliITSRawStreamSPD.cxx:539 AliITSRawStreamSPD.cxx:540 AliITSRawStreamSPD.cxx:541 AliITSRawStreamSPD.cxx:542 AliITSRawStreamSPD.cxx:543 AliITSRawStreamSPD.cxx:544 AliITSRawStreamSPD.cxx:545 AliITSRawStreamSPD.cxx:546 AliITSRawStreamSPD.cxx:547 AliITSRawStreamSPD.cxx:548 AliITSRawStreamSPD.cxx:549 AliITSRawStreamSPD.cxx:550 AliITSRawStreamSPD.cxx:551 AliITSRawStreamSPD.cxx:552 AliITSRawStreamSPD.cxx:553 AliITSRawStreamSPD.cxx:554 AliITSRawStreamSPD.cxx:555 AliITSRawStreamSPD.cxx:556 AliITSRawStreamSPD.cxx:557 AliITSRawStreamSPD.cxx:558 AliITSRawStreamSPD.cxx:559 AliITSRawStreamSPD.cxx:560 AliITSRawStreamSPD.cxx:561 AliITSRawStreamSPD.cxx:562 AliITSRawStreamSPD.cxx:563 AliITSRawStreamSPD.cxx:564 AliITSRawStreamSPD.cxx:565 AliITSRawStreamSPD.cxx:566 AliITSRawStreamSPD.cxx:567 AliITSRawStreamSPD.cxx:568 AliITSRawStreamSPD.cxx:569 AliITSRawStreamSPD.cxx:570 AliITSRawStreamSPD.cxx:571 AliITSRawStreamSPD.cxx:572 AliITSRawStreamSPD.cxx:573 AliITSRawStreamSPD.cxx:574 AliITSRawStreamSPD.cxx:575 AliITSRawStreamSPD.cxx:576 AliITSRawStreamSPD.cxx:577 AliITSRawStreamSPD.cxx:578 AliITSRawStreamSPD.cxx:579 AliITSRawStreamSPD.cxx:580 AliITSRawStreamSPD.cxx:581 AliITSRawStreamSPD.cxx:582 AliITSRawStreamSPD.cxx:583 AliITSRawStreamSPD.cxx:584 AliITSRawStreamSPD.cxx:585 AliITSRawStreamSPD.cxx:586 AliITSRawStreamSPD.cxx:587 AliITSRawStreamSPD.cxx:588 AliITSRawStreamSPD.cxx:589 AliITSRawStreamSPD.cxx:590 AliITSRawStreamSPD.cxx:591 AliITSRawStreamSPD.cxx:592 AliITSRawStreamSPD.cxx:593 AliITSRawStreamSPD.cxx:594 AliITSRawStreamSPD.cxx:595 AliITSRawStreamSPD.cxx:596 AliITSRawStreamSPD.cxx:597 AliITSRawStreamSPD.cxx:598 AliITSRawStreamSPD.cxx:599 AliITSRawStreamSPD.cxx:600 AliITSRawStreamSPD.cxx:601 AliITSRawStreamSPD.cxx:602 AliITSRawStreamSPD.cxx:603 AliITSRawStreamSPD.cxx:604 AliITSRawStreamSPD.cxx:605 AliITSRawStreamSPD.cxx:606 AliITSRawStreamSPD.cxx:607 AliITSRawStreamSPD.cxx:608 AliITSRawStreamSPD.cxx:609 AliITSRawStreamSPD.cxx:610 AliITSRawStreamSPD.cxx:611 AliITSRawStreamSPD.cxx:612 AliITSRawStreamSPD.cxx:613 AliITSRawStreamSPD.cxx:614 AliITSRawStreamSPD.cxx:615 AliITSRawStreamSPD.cxx:616 AliITSRawStreamSPD.cxx:617 AliITSRawStreamSPD.cxx:618 AliITSRawStreamSPD.cxx:619 AliITSRawStreamSPD.cxx:620 AliITSRawStreamSPD.cxx:621 AliITSRawStreamSPD.cxx:622 AliITSRawStreamSPD.cxx:623 AliITSRawStreamSPD.cxx:624 AliITSRawStreamSPD.cxx:625 AliITSRawStreamSPD.cxx:626 AliITSRawStreamSPD.cxx:627 AliITSRawStreamSPD.cxx:628 AliITSRawStreamSPD.cxx:629 AliITSRawStreamSPD.cxx:630 AliITSRawStreamSPD.cxx:631 AliITSRawStreamSPD.cxx:632 AliITSRawStreamSPD.cxx:633 AliITSRawStreamSPD.cxx:634 AliITSRawStreamSPD.cxx:635 AliITSRawStreamSPD.cxx:636 AliITSRawStreamSPD.cxx:637 AliITSRawStreamSPD.cxx:638 AliITSRawStreamSPD.cxx:639 AliITSRawStreamSPD.cxx:640 AliITSRawStreamSPD.cxx:641 AliITSRawStreamSPD.cxx:642 AliITSRawStreamSPD.cxx:643 AliITSRawStreamSPD.cxx:644 AliITSRawStreamSPD.cxx:645 AliITSRawStreamSPD.cxx:646 AliITSRawStreamSPD.cxx:647 AliITSRawStreamSPD.cxx:648 AliITSRawStreamSPD.cxx:649 AliITSRawStreamSPD.cxx:650 AliITSRawStreamSPD.cxx:651 AliITSRawStreamSPD.cxx:652 AliITSRawStreamSPD.cxx:653 AliITSRawStreamSPD.cxx:654 AliITSRawStreamSPD.cxx:655 AliITSRawStreamSPD.cxx:656 AliITSRawStreamSPD.cxx:657 AliITSRawStreamSPD.cxx:658 AliITSRawStreamSPD.cxx:659 AliITSRawStreamSPD.cxx:660 AliITSRawStreamSPD.cxx:661 AliITSRawStreamSPD.cxx:662 AliITSRawStreamSPD.cxx:663 AliITSRawStreamSPD.cxx:664 AliITSRawStreamSPD.cxx:665 AliITSRawStreamSPD.cxx:666 AliITSRawStreamSPD.cxx:667 AliITSRawStreamSPD.cxx:668 AliITSRawStreamSPD.cxx:669 AliITSRawStreamSPD.cxx:670 AliITSRawStreamSPD.cxx:671 AliITSRawStreamSPD.cxx:672 AliITSRawStreamSPD.cxx:673 AliITSRawStreamSPD.cxx:674 AliITSRawStreamSPD.cxx:675 AliITSRawStreamSPD.cxx:676 AliITSRawStreamSPD.cxx:677 AliITSRawStreamSPD.cxx:678 AliITSRawStreamSPD.cxx:679 AliITSRawStreamSPD.cxx:680 AliITSRawStreamSPD.cxx:681 AliITSRawStreamSPD.cxx:682 AliITSRawStreamSPD.cxx:683 AliITSRawStreamSPD.cxx:684 AliITSRawStreamSPD.cxx:685 AliITSRawStreamSPD.cxx:686 AliITSRawStreamSPD.cxx:687 AliITSRawStreamSPD.cxx:688 AliITSRawStreamSPD.cxx:689 AliITSRawStreamSPD.cxx:690 AliITSRawStreamSPD.cxx:691 AliITSRawStreamSPD.cxx:692 AliITSRawStreamSPD.cxx:693 AliITSRawStreamSPD.cxx:694 AliITSRawStreamSPD.cxx:695 AliITSRawStreamSPD.cxx:696 AliITSRawStreamSPD.cxx:697 AliITSRawStreamSPD.cxx:698 AliITSRawStreamSPD.cxx:699 AliITSRawStreamSPD.cxx:700 AliITSRawStreamSPD.cxx:701 AliITSRawStreamSPD.cxx:702 AliITSRawStreamSPD.cxx:703 AliITSRawStreamSPD.cxx:704 AliITSRawStreamSPD.cxx:705 AliITSRawStreamSPD.cxx:706 AliITSRawStreamSPD.cxx:707 AliITSRawStreamSPD.cxx:708 AliITSRawStreamSPD.cxx:709 AliITSRawStreamSPD.cxx:710 AliITSRawStreamSPD.cxx:711 AliITSRawStreamSPD.cxx:712 AliITSRawStreamSPD.cxx:713 AliITSRawStreamSPD.cxx:714 AliITSRawStreamSPD.cxx:715 AliITSRawStreamSPD.cxx:716 AliITSRawStreamSPD.cxx:717 AliITSRawStreamSPD.cxx:718 AliITSRawStreamSPD.cxx:719 AliITSRawStreamSPD.cxx:720 AliITSRawStreamSPD.cxx:721 AliITSRawStreamSPD.cxx:722 AliITSRawStreamSPD.cxx:723 AliITSRawStreamSPD.cxx:724 AliITSRawStreamSPD.cxx:725 AliITSRawStreamSPD.cxx:726 AliITSRawStreamSPD.cxx:727 AliITSRawStreamSPD.cxx:728 AliITSRawStreamSPD.cxx:729 AliITSRawStreamSPD.cxx:730 AliITSRawStreamSPD.cxx:731 AliITSRawStreamSPD.cxx:732 AliITSRawStreamSPD.cxx:733 AliITSRawStreamSPD.cxx:734 AliITSRawStreamSPD.cxx:735 AliITSRawStreamSPD.cxx:736 AliITSRawStreamSPD.cxx:737 AliITSRawStreamSPD.cxx:738 AliITSRawStreamSPD.cxx:739 AliITSRawStreamSPD.cxx:740 AliITSRawStreamSPD.cxx:741 AliITSRawStreamSPD.cxx:742 AliITSRawStreamSPD.cxx:743 AliITSRawStreamSPD.cxx:744 AliITSRawStreamSPD.cxx:745 AliITSRawStreamSPD.cxx:746 AliITSRawStreamSPD.cxx:747 AliITSRawStreamSPD.cxx:748 AliITSRawStreamSPD.cxx:749 AliITSRawStreamSPD.cxx:750 AliITSRawStreamSPD.cxx:751 AliITSRawStreamSPD.cxx:752 AliITSRawStreamSPD.cxx:753 AliITSRawStreamSPD.cxx:754 AliITSRawStreamSPD.cxx:755 AliITSRawStreamSPD.cxx:756 AliITSRawStreamSPD.cxx:757 AliITSRawStreamSPD.cxx:758 AliITSRawStreamSPD.cxx:759 AliITSRawStreamSPD.cxx:760 AliITSRawStreamSPD.cxx:761 AliITSRawStreamSPD.cxx:762 AliITSRawStreamSPD.cxx:763 AliITSRawStreamSPD.cxx:764 AliITSRawStreamSPD.cxx:765 AliITSRawStreamSPD.cxx:766 AliITSRawStreamSPD.cxx:767 AliITSRawStreamSPD.cxx:768 AliITSRawStreamSPD.cxx:769 AliITSRawStreamSPD.cxx:770 AliITSRawStreamSPD.cxx:771 AliITSRawStreamSPD.cxx:772 AliITSRawStreamSPD.cxx:773 AliITSRawStreamSPD.cxx:774 AliITSRawStreamSPD.cxx:775 AliITSRawStreamSPD.cxx:776 AliITSRawStreamSPD.cxx:777 AliITSRawStreamSPD.cxx:778 AliITSRawStreamSPD.cxx:779 AliITSRawStreamSPD.cxx:780 AliITSRawStreamSPD.cxx:781 AliITSRawStreamSPD.cxx:782 AliITSRawStreamSPD.cxx:783 AliITSRawStreamSPD.cxx:784 AliITSRawStreamSPD.cxx:785 AliITSRawStreamSPD.cxx:786 AliITSRawStreamSPD.cxx:787 AliITSRawStreamSPD.cxx:788 AliITSRawStreamSPD.cxx:789 AliITSRawStreamSPD.cxx:790 AliITSRawStreamSPD.cxx:791 AliITSRawStreamSPD.cxx:792 AliITSRawStreamSPD.cxx:793 AliITSRawStreamSPD.cxx:794 AliITSRawStreamSPD.cxx:795 AliITSRawStreamSPD.cxx:796 AliITSRawStreamSPD.cxx:797 AliITSRawStreamSPD.cxx:798 AliITSRawStreamSPD.cxx:799 AliITSRawStreamSPD.cxx:800 AliITSRawStreamSPD.cxx:801 AliITSRawStreamSPD.cxx:802 AliITSRawStreamSPD.cxx:803 AliITSRawStreamSPD.cxx:804 AliITSRawStreamSPD.cxx:805 AliITSRawStreamSPD.cxx:806 AliITSRawStreamSPD.cxx:807 AliITSRawStreamSPD.cxx:808 AliITSRawStreamSPD.cxx:809 AliITSRawStreamSPD.cxx:810 AliITSRawStreamSPD.cxx:811