| 1 | //----------------------------------------------------------------
 | 
|---|
| 2 | // ---- classes de threads pour lecture (transfert DMA) 
 | 
|---|
| 3 | //      et ecriture disque pour acquisition   BAORadio       -----
 | 
|---|
| 4 | // LAL -      R. Ansari - Juin/Juillet 2008 
 | 
|---|
| 5 | //----------------------------------------------------------------
 | 
|---|
| 6 | 
 | 
|---|
| 7 | #include "racqurw.h"
 | 
|---|
| 8 | 
 | 
|---|
| 9 | #include <stdlib.h>
 | 
|---|
| 10 | #include <unistd.h>
 | 
|---|
| 11 | #include <fstream>
 | 
|---|
| 12 | #include <signal.h>
 | 
|---|
| 13 | #include "pexceptions.h"
 | 
|---|
| 14 | #include "timestamp.h"
 | 
|---|
| 15 | 
 | 
|---|
| 16 | #include "pciewrap.h"
 | 
|---|
| 17 | #include "brpaqu.h"
 | 
|---|
| 18 | #include "minifits.h"
 | 
|---|
| 19 | 
 | 
|---|
| 20 | #include "resusage.h" // Pour mesure temps elapsed/CPU ...
 | 
|---|
| 21 | #include "datatable.h" // Pour sauver les entetes de paquet 
 | 
|---|
| 22 | #include <sys/time.h>  // pour gettimeofday
 | 
|---|
| 23 | //-------------------------------------------------------
 | 
|---|
| 24 | // Classe thread de lecture PCI-Express
 | 
|---|
| 25 | //-------------------------------------------------------
 | 
|---|
| 26 | 
 | 
|---|
| 27 | PCIEReader::PCIEReader(PCIEWrapper &pciw,uint_4 sizeFrame,uint_4 packSize ,RAcqMemZoneMgr& mem, 
 | 
|---|
| 28 |                        uint_4 nmax, BRDataFmtConv swapall)
 | 
|---|
| 29 |   :   memgr(mem) , pciw_ (pciw)
 | 
|---|
| 30 | {
 | 
|---|
| 31 |   nmax_ = nmax; 
 | 
|---|
| 32 |   swapall_ = swapall;   // select data swap/format conversion for BRPaquet 
 | 
|---|
| 33 |   stop_ = false;
 | 
|---|
| 34 |   packSize_ = packSize;
 | 
|---|
| 35 |   sizeFr_ =sizeFrame;
 | 
|---|
| 36 |   // Pour la logique de gestion des paquets ds zone memoire
 | 
|---|
| 37 |   mid_ = -2;
 | 
|---|
| 38 |   targ_npaq_ = 0;
 | 
|---|
| 39 |  
 | 
|---|
| 40 |  max_targ_npaq = memgr.NbPaquets();
 | 
|---|
| 41 |   mmbuf_ = NULL;
 | 
|---|
| 42 | }
 | 
|---|
| 43 | 
 | 
|---|
| 44 | bool PCIEReader::MZoneManage(bool fgclean)    // Retourne true si probleme 
 | 
|---|
| 45 | {
 | 
|---|
| 46 |   /* Pour debug 
 | 
|---|
| 47 |   cout << " PCIEReader::MZoneManage() mid_=" << mid_ << " arg_npaq_= " << targ_npaq_  
 | 
|---|
| 48 |        << " max_targ_npaq=" << max_targ_npaq << endl;
 | 
|---|
| 49 |   */
 | 
|---|
| 50 |   if (mid_ >= 0)  memgr.FreeMemZone(mid_, MemZS_Filled);
 | 
|---|
| 51 |   mmbuf_ = NULL;  targ_npaq_ = 0;  mid_ = -2;
 | 
|---|
| 52 |   if (fgclean)  return false;
 | 
|---|
| 53 |   mid_ = memgr.FindMemZoneId(MemZA_Fill);
 | 
|---|
| 54 |   mmbuf_ = memgr.GetMemZone(mid_);
 | 
|---|
| 55 |   if (mmbuf_==NULL) return true;
 | 
|---|
| 56 |   return false;
 | 
|---|
| 57 | }
 | 
|---|
| 58 | 
 | 
|---|
| 59 | void PCIEReader::run()
 | 
|---|
| 60 | {
 | 
|---|
| 61 |   struct sigaction act;
 | 
|---|
| 62 |   struct sigaction old_act;
 | 
|---|
| 63 |    //Precision insuffisante  ResourceUsage ru; ru.Update();  // Pour recuperer le temps passe
 | 
|---|
| 64 |   struct timeval tv1, tv2;
 | 
|---|
| 65 |   gettimeofday(&tv1, NULL);
 | 
|---|
| 66 |   
 | 
|---|
| 67 |   try{
 | 
|---|
| 68 |   cout << " PCIEReader::run() - Starting , NMaxMemZones=" << nmax_ 
 | 
|---|
| 69 |        << "memgr.NbPaquets()=" << memgr.NbPaquets() << endl;    
 | 
|---|
| 70 |   setRC(1);     
 | 
|---|
| 71 | 
 | 
|---|
| 72 |   uint_4 cpt=0;
 | 
|---|
| 73 |   // sigaddset(&act.sa_mask,SIGINT);  // pour proteger le transfert DMA
 | 
|---|
| 74 |   //sigaction(SIGINT,&act,NULL);  
 | 
|---|
| 75 |         
 | 
|---|
| 76 |   uint_4 paqsz = memgr.PaqSize();
 | 
|---|
| 77 |   uint_4 dmasz = pciw_.TransferSize();
 | 
|---|
| 78 | 
 | 
|---|
| 79 |   Byte* Datas = NULL;
 | 
|---|
| 80 |   Byte* tampon = new Byte[paqsz];
 | 
|---|
| 81 |   Byte* nextpaq = NULL;
 | 
|---|
| 82 | 
 | 
|---|
| 83 |   uint_4 off_acheval = 0;
 | 
|---|
| 84 |   
 | 
|---|
| 85 |   int nerrdma = 0;
 | 
|---|
| 86 |   int maxerrdma = 10;
 | 
|---|
| 87 |   bool fgarret = false;
 | 
|---|
| 88 |   
 | 
|---|
| 89 |   uint_4 npaqfait = 0;    //  Nb total de paquets traites (DMA + decode)
 | 
|---|
| 90 |   
 | 
|---|
| 91 |   ///  do{  si boucle infini 
 | 
|---|
| 92 |   //  for (uint_4 kmz=0; kmz<nmax_; kmz++)  {
 | 
|---|
| 93 |   while (npaqfait < nmax_*memgr.NbPaquets()) {
 | 
|---|
| 94 |     if (stop_) break;
 | 
|---|
| 95 |     if (fgarret) break;
 | 
|---|
| 96 |     // On pointe vers le debut de la zone a remplir aver le prochain DMA
 | 
|---|
| 97 |       Datas=pciw_.DoTransferData();
 | 
|---|
| 98 |       if (Datas == NULL) { // No data Read in DMA 
 | 
|---|
| 99 |         nerrdma ++;
 | 
|---|
| 100 |         cout << "PCIEReaderChecker/Erreur Waiting for datas ..." << endl;
 | 
|---|
| 101 |         pciw_.PrintStatus(cout);
 | 
|---|
| 102 |         if (nerrdma>=maxerrdma) { fgarret = true; break; }
 | 
|---|
| 103 |       }
 | 
|---|
| 104 |       else {  // DMA reussi 
 | 
|---|
| 105 |         uint_4 curoff = 0;
 | 
|---|
| 106 |         //1- On traite le paquet a cheval, rempli partiellement avec le DMA d'avant si necessaire
 | 
|---|
| 107 |         if (off_acheval > 0) {
 | 
|---|
| 108 |           if ((paqsz-off_acheval)< dmasz) { 
 | 
|---|
| 109 |             memcpy((void *)(tampon+off_acheval), (void *)Datas, paqsz-off_acheval);
 | 
|---|
| 110 |             curoff = paqsz-off_acheval;  off_acheval = 0;  
 | 
|---|
| 111 |             
 | 
|---|
| 112 |             if ((nextpaq=NextPaqTarget()) == NULL) {
 | 
|---|
| 113 |               cout << "2 PCIEReader::run()/Error NextPaqTarget() returned NULL ->STOP 9" << endl;
 | 
|---|
| 114 |               setRC(9);  fgarret=true; break;
 | 
|---|
| 115 |             }
 | 
|---|
| 116 |             BRPaquet paq(tampon, nextpaq, paqsz, swapall_);
 | 
|---|
| 117 |             npaqfait++;  // Ne pas oublier le compteur de paquets faits 
 | 
|---|
| 118 |           }
 | 
|---|
| 119 |           else {
 | 
|---|
| 120 |             memcpy((void *)(tampon+off_acheval), (void *)Datas, dmasz);
 | 
|---|
| 121 |             curoff =dmasz;
 | 
|---|
| 122 |             off_acheval = (dmasz+off_acheval);
 | 
|---|
| 123 |           }
 | 
|---|
| 124 |         }
 | 
|---|
| 125 |         //2- On traite les paquets complet qui se trouvent dans la zone du DMA 
 | 
|---|
| 126 |         while((curoff+paqsz)<=dmasz) {
 | 
|---|
| 127 |           //          BRPaquet paq((Byte*)(Datas)+((paqsz*j)), nextdma+j*paqsz, paqsz, swapall_);
 | 
|---|
| 128 |           if ((nextpaq=NextPaqTarget()) == NULL) {
 | 
|---|
| 129 |             cout << "3 PCIEReader::run()/Error NextPaqTarget() returned NULL ->STOP 9" << endl;
 | 
|---|
| 130 |             setRC(9);  fgarret=true; break;
 | 
|---|
| 131 |           }
 | 
|---|
| 132 |           BRPaquet paq(Datas+curoff, nextpaq, paqsz, swapall_);
 | 
|---|
| 133 |           curoff += paqsz;  // On avance l'index dans le buffer du DMA
 | 
|---|
| 134 |           npaqfait++;  // Ne pas oublier le compteur de paquets faits 
 | 
|---|
| 135 |         }  // -- FIN traitement des paquets complets ds un DMA 
 | 
|---|
| 136 |         //3- On copie si besoin la fin du DMA dans la zone tampon
 | 
|---|
| 137 |         if (curoff < dmasz) {
 | 
|---|
| 138 |           if (fgarret) break;  // pour sortir si l'on est passe par un STOP 9
 | 
|---|
| 139 |           off_acheval = dmasz-curoff;
 | 
|---|
| 140 |           memcpy(tampon, (void*)(Datas+curoff), off_acheval);
 | 
|---|
| 141 |           curoff += off_acheval; 
 | 
|---|
| 142 |         }
 | 
|---|
| 143 |       }  //   Traitement d'un DMA OK 
 | 
|---|
| 144 |   }
 | 
|---|
| 145 | //  }while(!stop_);     
 | 
|---|
| 146 |   
 | 
|---|
| 147 |   
 | 
|---|
| 148 |   gettimeofday(&tv2, NULL);
 | 
|---|
| 149 |   double tmelaps2 = (tv2.tv_sec-tv1.tv_sec)*1000.+(tv2.tv_usec-tv1.tv_usec)/1000.;
 | 
|---|
| 150 |   if (tmelaps2<0.1) tmelaps2=0.1; 
 | 
|---|
| 151 |   cout << " ------------------ PCIEReader::run()-End summary -------------------" << endl;
 | 
|---|
| 152 |   cout << " PCIEReader/Info TotTransfer=" << pciw_.TotTransferBytes()/1024 
 | 
|---|
| 153 |        << " kb , ElapsTime=" << tmelaps2 << " ms ->" 
 | 
|---|
| 154 |        << (double)pciw_.TotTransferBytes()/tmelaps2 << " kb/s" << endl; 
 | 
|---|
| 155 |   cout << " --------------------------------------------------------------------" << endl;
 | 
|---|
| 156 |   
 | 
|---|
| 157 |   MZoneManage(true);
 | 
|---|
| 158 |   delete [] tampon;
 | 
|---|
| 159 |  
 | 
|---|
| 160 |   }catch (PException& exc) {
 | 
|---|
| 161 |     cout << " PCIEREADER::run()/catched PException " << exc.Msg() << endl;
 | 
|---|
| 162 |     setRC(3);   
 | 
|---|
| 163 |     return; 
 | 
|---|
| 164 |   }
 | 
|---|
| 165 |   catch(...) {
 | 
|---|
| 166 |     cout << "  PCIEREADER::run()/catched unknown ... exception " << endl;
 | 
|---|
| 167 |     setRC(4);   
 | 
|---|
| 168 |     return; 
 | 
|---|
| 169 |   }
 | 
|---|
| 170 |   setRC(0);
 | 
|---|
| 171 |  
 | 
|---|
| 172 |   return;
 | 
|---|
| 173 | }
 | 
|---|
| 174 | 
 | 
|---|
| 175 | 
 | 
|---|
| 176 | void PCIEReader::Stop()
 | 
|---|
| 177 | { 
 | 
|---|
| 178 |   // cout << " PCIEReader::Stop() -------------> STOP" <<endl; 
 | 
|---|
| 179 |   stop_ = true;
 | 
|---|
| 180 |   return;
 | 
|---|
| 181 | }
 | 
|---|
| 182 | 
 | 
|---|
| 183 | 
 | 
|---|
| 184 | //-------------------------------------------------------
 | 
|---|
| 185 | // Classe thread de sauvegarde sur fichiers
 | 
|---|
| 186 | //-------------------------------------------------------
 | 
|---|
| 187 | 
 | 
|---|
| 188 | DataSaver::DataSaver(RAcqMemZoneMgr& mem, string& path, uint_4 nfiles, uint_4 nblocperfile, bool savesig)
 | 
|---|
| 189 |   :  memgr(mem) 
 | 
|---|
| 190 | {
 | 
|---|
| 191 |   nfiles_ = nfiles;
 | 
|---|
| 192 |   nblocperfile_ = nblocperfile;
 | 
|---|
| 193 |   nmax_ = nblocperfile_*nfiles_;
 | 
|---|
| 194 |   savesig_ = savesig;  // Si false, pas d'ecriture des fichiers FITS du signal  
 | 
|---|
| 195 |   stop_ = false;        
 | 
|---|
| 196 |   path_ = path; 
 | 
|---|
| 197 | }
 | 
|---|
| 198 | void DataSaver::Stop()
 | 
|---|
| 199 | {
 | 
|---|
| 200 |   // cout<< " DataSaver:Stop ........ " << endl;
 | 
|---|
| 201 |   stop_=true;
 | 
|---|
| 202 | 
 | 
|---|
| 203 | }
 | 
|---|
| 204 | void DataSaver::run()
 | 
|---|
| 205 | {
 | 
|---|
| 206 |   setRC(1);     
 | 
|---|
| 207 |   BRPaqChecker pcheck;  // Verification/comptage des paquets 
 | 
|---|
| 208 | 
 | 
|---|
| 209 |   try {
 | 
|---|
| 210 |     TimeStamp ts; 
 | 
|---|
| 211 |     cout << " DataSaver::run() - Starting " << ts << " NbFiles=" << nfiles_ << " NBloc/File=" 
 | 
|---|
| 212 |          << nblocperfile_ << " NMaxMemZones=" << nmax_ << endl; 
 | 
|---|
| 213 |     char fname[512];
 | 
|---|
| 214 | 
 | 
|---|
| 215 |     sprintf(fname,"%s/saver.log",path_.c_str());
 | 
|---|
| 216 |     ofstream filog(fname);
 | 
|---|
| 217 |     filog << " DataProc::run() - starting log file " << ts << endl;                    
 | 
|---|
| 218 |     filog << " NbFiles=" << nfiles_ << " NBloc/File="  << nblocperfile_ << " NMaxMemZones=" << nmax_ << endl;
 | 
|---|
| 219 |         
 | 
|---|
| 220 |     DataTable dt;
 | 
|---|
| 221 |     dt.AddLongColumn("TimeTag");
 | 
|---|
| 222 |     dt.AddIntegerColumn("FrameCounter");
 | 
|---|
| 223 |     dt.AddIntegerColumn("FrameLength");
 | 
|---|
| 224 |     dt.AddIntegerColumn("Num");
 | 
|---|
| 225 |     DataTableRow dtr = dt.EmptyRow();
 | 
|---|
| 226 |     uint_8 timtag = 0;
 | 
|---|
| 227 |     uint_4 numpaq = 0;
 | 
|---|
| 228 |     bool dthead = false;  // Mettre a false pour ne pas remplir DataTable Headers
 | 
|---|
| 229 | 
 | 
|---|
| 230 | 
 | 
|---|
| 231 |     uint_4 fnum=0;
 | 
|---|
| 232 |     uint_4 paqsz = memgr.PaqSize();
 | 
|---|
| 233 |     for (uint_4 nbFile=0;nbFile<nfiles_ ;nbFile++) {
 | 
|---|
| 234 |       if (stop_ )   break;
 | 
|---|
| 235 |       sprintf(fname,"%s/HDRfits%d.txt",path_.c_str(),fnum);
 | 
|---|
| 236 |       ofstream header(fname);
 | 
|---|
| 237 | 
 | 
|---|
| 238 |       BRPaquet paq0(NULL, NULL, paqsz); 
 | 
|---|
| 239 |       uint_4 npaqperfile = memgr.NbPaquets()*nblocperfile_;  // Nombre de paquets ecrits dans un fichier 
 | 
|---|
| 240 | 
 | 
|---|
| 241 |       MiniFITSFile mff; 
 | 
|---|
| 242 |       if (savesig_) { //Reza - Ouverture conditionnel fichier 
 | 
|---|
| 243 |         sprintf(fname,"%s/signal%d.fits",path_.c_str(),(int)fnum++);
 | 
|---|
| 244 |         mff.Open(fname,MF_Write);  //Reza - Ouverture conditionnel fichier 
 | 
|---|
| 245 |         mff.setDTypeNaxis(MF_Byte, paq0.DataSize()+paq0.HeaderSize(), npaqperfile); 
 | 
|---|
| 246 |       }
 | 
|---|
| 247 |       else sprintf(fname,"MemDataBloc[%d]-NoDataFile",(int)fnum++);
 | 
|---|
| 248 | 
 | 
|---|
| 249 |       for (uint_4 kmz=0; kmz<nblocperfile_; kmz++) {
 | 
|---|
| 250 |         if (stop_) break;
 | 
|---|
| 251 |           //DBG cout << " DataSaver::run()- nbFile=" << nbFile << " kmz=" << kmz << endl;       
 | 
|---|
| 252 |         int mid = memgr.FindMemZoneId(MemZA_Save);  
 | 
|---|
| 253 |         Byte* buff = memgr.GetMemZone(mid);
 | 
|---|
| 254 |         if (buff == NULL) {
 | 
|---|
| 255 |           cout << " DataSaver::run()/ERROR memgr.GetMemZone(" << mid << ") -> NULL" << endl;
 | 
|---|
| 256 |           setRC(2);     
 | 
|---|
| 257 |           return;       
 | 
|---|
| 258 |         }
 | 
|---|
| 259 |         for(uint_4 i=0; i<memgr.NbPaquets(); i++) {
 | 
|---|
| 260 |  
 | 
|---|
| 261 |           BRPaquet paq(NULL, buff+i*paqsz, paqsz);
 | 
|---|
| 262 |           pcheck.Check(paq);   // Verification du paquet / FrameCounter 
 | 
|---|
| 263 | 
 | 
|---|
| 264 |           header << hex << paq.HDRMarker() << " " << paq.TRLMarker() << " " << paq.TimeTag2()<< " "<< paq.TimeTag1()<< " " << paq.FrameCounter() << " " << paq.PaqLen()  << endl;
 | 
|---|
| 265 | 
 | 
|---|
| 266 |           if (dthead) {  // Remplissage DataTable entetes paquets 
 | 
|---|
| 267 |             timtag = (uint_8)paq.TimeTag2()*0x100000000ULL+paq.TimeTag1();
 | 
|---|
| 268 |             dtr[0] = timtag;
 | 
|---|
| 269 |             dtr[1] = paq.FrameCounter();
 | 
|---|
| 270 |             dtr[2] = paq.PaqLen();
 | 
|---|
| 271 |             dtr[3] = numpaq++;
 | 
|---|
| 272 |             dt.AddRow(dtr);
 | 
|---|
| 273 |           }
 | 
|---|
| 274 | 
 | 
|---|
| 275 |           if (savesig_) // Reza - Ecriture conditionnel fichier fits signal 
 | 
|---|
| 276 |           //  mff.WriteB(paq.Data1(), paq.DataSize());
 | 
|---|
| 277 |             mff.WriteB(paq.Header(),paq.DataSize()+paq.HeaderSize()); // ecriture datas + header
 | 
|---|
| 278 |         }
 | 
|---|
| 279 |         memgr.FreeMemZone(mid, MemZS_Saved);
 | 
|---|
| 280 |       }
 | 
|---|
| 281 |       ts.SetNow(); 
 | 
|---|
| 282 |       filog << ts << " : OK data file  " << fname << endl;                     
 | 
|---|
| 283 |       cout << " DataSaver::run() " << ts << " : OK data file  " << fname << endl;
 | 
|---|
| 284 |     }
 | 
|---|
| 285 |     if (dthead) {
 | 
|---|
| 286 |       cout << dt;
 | 
|---|
| 287 |       char fname2[256];
 | 
|---|
| 288 |       sprintf(fname2,"%s/headers.ppf",path_.c_str());
 | 
|---|
| 289 |       POutPersist po(fname2);
 | 
|---|
| 290 |       po << dt;
 | 
|---|
| 291 |     }
 | 
|---|
| 292 |     cout << " --------------------  DataSaver::run() -------------------- " << endl;
 | 
|---|
| 293 |     pcheck.Print(cout);
 | 
|---|
| 294 |     cout << " ---------------------------------------------------------- " << endl;
 | 
|---|
| 295 |     ts.SetNow();
 | 
|---|
| 296 |     pcheck.Print(filog);
 | 
|---|
| 297 |     filog << " DataSaver::run() - End of processing/run() " << ts << endl;                     
 | 
|---|
| 298 | 
 | 
|---|
| 299 |   }
 | 
|---|
| 300 |   catch (MiniFITSException& exc) {
 | 
|---|
| 301 |     cout << " DataSaver::run()/catched MiniFITSException " << exc.Msg() << endl;
 | 
|---|
| 302 |     setRC(3);   
 | 
|---|
| 303 |     return; 
 | 
|---|
| 304 |   }
 | 
|---|
| 305 |   catch(...) {
 | 
|---|
| 306 |     cout << " DataSaver::run()/catched unknown ... exception " << endl;
 | 
|---|
| 307 |     setRC(4);   
 | 
|---|
| 308 |     return; 
 | 
|---|
| 309 |   }
 | 
|---|
| 310 |   setRC(0);
 | 
|---|
| 311 |   return;
 | 
|---|
| 312 | }   
 | 
|---|
| 313 | 
 | 
|---|
| 314 | 
 | 
|---|
| 315 | 
 | 
|---|
| 316 | 
 | 
|---|
| 317 | //----------------------------------------------------------------------------------------------------------
 | 
|---|
| 318 | // Classe thread de lecture PCI-Express + Check pour tests de verification de debit/etc avec un seul thread
 | 
|---|
| 319 | //----------------------------------------------------------------------------------------------------------
 | 
|---|
| 320 | 
 | 
|---|
| 321 | PCIEReaderChecker::PCIEReaderChecker(PCIEWrapper &pciw,uint_4 sizeFrame,uint_4 packSize ,RAcqMemZoneMgr& mem, 
 | 
|---|
| 322 |                                      uint_4 nmax, BRDataFmtConv swapall)
 | 
|---|
| 323 |   :   memgr(mem) , pciw_ (pciw)
 | 
|---|
| 324 | {
 | 
|---|
| 325 |   nmax_ = nmax; 
 | 
|---|
| 326 |   swapall_ = swapall;   // select data swap/format conversion for BRPaquet
 | 
|---|
| 327 |   stop_ = false;
 | 
|---|
| 328 |   packSize_ = packSize;
 | 
|---|
| 329 |   sizeFr_ =sizeFrame;
 | 
|---|
| 330 | }
 | 
|---|
| 331 | void PCIEReaderChecker::run()
 | 
|---|
| 332 | {
 | 
|---|
| 333 |   
 | 
|---|
| 334 |   struct timeval tv1, tv2;
 | 
|---|
| 335 |   gettimeofday(&tv1, NULL);
 | 
|---|
| 336 |   
 | 
|---|
| 337 |   cout << " PCIEReaderChecker::run() - Starting , NMaxMemZones=" << nmax_ 
 | 
|---|
| 338 |        << " memgr.NbPaquets()=" << memgr.NbPaquets() << endl;   
 | 
|---|
| 339 |   setRC(1);     
 | 
|---|
| 340 |   cout << " ... RAcqMemZoneMgr not used - using s fixed memory location for packets decoding ..." << endl;
 | 
|---|
| 341 | 
 | 
|---|
| 342 |   uint_4 cpt=0;
 | 
|---|
| 343 |   // sigaddset(&act.sa_mask,SIGINT);  // pour proteger le transfert DMA
 | 
|---|
| 344 |   //sigaction(SIGINT,&act,NULL);        
 | 
|---|
| 345 |   uint_4 paqsz = memgr.PaqSize();
 | 
|---|
| 346 |   uint_4 dmasz = pciw_.TransferSize();
 | 
|---|
| 347 | 
 | 
|---|
| 348 |   BRPaqChecker pcheck;  // Verification/comptage des paquets 
 | 
|---|
| 349 | 
 | 
|---|
| 350 |   Byte* Datas = NULL;
 | 
|---|
| 351 |   Byte* locdata = new Byte[paqsz];
 | 
|---|
| 352 |   Byte* tampon = new Byte[paqsz];
 | 
|---|
| 353 | 
 | 
|---|
| 354 |   uint_4 off_acheval = 0;
 | 
|---|
| 355 | 
 | 
|---|
| 356 |   int nerrdma = 0;
 | 
|---|
| 357 |   int maxerrdma = 10;
 | 
|---|
| 358 |   bool fgarret = false;
 | 
|---|
| 359 |   for (uint_4 kmz=0; kmz<nmax_; kmz++)  {
 | 
|---|
| 360 |     if (stop_) break;
 | 
|---|
| 361 |     if (fgarret) break;
 | 
|---|
| 362 | 
 | 
|---|
| 363 |     Byte* nextdma = locdata;
 | 
|---|
| 364 |     uint_4 npaqfait = 0;      
 | 
|---|
| 365 |     //      for (uint_4 i=0; i<memgr.NbPaquets(); i += pktInDMATr) {  // attention pktInDMATr paquets dans 1 seul DMA
 | 
|---|
| 366 |     while (npaqfait < memgr.NbPaquets()) {
 | 
|---|
| 367 |       if (fgarret) break;
 | 
|---|
| 368 |       // On pointe vers le debut de la zone a remplir aver le prochain DMA
 | 
|---|
| 369 |       //-- Zone memoire locale Byte* nextdma = buff+i*paqsz;
 | 
|---|
| 370 |         Datas=pciw_.DoTransferData();
 | 
|---|
| 371 |         
 | 
|---|
| 372 |         if (Datas == NULL) { // No data Read in DMA 
 | 
|---|
| 373 |           nerrdma ++;
 | 
|---|
| 374 |           cout << "PCIEReaderChecker/Erreur Waiting for datas ..." << endl;
 | 
|---|
| 375 |           pciw_.PrintStatus(cout);
 | 
|---|
| 376 |           if (nerrdma>=maxerrdma) { fgarret = true; break; }
 | 
|---|
| 377 |         }
 | 
|---|
| 378 |         else {
 | 
|---|
| 379 |           uint_4 curoff = 0;
 | 
|---|
| 380 |           //1- On traite le paquet a cheval, rempli partiellement avec le DMA d'avant si necessaire
 | 
|---|
| 381 |           //      if (off_acheval > 0) {  
 | 
|---|
| 382 |           //  memcpy((void *)(tampon+off_acheval), (void *)Datas, paqsz-off_acheval);
 | 
|---|
| 383 |           //  curoff = paqsz-off_acheval;  off_acheval = 0;  
 | 
|---|
| 384 |             
 | 
|---|
| 385 |           // BRPaquet paq(tampon, locdata, paqsz, swapall_);
 | 
|---|
| 386 |           //  npaqfait++;  // Ne pas oublier le compteur de paquets faits 
 | 
|---|
| 387 |           //  pcheck.Check(paq);   // Verification du paquet / FrameCounter 
 | 
|---|
| 388 |           //}
 | 
|---|
| 389 |         if (off_acheval > 0) {
 | 
|---|
| 390 |           if ((paqsz-off_acheval)< dmasz) { 
 | 
|---|
| 391 |             memcpy((void *)(tampon+off_acheval), (void *)Datas, paqsz-off_acheval);
 | 
|---|
| 392 |             curoff = paqsz-off_acheval;  off_acheval = 0;  
 | 
|---|
| 393 |             
 | 
|---|
| 394 |             BRPaquet paq(tampon, locdata, paqsz, swapall_);
 | 
|---|
| 395 |             npaqfait++;  // Ne pas oublier le compteur de paquets faits
 | 
|---|
| 396 |             pcheck.Check(paq);   // Verification du paquet / FrameCounter 
 | 
|---|
| 397 |           }
 | 
|---|
| 398 |           else {
 | 
|---|
| 399 |             memcpy((void *)(tampon+off_acheval), (void *)Datas, dmasz);
 | 
|---|
| 400 |             curoff =dmasz;
 | 
|---|
| 401 |             off_acheval = (dmasz+off_acheval);
 | 
|---|
| 402 |           }
 | 
|---|
| 403 |         }
 | 
|---|
| 404 |           //2- On traite les paquets complet qui se trouvent dans la zone du DMA 
 | 
|---|
| 405 |           while((curoff+paqsz)<=dmasz) {
 | 
|---|
| 406 |             //        BRPaquet paq((Byte*)(Datas)+((paqsz*j)), nextdma+j*paqsz, paqsz, swapall_);
 | 
|---|
| 407 |             BRPaquet paq(Datas+curoff, locdata, paqsz, swapall_);
 | 
|---|
| 408 |             curoff += paqsz;  // On avance l'index dans le buffer du DMA
 | 
|---|
| 409 |             npaqfait++;  // Ne pas oublier le compteur de paquets faits 
 | 
|---|
| 410 |             pcheck.Check(paq);   // Verification du paquet / FrameCounter 
 | 
|---|
| 411 |           }  // -- FIN traitement des paquets complets ds un DMA 
 | 
|---|
| 412 |           //3- On copie si besoin la fin du DMA dans la zone tampon
 | 
|---|
| 413 |           if (curoff < dmasz) {
 | 
|---|
| 414 |             off_acheval = dmasz-curoff;
 | 
|---|
| 415 |             memcpy(tampon, (void*)(Datas+curoff), off_acheval);
 | 
|---|
| 416 |             curoff += off_acheval; 
 | 
|---|
| 417 |           }
 | 
|---|
| 418 |         }  //   Traitement d'un DMA OK 
 | 
|---|
| 419 |         
 | 
|---|
| 420 |     }  // Fin boucle de remplissage d'une zone memoire
 | 
|---|
| 421 |   } //  Fin boucle sur les zones 
 | 
|---|
| 422 |   
 | 
|---|
| 423 |   setRC(0);
 | 
|---|
| 424 |   gettimeofday(&tv2, NULL);
 | 
|---|
| 425 |   double tmelaps2 = (tv2.tv_sec-tv1.tv_sec)*1000.+(tv2.tv_usec-tv1.tv_usec)/1000.;
 | 
|---|
| 426 |   if (tmelaps2<0.1) tmelaps2=0.1; 
 | 
|---|
| 427 |   cout << " ------------------ PCIEReaderChecker::run()-End summary -------------------" << endl;
 | 
|---|
| 428 |   cout << " PCIEReaderChecker/Info TotTransfer=" << pciw_.TotTransferBytes()/1024 
 | 
|---|
| 429 |        << " kb , ElapsTime=" << tmelaps2 << " ms ->" 
 | 
|---|
| 430 |        << (double)pciw_.TotTransferBytes()/tmelaps2 << " kb/s" << endl; 
 | 
|---|
| 431 |   pcheck.Print(cout);
 | 
|---|
| 432 |   cout << " --------------------------------------------------------------------" << endl;
 | 
|---|
| 433 | 
 | 
|---|
| 434 |   delete [] locdata;
 | 
|---|
| 435 |   delete [] tampon;
 | 
|---|
| 436 | 
 | 
|---|
| 437 |   return;
 | 
|---|
| 438 | }
 | 
|---|
| 439 | void PCIEReaderChecker::Stop()
 | 
|---|
| 440 | { 
 | 
|---|
| 441 |   // cout << " PCIEReaderChecker::stop()  ........ STOP" <<endl; 
 | 
|---|
| 442 |   stop_ = true;
 | 
|---|
| 443 | 
 | 
|---|
| 444 | }
 | 
|---|