ROOT logo
/**************************************************************************
 * Copyright(c) 2007-2009, ALICE Experiment at CERN, All rights reserved. *
 *                                                                        *
 * Author: The ALICE Off-line Project.                                    *
 * Contributors are mentioned in the code where appropriate.              *
 *                                                                        *
 * Permission to use, copy, modify and distribute this software and its   *
 * documentation strictly for non-commercial purposes is hereby granted   *
 * without fee, provided that the above copyright notice appears in all   *
 * copies and that both the copyright notice and this permission notice   *
 * appear in the supporting documentation. The authors make no claims     *
 * about the suitability of this software for any purpose. It is          *
 * provided "as is" without express or implied warranty.                  *
 **************************************************************************/

/* $Id$ */

///////////////////////////////////////////////////////////////////////////////
///
/// This class provides access to ITS SPD digits in raw data.
///
///////////////////////////////////////////////////////////////////////////////

#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)
{
  // create an object to read ITS SPD raw digits
  fRawReader->Reset();
  fRawReader->Select("ITSSPD");
  // reset calib header words
  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)
{
  // copy constructor
  AliError("Copy constructor should not be used.");
}
//__________________________________________________________________________
AliITSRawStreamSPD& AliITSRawStreamSPD::operator=(const AliITSRawStreamSPD& rstream) {
  // assignment operator
  if (this!=&rstream) {}
  AliError("Assignment opertator should not be used.");
  return *this;
}
//__________________________________________________________________________
Bool_t AliITSRawStreamSPD::ReadNextShort() {
  // read next 16 bit word into fData
  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) { // if new event...
	NewEvent();
	fPrevEventId=*intPtr;
      }
    }
    fFirstWord=kFALSE;
  }
  else {
    fFirstWord=kTRUE;
    fData = fDataChar1+(fDataChar2<<8);
  }
  fEqPLBytesRead+=2;
  
  return kTRUE;
}
//__________________________________________________________________________
Bool_t AliITSRawStreamSPD::ReadNextInt() {
  // reads next 32 bit into fDataChar1..4 
  // (if first 16 bits read already, just completes the present word)
  if (fFirstWord) {
    if (ReadNextShort() && ReadNextShort()) {
      return kTRUE;
    }
  }
  else {
    if (ReadNextShort()) {
      return kTRUE;
    }
  }
  return kFALSE;
}
//__________________________________________________________________________
void AliITSRawStreamSPD::NewEvent() {
  // call this to reset flags for a new event
  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() {
  // needs to be called in the beginning of each equipment data
  // read the extra calibration header
  // returns the length of the header if it is present, -1 otherwise

  Int_t ddlID = fRawReader->GetDDLID();
  if (ddlID==-1) { // we may need to read one word to get the blockAttr
    if (!ReadNextShort()) return -1;
    ddlID = fRawReader->GetDDLID();
    if(ddlID<0){
      AliError("fRawReader->GetDDLID() returns a negative value");
      ddlID=0;
    }
  }
  // reset flags and counters
  fEqPLBytesRead = 2;
  fEqPLChipHeadersRead = 0;
  fEqPLChipTrailersRead = 0;
  fHeaderOrTrailerReadLast = kFALSE;
  fFillOutOfSynch = kFALSE;

  // check router error bits:
  UInt_t statusBits = fRawReader->GetStatusBits();
  if ((statusBits >> 5) & 1) { // linkrx/detector fatal error bit
    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) { // trigger sequence monitor error bit
    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)) { // bunch crossing difference error bit
    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());
  }

  // set eq active and the participating half-staves (for access from outside this class), 
  // set what number of chip headers/trailers to expect (for the moment not used)
  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)) { // is the calib header present?
    if (ReadNextInt()) {
      // length of cal header:
      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() {
// read the next raw digit
// returns kFALSE if there is no digit left

  fPrevModuleID = fModuleID;

  while (ReadNextShort()) {

    fLastDDLID = fDDLID;
    fDDLID = fRawReader->GetDDLID();
    if (fDDLID>=0 && fDDLID<20) {
      if (!fCalHeadRead[fDDLID]) {
	if (fLastDDLID!=-1) {  // if not the first equipment for this event
	  fEqPLBytesRead -= 2;
	  // The next line is commented, since we do not have the information how many chips to expect
	  // CheckHeaderAndTrailerCount(fLastDDLID);
	}
	if (ReadCalibHeader()>=0) continue; // skip to next word if we found a calib header, otherwise parse this word as regular data (go on with this while loop)
      }
    }
    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); // -> for printouts
    
    if ((fData & 0xC000) == 0x4000) {         // header
      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;
      // translate  ("online") ddl, hs, chip nr  to  ("offline") module id :
      fModuleID = GetOfflineModuleFromOnline(fDDLID,fHalfStaveNr,fChipAddr);
    }

    else if ((fData & 0xC000) == 0x0000) {    // trailer
      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) {    // pixel hit
      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 {                                    // fill word
      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) {
    // The next line is commented, since we do not have the information how many chips to expect
    // CheckHeaderAndTrailerCount(fDDLID);
  }
  return kFALSE;
}
//__________________________________________________________________________
void AliITSRawStreamSPD::CheckHeaderAndTrailerCount(Int_t ddlID) {
  // Checks that the number of header and trailers found for the ddl are as expected
  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) {
  // Activate the advanced error logging.
  // Logger object has to be created elsewhere and a pointer sent here.
  fAdvancedErrorLog=activate;
  if (activate && advLogger!=NULL) {
    fAdvLogger = advLogger;
  }
  if (fAdvLogger==NULL) {
    fAdvancedErrorLog=kFALSE;
  }
}
//__________________________________________________________________________
const Char_t* AliITSRawStreamSPD::GetErrorName(UInt_t errorCode) {
  // Returns a string for each error code
  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) {
  // returns if there was a fastor signal from this 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 {
  // returns if the eq is active (seen in data)
  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 {
  // returns if the hs is active (info from block attr)
  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 {
  // returns if the chip is active (seen in data)
  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) {
  // Reads the half stave present status from the block attributes
  // This is not really needed anymore (kept for now in case it is still used somewhere).
  // The same information can be reached through the "IsActiveHS" method instead.
  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) { // bit set means not present
      return kFALSE;
    }
    else {
      return kTRUE;
    }
  }
}
//__________________________________________________________________________
Bool_t AliITSRawStreamSPD::IsEventCounterFullConsistent() const {
  // checks if the event counter values are consistent within the event
  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 the eq is active; returns the event counter value
  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 the eq,hs is active; returns the event counter value
  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 the eq,hs,chip is active; returns the event counter value
  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) {
  // converts offline coordinates to online
  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) {
  // converts online coordinates to offline
  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) {
  // offline->online (eq)
  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; // error
}
//__________________________________________________________________________
UInt_t AliITSRawStreamSPD::GetOnlineHSFromOffline(UInt_t module) {
  // offline->online (hs)
  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; // error
}
//__________________________________________________________________________
UInt_t AliITSRawStreamSPD::GetOnlineChipFromOffline(UInt_t module, UInt_t colM) {
  // offline->online (chip)
  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) { // side A
	    return (159-colM)/32 + 5*(iModule%2);
	  }
	  else { // side C
	    return colM/32 + 5*(iModule%2);
	  }
	}
	else if (module<240) {
	  if (eq<10) { // side A
	    return colM/32 + 5*(iModule%2);
	  }
	  else { // side C
	    return (159-colM)/32 + 5*(iModule%2);
	  }
	}
      }
    }
  }
  return 10; // error
}
//__________________________________________________________________________
UInt_t AliITSRawStreamSPD::GetOnlineColFromOffline(UInt_t module, UInt_t colM) {
  // offline->online (col)
  if (module<80) { // inner layer
    return colM%32;
  }
  else if (module<240) { // outer layer
    return colM%32;
  }
  return 32; // error
}
//__________________________________________________________________________
UInt_t AliITSRawStreamSPD::GetOnlineRowFromOffline(UInt_t module, UInt_t rowM) {
  // offline->online (row)
  if (module<80) { // inner layer
    return (255-rowM);
  }
  else if (module<240) { // outer layer
    return (255-rowM);
  }
  return 256; // error
}
//__________________________________________________________________________
UInt_t AliITSRawStreamSPD::GetOfflineModuleFromOnline(UInt_t eqId, UInt_t hs, UInt_t chip) {
  // online->offline (module)
  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) {
  // online->offline (chip key: 0-1199)
  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;  // side C only
    return (module*5 + chipInModule);
  } else return 1200;
}
//__________________________________________________________________________
UInt_t AliITSRawStreamSPD::GetOfflineColFromOnline(UInt_t eqId, UInt_t hs, UInt_t chip, UInt_t col) {
  // online->offline (col)
  if (eqId>=20 || hs>=6 || chip>=10 || col>=32) return 160; // error
  UInt_t offset = 32 * (chip % 5);
  if (hs<2) {
    if (eqId<10) {
      return 159 - (31-col + offset); // inner layer, side A
    }
    else {
      return col + offset; // inner layer, side C
    }
  }
  else {
    if (eqId<10) {
      return (col + offset); // outer layer, side A
    }
    else {
      return 159 - (31-col + offset); // outer layer, side C
    }
  }
}
//__________________________________________________________________________
UInt_t AliITSRawStreamSPD::GetOfflineRowFromOnline(UInt_t eqId, UInt_t hs, UInt_t chip, UInt_t row) {
  // online->offline (row)
  if (eqId>=20 || hs>=6 || chip>=10 || row>=256) return 256; // error
  return 255-row;
}

 AliITSRawStreamSPD.cxx:1
 AliITSRawStreamSPD.cxx:2
 AliITSRawStreamSPD.cxx:3
 AliITSRawStreamSPD.cxx:4
 AliITSRawStreamSPD.cxx:5
 AliITSRawStreamSPD.cxx:6
 AliITSRawStreamSPD.cxx:7
 AliITSRawStreamSPD.cxx:8
 AliITSRawStreamSPD.cxx:9
 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