1 | #ifndef BRBASEPROC_H_SEEN
|
---|
2 | #define BRBASEPROC_H_SEEN
|
---|
3 |
|
---|
4 | //----------------------------------------------------------------
|
---|
5 | // Projet BAORadio - (C) LAL/IRFU 2008-2011
|
---|
6 | // Classes de threads de traitememt donnees BAORadio
|
---|
7 | //----------------------------------------------------------------
|
---|
8 |
|
---|
9 |
|
---|
10 | #include "racqumem.h"
|
---|
11 | #include <string>
|
---|
12 | #include <vector>
|
---|
13 | #include <iostream>
|
---|
14 |
|
---|
15 | #include "brpaqu.h"
|
---|
16 | #include "timestamp.h" // include SOPHYA
|
---|
17 |
|
---|
18 | using namespace std;
|
---|
19 |
|
---|
20 | //---------------------------------------------------------------------
|
---|
21 | // Classe de base pour l'analyse donnees (paquets acquisition) BAORadio
|
---|
22 | // Les classes de traitement des paquets BAORadio peuvent heriter de
|
---|
23 | // cette classe de base BRBaseProcessor en redefinissant la methode Process()
|
---|
24 | //---------------------------------------------------------------------
|
---|
25 | class BRBaseProcessor : public SOPHYA::ZThread {
|
---|
26 | public:
|
---|
27 | BRBaseProcessor(RAcqMemZoneMgr& memgr, MemZaction mmact=MemZA_ProcA);
|
---|
28 |
|
---|
29 | MemZStatus SetMemZAction(MemZaction mmact=MemZA_ProcA);
|
---|
30 |
|
---|
31 | virtual void run();
|
---|
32 |
|
---|
33 | inline void Stop() { stop_ = true; }
|
---|
34 | inline void STOP() { stop_ = true; }
|
---|
35 |
|
---|
36 | inline void setNameId(const char* nom, int id)
|
---|
37 | { bpnom_=nom; bpid_=id; }
|
---|
38 | inline void setNameId(string const& nom, int id)
|
---|
39 | { bpnom_=nom; bpid_=id; }
|
---|
40 |
|
---|
41 | // Definition de la fentre en temps des paquets a traiter - par defaut, traitement de tous les paquets
|
---|
42 | // Process() est alors appele pour les paquets des zones MemZoneMgr
|
---|
43 | // avec TimeStart <= getObsTime() <= TimeEnd
|
---|
44 | inline void SetProcTimeWindow(SOPHYA::TimeStamp tmstart, SOPHYA::TimeStamp tmend)
|
---|
45 | { tmstart_=tmstart; tmend_=tmend; fgproctimewin_=true; }
|
---|
46 | // Annulation de la definition de la fenetre de traitement en temps
|
---|
47 | inline void ClearProcTimeWindow()
|
---|
48 | { fgproctimewin_=false; }
|
---|
49 |
|
---|
50 | // get Observation Time ( obtained from MemZoneMgr )
|
---|
51 | inline SOPHYA::TimeStamp& getObsTime() { return cts_; }
|
---|
52 | // Attention : les methodes suivantes ne sont pas protegees pour le numero de fibre
|
---|
53 | // Renvoie le numero de frame-counter courant - si fgz=true, soustrait le FC du premier paquet
|
---|
54 | inline uint_8 getCurFrameCounter(size_t fib=0, bool fgz=true)
|
---|
55 | { if (fgz) return (curfc_[fib]-fcfirst_[fib]) ; else return curfc_[fib]; }
|
---|
56 | // Renvoie le TimeTag courant (unite coups d'horloge) - si fgz=true, soustrait le TT du premier paquet
|
---|
57 | inline uint_8 getCurTimeTag(size_t fib=0, bool fgz=true)
|
---|
58 | { if (fgz) return (vpaq_[fib].TimeTag()-ttfirst_[fib]) ; else return vpaq_[fib].TimeTag(); }
|
---|
59 | // Renvoie le TimeTag courant converti en secondes - si fgz=true, soustrait le TT du premier paquet
|
---|
60 | inline double getCurTimeTagSeconds(size_t fib=0, bool fgz=true)
|
---|
61 | {
|
---|
62 | if (fgz) return ((double)(vpaq_[fib].TimeTag()-ttfirst_[fib])/1.25e8) ;
|
---|
63 | else return ((double)vpaq_[fib].TimeTag()/1.25e8);
|
---|
64 | }
|
---|
65 | //---- niveau d'impression
|
---|
66 | inline void SetPrintLevel(int lev=0, uint_8 prtmodulo=10)
|
---|
67 | { prtlev_=lev; prtmodulo_=prtmodulo;}
|
---|
68 |
|
---|
69 | protected:
|
---|
70 | // Methode devant etre redefinie pour effectuer le traitement - appele pour chaque trigger
|
---|
71 | virtual int Process(); // renvoie 0 si OK, sinon, arret traitement
|
---|
72 |
|
---|
73 | RAcqMemZoneMgr& memgr_;
|
---|
74 | MemZaction mmact_; // Definition de l'action sur les paquets (defaut=MemZA_ProcA)
|
---|
75 | MemZStatus mmsta_; // Statut associe a mmact_ (defaut=MemZS_ProcA)
|
---|
76 | int mid_; // Identificateur zone memoire courant
|
---|
77 | bool stop_;
|
---|
78 | vector<Byte*> fbuff_; // Vecteur de pointeur de zone memoire pour chaque fibre
|
---|
79 | vector<Byte*> fprocbuff_; // Vecteur de pointeur de proc_zone_mem pour chaque fibre
|
---|
80 | vector<BRPaquet> vpaq_; // Vecteur de BRPaquet pour chaque fibre
|
---|
81 | vector<Byte*> vprocpaq_; // Vecteur de pointeur de zone memoire pour donnees traitees de chaque paquet/fibre
|
---|
82 | vector<BRPaqChecker> vpchk_;
|
---|
83 | vector<uint_8> vfgok_; // Vecteur de flag si paquet OK pour chaque fibre
|
---|
84 | vector<uint_8> curfc_; // Vecteur de numero de FrameCounter pour chaque fibre
|
---|
85 | vector<uint_8> fcfirst_; // numero du FrameCounter pour le premier paquet
|
---|
86 | vector<uint_8> ttfirst_; // TimeTag pour le premier paquet
|
---|
87 | bool fgokallfibers_; // true -> paquets for all fibers OK
|
---|
88 |
|
---|
89 | uint_8 totprocnpaq_;
|
---|
90 | SOPHYA::TimeStamp cts_; // current time stamp, get from MemZoneMgr
|
---|
91 |
|
---|
92 | string bpnom_; // nom du processeur
|
---|
93 | int bpid_; // numero d'identificateur
|
---|
94 |
|
---|
95 | SOPHYA::TimeStamp tmstart_, tmend_; // definition de la fenetre en temps pour appel de Process()
|
---|
96 | bool fgproctimewin_; // false -> pas de fenetre en temps, Process() appele pour tous les paquets
|
---|
97 |
|
---|
98 | int prtlev_; // print level
|
---|
99 | uint_8 prtmodulo_; // print periodicity (modulo)
|
---|
100 | };
|
---|
101 |
|
---|
102 |
|
---|
103 |
|
---|
104 | #endif
|
---|