/[PAMELA software]/yoda/techmodel/forroutines/anticounter/AC.c
ViewVC logotype

Diff of /yoda/techmodel/forroutines/anticounter/AC.c

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

revision 2.2 by kusanagi, Fri Dec 3 22:08:07 2004 UTC revision 5.0 by kusanagi, Mon Aug 29 09:46:13 2005 UTC
# Line 1  Line 1 
1  /*******************************v1.0********************************  /*******************************v1.3********************************
2    
3  Functions to read AC physics data (ACphysics) and AC calibration  Functions to read AC physics data (ACphysics) and AC calibration
4  data (ACcalib).  data (ACcalib).
5  Author: Petter Hofverberg, petter@particle.kth.se  Author: Petter Hofverberg, petter@particle.kth.se
6    
7  0410 v1.0 alive  0410 v1.0 alive
8    0412 v1.1 fixed problem with found, and changed headers
9    0502 v1.2 added a crc check
10    0502 v1.3 increased buffer size
11    
12  Errors: (returned to the main program as the variable "err")  Errors: (returned to the main program as the variable "err")
13  err=  err=
# Line 13  err= Line 16  err=
16  0x0F - only data from extra card found  0x0F - only data from extra card found
17  0x00 - no data found  0x00 - no data found
18    
19    CRCcheck:  1 - OK, 0 - error
20  ******************************************************************/  ******************************************************************/
21    
22  #include <stdio.h>  #include <stdio.h>
23  #include "AC.h"  #include "AC.h"
24    #define TRUE 1
25    #define FALSE 0
26    
27  int i,found,j;  int i,j,found;
28  unsigned short buffer[1000];  unsigned short buffer[8300];
29  unsigned short tmp1,tmp2;  unsigned short tmp1,tmp2,check;
30  unsigned char err;  unsigned char err;
31    
32  struct physicsstruct physicsdata[2];  struct physicsstruct physicsdata[2];
33  struct physicsstruct *physicspointer;  struct physicsstruct *physicspointer;
34    
35  struct calibstruct calibdata[2];  struct calibstruct calibdata;
36  struct calibstruct *calibpointer;  struct calibstruct *calibpointer;
37    
38    
39    //CRC check function
40    short crc(short old,short new)
41    {
42      union crc_data {
43        short word;
44        struct bit_field {
45          unsigned b0:1;
46          unsigned b1:1;
47          unsigned b2:1;
48          unsigned b3:1;
49          unsigned b4:1;
50          unsigned b5:1;
51          unsigned b6:1;
52          unsigned b7:1;
53          unsigned b8:1;
54          unsigned b9:1;
55          unsigned b10:1;
56          unsigned b11:1;
57          unsigned b12:1;
58          unsigned b13:1;
59          unsigned b14:1;
60          unsigned b15:1;
61        } bit;
62      } c,d,r;
63    
64      c.word = old;
65      d.word = new;
66      r.word = 0;
67    
68      r.bit.b0 = c.bit.b0 ^ c.bit.b4 ^ c.bit.b8 ^ c.bit.b11 ^ c.bit.b12 ^
69                 d.bit.b0 ^ d.bit.b4 ^ d.bit.b8 ^ d.bit.b11 ^ d.bit.b12;
70    
71      r.bit.b1 = c.bit.b1 ^ c.bit.b5 ^ c.bit.b9 ^ c.bit.b12 ^ c.bit.b13 ^
72                 d.bit.b1 ^ d.bit.b5 ^ d.bit.b9 ^ d.bit.b12 ^ d.bit.b13;
73    
74      r.bit.b2 = c.bit.b2 ^ c.bit.b6 ^ c.bit.b10 ^ c.bit.b13 ^ c.bit.b14 ^
75                 d.bit.b2 ^ d.bit.b6 ^ d.bit.b10 ^ d.bit.b13 ^ d.bit.b14;
76    
77      r.bit.b3 = c.bit.b3 ^ c.bit.b7 ^ c.bit.b11 ^ c.bit.b14 ^ c.bit.b15 ^
78                 d.bit.b3 ^ d.bit.b7 ^ d.bit.b11 ^ d.bit.b14 ^ d.bit.b15;
79    
80      r.bit.b4 = c.bit.b4 ^ c.bit.b8 ^ c.bit.b12 ^ c.bit.b15 ^
81                 d.bit.b4 ^ d.bit.b8 ^ d.bit.b12 ^ d.bit.b15;
82    
83      r.bit.b5 = c.bit.b0 ^ c.bit.b4 ^ c.bit.b5 ^ c.bit.b8 ^ c.bit.b9 ^
84                 c.bit.b11 ^ c.bit.b12 ^ c.bit.b13 ^
85                 d.bit.b0 ^ d.bit.b4 ^ d.bit.b5 ^ d.bit.b8 ^ d.bit.b9 ^
86                 d.bit.b11 ^ d.bit.b12 ^ d.bit.b13;
87    
88      r.bit.b6 = c.bit.b1 ^ c.bit.b5 ^ c.bit.b6 ^ c.bit.b9 ^ c.bit.b10 ^
89                 c.bit.b12 ^ c.bit.b13 ^ c.bit.b14 ^
90                 d.bit.b1 ^ d.bit.b5 ^ d.bit.b6 ^ d.bit.b9 ^ d.bit.b10 ^
91                 d.bit.b12 ^ d.bit.b13 ^ d.bit.b14;
92    
93      r.bit.b7 = c.bit.b2 ^ c.bit.b6 ^ c.bit.b7 ^ c.bit.b10 ^ c.bit.b11 ^
94                 c.bit.b13 ^ c.bit.b14 ^ c.bit.b15 ^
95                 d.bit.b2 ^ d.bit.b6 ^ d.bit.b7 ^ d.bit.b10 ^ d.bit.b11 ^
96                 d.bit.b13 ^ d.bit.b14 ^ d.bit.b15;
97    
98      r.bit.b8 = c.bit.b3 ^ c.bit.b7 ^ c.bit.b8 ^ c.bit.b11 ^ c.bit.b12 ^
99                 c.bit.b14 ^ c.bit.b15 ^
100                 d.bit.b3 ^ d.bit.b7 ^ d.bit.b8 ^ d.bit.b11 ^ d.bit.b12 ^
101                 d.bit.b14 ^ d.bit.b15;
102    
103      r.bit.b9 = c.bit.b4 ^ c.bit.b8 ^ c.bit.b9 ^ c.bit.b12 ^ c.bit.b13 ^
104                 c.bit.b15 ^
105                 d.bit.b4 ^ d.bit.b8 ^ d.bit.b9 ^ d.bit.b12 ^ d.bit.b13 ^
106                 d.bit.b15;
107    
108      r.bit.b10 = c.bit.b5 ^ c.bit.b9 ^ c.bit.b10 ^ c.bit.b13 ^ c.bit.b14 ^
109                  d.bit.b5 ^ d.bit.b9 ^ d.bit.b10 ^ d.bit.b13 ^ d.bit.b14;
110    
111      r.bit.b11 = c.bit.b6 ^ c.bit.b10 ^ c.bit.b11 ^ c.bit.b14 ^ c.bit.b15 ^
112                  d.bit.b6 ^ d.bit.b10 ^ d.bit.b11 ^ d.bit.b14 ^ d.bit.b15;
113    
114      r.bit.b12 = c.bit.b0 ^ c.bit.b4 ^ c.bit.b7 ^ c.bit.b8 ^ c.bit.b15 ^
115                  d.bit.b0 ^ d.bit.b4 ^ d.bit.b7 ^ d.bit.b8 ^ d.bit.b15;
116    
117      r.bit.b13 = c.bit.b1 ^ c.bit.b5 ^ c.bit.b8 ^ c.bit.b9 ^
118                  d.bit.b1 ^ d.bit.b5 ^ d.bit.b8 ^ d.bit.b9;
119    
120      r.bit.b14 = c.bit.b2 ^ c.bit.b6 ^ c.bit.b9 ^ c.bit.b10 ^
121                  d.bit.b2 ^ d.bit.b6 ^ d.bit.b9 ^ d.bit.b10;
122    
123      r.bit.b15 = c.bit.b3 ^ c.bit.b7 ^ c.bit.b10 ^ c.bit.b11 ^
124                  d.bit.b3 ^ d.bit.b7 ^ d.bit.b10 ^ d.bit.b11;
125    
126      return r.word;
127    }
128    
129    
130    //Fill physicsdata from buffer
131    void fillphys(int k,unsigned short *buff)
132    {
133      for(i=0;i<2;i++) physicsdata[k].header[i]=buff[i];
134      physicsdata[k].status=buff[2];
135      physicsdata[k].hitmap=buff[3];
136      for(i=0;i<6;i++) physicsdata[k].regist[i]=buff[4+i];
137      for(i=0;i<16;i++) physicsdata[k].shift[i]=buff[10+i];
138      for(i=0;i<16;i++) physicsdata[k].counters[i]=buff[26+i];
139      for(i=0;i<8;i++) physicsdata[k].coinc[i]=buff[42+i];
140      physicsdata[k].trigg=buff[50];
141      for(i=0;i<2;i++) physicsdata[k].clock[i]=buff[51+i];
142      for(i=0;i<2;i++) physicsdata[k].temp[i]=buff[53+i];
143      for(i=0;i<8;i++) physicsdata[k].DAC[i]=buff[55+i];
144      physicsdata[k].CRC=buff[63];
145      if(check==physicsdata[k].CRC)
146        physicsdata[k].CRCcheck=TRUE;
147      else
148        physicsdata[k].CRCcheck=FALSE;
149    }
150    
151    //Fill calibdata from buffer
152    void fillcalib(unsigned short *buff)
153    {
154      for(i=0;i<2;i++) calibdata.header[i]=buff[i];
155      for(i=0;i<5;i++) calibdata.status[i]=buff[2+i];
156      for(i=0;i<8;i++) calibdata.temp[i]=buff[7+i];
157      for(i=0;i<8;i++) calibdata.DAC1[i]=buff[15+i];
158      for(i=0;i<8;i++) calibdata.DAC2[i]=buff[23+i];
159      for(i=0;i<6;i++) calibdata.regist[i]=buff[31+i];
160      for(i=0;i<8;i++) calibdata.time[i]=buff[37+i];
161      calibdata.n_tr=buff[45];
162      for(i=0;i<16;i++) calibdata.hitmap_tr[i]=buff[46+i];
163      for(i=0;i<4096;i++) calibdata.curve1[i]=buff[62+i];
164      for(i=0;i<4096;i++) calibdata.curve2[i]=buff[4158+i];
165      calibdata.iCRC=buff[8254];
166      calibdata.tail=buff[8255];
167      calibdata.CRC=buff[8256];
168      if(check==calibdata.CRC)
169        calibdata.CRCcheck=TRUE;
170      else
171        calibdata.CRCcheck=FALSE;
172    }
173    
174  unsigned char ACphysics(int length,unsigned char* datapointer,struct physicsstruct* physicspointer)  unsigned char ACphysics(int length,unsigned char* datapointer,struct physicsstruct* physicspointer)
175  {  {
176    
177   int iter=2;    err=0;
178    physicspointer[0]=physicsdata[0];    found=0;
179    physicspointer[1]=physicsdata[1];    check=0;
180      int iter=2;
181      for(i=0;i<8300;i++)
182        buffer[i]=0;
183      fillphys(0,&buffer[0]);
184      fillphys(1,&buffer[0]);
185    
186    //look for top header ACAC, then unpack data to main card buffer or extra card buffer depending on the subheader    //look for top header ACAC, then unpack data to main card buffer or extra card buffer depending on the subheader
187    //AC11 for main, AC22 for extra    //AC11 for main, AC22 for extra
# Line 44  unsigned char ACphysics(int length,unsig Line 189  unsigned char ACphysics(int length,unsig
189      {      {
190        tmp1 = ((*datapointer) << 8) | *(datapointer+1);        tmp1 = ((*datapointer) << 8) | *(datapointer+1);
191        tmp2 = ((*(datapointer+2)) << 8) | *(datapointer+3);        tmp2 = ((*(datapointer+2)) << 8) | *(datapointer+3);
192          if(tmp1 == 0xACAC && ((tmp2 == 0xAC11 && (err&0xF0)==0x0) || (tmp2 == 0xAC22 && (err&0x0F)==0x0)))
       if(tmp1 == 0xAC11 && ((tmp2 == 0xAC11 && (err&0xF0)==0x0) || (tmp2 == 0xAC22 && (err&0x0F)==0x0)))  
193          {          {
           
194            for(i=0;i<64;i++)            for(i=0;i<64;i++)
195              {              {
196                buffer[i]=((*datapointer) << 8) | *(datapointer+1);                buffer[i]=((*datapointer) << 8) | *(datapointer+1);
197                  if(i<63)
198                    check=crc(check,buffer[i]);
199                datapointer=datapointer+2;                datapointer=datapointer+2;
200              }              }
             
201            if(tmp2==0xAC11){          //main card            if(tmp2==0xAC11){          //main card
202              fillphys(0,&buffer[0]);              fillphys(0,&buffer[0]);
203              err |= 0xF0;              err |= 0xF0;
# Line 63  unsigned char ACphysics(int length,unsig Line 207  unsigned char ACphysics(int length,unsig
207              err |= 0x0F;              err |= 0x0F;
208            }            }
209            tmp1=tmp2=0x0000;            tmp1=tmp2=0x0000;
210              check=0x0;
211            found++;            found++;
212          }          }
213        else{        else{
214          datapointer++;          datapointer++;
215          iter=iter+1;}          iter=iter+1;}
216      }      }
217      //point struct-pointer to physicsdata
218      physicspointer[0]=physicsdata[0];  //card1
219      physicspointer[1]=physicsdata[1];  //card2
220    
221    return err;    return err;
222    
# Line 78  unsigned char ACphysics(int length,unsig Line 226  unsigned char ACphysics(int length,unsig
226  unsigned char ACcalib(int length, unsigned char* datapointer, struct calibstruct* calibpointer)  unsigned char ACcalib(int length, unsigned char* datapointer, struct calibstruct* calibpointer)
227  {  {
228    
229      err=0;
230      found=0;
231      check=0;
232    int iter=2;    int iter=2;
233                  for(i=0;i<8300;i++)
234    //point struct-pointer to calibdata      buffer[i]=0;
235    calibpointer[0]=calibdata[0];  //card1    fillcalib(&buffer[0]);
   calibpointer[1]=calibdata[1];  //card2  
236    
237    //look for the top header 0xACCA, then the subheaders 0xAC11 and 0xAC22, and unpack the data    //look for the top header 0xACCA, then the subheaders 0xAC11 and 0xAC22, and unpack the data
238    //to each card depending on these.    //to each card depending on these.
239    while(found<2 && iter<length)    while(found<1 && iter<length)
240      {      {
241        tmp1 = ((*datapointer) << 8) | *(datapointer+1);        tmp1 = ((*datapointer) << 8) | *(datapointer+1);
242        tmp2 = ((*(datapointer+2)) << 8) | *(datapointer+3);        tmp2 = ((*(datapointer+2)) << 8) | *(datapointer+3);
243          
244        if(tmp1 == 0xACCA && ((tmp2 == 0xAC11 && (err&0xF0)==0x0) || (tmp2 == 0xAC22 && (err&0x0F)==0x0)))        if(tmp1 == 0xACCA && ((tmp2 == 0xAC11 && (err&0xF0)==0x0) || (tmp2 == 0xACA2 && (err&0x0F)==0x0)))
245          {          {
246            for(i=0;i<8256;i++)            for(i=0;i<8257;i++)
247              {              {
248                buffer[i]=((*datapointer) << 8) | *(datapointer+1);                buffer[i]=((*datapointer) << 8) | *(datapointer+1);
249                  if(i<8256) //8257
250                    check=crc(check,buffer[i]);
251                datapointer=datapointer+2;                datapointer=datapointer+2;
252              }                }
253                      
254            if(tmp2==0xAC11){          //main            if(tmp2==0xAC11){          //main
255              fillcalib(0,&buffer[0]);              fillcalib(&buffer[0]);
256              err |= 0xF0;              err |= 0xF0;
257            }            }
258            else{                      //extra            else{                      //extra
259              fillcalib(1,&buffer[0]);              fillcalib(&buffer[0]);
260              err |= 0x0F;              err |= 0x0F;
261            }              }
262             tmp1=tmp2=0x0000;            tmp1=tmp2=0x0000;
263            found++;            found++;
264          }          }
265        else{        else{
266          datapointer++;          datapointer++;
267          iter=iter+1;}          iter=iter+1;}
268      }      }
269      memcpy(calibpointer,&calibdata,sizeof(calibdata));
270      
271    return err;    return err;
272  }  }
273    
 //Fill physicsdata from buffer  
 void fillphys(int k,unsigned short *buff)  
 {  
   for(i=0;i<2;i++) physicsdata[k].header[i]=buff[i];  
   physicsdata[k].status=buff[2];  
   physicsdata[k].hitmap=buff[3];  
   for(i=0;i<6;i++) physicsdata[k].regist[i]=buff[4+i];  
   for(i=0;i<16;i++) physicsdata[k].shift[i]=buff[10+i];  
   for(i=0;i<16;i++) physicsdata[k].counters[i]=buff[26+i];  
   for(i=0;i<8;i++) physicsdata[k].coinc[i]=buff[42+i];  
   physicsdata[k].trigg=buff[50];  
   for(i=0;i<2;i++) physicsdata[k].clock[i]=buff[51+i];  
   for(i=0;i<2;i++) physicsdata[k].temp[i]=buff[53+i];  
   for(i=0;i<8;i++) physicsdata[k].DAC[i]=buff[55+i];  
   physicsdata[k].CRC=buff[63];  
   
 }  
   
 //Fill calibdata from buffer  
 void fillcalib(int k,unsigned short *buff)  
 {  
   calibdata[k].header=buff[0];  
   for(i=0;i<5;i++) calibdata[k].status[i]=buff[1+i];  
   for(i=0;i<8;i++) calibdata[k].temp[i]=buff[6+i];  
   for(i=0;i<8;i++) calibdata[k].DAC1[i]=buff[14+i];  
   for(i=0;i<8;i++) calibdata[k].DAC2[i]=buff[22+i];  
   for(i=0;i<6;i++) calibdata[k].regist[i]=buff[30+i];  
   for(i=0;i<8;i++) calibdata[k].time[i]=buff[36+i];  
   calibdata[k].n_tr=buff[44];  
   for(i=0;i<16;i++) calibdata[k].hitmap_tr[i]=buff[45+i];  
   for(i=0;i<4096;i++) calibdata[k].curve1[i]=buff[61+i];  
   for(i=0;i<4096;i++) calibdata[k].curve2[i]=buff[4157+i];  
   calibdata[k].iCRC=buff[8253];  
   calibdata[k].tail=buff[8254];  
   calibdata[k].CRC=buff[8255];  
 }  

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

  ViewVC Help
Powered by ViewVC 1.1.23