removing obsolete classes regarding the fast decoder of 40bit Altro data, all input...
authorrichterm <richterm@f7af4fe6-9843-0410-8265-dc069ae4e863>
Wed, 27 Apr 2011 20:37:51 +0000 (20:37 +0000)
committerrichterm <richterm@f7af4fe6-9843-0410-8265-dc069ae4e863>
Wed, 27 Apr 2011 20:37:51 +0000 (20:37 +0000)
RAW/AliAltroBunch.cxx [deleted file]
RAW/AliAltroBunch.h [deleted file]
RAW/AliAltroData.cxx [deleted file]
RAW/AliAltroData.h [deleted file]
RAW/AliAltroDecoder.cxx [deleted file]
RAW/AliAltroDecoder.h [deleted file]
RAW/AliAltroRawStreamFast.cxx [deleted file]
RAW/AliAltroRawStreamFast.h [deleted file]
RAW/CMakelibRAWDatarec.pkg
RAW/RAWDatarecLinkDef.h

diff --git a/RAW/AliAltroBunch.cxx b/RAW/AliAltroBunch.cxx
deleted file mode 100644 (file)
index 9530349..0000000
+++ /dev/null
@@ -1,37 +0,0 @@
-/**************************************************************************
- * This file is property of and copyright by the ALICE HLT Project        * 
- * All rights reserved.                                                   *
- *                                                                        *
- * Primary Author: Per Thomas Hille  <perthi@fys.uio.no>                  *
- *                                                                        *
- * 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.                  *
- **************************************************************************/
-
-#include "AliAltroBunch.h"
-
-ClassImp(AliAltroBunch)
-
-AliAltroBunch::AliAltroBunch() : 
-  fData(NULL),
-  fBunchSize(-1),
-  fEndTimeBin(0),
-  fStartTimeBin(999),
-  fPrevBunchSize(0),
-  fPrevEndTimeBin(0)
-//  fIsFirstBunch(true)
-{
-  // Default constructor
-}
-
-
-AliAltroBunch::~AliAltroBunch()
-{
-  // Default destructor
-}
-
diff --git a/RAW/AliAltroBunch.h b/RAW/AliAltroBunch.h
deleted file mode 100644 (file)
index a002035..0000000
+++ /dev/null
@@ -1,61 +0,0 @@
-#ifndef ALIALTROBUNCH_H
-#define ALIALTROBUNCH_H
-/* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
- * See cxx source for full Copyright notice                               */
-
-#include <TObject.h>
-
-#define DECODERERROR -3
-
-class AliAltroBunch: public TObject {
-public:
-
-  AliAltroBunch();
-  ~ AliAltroBunch();
-  inline const  UInt_t* GetData() const { return fData; }
-
-  inline void   SetData(UInt_t *data) 
-  {
-    fData = data; 
-  }
-  
-  inline Int_t  GetBunchSize()    const { return fBunchSize; }
-  inline void SetBunchSize(Int_t size) 
-  {
-    fPrevBunchSize =  fBunchSize;  fBunchSize = size; 
-  }
-  inline int CheckConsistency()    
-  {
-    if( fPrevEndTimeBin <= fEndTimeBin + fPrevBunchSize )
-      {
-       //      printf("%s:%d, ERROR conistency check failed\n", __FILE__ , __LINE__ );
-       return  DECODERERROR;
-     }
-    else
-      {
-       return kTRUE;
-      }
-  }
-
-  UInt_t GetEndTimeBin()   const { return fEndTimeBin; }
-  inline void   SetEndTimeBin(UInt_t bin) {fPrevEndTimeBin =  fEndTimeBin;  fEndTimeBin = bin; }
-  UInt_t GetStartTimeBin() const { return (fEndTimeBin - (fBunchSize -1)); }
-  void   SetStartTimeBin(UInt_t bin) { fStartTimeBin = bin; }
-
-private:
-  AliAltroBunch& operator = (const AliAltroBunch& bunch);
-  AliAltroBunch(const AliAltroBunch& bunch);
-  UInt_t *fData;          // pointer to data of current bunch
-  Int_t   fBunchSize;     // total size of current bunch including timestamp and the size indicator (i.e a bunch with just one sample will have size 3)
-  UInt_t  fEndTimeBin;    // Time stamp of the last sample in the bunch in entities of sample indexes
-  UInt_t  fStartTimeBin;  // Time index of the first bin in the bunch 
-  UInt_t  fPrevBunchSize; // Previous bunch size  
-  UInt_t  fPrevEndTimeBin;// Previous end time bin
-  // bool fIsFirstBunch;
-
-  ClassDef(AliAltroBunch,0) // container class for Altro bunches
-};
-
-#endif
-
diff --git a/RAW/AliAltroData.cxx b/RAW/AliAltroData.cxx
deleted file mode 100644 (file)
index a94e1f8..0000000
+++ /dev/null
@@ -1,214 +0,0 @@
-/**************************************************************************
- * This file is property of and copyright by the ALICE HLT Project        * 
- * All rights reserved.                                                   *
- *                                                                        *
- * Primary Author:  Per Thomas Hille  <perthi@fys.uio.no>                 *
- *                                                                        *
- * 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.                  *
- **************************************************************************/
-
-#include "AliAltroData.h"
-#include "AliAltroBunch.h"
-
-ClassImp(AliAltroData)
-
-AliAltroData::AliAltroData(): fData(0),
-                             fBunchData(0),
-                             fDataSize(0),
-                             fWc(0),
-                             fHadd(-1),
-                             fPrevHadd(-1),
-                             fBunchCounter(0),
-                             fIsComplete(0),
-                             fBufferLeft(0)
-{
-
-
-}
-
-
-
-AliAltroData::~AliAltroData()
-{
-
-
-}
-
-
-/*
-bool
-//AliHLTAltroData::NextBunch(AliHLTAltroBunch *altroBunch)
-AliAltroData::NextBunch(AliAltroBunch *altroBunch)
-{
-  //comment
-  if(fIsComplete == true)
-    {
-
-      if(fBunchCounter == 0)
-       {
-         fBunchData = &fData[fDataSize - 1];
-         altroBunch->fData = &fData[fDataSize - 1];
-         
-       }
-
-      if(fWc < fDataSize)
-       {
-         fWc += *fBunchData;
-         altroBunch->fBunchSize = *fBunchData;
-         altroBunch->fBunchDataSize = altroBunch->fBunchSize  -2;
-
-         fBunchData --;
-         altroBunch->fEndTimeBin = *fBunchData;
-         fBunchData ++;
-
-         fBunchData = fBunchData  -  (altroBunch->fBunchSize);
-         altroBunch->fData = altroBunch->fData -  (altroBunch->fBunchSize);
-         fBunchCounter ++;
-         return true;
-
-       }
-      else
-       {
-         fBunchCounter = 0;
-         fWc = 0;
-         return false;
-       }
-    }
-  else
-    {
-      printf("\nAliHLTAltroData::NextBunch: WARNING, dataset is not complet. 2AAA endmarker is missing ");
-      printf("\nfor branch %d, card %d, chip %d, channel %d\n",  GetBranch(), GetCard(), GetChip(), GetChannel());
-      return false;
-    }
-}
-
-*/
-
-
-
-
- //Bool_t AliAltroData::NextBunch(AliAltroBunch *altroBunch)
-int AliAltroData::NextBunch(AliAltroBunch *altroBunch)
-{
-
-  if(fIsComplete == kTRUE)
-    {
-      if(fBunchCounter == 0)
-       {
-         fBunchData = &fData[fDataSize - 1];
-       }
-
-      if(fWc < fDataSize)
-       {
-         if(*fBunchData == 0){ fWc += 1;};
-         fWc += *fBunchData;
-         altroBunch->SetData(fData + fDataSize - fWc);
-
-         int tmpsize =  *fBunchData -2;  
-
-         //      altroBunch->SetBunchSize(         *fBunchData -2       );
-         altroBunch->SetBunchSize( tmpsize );
-         
-
-         fBufferLeft -= *fBunchData;
-         //      printf("%s:%d, bufferleft = %d \n", __FILE__,  __LINE__ , fBufferLeft);
-         fBunchData --;
-         altroBunch->SetEndTimeBin( *fBunchData );
-         
-         // Matthias Oct 10 2008: those checks are certainly a bug, first the 
-         // bunch size is subtracted from fBufferLeft ... and than once again
-         // I can understand that it should not be negative but the check as
-         // committed in revision 29090 is wrong.
-         // Effectively, this is always skipping the last bunch of the last
-         // channel.
-         //      if( (fBufferLeft <=  7 ) || ( fBufferLeft - tmpsize)  <= 7)
-         //if( fBufferLeft - tmpsize  <= 7)
-         if( fBufferLeft < 0)
-           {
-             //              printf("%s:%d, ERROR, attempt too access buffer outside allowed range\n",  __FILE__ ,  __LINE__ );
-             return kFALSE;
-           }
-         
-
-         if(fBunchCounter >0)
-           {
-             int tmpret = altroBunch->CheckConsistency();
-             
-             if(tmpret != kTRUE)
-               {
-                 return tmpret;
-               }
-
-             /*
-               if( altroBunch->CheckConsistency() == kFALSE)
-               {
-                 return kFALSE;
-               }
-             */
-           }
-
-         //      altroBunch->SetStartTimeBin(*fBunchData - fBunchSize);
-         fBunchData -= (altroBunch->GetBunchSize() +1);
-
-         // PATCH from Per Thomas Hille 250408 mke sure tha
-         // Data is consistent by cheking the start timebin, should never be negative
-         if( (int)altroBunch->GetStartTimeBin( ) < 0)
-           {
-             //              printf("ERROR altroBunch->GetStartTimeBin( ) is  %d", (int)altroBunch->GetStartTimeBin( ) );
-             return kFALSE;
-           }
-
-         fBunchCounter ++;
-         return kTRUE;
-       }
-      else
-       {
-         fBunchCounter = 0;
-         fWc = 0;
-         return kFALSE;
-       }
-    }
-  else
-    {
-      //     printf("\nAliAltroData::NextBunch: WARNING, dataset is not complet. 2AAA endmarker is missing ");
-      //     printf("\nfor branch %d, card %d, chip %d, channel %d\n",  GetBranch(), GetCard(), GetChip(), GetChannel());
-      return kFALSE;
-    }
-
-}
-
-
-
-void AliAltroData::Reset()
-{
-   fWc = 0;
-   fBunchCounter = 0;
-}
-
-
-Int_t AliAltroData::GetChannel() const
-{
- return  fHadd & 0xf;
-}
-
-Int_t AliAltroData::GetChip() const
-{
- return  (fHadd & 0x70) >> 4 ;
-}
-
-Int_t AliAltroData::GetCard() const
-{
- return   (fHadd & 0x780) >>  7;
-}
-
-
-Int_t AliAltroData::GetBranch() const
-{
- return   (fHadd & 0x800 ) >> 11;
-}
diff --git a/RAW/AliAltroData.h b/RAW/AliAltroData.h
deleted file mode 100644 (file)
index a7da48f..0000000
+++ /dev/null
@@ -1,63 +0,0 @@
-#ifndef ALIALTRODATA_H
-#define ALIALTRODATA_H
-/* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
- * See cxx source for full Copyright notice                               */
-
-#define DECODERERROR -3
-
-#include <TObject.h>
-
-class AliAltroBunch;
-
-class AliAltroData: public TObject {
-public:
-
-  AliAltroData();
-  ~ AliAltroData();
-
-  //  Bool_t  NextBunch(AliAltroBunch *altrobunch);
-  int  NextBunch(AliAltroBunch *altrobunch); 
-
-  Int_t   GetChannel() const;
-  Int_t   GetChip() const;
-  Int_t   GetCard() const;
-  Int_t   GetBranch() const;
-  void    Reset();
-
-  Bool_t  IsComplete()      const { return fIsComplete; }
-  void    SetIsComplete(Bool_t iscomplete) { fIsComplete = iscomplete; }
-  Int_t   GetHadd()         const { return fHadd; }
-  Int_t   GetPrevHadd()     const { return fPrevHadd; }
-  Bool_t  IsNewHadd()       const { return (fHadd != fPrevHadd); }
-  //  void    SetHadd(Int_t add)      { fPrevHadd = fHadd; fHadd = add; }
-  void    SetHadd(Int_t add, Int_t bufferleft)      { fPrevHadd = fHadd; fHadd = add; fBufferLeft  = bufferleft ; }
-
-  const   UInt_t* GetData() const { return fData; }
-  void    SetData(UInt_t *data)   { fData = data; }
-  //  UInt_t* GetData() const { return fData; } 
-  Int_t   GetDataSize()     const { return fDataSize; }
-  void    SetDataSize(Int_t size) { fDataSize = size; }
-
-private:
-
-  AliAltroData& operator = (const AliAltroData& altrodata);
-  AliAltroData(const AliAltroData& altrodata);
-
-  UInt_t *fData;
-  UInt_t *fBunchData;
-  Int_t   fDataSize;
-  Int_t   fWc;
-  Int_t   fHadd;
-  Int_t   fPrevHadd;
-  Int_t   fBunchCounter;
-  Bool_t  fIsComplete;
-
-  // Int_t fMaxBunchSize;
-  Int_t fBufferLeft;
-
-  ClassDef(AliAltroData, 0)  // container class for Altro payload
-
-};
-
-#endif
-
diff --git a/RAW/AliAltroDecoder.cxx b/RAW/AliAltroDecoder.cxx
deleted file mode 100644 (file)
index a92d73f..0000000
+++ /dev/null
@@ -1,584 +0,0 @@
-// $Id$
-
-/**************************************************************************
- * This file is property of and copyright by the ALICE HLT Project        * 
- * All rights reserved.                                                   *
- *                                                                        *
- * Primary Authors: Per Thomas Hille  <perthi@fys.uio.no>                 *
- *                  Oystein Djuvsland <oystein.djuvsland@gmail.com>       *
- *                                                                        *
- * 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.                  *
- **************************************************************************/
-
-/**
-   @file AliAltroDocoder.cxx
-   @author Per Thomas Hille, Oystein Djuvsland
-   @date   
-   @brief High performance decoder class for the RCU/Altro data format
-*/
-
-#include  <cassert>
-#include  <Riostream.h>
-#include  "AliAltroDecoder.h"
-#include  "AliAltroData.h"
-#include  "AliLog.h"
-
-// Class for fast decoding of RCU/Altro raw data format (DDL format)
-// to PC readable form. The decoding is done in 3 steps.
-// 1) The RCU payload consist of a variable number of 160 bit words
-//    denoted a DDL block. All the DDL blocks of an RCU payload are transformed
-//    into 16 bit integers and stored into a buffer of integers big enought to contain the
-//    biggest number of samples possible
-// 2) The decoded buffer is then accesible for the NextChannel functions wich reads 
-//    the altro channel data (samples) contained in the payload. The first call to NextChannel gives the
-//    last altro channel of the back linked list, the next call the second last channel ..etc until
-//    all channels are read.
-// 3) (optional) For each Altro channel one chan invoke the member function NextBunch which gives on first call
-//    The last bunch (the bunch with the highest timestamp), on next call the second last bunch..etc
-//    untill all bunches are read
-  
-
-ClassImp(AliAltroDecoder)
-
-AliAltroDecoder::AliAltroDecoder() : f32DtaPtr(0),
-                                    f8DtaPtr(0),
-                                    fkN32HeaderWords(8), 
-                                    fN40AltroWords(0), 
-                                    fN40RcuAltroWords(0),
-                                    fNDDLBlocks(0), 
-                                    f32LastDDLBlockSize(5), 
-                                    f8PayloadSize(0),
-                                    fOutBufferIndex(0),
-                                    fSize(0), 
-                                    fNAltro10bitWords(0),
-                                    fComplete(0),
-                                    fInComplete(0),
-                                    fDecodeIfCorruptedTrailer(kTRUE),
-                                    fIsDecoded(kFALSE),
-                                    fIsFatalCorruptedTrailer(kTRUE)
-  //                                fIsFirstChannelOfPayload(kTRUE)
-{
- // Default constructor
-  memset(fOutBuffer, 0, sizeof(fOutBuffer));
-  memset(fDDLBlockDummy, 0, sizeof(fDDLBlockDummy));
-}
-
-
-AliAltroDecoder::~AliAltroDecoder()
-{
-  // Default destructor
-}
-
-
-Bool_t AliAltroDecoder::CheckPayloadTrailer() const
-{
-  //Check consistency between the number of 40 bit altro words given by
-  //the RCU payload and the number of 40 bit words calculated from the size of the RCU payload.
-
-  if(fN40AltroWords != fN40RcuAltroWords)
-    {
-      return  kFALSE;
-    } 
-  else
-    {
-      return kTRUE;
-    }
-}
-
-
-Bool_t AliAltroDecoder::Decode()
-{ 
-  // Decodes the RCU payload (all altro channels in one go) from the DDL/Altro
-  // format to PC readable format.
-  // The 10 bit words of the 40/10 bit Altro format are transformed to separated
-  // integers.
-
-  if( fIsFatalCorruptedTrailer == kTRUE)
-    {
-      //      printf("\n AliAltroDecoder::Decode(), WARNING, attempt to decode badly corrupted data\n");
-      //     printf("\n AliAltroDecoder::Decode(). Please check on the return value (-1 if fataly corrupted) of the SetMemory() function\n");    
-      return kFALSE;
-    }
-  else if (!f8DtaPtr || !f32DtaPtr ||
-          (UChar_t*)f32DtaPtr < f8DtaPtr-fSize ||
-          (UChar_t*)f32DtaPtr > f8DtaPtr)
-    {
-      return kFALSE;
-    }
-  else
-    {
-      // see header file for class documentation
-      fComplete = 0;
-      fInComplete = 0;
-
-      Int_t tmpcnt = CountAAApaddings();
-  
-      if(tmpcnt == 3)
-       {
-         fN40AltroWords = fN40AltroWords -1;
-       } 
-      else if(tmpcnt == 5)
-       {
-         fN40AltroWords = fN40AltroWords -2;
-       } 
-      else if(tmpcnt == 8)
-       {
-         fN40AltroWords = fN40AltroWords -3;
-       } 
-
-      if(  ((CheckPayloadTrailer() == kTRUE) || fDecodeIfCorruptedTrailer == kTRUE  )  &&  (fSize > 32) )
-       {
-         fOutBufferIndex = 0;
-
-         for(Int_t i = 0; i < fNDDLBlocks; i++)
-           {
-             DecodeDDLBlock();
-           }
-
-         DecodeLastDDLBlock(); 
-         fOutBufferIndex =  fN40AltroWords*4  -  1;
-         fIsDecoded = kTRUE;
-         return kTRUE;
-       }
-
-      else
-       {
-//       cout <<" ERROR: data integrity check failed, discarding data" << endl;
-//       cout << "Size of datablock is  " << fSize   << endl;
-//       cout << "fN40AltroWords = "      << fN40AltroWords   << endl;
-//       cout << "fN40RcuAltroWords = "   << fN40RcuAltroWords  << endl;
-         return kFALSE;
-       }
-
-    }
-}
-
-
-
-
-Bool_t AliAltroDecoder::NextChannel(AliAltroData *altroDataPtr)
-{
-  // Reads the next altro channel in the RCU payload after the RCU payload
-  // has been decoded. The channels are read starting from the end (backlinked list) 
-  // Returns kTRUE as long as ther are unread channels in the payload
-  // Returns kFALSE when all the channels have been read. 
-
-  if(fIsFatalCorruptedTrailer == kTRUE)
-    {
-      return kFALSE;
-    } 
-  
-  else
-    {
-
-      if(fIsDecoded != kTRUE)
-       {
-         Decode();
-       }
-
-      // an altro block must constist of at least 2 40bit words:
-      // - 40bit Altro trailer
-      // - at least 3 10bit words (bunch length, time bin, signal) padded to 40 bit
-      // we are reading backwards, so the index is already 1 inside the block
-      if(fOutBufferIndex >= 7)
-       {
-         if(((fOutBuffer[fOutBufferIndex] << 4 ) | ((fOutBuffer[fOutBufferIndex-1] & 0x3c0) >> 6)) == 0x2aaa)
-           {
-             altroDataPtr->SetIsComplete(kTRUE);
-             fComplete ++;
-           }
-         else
-           {
-             altroDataPtr->SetIsComplete(kFALSE);
-             fInComplete ++;
-           }
-
-         fOutBufferIndex --;
-         fNAltro10bitWords = ( (fOutBuffer[fOutBufferIndex] & 0x3f) << 4 )   |  ((fOutBuffer[fOutBufferIndex -1]  & (0xF << 6)) >> 6) ;
-         fOutBufferIndex --;
-         altroDataPtr->SetHadd( ((fOutBuffer[fOutBufferIndex] & 0x3)) << 10 | ( fOutBuffer[fOutBufferIndex-1] ), fOutBufferIndex);
-      
-         fOutBufferIndex --;
-
-         if(fNAltro10bitWords%4 == 0)
-           {
-             fOutBufferIndex = fOutBufferIndex  -  fNAltro10bitWords;
-           }
-         else
-           {
-             fOutBufferIndex = fOutBufferIndex - fNAltro10bitWords -(4 - fNAltro10bitWords%4);
-           }
-         
-         if(fOutBufferIndex >= 0)
-           {
-             altroDataPtr->SetData( &fOutBuffer[fOutBufferIndex] );
-             fOutBufferIndex --;
-             altroDataPtr->SetDataSize( fNAltro10bitWords );
-             return kTRUE;
-           }
-         else
-           {
-             //TODO write a fatal log message when this happends
-             return kFALSE;
-           }
-
-       }
-      else
-       {
-         return kFALSE;
-       }
-
-    }
-}
-
-
-Int_t AliAltroDecoder::CountAAApaddings() const
-{
-  // Use for simulated data only.
-  // Patch for incorrectly simulated data. Counts the number of 
-  // 2aaa word in the trailer of the payload and tries to figure out
-  // the correct number of 40 bit altro words in the RCU pauload
-  // 
-  // The simulated raw data differs from the real data by a number
-  // of additional 0x2aa words between the Altro payload and the
-  // RCU trailer. This is most likely to bring the total number of
-  // bytes to a common multiple of 4 and 5.
-  UShort_t *tailPtr= (UShort_t *)((UChar_t*)f32DtaPtr + f8PayloadSize);
-  Int_t cnt = 0;
-
-  tailPtr --;
-
-  while(*tailPtr == 0xaaaa)
-    {
-      cnt ++;
-      tailPtr --;
-    }
-  
-  tailPtr  = tailPtr + cnt +1;
-
-  return cnt;
-}
-
-
-Float_t AliAltroDecoder::GetFailureRate()
-{
-  // Prints to stdout the percent of altroblocks that
-  // is missing the 2aaa trailer.
-  Float_t tmp = 0;
-  //  cout << "Number of Complete channles = " << fComplete <<endl;
-  // cout << "Number of InComplete channles = " << fInComplete <<endl;
-  tmp = (100*(Float_t)fInComplete)/((Float_t)fComplete + (Float_t)fInComplete);
-  // cout <<"There are "<<  tmp <<"% incomplete channels"<<endl;
-  return  tmp;
-}
-
-
-
-void AliAltroDecoder::PrintInfo(AliAltroData &altrodata, Int_t n, Int_t nPerLine)
-{
-  // prints data and address information contained in altrodata 
-  // to the standard output
-
-  //  cout << "altrodata.fDataSize = " << altrodata.GetDataSize() <<  endl;
-  // cout << "altrodata.fHadd = "     << altrodata.GetHadd()  <<endl;
-  const UInt_t* data = altrodata.GetData();
-  for(Int_t i= 0; i< n; i++)
-    {
-      if( (i%nPerLine == 0) && (i != 0) )
-       {
-         printf("\n");
-       }
-      printf("%d\t", data[i]);
-    }
-  printf("\n");
-}
-
-
-int AliAltroDecoder::SetMemory(UChar_t *dtaPtr, UInt_t size)
-{
-  // Sets the pointer to the memory block that should be decoded
-  // Returns a negative value if an inconsistency in the data is detected
-
-  //  fIsFirstChannelOfPayload = kTRUE;
-  int iRet = 0;
-  fIsDecoded = kFALSE; 
-
-  if(dtaPtr == 0)
-    {
-      //     printf("\nAliAltroDecoder::SetMemory(UChar_t *dtaPtr, UInt_t size) FATAL ERROR, dtaPtr = ZERO !!!!!!!!!!!!\n");
-      //      printf("Please check your code that you don't give a zero pointer to the decoder \n");
-      return -99;
-    }
-
-  if ((Int_t)size<(fkN32HeaderWords+1)*4)
-    {
-      //      printf("\nAliAltroDecoder::SetMemory(UChar_t *dtaPtr, UInt_t size) FATAL ERROR, too little data (%d)\n", size);
-      //      printf("Data buffer must contain the CDH and at least one 32bit RCU trailer word\n");
-      return -99;
-    }
-
-  UInt_t tmpTrailerSize;
-  f8DtaPtr =dtaPtr;
-  fSize = size;
-  f8DtaPtr =f8DtaPtr + fSize;
-  f32DtaPtr = (UInt_t *)f8DtaPtr;
-  tmpTrailerSize = *(f32DtaPtr - 1);
-
-  // format of the trailer has been fixed in the RCU FW2
-  // Bit 31 to 16: 0xaaaa         (16 bit)
-  // Bit 15 to  7: RCU address    ( 9 bit)
-  // Bit  6 to  0: Trailer length ( 7 bit)
-  //
-  // RCU FW1 has one trailer word containing the number of
-  // 10bit Altro words. According to some early documents,
-  // it should have at least 2 32bit words: trailer length and
-  // the number of 10bit Altro words. This is the format of
-  // the simulation at time of writing (June 2008)
-  bool haveFw2=false;
-  if ((tmpTrailerSize>>16)==0xaaaa) {
-      haveFw2=true;
-      tmpTrailerSize = tmpTrailerSize&0x7f; // 7 LSBs of the last word
-  } else
-  if(tmpTrailerSize <=  MAX_TRAILER_WORDS)
-    {
-      tmpTrailerSize = tmpTrailerSize; //assume that the last word of the buffer gives the number of trailer words 
-    }
-  // nof 10bit AltroWords * 5/4  + bytes in the CDH   + 4 bytes RCU trailer
-  else if (((*(f32DtaPtr-1)*5)/4 + fkN32HeaderWords*4 + 4)<=fSize)
-    {
-      tmpTrailerSize = 1; //assume that last word is ONE, and that the this word gives the number of 40 bit altro words
-    }
-  else
-    {
-      tmpTrailerSize=0;
-      fIsFatalCorruptedTrailer = kTRUE;
-      iRet = -1;
-    }
-
-  if(tmpTrailerSize > 0 && (fkN32HeaderWords + tmpTrailerSize)*4<=fSize)
-    {
-      f8PayloadSize = fSize - (fkN32HeaderWords + tmpTrailerSize)*4;
-      fN40AltroWords = f8PayloadSize/5; 
-      fNDDLBlocks =  fN40AltroWords/4;
-      f32LastDDLBlockSize =  ((f8PayloadSize%(4*DDL_32BLOCK_SIZE))+3)/4;
-
-      f32DtaPtr =  f32DtaPtr -  tmpTrailerSize;
-      fN40RcuAltroWords =  *f32DtaPtr;
-      f32DtaPtr = (UInt_t *)dtaPtr + fkN32HeaderWords;
-      fIsFatalCorruptedTrailer = kFALSE; 
-    }
-
-  // all subsequent consistency checks depend on the correct initialization
-  // of the pointer and size variables
-  assert(f8DtaPtr == dtaPtr + fSize);  
-  return iRet;
-
-}
-
-
-void AliAltroDecoder::DecodeDDLBlock()
-{
-  //Decode one 160 bit DDL block into 16 x 16 bit integers (only least significant 10 bits are filled)
-
-  fOutBuffer[fOutBufferIndex] =  *f32DtaPtr & 0x3ff;  //s0 
-  fOutBufferIndex ++;
-  fOutBuffer[fOutBufferIndex] = (*f32DtaPtr & 0xffc00) >> 10; //s1
-  fOutBufferIndex ++; 
-  fOutBuffer[fOutBufferIndex] = (*f32DtaPtr & 0x3ff00000) >> 20; //s2
-  fOutBufferIndex ++; 
-  fOutBuffer[fOutBufferIndex] = (*f32DtaPtr & 0xc0000000) >> 30; //s3_1 
-  f32DtaPtr ++;
-  fOutBuffer[fOutBufferIndex] =  fOutBuffer[fOutBufferIndex] | ((*f32DtaPtr & 0xff) << 2); //s3_2 
-  fOutBufferIndex ++;
-  fOutBuffer[fOutBufferIndex] =  (*f32DtaPtr & 0x3ff00) >> 8; //s4
-  fOutBufferIndex ++;
-  fOutBuffer[fOutBufferIndex] =  (*f32DtaPtr & 0xffc0000) >> 18; //s5
-  fOutBufferIndex ++;
-  fOutBuffer[fOutBufferIndex] =  (*f32DtaPtr & 0xf0000000) >> 28; //s6_1
-  f32DtaPtr ++;
-  fOutBuffer[fOutBufferIndex] =  fOutBuffer[fOutBufferIndex] | ((*f32DtaPtr & 0x3f) << 4); //s6_2 
-  fOutBufferIndex ++;
-  fOutBuffer[fOutBufferIndex] =  (*f32DtaPtr & 0xffc0) >> 6; //s7
-  fOutBufferIndex ++;
-  fOutBuffer[fOutBufferIndex] =  (*f32DtaPtr & 0x3ff0000) >> 16; //s8
-  fOutBufferIndex ++;
-  fOutBuffer[fOutBufferIndex] =  (*f32DtaPtr & 0xFC000000) >> 26; //s9_1
-  f32DtaPtr ++;
-  fOutBuffer[fOutBufferIndex] =  fOutBuffer[fOutBufferIndex] | ((*f32DtaPtr & 0xf) << 6); //s9_2
-  fOutBufferIndex ++;
-  fOutBuffer[fOutBufferIndex] =  (*f32DtaPtr & 0x3ff0) >> 4; //s10
-  fOutBufferIndex ++;
-  fOutBuffer[fOutBufferIndex] =  (*f32DtaPtr & 0xffc000) >> 14; //s11
-  fOutBufferIndex ++;
-  fOutBuffer[fOutBufferIndex] =  (*f32DtaPtr & 0xff000000) >> 24; //s12_1
-  f32DtaPtr ++;
-  fOutBuffer[fOutBufferIndex] =  fOutBuffer[fOutBufferIndex] | ((*f32DtaPtr & 0x3) << 8); //s12_2
-  fOutBufferIndex ++;
-  fOutBuffer[fOutBufferIndex] =  (*f32DtaPtr & 0xffc) >> 2; //s13
-  fOutBufferIndex ++;
-  fOutBuffer[fOutBufferIndex] =  (*f32DtaPtr & 0x3ff000) >> 12; //s14
-  fOutBufferIndex ++;
-  fOutBuffer[fOutBufferIndex] =  (*f32DtaPtr & 0xffc00000) >> 22; //s15
-  f32DtaPtr ++;
-  fOutBufferIndex ++;
-}
-
-
-
-
-
-
-
-
-void AliAltroDecoder::DecodeLastDDLBlock()
-{
-  // Decode one 160 bit DDL block into 16 integers. 
-  // In order to use the same decoding function (DecodeDDLBlock()) 
-  // a copy of the the last DDL block is made and  
-  // if the last block does not align with 160 bits then it is padded with zeroes 
-
-  for(Int_t i=0; i < f32LastDDLBlockSize; i++)
-    {
-      fDDLBlockDummy[i] = *f32DtaPtr;
-      f32DtaPtr ++;
-    }
-  
-  f32DtaPtr = fDDLBlockDummy; 
-  DecodeDDLBlock();
-  f32DtaPtr=(UInt_t*)(f8DtaPtr-fSize+f8PayloadSize+fkN32HeaderWords*4);
-}
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-Int_t AliAltroDecoder::CopyBackward(Byte_t* pBuffer, Int_t bufferSize)
-{
-  // Copy the original 10/40 bit encecoded data of the current channel.
-  // The funtions copies the data to the end of the provided buffer.
-  // @param pBuffer    target buffer
-  // @param bufferSize size of target buffer
-  // @return number of copied bytes, neg. error code if failed
-  Int_t iCopy=0;
-
-  if(fIsDecoded != kTRUE) {
-    AliWarning("buffer has not been decoded, no channel data available");
-    return 0;
-  }
-
-  // This method does not need to be the fastest possible implementation
-  // For the sake of stability, there are a lot of consistency checks.
-
-  // the fOutBufferIndex always points to the next channel, since we are
-  // reading backwards, this is one byte before the start of the current
-  // channel.
-  Int_t currentIndex=fOutBufferIndex+1;
-  if (fNAltro10bitWords>0 && currentIndex < fN40AltroWords*4 ) {
-
-    // calculate the position in the encoded data, beginning right
-    // after the CDH. 10 -> 8 bit: needs 5/4 times the index
-    Int_t position=(currentIndex*5)/4;
-    if (position*4==currentIndex*5) {
-      // no of 10 bit words is without the fill words to fill complete 40 bit words
-      // in addition, align to complete 40 bit words (the '+3')
-      iCopy=((fNAltro10bitWords+3)/4)*5;
-
-      // calculate the source pointer in the encoded data
-      // f8DtaPtr was set to the end of the whole data buffer
-      // f32DtaPtr is behind the payload after decoding
-      Byte_t* pSrc=f8DtaPtr-fSize+(fkN32HeaderWords*4)+position;
-      if (pSrc+5<(Byte_t*)f32DtaPtr) {
-
-       // check the first byte of the source buffer, has to be consistent
-       // with the 8 LSBs of the decoded 10 bit word at the beginning of
-       // the current channel
-       //assert(*pSrc==fOutBuffer[currentIndex]&0xff);
-       if (*pSrc==(fOutBuffer[currentIndex]&0xff)) {
-
-         // try to verfify the length of the channel
-         UInt_t lenCheck=*(pSrc+iCopy+2)|(*(pSrc+iCopy+3)&0x3)<<8;
-         if (lenCheck==fNAltro10bitWords) {
-
-           // copy including the 40 bit altro trailer
-           iCopy+=5; 
-           if (iCopy<=bufferSize) {
-
-             // copy to the end of the buffer
-             Byte_t* pTgt=pBuffer+bufferSize-iCopy;
-             memcpy(pTgt, pSrc, iCopy);
-           } else {
-             AliError(Form("target buffer too small: available %d, required %d", bufferSize, iCopy));
-             iCopy=-1;
-           }
-         } else {
-           AliWarning(Form("format error: can not reproduce channel length: expected %d, read %d", fNAltro10bitWords, lenCheck));
-           iCopy=-1;
-         }
-       } else {
-         AliError(Form("first byte of encoded data (%#x at %d) does not match decoded word (%#x at %d)", *pSrc, position, fOutBuffer[currentIndex]&0xff, currentIndex));
-         iCopy=-1;
-       }
-      } else {
-       AliError(Form("buffer size missmatch: payload ends at %p, but current channel pretends to end at %p", f32DtaPtr, pSrc+5));
-       iCopy=-1;
-      }
-    } else {
-      AliError(Form("current position does not match a byte: currentIndex=%d", currentIndex));
-      iCopy=-1;
-    }
-  }
-  return iCopy;
-}
-
-Bool_t  AliAltroDecoder::GetRCUTrailerData(UChar_t*& data) const
-{
-  // Provide a pointer to RCU trailer.
-  // The type of the parameter might not be optimal, but the function has
-  // been chosen that way to be similar to the counterpart in
-  // AliAltroRawStream.
-  // @return kTRUE if trailer available;
-  if (!f8DtaPtr) return kFALSE;
-  data=f8DtaPtr-(fSize-(f8PayloadSize+fkN32HeaderWords*sizeof(UInt_t)));
-  assert((UChar_t*)f32DtaPtr == data);
-  return kTRUE;
-}
-
-Int_t   AliAltroDecoder::GetRCUTrailerSize() const
-{
-  // Provide size of RCU trailer.
-  if (!f8DtaPtr || !fIsDecoded || fSize==0) return 0;
-  assert(fSize>(f8PayloadSize+fkN32HeaderWords*sizeof(UInt_t)));
-  return fSize-(f8PayloadSize+fkN32HeaderWords*sizeof(UInt_t));
-}
diff --git a/RAW/AliAltroDecoder.h b/RAW/AliAltroDecoder.h
deleted file mode 100644 (file)
index 2e5dbcd..0000000
+++ /dev/null
@@ -1,126 +0,0 @@
-//#-*- Mode: c++ -*-
-// $Id$
-
-#ifndef ALIALTRODECODER_H
-#define ALIALTRODECODER_H
-/* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
- * See cxx source for full Copyright notice                               */
-
-/**
-   @file AliAltroDocoder.h
-   @author Per Thomas Hille, Oystein Djuvsland
-   @date   
-   @brief High performance decoder class for the RCU/Altro data format
-*/
-
-///////////////////////////////////////////////////////////////////////////////
-///
-/// This is the class for fast decoding of TPC/PHOS/EMCAL raw data
-//  see .cxx file for more detailed comments.
-///
-///////////////////////////////////////////////////////////////////////////////
-
-
-#define DECODERERROR -3
-
-#include <TObject.h>
-
-#include <iostream>
-using namespace std;
-#define DDL_32BLOCK_SIZE         5
-#define MAX_BRANCHES             2
-#define MAX_FEE_PER_BRANCH       16
-#define MAX_ALTROS_PER_FEE       8
-#define CHANNELS_PER_ALTRO       16
-#define MAX_SAMPLES_PER_CHANNEL  1024
-#define ALTRO_TRAILER_SIZE       4
-#define MAX_TRAILER_WORDS        3
-
-class AliAltroData;
-
-class AliAltroDecoder: public TObject {
- public:
-  AliAltroDecoder();
-  virtual ~AliAltroDecoder();
-  Bool_t Decode();
-  Bool_t NextChannel(AliAltroData *altroDataPtr);
-
-  /**
-   * Copy the original 10/40 bit encecoded data of the current channel.
-   * The funtions copies the data to the end of the provided buffer.
-   * @param pBuffer    target buffer
-   * @param bufferSize size of target buffer
-   * @return number of copied bytes, neg. error code if failed
-   */
-  Int_t CopyBackward(Byte_t* pBuffer, Int_t bufferSize);
-
-  /* 
-   * DONT use !
-   * For debugging purphoses only, will be removed in near future
-   **/
-  template<typename T> 
-  void  DumpData(T *array, Int_t N, Int_t nPerLine)
-  {
-    cout <<   "DumpData N=  " << N <<endl;
-
-    for(Int_t i= 0; i< N; i++)
-      {
-       if((i%nPerLine == 0)  &&  (i != 0))
-         {
-           printf("\n");
-         }
-
-       cout << array[i]<< "\t";
-
-      }
-  }
-
-  int SetMemory(UChar_t  *dtaPtr, UInt_t size);
-  void PrintInfo(AliAltroData &altrodata, Int_t n = 0, Int_t nPerLine = 4);
-  Float_t GetFailureRate();
-
-  /**
-   * Provide a pointer to RCU trailer.
-   * The type of the parameter might not be optimal, but the function has
-   * been chosen that way to be similar to the counterpart in
-   * AliAltroRawStream.
-   * @return kTRUE if trailer available;
-   */
-  Bool_t  GetRCUTrailerData(UChar_t*& data) const;
-  Int_t   GetRCUTrailerSize() const;
-
- private:
-
-  AliAltroDecoder& operator = (const AliAltroDecoder& decoder);
-  AliAltroDecoder(const AliAltroDecoder& decoder);
-  Bool_t CheckPayloadTrailer() const;
-  void DecodeDDLBlock();
-  void DecodeLastDDLBlock();
-  Int_t CountAAApaddings() const;
-  UInt_t  *f32DtaPtr;                        // Pointer to dat of the input buffer in entities of 32 bit words (the RCU/DDL block)
-  UChar_t *f8DtaPtr;                         // Pointer to dat of the input buffer in entities of 8 bit words (the RCU/DDL block)
-  const Long_t fkN32HeaderWords;              // Number of 32 bit words in the common data header
-  Int_t    fN40AltroWords;                   // Number of 40 bit altro words contained in the RCU payload as calculated form the payload size
-  Int_t    fN40RcuAltroWords;                // Number of 40 bit altro words contained in the RCU payload as given by the RCU trailer        
-  Int_t    fNDDLBlocks;                      // Number of DDL blocks in the payload (the last blocj might/ight not be 160 bits )
-  Int_t    f32LastDDLBlockSize;              // Size of the last DDL block
-  UInt_t   fDDLBlockDummy[DDL_32BLOCK_SIZE]; // buffer to contain the las DDL block, if the block is not aligned with 160 bitm the remaining fileds are padded with zeroes
-  UInt_t   f8PayloadSize;                    // The size of the payload in bytes (after subtraction of the RCU header and the RCU trailer words)
-  Long_t   fOutBufferIndex;                  // current buffer position of the buffer for the decoded data (10 bit words represnted as int's)
-  UInt_t   fSize;                            // The size of the input RCU/DDL payload in entities of bytes, inluding the RCU header and trailer
-  UInt_t   fOutBuffer[MAX_FEE_PER_BRANCH*MAX_BRANCHES*MAX_ALTROS_PER_FEE*CHANNELS_PER_ALTRO*(MAX_SAMPLES_PER_CHANNEL + ALTRO_TRAILER_SIZE)]; // Buffer to hold the decoded data
-  UInt_t   fNAltro10bitWords;                // The total number of 10 bit altro words in the RCU payload, including trailers (disregardin that the altro trialer is not aligned with 10 bit)
-  Int_t    fComplete;                        // Number of altro channels that is only partially read out  (0x2aaa pattern missing in trailer)
-  Int_t    fInComplete;                      // Number of altro channels that is read out properly
-  Bool_t   fDecodeIfCorruptedTrailer;        // Wether or not to try to decode the data if the RCU trailer is incorrect (will succseed in most cases)
-  Bool_t   fIsDecoded;                       // Wether or not the buffer set last by the "SetMemory()" function has been decoded
-  Bool_t   fIsFatalCorruptedTrailer;          // If trailer is fataly corrupted, not possible in any way to recover, then it is not allowed to decode the DDL payload.  
-
-  //  Bool_t   fIsFirstChannelOfPayload;
-
-
-  ClassDef(AliAltroDecoder, 0)  // class for decoding Altro payload
-};
-
-#endif
diff --git a/RAW/AliAltroRawStreamFast.cxx b/RAW/AliAltroRawStreamFast.cxx
deleted file mode 100644 (file)
index 7adc3f4..0000000
+++ /dev/null
@@ -1,113 +0,0 @@
-/**************************************************************************
- * Copyright(c) 1998-1999, 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.                  *
- **************************************************************************/
-
-///////////////////////////////////////////////////////////////////////////////
-///
-/// This class provides fast access to Altro raw data.
-///
-/// It loops over all Altro payload in the raw data given by the AliRawReader.
-///
-///
-///////////////////////////////////////////////////////////////////////////////
-
-#include "AliAltroRawStreamFast.h"
-#include "AliRawReader.h"
-#include "AliLog.h"
-
-ClassImp(AliAltroRawStreamFast)
-
-
-//_____________________________________________________________________________
-AliAltroRawStreamFast::AliAltroRawStreamFast(AliRawReader* rawReader) :
-  fDDLNumber(-1),
-  fPrevDDLNumber(-1),
-  fDecoder(),
-  fData(),
-  fBunch(),
-  fRawReader(rawReader)
-{
-  // Default constructor
-  fRawReader->Reset();
-}
-
-AliAltroRawStreamFast::~AliAltroRawStreamFast()
-{
-  // Destructor
-}
-
-//_____________________________________________________________________________
-void AliAltroRawStreamFast::SelectRawData(Int_t detId)
-{
-  // Select the raw data for specific
-  // detector id
-  AliDebug(1,Form("Selecting raw data for detector %d",detId));
-  fRawReader->Select(detId);
-}
-
-//_____________________________________________________________________________
-void AliAltroRawStreamFast::SelectRawData(const char *detName)
-{
-  // Select the raw data for specific
-  // detector name
-  AliDebug(1,Form("Selecting raw data for detector %s",detName));
-  fRawReader->Select(detName);
-}
-//_____________________________________________________________________________
-void AliAltroRawStreamFast::Reset()
-{
-    // reset altro raw stream params
-
-    fDDLNumber = fPrevDDLNumber = -1;
-    if (fRawReader) fRawReader->Reset();
-
-}
-//_____________________________________________________________________________
-Bool_t AliAltroRawStreamFast::NextDDL()
-{
-  // Read next DDL raw-data payload and
-  // runs the altro decoder over the payload
-
-  UChar_t *dataPtr = NULL;
-  do {
-    if (!fRawReader->ReadNextData(dataPtr)) return kFALSE;
-  } while (fRawReader->GetDataSize() == 0);
-  fPrevDDLNumber = fDDLNumber;
-  fDDLNumber = fRawReader->GetDDLID();
-
-  // Temporary solution while Per Thomas is
-  // changing the decoder code
-  dataPtr -= sizeof(AliRawDataHeader);
-  Int_t length = fRawReader->GetDataSize() + sizeof(AliRawDataHeader);
-
-  fDecoder.SetMemory(dataPtr, length);
-  fDecoder.Decode();
-
-  return kTRUE;
-}
-//_____________________________________________________________________________
-Bool_t AliAltroRawStreamFast::NextChannel()
-{
-  // Get the data for the next altro channel
-  do {
-    if (!fDecoder.NextChannel(&fData)) return kFALSE;
-  }  while (fData.GetDataSize() == 0);
-  return kTRUE;
-}
-//_____________________________________________________________________________
-Bool_t AliAltroRawStreamFast::NextBunch()
-{
-  // Get the data for the next altro bunch
-  return fData.NextBunch(&fBunch);
-}
diff --git a/RAW/AliAltroRawStreamFast.h b/RAW/AliAltroRawStreamFast.h
deleted file mode 100644 (file)
index d3cbed6..0000000
+++ /dev/null
@@ -1,66 +0,0 @@
-#ifndef ALIALTRORAWSTREAMFAST_H
-#define ALIALTRORAWSTREAMFAST_H
-/* Copyright(c) 1998-1999, ALICE Experiment at CERN, All rights reserved. *
- * See cxx source for full Copyright notice                               */
-
-///////////////////////////////////////////////////////////////////////////////
-///
-/// This is a base class for reading raw data in Altro format.
-/// It makes use of the fast altro decoder written by Per Thomas.
-/// More information can be found in AliAltroDecoder class.
-///
-///////////////////////////////////////////////////////////////////////////////
-
-#include <TObject.h>
-#include <Riostream.h>
-
-#include "AliRawReader.h"
-#include "AliAltroDecoder.h"
-#include "AliAltroData.h"
-#include "AliAltroBunch.h"
-
-class AliAltroRawStreamFast: public TObject {
-  public :
-    AliAltroRawStreamFast(AliRawReader* rawReader);
-    virtual ~AliAltroRawStreamFast();
-
-    void SelectRawData(Int_t detId);                           // Select raw data for specific detector id
-    void SelectRawData(const char *detName);                   // Select raw data for specific detector name
-
-    virtual void   Reset();
-    virtual Bool_t NextDDL();
-    virtual Bool_t NextChannel();
-    virtual Bool_t NextBunch();
-
-    Int_t  GetDDLNumberOld()   const { return fRawReader->GetDDLID();         } // Provide current DDL number
-    Int_t  GetDDLNumber()      const { return fDDLNumber;                     } // Provide current DDL number
-    Int_t  GetPrevDDLNumber()  const { return fPrevDDLNumber;                 } // Provide previous DDL number
-    Bool_t IsNewDDLNumber()    const { return (fDDLNumber != fPrevDDLNumber); }
-
-    Int_t  GetHWAddress()      const { return fData.GetHadd();                } // Provide current hardware address
-    Int_t  GetPrevHWAddress()  const { return fData.GetPrevHadd();            } // Provide previous hardware address
-    Bool_t IsNewHWAddress()    const { return fData.IsNewHadd() || IsNewDDLNumber(); }
-
-    UInt_t GetStartTimeBin()   const { return fBunch.GetStartTimeBin();       } // Provide the index if the first time-bin in current bunch
-    UInt_t GetEndTimeBin()     const { return fBunch.GetEndTimeBin();         } // Provide the index if the last time-bin in current bunch
-    const UInt_t* GetSignals() const { return fBunch.GetData();               } // Provide access to altro data itself
-
-
-  private :
-    AliAltroRawStreamFast& operator = (const AliAltroRawStreamFast& stream);
-    AliAltroRawStreamFast(const AliAltroRawStreamFast& stream);
-
-
-    Int_t            fDDLNumber;    // index of current DDL number
-    Int_t            fPrevDDLNumber;// index of previous DDL number
-
-    AliAltroDecoder  fDecoder;      // decoder for altro payload
-    AliAltroData     fData;         // container for altro payload
-    AliAltroBunch    fBunch;        // container for altro bunches
-
-    AliRawReader*    fRawReader;    // object for reading the raw data
-
-    ClassDef(AliAltroRawStreamFast, 0)  // base class for fast reading of Altro raw data
-};
-
-#endif
index e50a3d0..5bb4e14 100644 (file)
@@ -25,7 +25,7 @@
 # SHLIBS - Shared Libraries and objects for linking (Executables only)           #
 #--------------------------------------------------------------------------------#
 
-set ( SRCS   AliFilter.cxx AliRawReader.cxx AliRawReaderFile.cxx AliRawReaderRoot.cxx AliRawReaderChain.cxx AliRawReaderDate.cxx AliRawReaderMemory.cxx AliRawHLTManager.cxx AliAltroRawStream.cxx AliCaloRawStream.cxx AliCaloRawStreamV3.cxx AliVMERawStream.cxx AliAltroDecoder.cxx AliAltroData.cxx AliAltroBunch.cxx AliAltroRawStreamFast.cxx AliAltroRawStreamV3.cxx )
+set ( SRCS   AliFilter.cxx AliRawReader.cxx AliRawReaderFile.cxx AliRawReaderRoot.cxx AliRawReaderChain.cxx AliRawReaderDate.cxx AliRawReaderMemory.cxx AliRawHLTManager.cxx AliAltroRawStream.cxx AliCaloRawStream.cxx AliCaloRawStreamV3.cxx AliVMERawStream.cxx AliAltroRawStreamV3.cxx )
 
 string ( REPLACE ".cxx" ".h" HDRS "${SRCS}" )
 
index 9696aa6..91df13c 100644 (file)
 #pragma link C++ class AliCaloRawStream+;
 #pragma link C++ class AliCaloRawStreamV3+;
 #pragma link C++ class AliVMERawStream+;
-#pragma link C++ class AliAltroDecoder+;
-#pragma link C++ class AliAltroData+;
-#pragma link C++ class AliAltroBunch+;
-#pragma link C++ class AliAltroRawStreamFast+;
 #pragma link C++ class AliRawHLTManager+;
 #pragma link C++ class AliAltroRawStreamV3+;
 #endif