/[PAMELA software]/yoda/techmodel/forroutines/tracker/readraw/trkunpack.f
ViewVC logotype

Diff of /yoda/techmodel/forroutines/tracker/readraw/trkunpack.f

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 5.0 by kusanagi, Mon Aug 29 09:46:13 2005 UTC revision 6.5 by mocchiut, Fri Oct 20 11:07:44 2006 UTC
# Line 1  Line 1 
1        subroutine trkeventpkt(YODAflag,event_file_name)  *************************************************************************
2    *     20/1/2006 modified by elena vannuccini to code error flag
3    *     10/9/2005 modified by david fedele to read buffer-data
4    *     instead raw-data-file
5    *     29/11/2005 modified by david fedele to include crc control
6    *     24/06/2006 modified by elena vannuccini
7    *     25/06/2006 modified by david fedele
8    *************************************************************************
9    
10          subroutine trkeventpkt(YODAflag,buffer,length_buffer,curpos)
11    
12          include '../common/commontracker.f'
13          include '../common/common_readraw.f'
14          include '../common/level0.f'
15    
16        include '../commonyoda/commontracker.f'        logical ALARMS
17        include '../commonyoda/dataformat.f'        integer runerror          !readevent error flag
18        include '../commonyoda/level0.f'        integer*1 crctemp
19    
20    *     -------------------
21    *     initializations
22  *     ---------------------------------------------------  *     ---------------------------------------------------
23  *     the general flag YODAflag contains information  *     the general flag YODAflag contains information
24  *     about the integrity of the packet.  *     about the integrity of the DSP packets.
 *      
 *     It is coded in bits:  
 *      
 *     x xxxx xxxx xxxx xxxx  
 *     | |||| |||| |||| ||||  
 *     | |||| |||| |||| |||- integrity flag of 1  st DSP packet  
 *     | |||| |||| |||| ||--     "       "   " 2  nd  "    "  
 *     | |||| |||| |||| |---     "       "   " 3  rd  "    "  
 *     | |||| ..............  
 *     | |..................  
 *     | ------------------- integrity flag of 12 th DSP packet  
 *     |  
 *     --------------------- flag that indicates if more than 12    
 *                           packets have been found  
 *  
 *     EXAMPLE 1.  
 *     If the event packet is truncated and only three DSP packets  
 *     are present in the fragment, the last being TRUNCATED,  
 *     the YODAflag will be:  
 *  
 *     YODAflag = b#00000000000000100 = 4  
25  *      *    
26  *     and only the two integer packets will be stored.  *     If some packets are missing or the crc check fails,
27  *  *     YODAflag is asserted
 *     EXAMPLE 2.  
 *     If instead the corruption of a packet results from  
 *     checksum or crc, the YODAflag will be asserted as explained,  
 *     but the packet will be stored.  
28  *     ---------------------------------------------------  *     ---------------------------------------------------
29        integer YODAflag        YODAflag=1                !bad by default
   
       logical DEBUG,ALARMs  
       common/DEBUGflag/DEBUG,ALARMS  
   
   
       integer ndummy  
       data ndummy/1000/  
         
       integer runerror          !readevent error flag  
       integer ffd_pkt           !pkt file descriptor  
 *                               (file temporaneo)      
       character*60 event_file_name !nome file  
   
       integer lun_pkt  
       data lun_pkt/20/  
   
       integer last_trigger(nviews)  
       common/trigger_counter/last_trigger  
   
   
       YODAflag=0  
   
       open(unit=lun_pkt,  
      $     name=EVENT_FILE_NAME(1:lnblnk(EVENT_FILE_NAME)),  
      $     status='old',  
      $     form='unformatted'  
      $     )  
       ffd_pkt = FNum(lun_pkt)   !reads unix file descriptor  
   
30        call initlevel0        call initlevel0
31          ALARMS=.false.
32        TOTDATAlength = 0.        !total length of data buffer        npkt=0                    !#good DSP packets
33        do iview=1,nviews!ndummy         !loop on views                      startcrc=0  
34           call searchtrkheader(runerror,ffd_pkt)        stopcrc=0
35          crctemp=0              
36    *     -------------------
37    
38    *     ===================================
39          if(length_buffer.gt.MAXBUFFLEN)then
40    c         print*,'trkeventpkt: buffer() size must be at least '
41    c     $        ,length_buffer,' !!!!'
42             goto 2222
43          endif
44    *     ===================================
45          
46          
47          do iview=1,nviews         !loop on DSPs
48             call searchtrkheader(runerror,buffer,length_buffer,curpos,
49         $        startcrc)
50           if(runerror.eq.1.or.runerror.eq.-1) then                             if(runerror.eq.1.or.runerror.eq.-1) then                  
51  *        --------------------------------------------------  *        --------------------------------------------------
52  *        no further DSP packet has been found ==> go to end  *        no DSP packet has been found ==> go to end
53  *        --------------------------------------------------  *        --------------------------------------------------
54              goto 2222           !go to end              goto 2222           !go to end
55           endif           endif
56            
57           if(checkheader.ne.2) then           if(checkheader.ne.2) then
58              print*,'>>>> ERROR <<<< (trkeventpkt)'              print*,'>>>> ERROR <<<< (trkeventpkt)'
59              print*,'>>>> CPU packet type ',!pkt_type,              print*,'>>>> CPU packet type ',!pkt_type,
# Line 92  Line 68 
68              goto 2525           !next view (==> search another DSP header)              goto 2525           !next view (==> search another DSP header)
69           endif           endif
70                    
71           call unpackdata(runerror,ffd_pkt)           call unpackdata(runerror,buffer,length_buffer,curpos,
72         $        startcrc,stopcrc,crctemp)
73           if(runerror.eq.-1.or.runerror.eq.1)then           if(runerror.eq.-1.or.runerror.eq.1)then
74  *        -----------------------------------------------             goto 2222            !go to end
75  *        an error occurred while reading the packet data           else if(runerror.eq.2) then
76  *        ===> assert packet error bit ===> go to end             crc_dat=2            !flag for corrupted packet
 *        -----------------------------------------------  
             YODAflag=ior(YODAflag,int(2**(iview-1)))  
             goto 2222           !end  
77           endif           endif
                             
          if(ALARMs)then  
             print*,'  '  
             print*,'  -----------------------------------',iview  
             print*,'  DSP number-----',DSPnumber_dat  
             print*,'  DAQ mode-------',DAQmode_dat  
             print*,'  event number   ',eventn_dat  
             print*,'  datalength (13-bit w) ---- ',datalength_dat  
             print*,'  L-1  addr---',addrcluster_dat(1)  
             print*,'       signal-',signcluster_dat(1)  
             print*,'  L-2  addr---',addrcluster_dat(2)  
             print*,'       signal-',signcluster_dat(2)  
             print*,'  L-3  addr---',addrcluster_dat(3)  
             print*,'       signal-',signcluster_dat(3)  
             print*,'  FC------',fc_dat  
             print*,'  compression time ',compressiontime_dat  
             print*,'  FL1--',fl1_dat  
             print*,'  FL2--',fl2_dat  
             print*,'  FL3--',fl3_dat  
             print*,'  FL4--',fl4_dat  
             print*,'  FL5--',fl5_dat  
             print*,'  FL6--',fl6_dat  
   
             print*,'*-*-*-*-*-*-TRAILER-*-*-*-*-*-*'  
             print*,'*  PNUM   (periferal num) ',pnum_dat  
             print*,'*  CMDNUM (command)       ',cmdnum_dat  
             print*,'*  BID    (board id)      ',bid_dat  
             print*,'*  ALARM                  ',alarm_dat  
             print*,'*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*'  
   
             DEBUG = .true.  
          endif          
78    
79           trk_DSP_ok(DSPnumber_dat)=1           npkt = npkt + 1
                     
80           call fillview(iview)           call fillview(iview)
81    *--------CRC check
82             if(crc(iview).eq.0.or.crc(iview).eq.2) then !OK
83    *----------- ALARMS
84               if(
85         $          fl1(iview).ne.0.or.
86         $          fl2(iview).ne.0.or.
87         $          fl3(iview).ne.0.or.
88         $          fl4(iview).ne.0.or.
89         $          fl5(iview).ne.0.or.
90         $          fl6(iview).ne.0.or.
91         $          fc(iview).ne.0.or.
92         $          DATAlength(iview).eq.0.or.
93         $          .false.)ALARMS=.true.
94             endif
95                    
96   2525    continue   2525    continue
97        enddo                     !end loop on views        enddo                     !end loop on views
98                
99   2222 continue   2222 continue
100    
101        close (lun_pkt)        if(npkt.eq.nviews)YODAflag=0
102          if(YODAflag.eq.0.and.(ALARMS.eqv..false.))good0=1
103    
104        return        return
105        end        end
106    
107  *     **********************************************  *     **********************************************************
108    *     *                                                        *
109    *     *                                                        *
110    *     *                                                        *
111    *     *                                                        *
112    *     *                                                        *
113    *     **********************************************************
114    
115        subroutine trkcalibpkt(runerror,event_file_name)        subroutine trkcalibpkt(YODAflag,buffer,length_buffer,curpos
116         $     )
117    
118        include '../commonyoda/commontracker.f'        include '../common/commontracker.f'
119        include '../commonyoda/dataformat.f'        include '../common/common_readraw.f'
120        include '../commonyoda/trk_calib_parameters.f'        include '../common/trk_calib_parameters.f'
121            
122        integer ndummy        logical ALARMs
       data ndummy/1000/  
         
123        integer runerror          !readevent error flag        integer runerror          !readevent error flag
124        integer ffd_pkt           !pkt file descriptor        integer*1 crctemp
                                 !(file temporaneo)      
       character*60 event_file_name !nome file  
   
       logical DEBUG,ALARMs  
       data DEBUG/.false./  
         
 ccc      data DEBUG/.true./  
 ccc      common/DEBUGflag/DEBUG  
   
   
       integer lun_pkt  
       data lun_pkt/10/  
125    
126    *     -------------------
127        open(unit=lun_pkt,  *     initializations
128       $     name=EVENT_FILE_NAME(1:lnblnk(EVENT_FILE_NAME)),  *     ---------------------------------------------------
129       $     status='old',  *     the general flag YODAflag contains information
130       $     form='unformatted'  *     about the integrity of the DSP packets.
131       $     )  *    
132        ffd_pkt = FNum(lun_pkt)   !reads unix file descriptor  *     If some packets are missing or the crc check fails,
133    *     YODAflag is asserted
134    *     ---------------------------------------------------
135          YODAflag = 1              !bad by default
136          call initcalib
137          ALARMS=.false.
138          npkt=0                    !#good DSP packets
139          startcrc=0  
140          stopcrc=0
141          crctemp=0        
142    *     -------------------
143    
144    *     ===================================
145          if(length_buffer.gt.MAXBUFFLEN)then
146    c         print*,'trkeventpkt: buffer() size must be at least '
147    c     $        ,length_buffer,' !!!!'
148             goto 2222
149          endif
150    *     ===================================
151                
152          do iview=1,nplanes        !loop on views (DSP pkt)
153    
154                   call searchtrkheader(runerror,buffer,length_buffer,curpos,
155        do iview=1,ndummy         !loop on views (DSP pkt)       $        startcrc)
156    
157           ALARMS=.false.           if(runerror.eq.1.or.runerror.eq.-1) then                  
           
          call searchtrkheader(runerror,ffd_pkt)  
 c         if(runerror.eq.-1) goto 24  
          if(runerror.eq.-1) goto 2222  
          if(runerror.eq.1) then                    
 c            print*,' '  
 c            print*,'readraw: END OF CPU PACKET '  
 c            print*,'______________________________________ '  
158              goto 2222           !end loop on views (DSP pkt)              goto 2222           !end loop on views (DSP pkt)
159           endif           endif
160    
161           if(checkheader.ne.3) then           if(checkheader.ne.3) then
162              print*,'>>>> ERROR <<<< (trkcalibpkt)'              print*,'>>>> ERROR <<<< (trkcalibpkt)'
163              print*,'>>>> CPU packet type ',!pkt_type,              print*,'>>>> CPU packet type ',!pkt_type,
# Line 210  c            print*,'___________________ Line 172  c            print*,'___________________
172              goto 2424           !next view (==> search another DSP header)              goto 2424           !next view (==> search another DSP header)
173           endif                               endif                    
174                    
175           call unpackcalibration(runerror,ffd_pkt)           call unpackcalibration(runerror,buffer,length_buffer,curpos,
176  c         if(runerror.eq.-1) goto 24       $        startcrc,stopcrc,crctemp)
177           if(runerror.eq.-1) goto 2222           if(runerror.eq.-1.or.runerror.eq.1)then
178  c         if(runerror.eq.1) goto 23              goto 2222           !end
          if(runerror.eq.1) goto 2222  
                     
          if(nused_event.ne.0.or.ff.ne.0)then  
             print*,'*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*'  
             print*,'*     !!! CALIBRATION FAILURE !!!     *'  
             print*,'*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*.*'  
 c            ALARMS=.true.  
          endif  
          if(ALARMS)then  
   
             print*,'Calibration packet ==> ',iview  
               
             print*,'---- Calibration packet ',iview,' ----'  
             print*,'  DSP number       ',DSPnumber_cal  
             print*,'  DAQ mode         ',DAQmode_cal  
             print*,'  calibration run  ',calibrationnumber  
             print*,'  n. event used    ',nused_event  
             print*,'  <PED> ladder 1   ',ped_1  
             print*,'  <PED> ladder 2   ',ped_2  
             print*,'  <PED> ladder 3   ',ped_3  
             print*,'  <SIG> ladder 1   ',sig_1  
             print*,'  <SIG> ladder 2   ',sig_2  
             print*,'  <SIG> ladder 3   ',sig_3  
             print*,'  n.BAD ladder 1   ',nbad_1  
             print*,'  n.BAD ladder 2   ',nbad_2        
             print*,'  n.BAD ladder 3   ',nbad_3  
             print*,'  error flag       ',ff  
179           endif           endif
180                                    
181    
182           DAQmode(iview)=DAQmode_cal           npkt = npkt + 1
183           DSPnumber(iview)=DSPnumber_cal           call fillview_cal(iview) !
184           calibnumber(iview)=calibrationnumber  *--------CRC check
185           ncalib_event(iview)=nused_event           if(  crc_hcal(iview).eq.0.and.
186           ped_l1(iview)=ped_1       $        crc_cal(iview,1).eq.0.and.
187           ped_l2(iview)=ped_2       $        crc_cal(iview,2).eq.0.and.
188           ped_l3(iview)=ped_3       $        crc_cal(iview,3).eq.0.and.
189           sig_l1(iview)=sig_1       $        .true.)then
190           sig_l2(iview)=sig_2  *----------- ALARMS
191           sig_l3(iview)=sig_3              if(  ncalib_event(iview).ne.0.or.
192           nbad_l1(iview)=nbad_1       $           cal_flag(iview).ne.0.or.
193           nbad_l2(iview)=nbad_2       $           .false.)ALARMS=.true.
194           nbad_l3(iview)=nbad_3           endif        
          cal_flag(iview)=ff  
195    
          do is=1,nstrips_view  
             DSPbad_par(iview,is)=DSPbad_o(DSPnumber_cal,is)  
             DSPped_par(iview,is)=DSPped_o(DSPnumber_cal,is)  
             DSPsig_par(iview,is)=DSPsig_o(DSPnumber_cal,is)  
          enddo  
 c          
          trk_DSP_ok(DSPnumber_cal)=1  
 c----------------------------------------------------------  
 c     NVIEWS calibration packets should have been found  
 c----------------------------------------------------------  
 c                  if(n_cal_pkt.eq.nviews)then  
 c                     found_cal_pkt = .true.  
 c                     n_cal_pkt = 0  
 c                  endif  
196   2424    continue   2424    continue
197        enddo                     ! end loop on views (calibration pkt)        enddo                     ! end loop on views (calibration pkt)
198    
199   2222 continue   2222 continue
200    
201        close (lun_pkt)        if(npkt.eq.nplanes)YODAflag=0
202          if(YODAflag.eq.0.and.(ALARMS.eqv..false.))good0=1
203    
204        return        return
205        end        end
206    
207  ***...***...***...***...***...***...***...***...***...***...***...***...***...***...***...***  *     **********************************************************
208  *  *     *                                                        *
209  *  *     *                                                        *
210  *  *     *                                                        *
211  *  *     *                                                        *
212  *  *     *                                                        *
213  *  *     **********************************************************
 *  
 *  
 ***...***...***...***...***...***...***...***...***...***...***...***...***...***...***...***  
214    
215        subroutine searchtrkheader(runerror,ffd)        subroutine searchtrkheader(runerror,buffer,length_buffer,
216         $     curpos,startcrc)
217  C.............................................................  C.............................................................
218  C     Search for a valid tracker DSP header (=>one view)  C     Search for a valid tracker DSP header (=>one view)
219  C     and return the type of header  C     and return the type of header
220  C.............................................................  C.............................................................
221    
222        include '../commonyoda/commontracker.f'        include '../common/commontracker.f'
223        include '../commonyoda/dataformat.f'        include '../common/common_readraw.f'
224    
       integer ffd               !input file descriptor  
225        integer runerror          !readevent error flag        integer runerror          !readevent error flag
226    
227  c--------------------------------------------------  c--------------------------------------------------
# Line 309  c     N.B.13 bit packing is done for eac Line 229  c     N.B.13 bit packing is done for eac
229  C     so each DSP 13 bit  C     so each DSP 13 bit
230  c     first word starts at the beginnig of a 16 bit word  c     first word starts at the beginnig of a 16 bit word
231  c--------------------------------------------------  c--------------------------------------------------
232    
233   9100 continue   9100 continue
234        runerror=0                !error flag initialization        runerror=0                !error flag initialization
235        checkheader=0        checkheader=0
# Line 317  c--------------------------------------- Line 238  c---------------------------------------
238  c     looks for a DSP header beginning  c     looks for a DSP header beginning
239  C     (a word beginning with 1110)  C     (a word beginning with 1110)
240  c--------------------------------------------------  c--------------------------------------------------
       call findstart(runerror,ffd)  
241                
242          call findstart(runerror,buffer,length_buffer,curpos)
243                
244        if(runerror.eq.1) goto 200 !end        if(runerror.eq.1) goto 200 !end
245        if(runerror.eq.-1)goto 200 !end        if(runerror.eq.-1)goto 200 !end
246  c--------------------------------------------------  c--------------------------------------------------
# Line 327  C     reads 13 8-bit words and Line 249  C     reads 13 8-bit words and
249  c     writes them in 16 13-bit words to check for all  c     writes them in 16 13-bit words to check for all
250  C     DSP header features  C     DSP header features
251  c--------------------------------------------------  c--------------------------------------------------
252                  
253        call hunpacker(header,runerror,ffd)        call hunpacker(header,runerror,buffer,length_buffer,curpos,
254               $     startcrc)
255                
256        if(runerror.eq.1) goto 200 !end        if(runerror.eq.1) goto 200 !end
257        if(runerror.eq.-1)goto 200 !end        if(runerror.eq.-1)goto 200 !end
258  c--------------------------------------------------  c--------------------------------------------------
# Line 366  c     then this is not a DSP header (or Line 289  c     then this is not a DSP header (or
289  c     noise lurks around) so go a word ahead and  c     noise lurks around) so go a word ahead and
290  c     try again  c     try again
291  c--------------------------------------------------  c--------------------------------------------------
292        if(checkheader.eq.1) then        if(checkheader.eq.1) then  
293           call skipbyte(ffd)     !new search           curpos=curpos-(13*2)+1 !goes back 13 words, then half 16 bit word ahead
294           goto 9100           goto 9100
295        endif        endif
296          
297   200  continue   200  continue
298        end        end
299    
300  *.............................................................        *     **********************************************************
301    *     *                                                        *
302    *     *                                                        *
303    *     *                                                        *
304    *     *                                                        *
305    *     *                                                        *
306    *     **********************************************************
307    
308  *.............................................................              subroutine unpackcalibration(runerror,buffer,length_buffer,curpos,
309         $     startcrc,stopcrc,crctemp)
310    
       subroutine unpackcalibration(runerror,ffd)  
311  *.............................................................  *.............................................................
312  *     decode calibration data  *     decode calibration data
313  *     header + data(PED SIG BAD) + trailer  *     header + data(PED SIG BAD) + trailer
314  *............................................................  *............................................................
315        include '../commonyoda/commontracker.f'        include '../common/commontracker.f'
316        include '../commonyoda/dataformat.f'        include '../common/common_readraw.f'
317    
318        integer ffd               !input file descriptor        integer*1 crctemp
319          integer*1 crc_trail
320    
321        integer runerror          !readevent error flag        integer runerror          !readevent error flag
 c     buffer temporanei  
322        integer*2 templ(nstrips_ladder)        integer*2 templ(nstrips_ladder)
323        real*4 tempf(nstrips_ladder)        real*4 tempf(nstrips_ladder)
324                
325    
326    
327   12   format(z4)   12   format(z4)
328    
329  *-----------------------------------------------------------  *-----------------------------------------------------------
# Line 406  c     buffer temporanei Line 337  c     buffer temporanei
337        DSPnumber_cal = iand(header(1),z'000f')        DSPnumber_cal = iand(header(1),z'000f')
338        dataword = ior(ishft(iand(header(2),z'03ff')        dataword = ior(ishft(iand(header(2),z'03ff')
339       $     ,10),iand(header(3),z'03ff'))       $     ,10),iand(header(3),z'03ff'))
 c      calibrationnumber = ior(ishft(iand(header(4)  
 c     $     ,z'03ff'),10),iand(header(5),z'03ff'))  
340        calibrationnumber = iand(header(4),z'03ff')        calibrationnumber = iand(header(4),z'03ff')
341        nused_event = iand(header(5),z'03ff')        nused_event = iand(header(5),z'03ff')
342        ped_1 = iand(header(6),z'03ff')        ped_1 = iand(header(6),z'03ff')
# Line 424  c     $     ,z'03ff'),10),iand(header(5) Line 353  c     $     ,z'03ff'),10),iand(header(5)
353        nbad_3 = iand(header(14),z'03ff')        nbad_3 = iand(header(14),z'03ff')
354        ff = ishft(iand(header(15),z'0300'),-8)        ff = ishft(iand(header(15),z'0300'),-8)
355        checksum_cal = iand(header(15),z'00ff')        checksum_cal = iand(header(15),z'00ff')
   
       runerror=0  
       call readtrailer(trailer,runerror,ffd)  
 c$$$      do i=1,3  
 c$$$         write(*,12)trailer(i)  
 c$$$      enddo  
356  c-----------------------------------------------------------  c-----------------------------------------------------------
357  c     the checksum is a 8-bit word calculated as the  c     the checksum is a 8-bit word calculated as the
358  c     XOR of the 16-bit data words,  c     XOR of the 16-bit data words,
359  c     hence the XOR between the two halfs  c     hence the XOR between the two halfs
360  C----------------------------------------------------------  C----------------------------------------------------------
       do il=1,3                 !loop on ladders  
361    
362           call readped(tempf,runerror,ffd)        runerror=0
363    c$$$      
364    c$$$      print*,'-----------------------------------'
365    c$$$      print*,'unpackcalibration: readtrailer  --- ',
366    c$$$*     $     trailer,runerror,buffer,length_buffer,curpos,
367    c$$$     $     startcrc,stopcrc,crctemp  
368    c$$$      print*,'-----------------------------------'
369          call readtrailer(trailer,runerror,buffer,length_buffer,curpos,
370         $     startcrc,stopcrc,crctemp)
371          
372          crc_trail=iand(trailer(3),z'00ff')
373          
374    c$$$      print *,'@@@@@@@@@@@@@ ',crctemp,crc_trail
375    
376          if (crctemp.eq.crc_trail)then
377             crc_hcalib=0
378          else
379             crc_hcalib=1
380          endif
381          
382          do il=1,3                 !loop on ladders
383             startcrc=curpos
384             call readped(tempf,runerror,buffer,length_buffer,curpos)
385           do is=1,nstrips_ladder           do is=1,nstrips_ladder
386              iss=is+nstrips_ladder*(il-1)              iss=is+nstrips_ladder*(il-1)
387              DSPped_o(DSPnumber_cal,iss)=tempf(is)              DSPped_o(DSPnumber_cal,iss)=tempf(is)
 c            print*,il,iss,DSPped_o(DSPnumber,iss)  
 c            print *,DSPnumber_cal,iss,tempf(is)  
   
388           enddo           enddo
389            
390           call readsig(tempf,runerror,ffd)           call readsig(tempf,runerror,buffer,length_buffer,curpos)
391           do is=1,nstrips_ladder           do is=1,nstrips_ladder
392              iss=is+nstrips_ladder*(il-1)              iss=is+nstrips_ladder*(il-1)
393              DSPsig_o(DSPnumber_cal,iss)=tempf(is)              DSPsig_o(DSPnumber_cal,iss)=tempf(is)
 c            print*,DSPsig_o(DSPnumber,iss)  
394           enddo           enddo
395            
396           call readbad(templ,runerror,ffd)           call readbad(templ,runerror,buffer,length_buffer,curpos)
397           do is=1,nstrips_ladder           do is=1,nstrips_ladder
398              iss=is+nstrips_ladder*(il-1)              iss=is+nstrips_ladder*(il-1)
399              DSPbad_o(DSPnumber_cal,iss)=templ(is)              DSPbad_o(DSPnumber_cal,iss)=templ(is)
 c            print*,il,is,iss,DSPbad_o(DSPnumber,iss)  
400           enddo           enddo
401            
 C//// CAPIRE PERCHE` NON C'E` LA PAROLA DI FINE LADDER \\\\  
 c         call readeol(word,runerror,ffd)  
402   11      format(i1,'   ',z4)   11      format(i1,'   ',z4)
403  c         write(*,11)il,word          
404           call readtrailer(trailer,runerror,ffd)           call readtrailer(trailer,runerror,buffer,length_buffer,curpos,
405  c$$$         do i=1,3       $        startcrc,stopcrc,crctemp)
 c$$$            write(*,12)trailer(i)  
 c$$$         enddo  
406    
407  c     print*,'fine ladder' !???           crc_trail=iand(trailer(3),z'00ff')
408                    
409             if (crctemp.eq.crc_trail)then
410               crc_calib(il)=0
411             else
412               crc_calib(il)=1
413             endif
414              
415        enddo                     !end loop on ladders        enddo                     !end loop on ladders
416                
417        return        return
418        end        end
 *.............................................................        
419    
420    *     **********************************************************
421    *     *                                                        *
422    *     *                                                        *
423    *     *                                                        *
424    *     *                                                        *
425    *     *                                                        *
426    *     **********************************************************
427    
428          subroutine unpackdata(runerror,buffer,length_buffer,curpos,
429         $     startcrc,stopcrc,crctemp)
430    
       subroutine unpackdata(runerror,ffd)  
431  *.............................................................  *.............................................................
432  *     decode event data  *     decode event data
433  *     header + data + trailer  *     header + data + trailer
434  *............................................................  *............................................................
       include '../commonyoda/commontracker.f'  
       include '../commonyoda/dataformat.f'  
       include '../commonyoda/level0.f'  
435    
436        integer ffd               !input file descriptor        include '../common/commontracker.f'
437        integer runerror          !readevent error flag        include '../common/common_readraw.f'
438        integer l_tra        include '../common/level0.f'
439    
440        logical DEBUG,ALARMs        integer*1 crctemp
441        common/DEBUGflag/DEBUG,ALARMs        integer*1 crcdat
 c      data ALARMs/.false./  
442    
443          integer runerror          !readevent error flag
444    c      integer l_tra
445    
446        ALARMs = .false.        integer bid1_dat,bid2_dat,bid3_dat,bid4_dat,bid5_dat,bid6_dat
447         $     ,bid7_dat,bid_dat_sum
448          
449                
450   12   format(z4)   12   format(z4)
451    
# Line 507  c      data ALARMs/.false./ Line 456  c      data ALARMs/.false./
456        DAQmode_dat = ishft(iand(header(1),z'03f0'),-4)        DAQmode_dat = ishft(iand(header(1),z'03f0'),-4)
457        DSPnumber_dat = iand(header(1),z'000f')        DSPnumber_dat = iand(header(1),z'000f')
458  C     ------------------------------------------------------  C     ------------------------------------------------------
459  c     words 2 and 3 give tshe number of transmitted 16-bit  c     words 2 and 3 give the number of transmitted 16-bit
460  c     words ( 13 header words + data )  c     words ( 13 header words + data )
461  c     NB: data are packed from 13-bit to 16-bit words,  c     NB: data are packed from 13-bit to 16-bit words,
462  c     so the stream is complited with zeros in order to have  c     so the stream is complited with zeros in order to have
# Line 530  C     ---------------------------------- Line 479  C     ----------------------------------
479        signcluster_dat(3) = iand(header(12),z'03ff')        signcluster_dat(3) = iand(header(12),z'03ff')
480        fc_dat = ishft(iand(header(13),z'0300'),-8)        fc_dat = ishft(iand(header(13),z'0300'),-8)
481        compressiontime_dat = iand(header(13),z'00ff')        compressiontime_dat = iand(header(13),z'00ff')
482        fl5_dat = ishft(iand(header(14),z'0300'),-8)  c      fl5_dat = ishft(iand(header(14),z'0300'),-8)
483        fl4_dat = ishft(iand(header(14),z'0300'),-6)  c      fl4_dat = ishft(iand(header(14),z'0300'),-6)
484        fl3_dat = ishft(iand(header(14),z'0300'),-4)  c      fl3_dat = ishft(iand(header(14),z'0300'),-4)
485        fl2_dat = ishft(iand(header(14),z'0300'),-2)  c      fl2_dat = ishft(iand(header(14),z'0300'),-2)
486        fl1_dat = iand(header(14),z'0300')  c      fl1_dat = iand(header(14),z'0300')
487        fl6_dat = ishft(iand(header(15),z'0300'),-8)  c      fl6_dat = ishft(iand(header(15),z'0300'),-8)
488          fl5_dat = iand(ishft(header(14),-8),z'0003')
489          fl4_dat = iand(ishft(header(14),-6),z'0003')
490          fl3_dat = iand(ishft(header(14),-4),z'0003')
491          fl2_dat = iand(ishft(header(14),-2),z'0003')
492          fl1_dat = iand(header(14),z'0003')
493          fl6_dat = iand(ishft(header(15),-8),z'0003')
494        checksum_dat = iand(header(15),z'00ff')        checksum_dat = iand(header(15),z'00ff')
495    
       if(  
      $     fc_dat.ne.0.or.  
      $     fl1_dat.ne.0.or.  
      $     fl2_dat.ne.0.or.  
      $     fl3_dat.ne.0.or.  
      $     fl4_dat.ne.0.or.  
      $     fl5_dat.ne.0.or.  
      $     fl6_dat.ne.0.or.  
      $     .false.)ALARMs=.true.  
496  c-----------------------------------------------------------  c-----------------------------------------------------------
497  c     the cheacksum is a 8-bit word calculated as the  c     the cheacksum is a 8-bit word calculated as the
498  c     XOR of the 16-bit data words,  c     XOR of the 16-bit data words,
# Line 554  c     hence the XOR between the two half Line 500  c     hence the XOR between the two half
500  C----------------------------------------------------------  C----------------------------------------------------------
501        runerror=0        runerror=0
502        nqualcosa=0        nqualcosa=0
503        if(l_tra.eq.0)then  c      if(l_tra.eq.0)then
504           ALARMs=.true.        if(l_tra.le.0)then
505           goto 18                !empty buffer           goto 18                !empty buffer
506        endif        endif
507        call dunpacker(l_tra,b_tra,runerror,ffd)        
508        if(runerror.eq.1.or.runerror.eq.-1) then                          if(l_tra.gt.MAXBUFFLEN .or.(curpos+l_tra-1).ge.MAXBUFFLEN )then
509    c         print*,'unpackdata: '
510    c     $        ,'tracker buffer length l_tra ',l_tra
511    c     $        ,' exceeds tracker buffer dimensions '
512    c         print*,'(packet corrupted)'
513    cc         runerror=1
514             runerror=2
515             goto 50
516          endif
517          call dunpacker(l_tra,b_tra,runerror,buffer,length_buffer,curpos)
518          if(runerror.eq.1.or.runerror.eq.-1) then
519           goto 50                !go to end           goto 50                !go to end
520        endif        endif
521    
# Line 568  C--------------------------------------- Line 524  C---------------------------------------
524        if (xx.eq.0) nqualcosa=nqualcosa -1        if (xx.eq.0) nqualcosa=nqualcosa -1
525                
526   18   datalength_dat= nqualcosa   18   datalength_dat= nqualcosa
   
527   11   format(i1,'   ',z4)   11   format(i1,'   ',z4)
528        call readtrailer(trailer,runerror,ffd)      
529          call readtrailer(trailer,runerror,buffer,length_buffer,curpos,
530         $     startcrc,stopcrc,crctemp)
531                
532  ***************************************************************        ***************************************************************      
533  *                      TRAILER                                *  *                      TRAILER                                *
# Line 588  C--------------------------------------- Line 545  C---------------------------------------
545        alarm_dat=ishft(iand(trailer(2),z'0300'),-8)          alarm_dat=ishft(iand(trailer(2),z'0300'),-8)  
546        aswr_dat=ior(ishft(iand(trailer(2),z'00ff'),8)        aswr_dat=ior(ishft(iand(trailer(2),z'00ff'),8)
547       $      ,ishft(iand(trailer(3),z'ff00'),-8))       $      ,ishft(iand(trailer(3),z'ff00'),-8))
548        crc_dat=iand(trailer(3),z'00ff')        crcdat=iand(trailer(3),z'00ff')
549    
550        bid_dat_sum = (bid1_dat + bid2_dat + bid3_dat + bid4_dat +  c$$$      print*,'######################',crcdat,crctemp
      &     bid5_dat + bid6_dat + bid7_dat)  
551    
       bid_dat = bid_dat_sum/7  
552    
553        if ((bid_dat.ne.1.and.bid_dat.ne.2).or.        if(crcdat.eq.crctemp)then
554       $    (mod(bid_dat_sum,7).ne.0).or.           crc_dat=0
555       $     .false.) then        else
556           write(*,*) '*** *** *** *** *** *** *** *** *** *** *** ***'           crc_dat=1
          write(*,*) 'unpack_data: TRAILER PACKET CORRUPTED - BID '  
      $        ,bid_dat  
          write(*,*) '*** *** *** *** *** *** *** *** *** *** *** ***'  
          ALARMs=.true.  
557        endif        endif
558    
559                bid_dat_sum = (bid1_dat + bid2_dat + bid3_dat + bid4_dat +
560        if (alarm_dat.eq.3) then       &     bid5_dat + bid6_dat + bid7_dat)
          write(*,*) '*** *** *** *** *** *** *** *** *** *** ***'  
          write(*,*) 'unpack_data: TRAILER --- AQUISITION ALARM!!!'  
          write(*,*) '*** *** *** *** *** *** *** *** *** *** ***'      
          write(*,*) alarm_dat  
          ALARMs=.true.  
   
       endif  
         
       if (alarm_dat.ne.3.and.alarm_dat.ne.0) then  
          write(*,*) '*** *** *** *** *** *** *** *** *** *** *** *** **'  
          write(*,*) 'unpack_data: TRAILER PACKET CORRUPTED - ALARM '  
      $        ,alarm_dat  
          write(*,*) '*** *** *** *** *** *** *** *** *** *** *** *** **'          
          ALARMs=.true.  
       endif  
561    
562          bid_dat = bid_dat_sum/7
563                
564   50   return   50   return
565        end        end
566    
567    *     **********************************************************
568    *     *                                                        *
569    *     *                                                        *
570    *     *                                                        *
571    *     *                                                        *
572    *     *                                                        *
573    *     **********************************************************
574    
 *.............................................................................  
575        subroutine initlevel0        subroutine initlevel0
         
       include '../commonyoda/commontracker.f'  
       include '../commonyoda/level0.f'  
576    
577          include '../common/commontracker.f'
578          include '../common/level0.f'
579    
580          good0=0
581          TOTDATAlength = 0
582    
583        do i=1, nviews        do i=1, nviews
584                    
# Line 664  C--------------------------------------- Line 609  C---------------------------------------
609           bid(i) = 1           bid(i) = 1
610           alarm(i)= 0           alarm(i)= 0
611           aswr(i) = 0           aswr(i) = 0
612             crc(i)=0
613    
614        enddo        enddo
615    
       TOTDATAlength = 0  
       good0=.true.  
616    
617        return        return
618        end        end
619    
620    *     **********************************************************
621    *     *                                                        *
622    *     *                                                        *
623    *     *                                                        *
624    *     *                                                        *
625    *     *                                                        *
626    *     **********************************************************
627    
 *     *** *** *** *** *** *** *** *** ***  
 *  
 *  
 *  
 *  
 *  
 *  
 *     *** *** *** *** *** *** *** *** ***  
628        subroutine fillview(i)        subroutine fillview(i)
629  c     -----------------------------------------------------  c     -----------------------------------------------------
630  c     fill variables related to view i  c     fill variables related to view i
# Line 688  c     which will be stored in the level0 Line 632  c     which will be stored in the level0
632  c     at the end of loop on views  c     at the end of loop on views
633  c     ----------------------------------------------------  c     ----------------------------------------------------
634    
635        include '../commonyoda/commontracker.f'        include '../common/commontracker.f'
636        include '../commonyoda/level0.f'        include '../common/level0.f'
637        include '../commonyoda/dataformat.f'        include '../common/common_readraw.f'
638    
639    
640        DAQmode(i) = DAQmode_dat        DAQmode(i) = DAQmode_dat
641        DSPnumber(i) =  DSPnumber_dat        DSPnumber(i) =  DSPnumber_dat
# Line 714  c     ---------------------------------- Line 659  c     ----------------------------------
659        fl6(i) = fl6_dat        fl6(i) = fl6_dat
660        checksum(i) = checksum_dat        checksum(i) = checksum_dat
661        DATAlength(i) = datalength_dat        DATAlength(i) = datalength_dat
662          crc(i) = crc_dat
663    
664  c    -----------------------------------------------------------------------  c    -----------------------------------------------------------------------
665  c     filling TRAILER variables  c     filling TRAILER variables
# Line 734  c     ---------------------------------- Line 680  c     ----------------------------------
680        return        return
681        end        end
682    
683    *     **********************************************************
684    *     *                                                        *
685    *     *                                                        *
686    *     *                                                        *
687    *     *                                                        *
688    *     *                                                        *
689    *     **********************************************************
690    
691          subroutine fillview_cal(i)
692    c     -----------------------------------------------------
693    c     fill variables related to view i
694    c     which will be stored in the calibration nt-ple
695    c     at the end of loop on views
696    c     ----------------------------------------------------
697    
698          include '../common/commontracker.f'
699          include '../common/trk_calib_parameters.f'
700          include '../common/common_readraw.f'
701    
702          DAQmode(i)     = DAQmode_cal
703          DSPnumber(i)   = DSPnumber_cal
704          calibnumber(i) = calibrationnumber
705          ncalib_event(i)= nused_event
706          ped_l1(i)      = ped_1
707          ped_l2(i)      = ped_2
708          ped_l3(i)      = ped_3
709          sig_l1(i)      = sig_1
710          sig_l2(i)      = sig_2
711          sig_l3(i)      = sig_3
712          nbad_l1(i)     = nbad_1
713          nbad_l2(i)     = nbad_2
714          nbad_l3(i)     = nbad_3
715          cal_flag(i)    = ff
716    
717          do is=1,nstrips_view
718             DSPbad_par(i,is) = DSPbad_o(DSPnumber_cal,is)
719             DSPped_par(i,is) = DSPped_o(DSPnumber_cal,is)
720             DSPsig_par(i,is) = DSPsig_o(DSPnumber_cal,is)
721          enddo
722    
723          crc_hcal(i)    = crc_hcalib      
724          crc_cal(i,1)   = crc_calib(1)
725          crc_cal(i,2)   = crc_calib(2)
726          crc_cal(i,3)   = crc_calib(3)
727          
728          return
729          end
730    
731    *     **********************************************************
732    *     *                                                        *
733    *     *                                                        *
734    *     *                                                        *
735    *     *                                                        *
736    *     *                                                        *
737    *     **********************************************************
738    
739          subroutine initcalib
740          include '../common/commontracker.f'
741          include '../common/trk_calib_parameters.f'
742    
743          good0=0
744    
745          do i=1,nplanes
746    
747             DAQmode(i)     = 0
748             DSPnumber(i)   = 0
749             calibnumber(i) = 0
750             ncalib_event(i)= 0
751             ped_l1(i)      = 0
752             ped_l2(i)      = 0
753             ped_l3(i)      = 0
754             sig_l1(i)      = 0
755             sig_l2(i)      = 0
756             sig_l3(i)      = 0
757             nbad_l1(i)     = 0
758             nbad_l2(i)     = 0
759             nbad_l3(i)     = 0
760             cal_flag(i)    = 0
761            
762             do is=1,nstrips_view
763                DSPbad_par(i,is) = 0
764                DSPped_par(i,is) = 0
765                DSPsig_par(i,is) = 0
766             enddo
767             crc_hcal(i)    = 0
768             crc_cal(i,1)   = 0
769             crc_cal(i,2)   = 0
770             crc_cal(i,3)   = 0
771          enddo
772    
773          return
774          end

Legend:
Removed from v.5.0  
changed lines
  Added in v.6.5

  ViewVC Help
Powered by ViewVC 1.1.23