Changeset 15413 for trunk/FACT++


Ignore:
Timestamp:
04/24/13 14:00:40 (12 years ago)
Author:
tbretz
Message:
Some more structural changes mainly around the allocation of memory and removal of some obsolete code to make everything a bit more compact.
File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/FACT++/src/EventBuilder.c

    r15379 r15413  
    535535} /*-----------------------------------------------------------------*/
    536536
    537 void swapEventHeaderBytes(int i);
    538537int checkRoiConsistency(int i, int roi[]);
    539538
     
    553552//   size_t needmem = 0;
    554553
    555     swapEventHeaderBytes(sk);
    556554
    557555    int nRoi[9];
     
    559557        return -9999;
    560558
    561    const int b = sk / 7;
    562 
    563    if (nRoi[0] < 0 || nRoi[0] > 1024) {
    564        factPrintf(kError, 999, "Illegal roi in channel 0: %d (allowed: 0<=roi<=1024)", nRoi[0]);
    565       gj.badRoiR++;
    566       gj.badRoi[b]++;
    567       return -9999;
    568    }
    569 
    570    for (int jr = 1; jr < 8; jr++) {
    571       if (nRoi[jr] != nRoi[0]) {
    572          factPrintf(kError, 711, "Mismatch of roi (%d) in channel %d with roi (%d) in channel 0.", nRoi[jr], jr, nRoi[0]);
    573          gj.badRoiB++;
    574          gj.badRoi[b]++;
    575          return -7101;
    576       }
    577    }
    578    if (nRoi[8] < nRoi[0]) {
    579       factPrintf(kError, 712, "Mismatch of roi (%d) in channel 8. Should be larger or equal than the roi (%d) in channel 0.", nRoi[8], nRoi[0]);
    580       gj.badRoiB++;
    581       gj.badRoi[b]++;
    582       return -7102;
    583    }
    584 
    585    const int  evID   = rd[sk].evtID;
    586    const uint runID  = rd[sk].runID;
    587    const int  fadlen = rd[sk].fadLen;
    588    const int  trgTyp = rd[sk].ftmTyp;
    589    const int  trgNum = rd[sk].ftmID;
    590    const int  fadNum = rd[sk].evtID;
    591 
    592    int i = evID % MAX_EVT;
    593    int evFree = -1;
    594 
    595    for (int k = 0; k < MAX_RUN; k++) {
    596       if (mBuffer[i].evNum == evID && mBuffer[i].runNum == runID) {     //event is already registered;
    597          // is it ok ????
    598          if (mBuffer[i].nRoi != nRoi[0]
    599              || mBuffer[i].nRoiTM != nRoi[8]) {
    600             factPrintf(kError, 821, "Mismatch of roi within event. Expected roi=%d and roi_tm=%d, got %d and %d.",
    601                        mBuffer[i].nRoi, mBuffer[i].nRoiTM, nRoi[0], nRoi[8]);
    602             gj.badRoiE++;
    603             gj.badRoi[b]++;
    604             return -8201;
    605          }
    606 //       count for inconsistencies
    607 
    608          if (mBuffer[i].trgNum != trgNum)
    609             mBuffer[i].Errors[0]++;
    610          if (mBuffer[i].fadNum != fadNum)
    611             mBuffer[i].Errors[1]++;
    612          if (mBuffer[i].trgTyp != trgTyp)
    613             mBuffer[i].Errors[2]++;
    614 
    615          //everything seems fine so far ==> use this slot ....
    616          return i;
    617       }
    618       if (evFree < 0 && mBuffer[i].evNum < 0)
    619          evFree = i;
    620       i += MAX_EVT;
    621    }
    622 
    623 
    624    //event does not yet exist; create it
    625    if (evFree < 0) {            //no space available in ctrl
    626       factPrintf(kError, 881, "No control slot to keep event %d", evID);
    627       return -1;
    628    }
    629    i = evFree;                  //found free entry; use it ...
    630 
    631    struct timeval tv;
    632    gettimeofday (&tv, NULL);
    633 
    634    const uint32_t tsec = tv.tv_sec;
    635    const uint32_t tusec = tv.tv_usec;
    636 
    637    //check if runId already registered in runCtrl
    638    evFree = -1;
    639 
    640    uint oldest = g_actTime + 1000;
    641    int jold = -1;
    642 
    643    for (int k = 0; k < MAX_RUN; k++) {
    644       if (runCtrl[k].runId == runID) {
    645 //         if (runCtrl[k].procId > 0) {   //run is closed -> reject
    646 //            snprintf (str, MXSTR, "skip event since run %d finished", runID);
    647 //            factOut (kInfo, 931, str);
    648 //            return -21;
    649 //         }
    650 
    651          if (runCtrl[k].roi0 != nRoi[0]
    652              || runCtrl[k].roi8 != nRoi[8]) {
    653             factPrintf(kError, 931, "Mismatch of roi within run. Expected roi=%d and roi_tm=%d, got %d and %d.",
    654                        runCtrl[k].roi0, runCtrl[k].roi8, nRoi[0], nRoi[8]);
    655             gj.badRoiR++;
    656             gj.badRoi[b]++;
    657             return -9301;
    658          }
    659          goto RUNFOUND;
    660       } else if (evFree < 0 && runCtrl[k].fileId < 0) { //not yet used
    661          evFree = k;
    662       } else if (evFree < 0 && runCtrl[k].fileId > 0) { //already closed
    663          if (runCtrl[k].closeTime < oldest) {
     559    //const int b = sk / 7;
     560
     561    const int  evID   = rd[sk].evtID;
     562    const uint runID  = rd[sk].runID;
     563    const int  fadlen = rd[sk].fadLen;
     564    const int  trgTyp = rd[sk].ftmTyp;
     565    const int  trgNum = rd[sk].ftmID;
     566    const int  fadNum = rd[sk].evtID;
     567
     568    int i = evID % MAX_EVT;
     569    int evFree = -1;
     570
     571    for (int k = 0; k < MAX_RUN; k++)
     572    {
     573        //event is already registered;
     574        if (mBuffer[i].evNum == evID && mBuffer[i].runNum == runID)
     575        {
     576            // is it ok ????
     577            if (mBuffer[i].nRoi != nRoi[0] || mBuffer[i].nRoiTM != nRoi[8])
     578            {
     579                factPrintf(kError, 821, "Mismatch of roi within event. Expected roi=%d and roi_tm=%d, got %d and %d.",
     580                           mBuffer[i].nRoi, mBuffer[i].nRoiTM, nRoi[0], nRoi[8]);
     581                return -8201;
     582            }
     583
     584            // count for inconsistencies
     585            if (mBuffer[i].trgNum != trgNum)
     586                mBuffer[i].Errors[0]++;
     587            if (mBuffer[i].fadNum != fadNum)
     588               mBuffer[i].Errors[1]++;
     589            if (mBuffer[i].trgTyp != trgTyp)
     590                mBuffer[i].Errors[2]++;
     591
     592            //everything seems fine so far ==> use this slot ....
     593            return i;
     594        }
     595
     596        if (evFree < 0 && mBuffer[i].evNum < 0)
     597            evFree = i;
     598
     599        i += MAX_EVT;
     600    }
     601
     602
     603    //event does not yet exist; create it
     604
     605    if (evFree < 0) //no space available in ctrl
     606    {
     607        factPrintf(kError, 881, "No control slot to keep event %d", evID);
     608        return -1;
     609    }
     610
     611    i = evFree;                  //found free entry; use it ...
     612
     613    // FIXME: This should be the time of the first receiped board
     614    struct timeval tv;
     615    gettimeofday (&tv, NULL);
     616
     617    const uint32_t tsec = tv.tv_sec;
     618    const uint32_t tusec = tv.tv_usec;
     619
     620    //check if runId already registered in runCtrl
     621    evFree = -1;
     622
     623    uint oldest = g_actTime + 1000;
     624    int jold = -1;
     625
     626    int found = 0;
     627
     628    for (int k = 0; k < MAX_RUN; k++)
     629    {
     630        if (runCtrl[k].runId == runID)
     631        {
     632            if (runCtrl[k].roi0 != nRoi[0] || runCtrl[k].roi8 != nRoi[8])
     633            {
     634                factPrintf(kError, 931, "Mismatch of roi within run. Expected roi=%d and roi_tm=%d, got %d and %d.",
     635                           runCtrl[k].roi0, runCtrl[k].roi8, nRoi[0], nRoi[8]);
     636                return -9301;
     637            }
     638
     639            found = 1;
     640            break;
     641        }
     642
     643        if (evFree>=0)
     644            continue;
     645
     646        //not yet used
     647        if (runCtrl[k].fileId < 0)
     648        {
     649            evFree = k;
     650            continue;
     651        }
     652
     653        //already closed
     654        if (runCtrl[k].fileId > 0 && runCtrl[k].closeTime < oldest)
     655        {
    664656            oldest = runCtrl[k].closeTime;
    665657            jold = k;
    666          }
    667       }
    668    }
    669 
    670    if (evFree < 0 && jold < 0) {
    671       factPrintf(kFatal, 883, "Not able to register the new run %d", runID);
    672       return -1001;
    673    }
    674 
    675       if (evFree < 0)
    676          evFree = jold;
    677       factPrintf(kInfo, 503, "New run %d (evFree=%d) registered with roi=%d and roi_tm=%d", runID,
    678                  evFree, nRoi[0], nRoi[8]);
    679       runCtrl[evFree].runId = runID;
    680       runCtrl[evFree].roi0 = nRoi[0];
    681       runCtrl[evFree].roi8 = nRoi[8];
    682       runCtrl[evFree].fileId = -2;
    683       runCtrl[evFree].procId = -2;
    684       runCtrl[evFree].lastEvt = -1;
    685       runCtrl[evFree].nextEvt = 0;
    686       runCtrl[evFree].actEvt = 0;
    687       runCtrl[evFree].procEvt = 0;
    688       runCtrl[evFree].maxEvt = 999999999;       //max number events allowed
    689       runCtrl[evFree].firstUsec = tusec;
    690       runCtrl[evFree].firstTime = runCtrl[evFree].lastTime = tsec;
    691       runCtrl[evFree].closeTime = tsec + 3600 * 24;     //max time allowed
    692 //    runCtrl[evFree].lastTime = 0;
    693 
    694       runTail[evFree].nEventsOk =
    695          runTail[evFree].nEventsRej =
    696          runTail[evFree].nEventsBad =
    697          runTail[evFree].PCtime0 = runTail[evFree].PCtimeX = 0;
    698 
    699  RUNFOUND:
    700  //ETIENNE
    701 /*   needmem = sizeof (EVENT) + NPIX * nRoi[0] * 2 + NTMARK * nRoi[0] * 2;        //
    702 
    703    headmem = NBOARDS * sizeof (PEVNT_HEADER);
    704 
    705    if (gj.usdMem + needmem + headmem + gi_maxSize > g_maxMem) {
    706       gj.maxMem = gj.usdMem + needmem + headmem + gi_maxSize;
    707       if (gi_memStat > 0) {
    708          gi_memStat = -99;
    709          snprintf (str, MXSTR, "no memory left to keep event %6d sock %3d",
    710                    evID, sk);
    711          factOut (kError, 882, str);
    712       } else {
    713          snprintf (str, MXSTR, "no memory left to keep event %6d sock %3d",
    714                    evID, sk);
    715          factOut (kDebug, 882, str);
    716       }
    717       return -11;
    718    }
    719    */
    720 
    721 #ifdef THOMAS_MALLOC
    722    mBuffer[i].FADhead = TGB_Malloc();
    723    mBuffer[i].fEvent  = NULL;
    724    mBuffer[i].buffer  = NULL;
    725    if (mBuffer[i].FADhead == NULL) {
    726       factPrintf(kError, 882, "malloc header failed for event %d", evID);
    727       return -12;
    728    }
    729    mBuffer[i].fEvent = (void*)((char*)mBuffer[i].FADhead+MAX_HEAD_MEM);
     658        }
     659    }
     660
     661    if (!found)
     662    {
     663        if (evFree < 0 && jold < 0)
     664        {
     665            factPrintf(kFatal, 883, "Not able to register the new run %d", runID);
     666            return -1001;
     667        }
     668
     669        if (evFree < 0)
     670            evFree = jold;
     671
     672        factPrintf(kInfo, 503, "New run %d (evFree=%d) registered with roi=%d and roi_tm=%d", runID,
     673                   evFree, nRoi[0], nRoi[8]);
     674
     675        runCtrl[evFree].runId      = runID;
     676        runCtrl[evFree].roi0       = nRoi[0];
     677        runCtrl[evFree].roi8       = nRoi[8];
     678        runCtrl[evFree].fileId     = -2;
     679        runCtrl[evFree].procId     = -2;
     680        runCtrl[evFree].lastEvt    = -1;
     681        runCtrl[evFree].nextEvt    = 0;
     682        runCtrl[evFree].actEvt     = 0;
     683        runCtrl[evFree].procEvt    = 0;
     684        runCtrl[evFree].maxEvt     = 999999999;       //max number events allowed
     685        runCtrl[evFree].firstTime  = tsec;
     686        runCtrl[evFree].firstUsec  = tusec;
     687        runCtrl[evFree].lastTime   = tsec;
     688        runCtrl[evFree].closeTime  = tsec + 3600 * 24;     //max time allowed
     689
     690        runTail[evFree].nEventsOk  = 0;
     691        runTail[evFree].nEventsRej = 0;
     692        runTail[evFree].nEventsBad = 0;
     693        runTail[evFree].PCtime0    = 0;
     694        runTail[evFree].PCtimeX    = 0;
     695    }
     696
     697    // FIXME: Why is that done if FOUND?
     698
     699    //flag all boards as unused
     700    mBuffer[i].nBoard = 0;
     701    for (int k = 0; k < NBOARDS; k++)
     702        mBuffer[i].board[k] = -1;
     703
     704    mBuffer[i].pcTime[0]         = tsec;
     705    mBuffer[i].pcTime[1]         = tusec;
     706    mBuffer[i].nRoi              = nRoi[0];
     707    mBuffer[i].nRoiTM            = nRoi[8];
     708    mBuffer[i].evNum             = evID;
     709    mBuffer[i].runNum            = runID;
     710    mBuffer[i].fadNum            = fadNum;
     711    mBuffer[i].trgNum            = trgNum;
     712    mBuffer[i].trgTyp            = trgTyp;
     713    mBuffer[i].Errors[0]         = 0;
     714    mBuffer[i].Errors[1]         = 0;
     715    mBuffer[i].Errors[2]         = 0;
     716    mBuffer[i].Errors[3]         = 0;
     717    mBuffer[i].fEvent            = NULL;
     718    mBuffer[i].buffer            = NULL;
     719    mBuffer[i].FADhead           = NULL;
     720
     721/*
     722#ifdef ETIENNE_MALLOC
     723    mBuffer[i].FADhead = ETI_Malloc(evID, i);
     724    mBuffer[i].buffer = NULL;
     725    if (mBuffer[i].FADhead != NULL)
     726        mBuffer[i].fEvent = (EVENT*)&(((char*)(mBuffer[i].FADhead))[MAX_HEAD_MEM]);
     727    else
     728    {
     729        mBuffer[i].fEvent = NULL;
     730        gj.usdMem = 0;
     731        for (int k=0;k<numAllocatedChunks;k++)
     732            gj.usdMem += EtiMemoryChunks[k].nSlots * MAX_SLOT_SIZE;
     733        if (gj.usdMem > gj.maxMem)
     734            gj.maxMem = gj.usdMem;
     735        else
     736        {
     737            factPrintf(kDebug, 882, "No memory left to keep event %6d sock %3d", evID, sk);
     738        }
     739        return -11;
     740    }
    730741#endif
    731742
     743#ifdef STANDARD_MALLOC
     744    mBuffer[i].FADhead = malloc (MAX_HEAD_MEM+MAX_EVT_MEM);
     745    mBuffer[i].fEvent  = NULL;
     746    mBuffer[i].buffer  = NULL;
     747    if (mBuffer[i].FADhead == NULL)
     748    {
     749        factPrintf(kError, 882, "malloc header failed for event %d", evID);
     750        return -12;
     751    }
     752    mBuffer[i].fEvent = (void*)((char*)mBuffer[i].FADhead+MAX_HEAD_MEM);
     753#endif
     754
    732755#ifdef ETIENNE_MALLOC
    733    mBuffer[i].FADhead = ETI_Malloc(evID, i);
    734    mBuffer[i].buffer = NULL;
    735    if (mBuffer[i].FADhead != NULL)
    736        mBuffer[i].fEvent = (EVENT*)&(((char*)(mBuffer[i].FADhead))[MAX_HEAD_MEM]);
    737    else
    738    {
    739        mBuffer[i].fEvent = NULL;
    740        gj.usdMem = 0;
    741        for (int k=0;k<numAllocatedChunks;k++)
    742            gj.usdMem += EtiMemoryChunks[k].nSlots * MAX_SLOT_SIZE;
    743        if (gj.usdMem > gj.maxMem)
    744           gj.maxMem = gj.usdMem;
    745        /*if (gi_memStat > 0) {
    746            gi_memStat = -99;
    747            snprintf (str, MXSTR, "No memory left to keep event %6d sock %3d",
    748                      evID, sk);
    749            factOut (kError, 882, str);
    750         }*/
    751 #ifdef EVTDEBUG
    752        else
    753        {
    754            factPrintf(kDebug, 882, "No memory left to keep event %6d sock %3d", evID, sk);
    755         }
     756    //ETIENNE
     757    //gj.usdMem += needmem + headmem + gi_maxSize;
     758    gj.usdMem = 0;
     759    for (int k=0;k<numAllocatedChunks;k++)
     760        gj.usdMem += EtiMemoryChunks[k].nSlots * MAX_SLOT_SIZE;
     761    //END ETIENNE
    756762#endif
    757        return -11;
    758    }
    759 #endif
    760 
    761 #ifdef STANDARD_MALLOC
    762 
    763    mBuffer[i].FADhead = malloc (MAX_HEAD_MEM+MAX_EVT_MEM);
    764    mBuffer[i].fEvent  = NULL;
    765    mBuffer[i].buffer  = NULL;
    766    if (mBuffer[i].FADhead == NULL) {
    767       factPrintf(kError, 882, "malloc header failed for event %d", evID);
    768       return -12;
    769    }
    770    mBuffer[i].fEvent = (void*)((char*)mBuffer[i].FADhead+MAX_HEAD_MEM);
    771 #endif
    772 
    773    /*
    774    mBuffer[i].FADhead = malloc (headmem);
    775    if (mBuffer[i].FADhead == NULL) {
    776       snprintf (str, MXSTR, "malloc header failed for event %d", evID);
    777       factOut (kError, 882, str);
    778       return -12;
    779    }
    780 
    781    mBuffer[i].fEvent = malloc (needmem);
    782    if (mBuffer[i].fEvent == NULL) {
    783       snprintf (str, MXSTR, "malloc data failed for event %d", evID);
    784       factOut (kError, 882, str);
    785       free (mBuffer[i].FADhead);
    786       mBuffer[i].FADhead = NULL;
    787       return -22;
    788    }
    789 
    790    mBuffer[i].buffer = malloc (gi_maxSize);
    791    if (mBuffer[i].buffer == NULL) {
    792       snprintf (str, MXSTR, "malloc buffer failed for event %d", evID);
    793       factOut (kError, 882, str);
    794       free (mBuffer[i].FADhead);
    795       mBuffer[i].FADhead = NULL;
    796       free (mBuffer[i].fEvent);
    797       mBuffer[i].fEvent = NULL;
    798       return -32;
    799    }*/
    800    //END ETIENNE
    801    //flag all boards as unused
    802    mBuffer[i].nBoard = 0;
    803    for (int k = 0; k < NBOARDS; k++) {
    804       mBuffer[i].board[k] = -1;
    805    }
    806    //flag all pixels as unused
    807    for (int k = 0; k < NPIX; k++) {
    808       mBuffer[i].fEvent->StartPix[k] = -1;
    809    }
    810    //flag all TMark as unused
    811    for (int k = 0; k < NTMARK; k++) {
    812       mBuffer[i].fEvent->StartTM[k] = -1;
    813    }
    814 
    815    mBuffer[i].fEvent->NumBoards = 0;
    816    mBuffer[i].fEvent->PCUsec = tusec;
    817    mBuffer[i].fEvent->PCTime = mBuffer[i].pcTime = tsec;
    818    mBuffer[i].nRoi = nRoi[0];
    819    mBuffer[i].nRoiTM = nRoi[8];
    820    mBuffer[i].evNum = evID;
    821    mBuffer[i].runNum = runID;
    822    mBuffer[i].fadNum = fadNum;
    823    mBuffer[i].trgNum = trgNum;
    824    mBuffer[i].trgTyp = trgTyp;
    825 //   mBuffer[i].evtLen = needmem;
    826    mBuffer[i].Errors[0] =
    827        mBuffer[i].Errors[1] = mBuffer[i].Errors[2] = mBuffer[i].Errors[3] = 0;
    828 
    829 #ifdef ETIENNE_MALLOC
    830 //ETIENNE
    831    //gj.usdMem += needmem + headmem + gi_maxSize;
    832    gj.usdMem = 0;
    833    for (int k=0;k<numAllocatedChunks;k++)
    834    {
    835        gj.usdMem += EtiMemoryChunks[k].nSlots * MAX_SLOT_SIZE;
    836    }
    837 //END ETIENNE
    838 #endif
    839 
    840 #ifdef THOMAS_MALLOC
    841    gj.usdMem = tgb_inuse;
    842 #endif
    843 
    844    if (gj.usdMem > gj.maxMem)
    845       gj.maxMem = gj.usdMem;
    846 
    847    gj.bufTot++;
    848    if (gj.bufTot > gj.maxEvt)
    849       gj.maxEvt = gj.bufTot;
    850 
    851    gj.rateNew++;
    852 
    853    //register event in 'active list (reading)'
    854 
    855    evtCtrl.evtBuf[evtCtrl.lastPtr] = i;
    856    evtCtrl.evtStat[evtCtrl.lastPtr] = 0;
    857    evtCtrl.pcTime[evtCtrl.lastPtr] = g_actTime;
    858    evtIdx[i] = evtCtrl.lastPtr;
    859 
    860 
    861 #ifdef EVTDEBUG
    862    factPrintf(kDebug, -11, "%5d %8d start new evt  %8d %8d sock %3d len %5d t %10d",
    863               evID, runID, i, evtCtrl.lastPtr, sk, fadlen, mBuffer[i].pcTime);
    864 #endif
    865    evtCtrl.lastPtr++;
    866    evtCtrl.lastPtr %= MAX_EVT * MAX_RUN;
    867 
    868    //gi.evtGet++;
    869 
    870    return i;
     763*/
     764
     765    return i;
    871766
    872767} /*-----------------------------------------------------------------*/
    873768
    874 
     769void initEvent(int i)
     770{
     771    mBuffer[i].fEvent = (void*)((char*)mBuffer[i].FADhead+MAX_HEAD_MEM);
     772
     773    //flag all pixels as unused
     774    for (int k = 0; k < NPIX; k++)
     775        mBuffer[i].fEvent->StartPix[k] = -1;
     776
     777    //flag all TMark as unused
     778    for (int k = 0; k < NTMARK; k++)
     779        mBuffer[i].fEvent->StartTM[k] = -1;
     780
     781    mBuffer[i].fEvent->NumBoards = 0;
     782    mBuffer[i].fEvent->PCTime    = mBuffer[i].pcTime[0];
     783    mBuffer[i].fEvent->PCUsec    = mBuffer[i].pcTime[1];
     784}
    875785
    876786
     
    1027937    int roiPtr = sizeof(PEVNT_HEADER)/2 + 2;
    1028938
    1029     roi[0] = rd[i].rBuf->S[roiPtr];
     939    roi[0] = ntohs(rd[i].rBuf->S[roiPtr]);
    1030940
    1031941    for (int jr = 0; jr < 9; jr++)
    1032942    {
    1033         roi[jr] = rd[i].rBuf->S[roiPtr];
    1034 
    1035         if (roi[jr]!=roi[0])
     943        roi[jr] = ntohs(rd[i].rBuf->S[roiPtr]);
     944
     945        if (roi[jr]<0 || roi[jr]>1024)
     946        {
     947            factPrintf(kError, 999, "Illegal roi in channel %d (allowed: 0<=roi<=1024)", jr, roi[jr]);
     948            return 0;
     949        }
     950
     951        // Check that the roi of pixels jr are compatible with the one of pixel 0
     952        if (jr!=8 && roi[jr]!=roi[0])
    1036953        {
    1037954            xjr = jr;
     
    1039956        }
    1040957
     958        // Check that the roi of all other DRS chips on boards are compatible
    1041959        for (int kr = 1; kr < 4; kr++)
    1042960        {
    1043             const int kroi = rd[i].rBuf->S[roiPtr];
     961            const int kroi = ntohs(rd[i].rBuf->S[roiPtr]);
    1044962            if (kroi != roi[jr])
    1045963            {
     
    1052970    }
    1053971
    1054     if (xjr<0)
    1055         return 1;
    1056 
    1057     if (xkr<0)
    1058         factPrintf(kFatal, 1, "Inconsistent Roi accross boards B=%d, expected %d, got %d", xjr, roi[xjr], roi[0]);
    1059     else
    1060         factPrintf(kFatal, 1, "Inconsistent Roi accross patches B=%d P=%d, expected %d, got %d", xjr, xkr, roi[xjr], rd[i].rBuf->S[roiPtr]);
    1061 
    1062     return 0;
     972    if (xjr>=0)
     973    {
     974        if (xkr<0)
     975            factPrintf(kFatal, 1, "Inconsistent Roi accross chips [DRS=%d], expected %d, got %d", xjr, roi[0], roi[xjr]);
     976        else
     977            factPrintf(kFatal, 1, "Inconsistent Roi accross channels [DRS=%d Ch=%d], expected %d, got %d", xjr, xkr, roi[xjr], ntohs(rd[i].rBuf->S[roiPtr]));
     978
     979        return 0;
     980    }
     981
     982    //const int b = i / 7;
     983
     984/*
     985    if (roi[0]<0 || roi[0] > 1024)
     986    {
     987        factPrintf(kError, 999, "Illegal roi in channel 0: %d (allowed: 0<=roi<=1024)", roi[0]);
     988        gj.badRoiR++;
     989        gj.badRoi[b]++;
     990        return 0;
     991    }
     992    */
     993    /*
     994    for (int jr = 1; jr < 8; jr++)
     995    {
     996        if (roi[jr] != roi[0])
     997        {
     998            factPrintf(kError, 711, "Mismatch of roi (%d) in channel %d with roi (%d) in channel 0.", roi[jr], jr, roi[0]);
     999            gj.badRoiB++;
     1000            gj.badRoi[b]++;
     1001            return 0;
     1002        }
     1003    }
     1004*/
     1005    if (roi[8] < roi[0])
     1006    {
     1007        factPrintf(kError, 712, "Mismatch of roi (%d) in channel 8. Should be larger or equal than the roi (%d) in channel 0.", roi[8], roi[0]);
     1008        //gj.badRoiB++;
     1009        //gj.badRoi[b]++;
     1010        return 0;
     1011    }
     1012
     1013    return 1;
    10631014}
    10641015
     
    10801031void copyData(int i, int evID, /*int roi,*/ int boardId)
    10811032{
     1033    swapEventHeaderBytes(i);
     1034
    10821035    memcpy(&mBuffer[evID].FADhead[boardId].start_package_flag,
    10831036           &rd[i].rBuf->S[0], sizeof(PEVNT_HEADER));
     
    11891142   const int minLen = sizeof(PEVNT_HEADER);  //min #bytes needed to check header: full header for debug
    11901143
    1191    int frst_len = sizeof(PEVNT_HEADER);  //max #bytes to read first: fad_header only, so each event must be longer, even for roi=0
    1192 
    11931144   start.S = 0xFB01;
    11941145   stop.S = 0x04FE;
     
    12431194#endif
    12441195      gj.bufNew = gj.bufEvt = 0;
    1245       gj.badRoiE = gj.badRoiR = gj.badRoiB =
    1246          gj.evtSkip = gj.evtWrite = gj.evtErr = 0;
    1247 
    1248       for (int b = 0; b < NBOARDS; b++)
    1249          gj.badRoi[b] = 0;
     1196      //gj.badRoiE = gj.badRoiR = gj.badRoiB = 0;
     1197      gj.evtSkip = gj.evtWrite = gj.evtErr = 0;
     1198
     1199      //for (int b = 0; b < NBOARDS; b++)
     1200      //   gj.badRoi[b] = 0;
    12501201
    12511202      mBufInit ();              //initialize buffers
     
    13491300              if (sockDef[b] > 0)
    13501301              {
    1351                   rd[i].bufTyp = 0;         // expect a header
    1352                   rd[i].bufLen = frst_len;  // max size to read at begining
     1302                  rd[i].bufTyp = 0;                     // expect a header
     1303                  rd[i].bufLen = sizeof(PEVNT_HEADER);  // max size to read at begining
    13531304              }
    13541305              else
     
    13701321
    13711322          // Do not read from this socket
    1372           if (rd[i].bufLen<=0)
     1323          if (rd[i].bufLen<0)
    13731324              continue;
    13741325
    13751326          //numok++;
    13761327
    1377           const int32_t jrd =
    1378               recv(rd[i].socket, &rd[i].rBuf->B[rd[i].bufPos],
    1379                    rd[i].bufLen, MSG_DONTWAIT);
    1380 
    1381           // recv failed
    1382           if (jrd<0)
     1328          if (rd[i].bufLen>0)
    13831329          {
    1384               // There was just nothing waiting
    1385               if (errno==EWOULDBLOCK || errno==EAGAIN)
     1330              const int32_t jrd =
     1331                  recv(rd[i].socket, &rd[i].rBuf->B[rd[i].bufPos],
     1332                       rd[i].bufLen, MSG_DONTWAIT);
     1333
     1334              // recv failed
     1335              if (jrd<0)
    13861336              {
    1387                   //numok--;
     1337                  // There was just nothing waiting
     1338                  if (errno==EWOULDBLOCK || errno==EAGAIN)
     1339                  {
     1340                      //numok--;
     1341                      continue;
     1342                  }
     1343
     1344                  factPrintf(kError, 442, "Reading from socket %d failed: %m (recv,rc=%d)", i, errno);
     1345                  //gi.gotErr[b]++;
    13881346                  continue;
    13891347              }
    13901348
    1391               factPrintf(kError, 442, "Reading from socket %d failed: %m (recv,rc=%d)", i, errno);
    1392               //gi.gotErr[b]++;
    1393               continue;
     1349              // connection was closed ...
     1350              if (jrd==0)
     1351              {
     1352                  factPrintf(kInfo, 441, "Socket %d closed by FAD", i);
     1353
     1354                  const int s0 = sockDef[b] > 0 ? +1 : -1;
     1355                  GenSock(s0, i, 0, NULL, &rd[i]);
     1356
     1357                  //gi.gotErr[b]++;
     1358
     1359                  gi_NumConnect[b]-= cntsock ;
     1360                  //gi.numConn[b]--;
     1361                  gj.numConn[b]--;
     1362
     1363                  continue;
     1364              }
     1365              // Success (jrd > 0)
     1366
     1367              gj.rateBytes[b] += jrd;
     1368
     1369              // are we skipping this board ...
     1370              if (rd[i].bufTyp < 0)
     1371                  continue;
     1372
     1373              rd[i].bufPos += jrd;  //==> prepare for continuation
     1374              rd[i].bufLen -= jrd;
     1375
     1376#ifdef EVTDEBUG
     1377              debugRead(i, jrd, rd[i].evtID, rd[i].ftmID, rd[i].runID, rd[i].bufTyp, tv.tv_sec, tv.tv_usec); // i=socket; jrd=#bytes; ievt=eventid; 1=finished event
     1378#endif
    13941379          }
    1395 
    1396           // connection was closed ...
    1397           if (jrd==0)
    1398           {
    1399               factPrintf(kInfo, 441, "Socket %d closed by FAD", i);
    1400 
    1401               const int s0 = sockDef[b] > 0 ? +1 : -1;
    1402               GenSock(s0, i, 0, NULL, &rd[i]);
    1403 
    1404               //gi.gotErr[b]++;
    1405 
    1406               gi_NumConnect[b]-= cntsock ;
    1407               //gi.numConn[b]--;
    1408               gj.numConn[b]--;
    1409 
    1410               continue;
    1411           }
    1412 
    1413           // Success (jrd > 0)
    1414 
    1415           //gi.gotByte[b]   += jrd;
    1416           gj.rateBytes[b] += jrd;
    1417 
    1418           // are we skipping this board ...
    1419           if (rd[i].bufTyp < 0)
    1420               continue;
    1421 
    1422           rd[i].bufPos += jrd;  //==> prepare for continuation
    1423           rd[i].bufLen -= jrd;
    14241380
    14251381          // are we reading data?
     
    14291385              if (rd[i].bufLen > 0)
    14301386                  continue;
    1431 
    1432               // ready to read next header
    1433               rd[i].bufTyp = 0;
    1434               rd[i].bufLen = frst_len;
    1435               rd[i].bufPos = 0;
    14361387
    14371388              if (rd[i].rBuf->B[rd[i].fadLen - 1] != stop.B[0] ||
     
    14421393                             i, rd[i].evtID, rd[i].fadLen, stop.B[0], stop.B[1],
    14431394                             rd[i].rBuf->B[rd[i].fadLen - 1], rd[i].rBuf->B[rd[i].fadLen - 2]);
     1395
     1396                  // ready to read next header
     1397                  rd[i].bufTyp = 0;
     1398                  rd[i].bufLen = sizeof(PEVNT_HEADER);
     1399                  rd[i].bufPos = 0;
     1400
    14441401                  continue;
    14451402              }
    1446 
    1447 #ifdef EVTDEBUG
    1448               debugRead (i, jrd, rd[i].evtID, rd[i].ftmID, rd[i].runID, 1, tv.tv_sec, tv.tv_usec); // i=socket; jrd=#bytes; ievt=eventid; 1=finished event
    1449 #endif
    14501403
    14511404              //  int actid;
     
    14581411              const int evID = mBufEvt(i);
    14591412
     1413              // no free entry in mBuffer, retry later
     1414              if (evID < 0)
     1415                  continue;
     1416
     1417              // If memory has not been allocated yet, allocate it
     1418              if (evID > 0 && mBuffer[evID].FADhead == NULL)
     1419              {
     1420                  mBuffer[evID].FADhead = TGB_Malloc();
     1421                  if (mBuffer[evID].FADhead == NULL)
     1422                  {
     1423                      // If this works properly, this is a hack which can be removed, or
     1424                      // replaced by a signal or dim message
     1425                      if (rd[i].bufTyp==2)
     1426                          factPrintf(kError, 882, "malloc failed for event %d", evID);
     1427                      rd[i].bufTyp = 2;
     1428                      continue;
     1429                  }
     1430
     1431                  initEvent(evID);
     1432
     1433                  // Some statistics
     1434                  gj.usdMem = tgb_inuse;
     1435
     1436                  if (gj.usdMem > gj.maxMem)
     1437                      gj.maxMem = gj.usdMem;
     1438
     1439                  gj.rateNew++;
     1440                  gj.bufTot++;
     1441                  if (gj.bufTot > gj.maxEvt)
     1442                      gj.maxEvt = gj.bufTot;
     1443
     1444                  //register event in 'active list (reading)'
     1445                  evtIdx[evID] = evtCtrl.lastPtr;
     1446
     1447                  evtCtrl.evtBuf[evtCtrl.lastPtr]  = evID;
     1448                  evtCtrl.evtStat[evtCtrl.lastPtr] = 0;
     1449                  evtCtrl.pcTime[evtCtrl.lastPtr]  = g_actTime;
     1450
     1451                  evtCtrl.lastPtr++;
     1452                  evtCtrl.lastPtr %= MAX_EVT * MAX_RUN;
     1453              }
     1454
     1455              // ready to read next header
     1456              rd[i].bufTyp = 0;
     1457              rd[i].bufLen = sizeof(PEVNT_HEADER);
     1458              rd[i].bufPos = 0;
     1459
     1460              // Fatal error occured. Event cannot be processed. Skip it. Start reading next header.
    14601461              if (evID < -1000)
    14611462                  continue;
    14621463
    1463               // no space left, retry later
    1464               if (evID < 0)
    1465               {
    1466                   rd[i].bufTyp = -1;
    1467                   rd[i].bufLen =  0;
    1468                   rd[i].bufPos = rd[i].fadLen;
    1469                   continue;
    1470               }
    1471 
    14721464              //we have a valid entry in mBuffer[]; fill it
    1473 
    14741465              const int boardId  = b;
    14751466              const int fadBoard = rd[i].rBuf->S[12];
     
    14891480                             rd[i].rBuf->B[rd[i].fadLen - 2],
    14901481                             rd[i].rBuf->B[rd[i].fadLen - 1]);
    1491                   // FIXME: Is that action the right one?
    1492                   continue;
     1482                  continue; // Continue reading next header
    14931483              }
    14941484
     
    15331523                  //gi.evtTot++;
    15341524              }
     1525
     1526              // Continue reading next header
    15351527          }
    15361528          else
     
    16191611
    16201612              const int fadBoard = rd[i].rBuf->S[12];
    1621               debugHead (i, fadBoard, rd[i].rBuf);
    1622               debugRead (i, jrd, rd[i].evtID, rd[i].ftmID, rd[i].runID, -1, tv.tv_sec, tv.tv_usec);        // i=socket; jrd=#bytes; ievt=eventid;-1=start event
     1613              debugHead(i, fadBoard, rd[i].rBuf);
     1614
     1615              // Continue reading data
     1616
    16231617          } // end if data or header
     1618
    16241619      } // end for loop over all sockets
    16251620
    1626       //gi.numRead[numok]++;
    1627 
    16281621      g_actTime = time (NULL);
    1629       if (g_actTime <= gi_SecTime) {
     1622      if (g_actTime <= gi_SecTime)
     1623      {
    16301624          usleep(1);
    16311625          continue;
Note: See TracChangeset for help on using the changeset viewer.