]> git.uio.no Git - u/mrichter/AliRoot.git/blobdiff - MUON/AliMUONPayloadTrigger.cxx
remoe duplicate QA initialisation and do ESD QA for same detectors as RecPoint QA
[u/mrichter/AliRoot.git] / MUON / AliMUONPayloadTrigger.cxx
index ba673388bc8347262caa17ad19478be1233829cb..c3dab7a4aab9c156b5e76f2156ce5722bc26bdc4 100644 (file)
@@ -76,7 +76,7 @@ AliMUONPayloadTrigger::~AliMUONPayloadTrigger()
 
 
 //______________________________________________________
-Bool_t AliMUONPayloadTrigger::Decode(UInt_t *buffer)
+Bool_t AliMUONPayloadTrigger::Decode(UInt_t *buffer, Bool_t scalerEvent)
 {
   /// decode trigger DDL
   /// store only notified cards
@@ -85,50 +85,30 @@ Bool_t AliMUONPayloadTrigger::Decode(UInt_t *buffer)
 
   AliMUONDarcHeader* darcHeader = fDDLTrigger->GetDarcHeader();
 
-  static Int_t kGlobalHeaderSize = darcHeader->GetGlobalHeaderLength(); 
-  static Int_t kDarcHeaderSize   = darcHeader->GetDarcHeaderLength(); 
-  static Int_t kRegHeaderSize    = fRegHeader->GetHeaderLength();
+  static Int_t kGlobalHeaderSize   = darcHeader->GetGlobalHeaderLength(); 
+  static Int_t kDarcHeaderSize     = darcHeader->GetDarcHeaderLength(); 
+  static Int_t kRegHeaderSize      = fRegHeader->GetHeaderLength();
+  static Int_t kRegEmptySize       = fRegHeader->GetHeaderLength()+1 + 16*(fLocalStruct->GetLength()+1);
+  static Int_t kRegEmptyScalerSize = fRegHeader->GetHeaderLength() + fRegHeader->GetScalerLength() + 1 +
+                                      16*(fLocalStruct->GetLength() + fLocalStruct->GetScalerLength() + 1);
 
-  Bool_t scalerEvent = kFALSE;
-  
   Int_t index = 0;
 
   memcpy(darcHeader->GetHeader(), &buffer[index], (kDarcHeaderSize)*4); 
   index += kDarcHeaderSize;
 
-//   if (!fNofRegSet) // if regional board number not set, set it with darc type
-//   { 
-    // darc type vardorh
-    if (darcHeader->GetDarcType() == 4)
+
+  // darc type vadorh
+  if (darcHeader->GetDarcType() == darcHeader->GetDarcVadohrType())
       fMaxReg = 1;
     
-    // darc type def.
-    if (darcHeader->GetDarcType() == 6)
+  // darc type def.
+  if (darcHeader->GetDarcType() == darcHeader->GetDarcDefaultType())
       fMaxReg = 8;
       
-    if(darcHeader->GetEventType() == 0) {
-      scalerEvent = kTRUE;
-    } else
-      scalerEvent = kFALSE;
-//   }
-
-// overwrite the event type in case
-// the raw-data contents contradicts with the
-// the header
-    if(scalerEvent &&
-       (buffer[index] == darcHeader->GetEndOfDarc()) &&
-       (buffer[index+darcHeader->GetDarcScalerLength()] != darcHeader->GetEndOfDarc())) {
-      // obviously not a scaler event
-      scalerEvent = kFALSE;
-      AliWarning("Overriding the event type obtained from the Darc header to physics event!");
-    }
-    if(!scalerEvent &&
-       (buffer[index] != darcHeader->GetEndOfDarc()) &&
-       (buffer[index+darcHeader->GetDarcScalerLength()] == darcHeader->GetEndOfDarc())) {
-      // obviously a scaler event
-      scalerEvent = kTRUE;
-      AliWarning("Overriding the event type obtained from the Darc header to software trigger event!");
-    }
+  if(darcHeader->GetEventType() == scalerEvent) 
+      if (fWarnings) AliWarning("Wrong event type obtained from the Darc header, take the one of CDH");
+
 
   if(scalerEvent) {
     // 6 DARC scaler words
@@ -165,6 +145,14 @@ Bool_t AliMUONPayloadTrigger::Decode(UInt_t *buffer)
   // 8 regional boards
   for (Int_t iReg = 0; iReg < fMaxReg; iReg++) {           //loop over regeonal card
 
+    // skip empty regaional board (not connected or with error reading)
+    if (buffer[index] == fRegHeader->GetErrorWord()) {
+      if (scalerEvent)
+        index += kRegEmptyScalerSize;
+      else 
+        index += kRegEmptySize;
+      continue;
+    }
     memcpy(fRegHeader->GetHeader(), &buffer[index], kRegHeaderSize*4);
     index += kRegHeaderSize;