##// END OF EJS Templates
Testing frame without semicolon.
imanay -
r103:104
parent child
Show More
@@ -1,459 +1,642
1 1 /* No newline at end of file
2 2 * Servidor.c No newline at end of file
3 3 * No newline at end of file
4 4 * Created on: Nov 3, 2009 No newline at end of file
5 5 * Author: Jose Francisco Quenta No newline at end of file
6 6 * No newline at end of file
7 7 * Se implementa: No newline at end of file
8 8 * -Carga en memoria los apuntes contenidos en un archivo de experimentos: apunte0 -> GPIO No newline at end of file
9 9 * -Cambio de apunte. No newline at end of file
10 10 * -Lectura del estado actual del apunte y grabado del mismo en un archivo No newline at end of file
11 11 */ No newline at end of file
12 12 No newline at end of file
13 13 #include <stdio.h> No newline at end of file
14 14 #include <stdlib.h> No newline at end of file
15 15 #include <string.h> No newline at end of file
16 16 #include <unistd.h> No newline at end of file
17 17 #include <errno.h> No newline at end of file
18 18 No newline at end of file
19 19 #include <sys/types.h> No newline at end of file
20 20 #include <sys/socket.h> No newline at end of file
21 21 #include <netinet/in.h> No newline at end of file
22 22 #include <arpa/inet.h> No newline at end of file
23 23 #include <netdb.h> No newline at end of file
24 24 No newline at end of file
25 25 #include "./Librerias/AT91gpio_Funciones.h" No newline at end of file
26 26 #include "./Librerias/Mensajes.h" No newline at end of file
27 27 No newline at end of file
28 28 #define PUERTO_SERVIDOR 5500 No newline at end of file
29 29 #define TAM_BUFFER 1024 No newline at end of file
30 30 No newline at end of file
31 31 #define maskc_out PC30+PC28+PC26+PC24+PC22+PC20 //MSB-UP-LSB MSB-DOWN-LSB //APUNTE No newline at end of file
32 32 No newline at end of file
33 33 #define maskb_in PB16+PB18+PB20+PB30+PB24+PB22 //MSB-UP-LSB MSB-DOWN-LSB //VERIFICACION No newline at end of file
34 34 No newline at end of file
35 35 #define bit_up_2 0x00010000 //Mascara de cada bit a revisar: bit_up_2 es MSB No newline at end of file
36 36 #define bit_up_1 0x00040000 No newline at end of file
37 37 #define bit_up_0 0x00100000 No newline at end of file
38 38 #define bit_dow_2 0x40000000 No newline at end of file
39 39 #define bit_dow_1 0x01000000 No newline at end of file
40 40 #define bit_dow_0 0x00400000 No newline at end of file
41 41 No newline at end of file
42 42 #define MyID 11 No newline at end of file
43 43 #define MAXPENDING 5 /* Maximum outstanding connection requests */ No newline at end of file
44 44 No newline at end of file
45 45 char *buff_experimento= NULL; No newline at end of file
46 46 No newline at end of file
47 47 AT91S_PIO *pioc; No newline at end of file
48 48 AT91S_PIO *piob; No newline at end of file
49 49 No newline at end of file
50 50 struct control_module_parameters { No newline at end of file
51 51 char ID[20]; No newline at end of file
52 52 char param2[20]; No newline at end of file
53 53 char param3[20]; No newline at end of file
54 54 char param4[20]; No newline at end of file
55 55 }; No newline at end of file
56 56 No newline at end of file
57 57 typedef struct control_module_parameters cmp; No newline at end of file
58 58 No newline at end of file
59
No newline at end of file
60 char *header = NULL;
No newline at end of file
61 char *TypeOfInstrument = NULL;
No newline at end of file
62 char *iDSource = NULL;
No newline at end of file
63 char *iDDestino = NULL;
No newline at end of file
64 char *len = NULL;
No newline at end of file
65 char *cmd = NULL;
No newline at end of file
66 char *rx_data = NULL;
No newline at end of file
67 char *crc = NULL;
No newline at end of file
68 No newline at end of file
59 69 cmp parameters; No newline at end of file
60 70 /* No newline at end of file
61 71 * Zona de declaracion de cabeceras. No newline at end of file
62 72 */ No newline at end of file
63 73 cmp inicializa_modulo(cmp p); No newline at end of file
64 74 int inicializa_ethernet(); No newline at end of file
65 75 int rxData(int, char*); No newline at end of file
66 76 void txData(int, char*); No newline at end of file
67 77 void inicializa_gpio(); No newline at end of file
68 78 void procesa_peticion(char *rx_buffer, char *tx_buffer); No newline at end of file
69 79 int cambia_apuntamiento(char *puntero_char); No newline at end of file
70 80 int carga_experimento(char *nombre_archivo);
81 No newline at end of file
71 int chequeo_sistema(char *filename, char *numero_muestras); No newline at end of file
No newline at end of file
82 int chequeo_sistema2(char *filename, char *numero_muestras); No newline at end of file
72 83 void recibe_experimento(char *data, char filename[]); No newline at end of file
73 84 char* File2buffer(char *filename2, int n); No newline at end of file
85 void SplitFrame(char *frame);
No newline at end of file
86 void procesa_peticion2(char *rx_buffer, char *tx_buffer); No newline at end of file
74 87 No newline at end of file
75 88 /* No newline at end of file
76 89 * No newline at end of file
77 90 */ No newline at end of file
78 91 int main(){ No newline at end of file
79 92 No newline at end of file
80 93 int servSocket; No newline at end of file
81 94 int clntSocket; No newline at end of file
82 95 No newline at end of file
83 96 No newline at end of file
84 97 char *rx_buffer = (char *) malloc(TAM_BUFFER); No newline at end of file
85 98 char *tx_buffer = (char *) malloc(TAM_BUFFER); No newline at end of file
86 99 /* Inicializa parametros del modulo*/ No newline at end of file
87 100 parameters = inicializa_modulo(parameters);
101 No newline at end of file
88 printf("%s%s%s%s",parameters.ID, parameters.param2, parameters.param3, parameters.param4); No newline at end of file
89 102 /* Inicializa red*/ No newline at end of file
90 103 servSocket = inicializa_ethernet(); No newline at end of file
91 104 /* Inicializamos el puerto GPIO del sistema embebido GSBC-9260S */ No newline at end of file
92 105 inicializa_gpio(); No newline at end of file
93 106 No newline at end of file
94 107 while(1){ No newline at end of file
95 108 // RecepciΓ³n TCP de peticiΓ³n No newline at end of file
96 109 clntSocket = rxData(servSocket, rx_buffer); No newline at end of file
97 110 //testpoint No newline at end of file
98 111 printf("rx:%s\n",rx_buffer); No newline at end of file
99 112 // Procesamiento de la peticiΓ³n No newline at end of file
100 113 procesa_peticion(rx_buffer, tx_buffer); No newline at end of file
101 114 //testpoint No newline at end of file
102 115 printf("tx:%s\n",tx_buffer); No newline at end of file
103 116 // Respuesta del modulo de control No newline at end of file
104 117 txData(clntSocket, tx_buffer); No newline at end of file
105 118 No newline at end of file
106 119 } No newline at end of file
107 120 } No newline at end of file
108 121 No newline at end of file
109 122 No newline at end of file
110 123 int inicializa_ethernet(){ No newline at end of file
111 124 No newline at end of file
112 125 struct sockaddr_in inf_servidor; No newline at end of file
113 126 No newline at end of file
114 127 int servSocket; No newline at end of file
115 128 No newline at end of file
116 129 int resultado; No newline at end of file
117 130 No newline at end of file
118 131 /* Haciendo la estructura local*/ No newline at end of file
119 132 memset(&inf_servidor, 0, sizeof(inf_servidor)); No newline at end of file
120 133 inf_servidor.sin_family= AF_INET; No newline at end of file
121 134 inf_servidor.sin_port= htons(PUERTO_SERVIDOR); No newline at end of file
122 135 inf_servidor.sin_addr.s_addr= INADDR_ANY; No newline at end of file
123 136 No newline at end of file
124 137 /* Se establece el socket */ No newline at end of file
125 138 servSocket = socket(AF_INET,SOCK_STREAM, IPPROTO_TCP); No newline at end of file
126 139 if (servSocket == -1){ No newline at end of file
127 140 ERROR_FATAL("No se establecio correctamente el socket: socket()\n"); No newline at end of file
128 141 exit(-1); No newline at end of file
129 142 } No newline at end of file
130 143 No newline at end of file
131 144 /* Se asocia el socket a un puerto y una IP */ No newline at end of file
132 145 resultado = bind(servSocket,(struct sockaddr *)&inf_servidor,sizeof(inf_servidor)); No newline at end of file
133 146 if (resultado== -1){ No newline at end of file
134 147 ERROR_FATAL("No se establecio correctamente el socket: bind()\n"); No newline at end of file
135 148 exit(-1); No newline at end of file
136 149 } No newline at end of file
137 150 No newline at end of file
138 151 if (listen(servSocket, MAXPENDING) < 0){ No newline at end of file
139 152 printf("listen() failed\n"); No newline at end of file
140 153 exit(-1); No newline at end of file
141 154 } No newline at end of file
142 155 No newline at end of file
143 156 return servSocket; No newline at end of file
144 157 No newline at end of file
145 158 } No newline at end of file
146 159 No newline at end of file
147 160 int rxData(int servSocket, char* rx_buffer){ No newline at end of file
148 161 No newline at end of file
149 162 int clntSocket; No newline at end of file
150 163 struct sockaddr_in inf_cliente; No newline at end of file
151 164 int numbytes_recibidos; No newline at end of file
152 165 unsigned int inf_client_Len; No newline at end of file
153 166 No newline at end of file
154 167 printf("\nEsperando solicitud de cliente...\n"); No newline at end of file
155 168 No newline at end of file
156 169 /* Set the size of the in-out parameter */ No newline at end of file
157 170 inf_client_Len = sizeof(inf_cliente); No newline at end of file
158 171 /* Se espera hasta que un cliente se conecte */ No newline at end of file
159 172 if ((clntSocket = accept(servSocket, (struct sockaddr *) &inf_cliente, No newline at end of file
160 173 &inf_client_Len)) < 0) No newline at end of file
161 174 printf("accept() failed\n"); No newline at end of file
162 175 No newline at end of file
163 176 if ((numbytes_recibidos = recv(clntSocket, rx_buffer, TAM_BUFFER, 0)) < 0) No newline at end of file
164 177 printf("recv() failed\n"); No newline at end of file
165 178 No newline at end of file
166 179 /* Se procede a procesar los datos recibidos */ No newline at end of file
167 180 rx_buffer[numbytes_recibidos]= '\0'; No newline at end of file
168 181 No newline at end of file
169 182 return clntSocket; No newline at end of file
170 183 } No newline at end of file
171 184 No newline at end of file
172 185 void txData(int clntSocket, char* data){ No newline at end of file
173 186 No newline at end of file
174 187 /* Echo message back to client */ No newline at end of file
175 188 if (send(clntSocket, data, strlen(data), 0) != strlen(data)) No newline at end of file
176 189 printf("send() failed\n"); No newline at end of file
177 190 No newline at end of file
178 191 close(clntSocket); /* Close client socket */ No newline at end of file
179 192 } No newline at end of file
180 193 /* No newline at end of file
181 194 * Esta funcion incializa el puerto GPIO No newline at end of file
182 195 */ No newline at end of file
183 196 void inicializa_gpio(){ No newline at end of file
184 197 No newline at end of file
185 198 // Configuracion de los pines de APUNTE No newline at end of file
186 199 pioc = pio_map(PIOC_BASE); No newline at end of file
187 200 pio_enable(pioc, maskc_out); No newline at end of file
188 201 pio_disable_irq(pioc, maskc_out); No newline at end of file
189 202 pio_disable_multiple_driver(pioc, maskc_out); No newline at end of file
190 203 pio_disable_pull_ups(pioc, maskc_out); No newline at end of file
191 204 pio_synchronous_data_output(pioc, maskc_out); No newline at end of file
192 205 pio_output_enable(pioc, maskc_out); No newline at end of file
193 206 No newline at end of file
194 207 // Configuracion de los pines de VERIFICACION No newline at end of file
195 208 piob = pio_map(PIOB_BASE); No newline at end of file
196 209 pio_enable(piob, maskb_in); No newline at end of file
197 210 pio_disable_irq(piob, maskb_in); No newline at end of file
198 211 pio_disable_multiple_driver(piob, maskb_in); No newline at end of file
199 212 pio_disable_pull_ups(piob, maskb_in); No newline at end of file
200 213 pio_input_enable(piob, maskb_in); No newline at end of file
201 214 No newline at end of file
202 215 } No newline at end of file
203 216 No newline at end of file
204 217 /* No newline at end of file
205 218 * Esta funcion procesa el mensaje de peticion y genera respuesta No newline at end of file
206 219 */
220 No newline at end of file
207 void procesa_peticion(char *rx_buffer, char *tx_buffer){ No newline at end of file
208 221 int n = 0; No newline at end of file
209 222 char filename1[50]; No newline at end of file
210 223 char filename2[] = "verificacion.txt"; No newline at end of file
211 224 char *tx_data = NULL; No newline at end of file
212 225 char *header = strtok(rx_buffer, ":"); No newline at end of file
213 226 char *TypeOfInstrument = strtok(NULL, ":"); No newline at end of file
214 227 char *iDSource = strtok(NULL, ":"); No newline at end of file
215 228 char *iDDestino = strtok(NULL, ":"); No newline at end of file
216 229 char *len = strtok(NULL, ":"); No newline at end of file
217 230 char *cmd = strtok(NULL, ":"); No newline at end of file
218 231 char *rx_data = strtok(NULL, ":"); No newline at end of file
219 232 char *crc = strtok(NULL, ":"); No newline at end of file
220 233 No newline at end of file
221 234 if ((cmd == NULL) || (rx_data == NULL)){ No newline at end of file
222 235 ERROR("procesarPeticion: formato de mensaje incorrecto"); No newline at end of file
223 236 } No newline at end of file
224 237 else{ No newline at end of file
225 238 if(strcmp(cmd,"SNDF") == 0){ No newline at end of file
226 239 recibe_experimento(rx_data,filename1); No newline at end of file
227 240 carga_experimento(filename1); No newline at end of file
228 241 cambia_apuntamiento("0"); No newline at end of file
229 242 tx_data = (char*)malloc(3); No newline at end of file
230 243 tx_data = "OK"; No newline at end of file
231 244 } No newline at end of file
232 245 else if(strcmp(cmd,"CHGB") == 0){ No newline at end of file
233 246 cambia_apuntamiento(rx_data); No newline at end of file
234 247 tx_data = (char*)malloc(3); No newline at end of file
235 248 tx_data = "OK"; No newline at end of file
236 249 No newline at end of file
237 250 } No newline at end of file
238 251 No newline at end of file
239 252 else if(strcmp(cmd,"ANST") == 0){
253 No newline at end of file
240 n = chequeo_sistema(filename2,rx_data); No newline at end of file
241 254 printf("%i\n",n); No newline at end of file
242 255 tx_data = File2buffer(filename2, n); No newline at end of file
243 256 } No newline at end of file
244 257 else{ No newline at end of file
245 258 tx_data = (char*)malloc(6); No newline at end of file
246 259 tx_data = "Error"; No newline at end of file
247 260 ERROR("procesa_peticion: comando no reconocido"); No newline at end of file
248 261 } No newline at end of file
249 262 No newline at end of file
250 263 strcpy(tx_buffer,header); No newline at end of file
251 264 strcat(tx_buffer,":"); No newline at end of file
252 265 strcat(tx_buffer,TypeOfInstrument); No newline at end of file
253 266 strcat(tx_buffer,":"); No newline at end of file
254 267 strcat(tx_buffer,iDDestino); No newline at end of file
255 268 strcat(tx_buffer,":"); No newline at end of file
256 269 strcat(tx_buffer,iDSource); No newline at end of file
257 270 strcat(tx_buffer,":"); No newline at end of file
258 271 strcat(tx_buffer,len); No newline at end of file
259 272 strcat(tx_buffer,":"); No newline at end of file
260 273 strcat(tx_buffer,cmd); No newline at end of file
261 274 strcat(tx_buffer,":"); No newline at end of file
262 275 strcat(tx_buffer,tx_data); No newline at end of file
263 276 strcat(tx_buffer,":"); No newline at end of file
264 277 strcat(tx_buffer,crc); No newline at end of file
265 278 strcat(tx_buffer,":"); No newline at end of file
266 279 strcat(tx_buffer,"quit"); No newline at end of file
280 }
No newline at end of file
281 }
No newline at end of file
282
No newline at end of file
283 void SplitFrame(char *frame){
No newline at end of file
284 header = malloc(4);
No newline at end of file
285 *header = *frame;
No newline at end of file
286 *(header + 1) = *(frame + 1);
No newline at end of file
287 *(header + 2) = *(frame + 2);
No newline at end of file
288 *(header + 3) = '\0';
No newline at end of file
289 TypeOfInstrument = malloc(4);
No newline at end of file
290 *TypeOfInstrument = *(frame + 3);
No newline at end of file
291 *(TypeOfInstrument + 1) = *(frame + 4);
No newline at end of file
292 *(TypeOfInstrument + 2) = *(frame + 5);
No newline at end of file
293 *(TypeOfInstrument + 3) = '\0';
No newline at end of file
294 iDSource = malloc(8);
No newline at end of file
295 *iDSource = *(frame + 6);
No newline at end of file
296 *(iDSource + 1) = *(frame + 7);
No newline at end of file
297 *(iDSource + 2) = *(frame + 8);
No newline at end of file
298 *(iDSource + 3) = *(frame + 9);
No newline at end of file
299 *(iDSource + 4) = *(frame + 10);
No newline at end of file
300 *(iDSource + 5) = *(frame + 11);
No newline at end of file
301 *(iDSource + 6) = *(frame + 12);
No newline at end of file
302 *(iDSource + 7) = '\0';
No newline at end of file
303 iDDestino = malloc(8);
No newline at end of file
304 *iDDestino = *(frame + 13);
No newline at end of file
305 *(iDDestino + 1) = *(frame + 14);
No newline at end of file
306 *(iDDestino + 2) = *(frame + 15);
No newline at end of file
307 *(iDDestino + 3) = *(frame + 16);
No newline at end of file
308 *(iDDestino + 4) = *(frame + 17);
No newline at end of file
309 *(iDDestino + 5) = *(frame + 18);
No newline at end of file
310 *(iDDestino + 6) = *(frame + 19);
No newline at end of file
311 *(iDDestino + 7) = '\0';
No newline at end of file
312 len = malloc(7);
No newline at end of file
313 *len = *(frame + 20);
No newline at end of file
314 *(len + 1) = *(frame + 21);
No newline at end of file
315 *(len + 2) = *(frame + 22);
No newline at end of file
316 *(len + 3) = *(frame + 23);
No newline at end of file
317 *(len + 4) = *(frame + 24);
No newline at end of file
318 *(len + 5) = *(frame + 25);
No newline at end of file
319 *(len + 6) = '\0';
No newline at end of file
320 cmd = malloc(5);
No newline at end of file
321 *cmd = *(frame + 26);
No newline at end of file
322 *(cmd + 1) = *(frame + 27);
No newline at end of file
323 *(cmd + 2) = *(frame + 28);
No newline at end of file
324 *(cmd + 3) = *(frame + 29);
No newline at end of file
325 *(cmd + 4) = '\0';
No newline at end of file
326
No newline at end of file
327 int l = atoi(len) - 31; //Resto del tamaΓ±o total de la trama los 31 bytes fijos
No newline at end of file
328 rx_data = malloc(l);
No newline at end of file
329 int i;
No newline at end of file
330 for (i = 30; i < 30 + l; i++)
No newline at end of file
331 *(rx_data + (i-30)) = *(frame + i);
No newline at end of file
332 *(rx_data + l) = '\0';
No newline at end of file
333 crc = malloc(2);
No newline at end of file
334 *crc = *(frame + 30 + l);
No newline at end of file
335 *(crc + 1) = '\0';
No newline at end of file
336 }
No newline at end of file
337
No newline at end of file
338 void procesa_peticion(char *rx_buffer, char *tx_buffer){
No newline at end of file
339 // int n = 0;
No newline at end of file
340 char filename1[50];
No newline at end of file
341 char filename2[] = "verificacion.txt";
No newline at end of file
342 char *tx_data = NULL;
No newline at end of file
343 SplitFrame(rx_buffer);
No newline at end of file
344 printf("Split\n");
No newline at end of file
345 printf("%s\n",header);
No newline at end of file
346 printf("%s\n",TypeOfInstrument);
No newline at end of file
347 printf("%s\n",iDSource);
No newline at end of file
348 printf("%s\n",iDDestino);
No newline at end of file
349 printf("%s\n",len);
No newline at end of file
350 printf("%s\n",cmd);
No newline at end of file
351 printf("%s\n",rx_data);
No newline at end of file
352 printf("%s\n",crc);
No newline at end of file
353 printf("Split\n");
No newline at end of file
354
No newline at end of file
355 if ((cmd == NULL) || (rx_data == NULL)){
No newline at end of file
356 ERROR("procesarPeticion: formato de mensaje incorrecto");
No newline at end of file
357 }
No newline at end of file
358 else{
No newline at end of file
359 if(strcmp(cmd,"SNDF") == 0){
No newline at end of file
360 recibe_experimento(rx_data,filename1);
No newline at end of file
361 carga_experimento(filename1);
No newline at end of file
362 cambia_apuntamiento("0");
No newline at end of file
363 tx_data = (char*)malloc(3);
No newline at end of file
364 tx_data = "OK";
No newline at end of file
365 }
No newline at end of file
366 else if(strcmp(cmd,"CHGB") == 0){
No newline at end of file
367 cambia_apuntamiento(rx_data);
No newline at end of file
368 tx_data = (char*)malloc(3);
No newline at end of file
369 tx_data = "OK";
No newline at end of file
370
No newline at end of file
371 }
No newline at end of file
372
No newline at end of file
373 else if(strcmp(cmd,"ANST") == 0){
No newline at end of file
374 /*n = chequeo_sistema(filename2,rx_data);
No newline at end of file
375 printf("%i\n",n);
No newline at end of file
376 tx_data = File2buffer(filename2, n);*/
No newline at end of file
377 tx_data = chequeo_sistema(filename2,rx_data);
No newline at end of file
378 printf("%s\n",tx_data);
No newline at end of file
379 }
No newline at end of file
380 else{
No newline at end of file
381 tx_data = (char*)malloc(6);
No newline at end of file
382 tx_data = "Error";
No newline at end of file
383 ERROR("procesa_peticion: comando no reconocido");
No newline at end of file
384 }
No newline at end of file
385
No newline at end of file
386 strcpy(tx_buffer,header); //3
No newline at end of file
387 strcat(tx_buffer,TypeOfInstrument); //3
No newline at end of file
388 strcat(tx_buffer,parameters.ID); //7
No newline at end of file
389 strcat(tx_buffer,iDSource); //7
No newline at end of file
390 strcat(tx_buffer,"00032"); //5
No newline at end of file
391 strcat(tx_buffer,cmd); //4
No newline at end of file
392 strcat(tx_buffer,tx_data); //2
No newline at end of file
393 strcat(tx_buffer,crc); //1 No newline at end of file
267 394 No newline at end of file
268 395 } No newline at end of file
269 396 No newline at end of file
270 397 } No newline at end of file
271 398 No newline at end of file
272 399 /* No newline at end of file
273 400 * Esta funciΓ³n genera el archivo de experimento a partir de la trama TCP recibida No newline at end of file
274 401 */ No newline at end of file
275 402 No newline at end of file
276 403 void recibe_experimento(char *p_data, char filename[]){ No newline at end of file
277 404 FILE *fd; No newline at end of file
278 405 int i = 0; No newline at end of file
279 406 No newline at end of file
280 407 while (*p_data != '\n'){ No newline at end of file
281 408 filename[i] = *p_data; No newline at end of file
282 409 i++; No newline at end of file
283 410 p_data++; No newline at end of file
284 411 } No newline at end of file
285 412 filename[i] = '\0'; No newline at end of file
286 413 p_data = p_data - i; No newline at end of file
287 414 fd = fopen(filename,"w"); No newline at end of file
288 415 fprintf(fd, p_data); No newline at end of file
289 416 fclose(fd); No newline at end of file
290 417 } No newline at end of file
291 418 No newline at end of file
292 419 /* No newline at end of file
293 420 * Esta funcion carga un archivo en un buffer que esta ubicado en memoria, luego No newline at end of file
294 421 * este buffer es usado en la funcion "cambia_apuntamiento" para obtener el dato No newline at end of file
295 422 * que sera usado en el cambio de apuntamiento. No newline at end of file
296 423 */ No newline at end of file
297 424 int carga_experimento(char *nombre_archivo){ No newline at end of file
298 425 No newline at end of file
299 426 FILE *Archivo_Fd; No newline at end of file
300 427 No newline at end of file
301 428 char *cadena = (char *) malloc(25); No newline at end of file
302 429 No newline at end of file
303 430 int longitud_cadena; No newline at end of file
304 431 int num_bytes= 0; No newline at end of file
305 432 int num_filas= 0; No newline at end of file
306 433 No newline at end of file
307 434 Archivo_Fd = fopen(nombre_archivo,"r"); // Se procede a abrir el archivo, segun la ruta especificada No newline at end of file
308 435 if(!Archivo_Fd){ No newline at end of file
309 436 ERROR("carga_archivo: No se pudo abrir el archivo!!! --> fopen()\n"); No newline at end of file
310 437 return -1; No newline at end of file
311 438 }else{ No newline at end of file
312 439 No newline at end of file
313 440 while(!feof(Archivo_Fd)){ // Se procede a calcular la longitud del archivo para separar memoria No newline at end of file
314 441 fgets(cadena,20,Archivo_Fd); No newline at end of file
315 442 longitud_cadena= strlen(cadena); No newline at end of file
316 443 cadena[longitud_cadena-1] = '\0'; No newline at end of file
317 444 num_bytes = num_bytes + longitud_cadena; No newline at end of file
318 445 num_filas++; No newline at end of file
319 446 } No newline at end of file
320 447 No newline at end of file
321 448 rewind(Archivo_Fd); // Se reinicia el puntero del archivo No newline at end of file
322 449 No newline at end of file
323 450 char *buffer_temporal = (char *) malloc(num_bytes+1); // Se separa espacio de memoria segun No newline at end of file
324 451 // la longitud del archivo No newline at end of file
325 452 fread(buffer_temporal, sizeof(char), num_bytes, Archivo_Fd); No newline at end of file
326 453 No newline at end of file
327 454 char *puntero= strstr(buffer_temporal,".ab1"); // Se procede a eliminar la cabecera del archivo No newline at end of file
328 455 puntero= puntero + 12; No newline at end of file
329 456 No newline at end of file
330 457 buff_experimento = (char *) malloc(7*(num_filas-3)); // num_bytes_fila*(num_filas-3); No newline at end of file
331 458 strncpy(buff_experimento,puntero,7*(num_filas-3)); // Se carga en memoria la informacion del archivo No newline at end of file
332 459 No newline at end of file
333 460 fclose(Archivo_Fd); No newline at end of file
334 461 No newline at end of file
335 462 return 1; No newline at end of file
336 463 } No newline at end of file
337 464 } No newline at end of file
338 465 No newline at end of file
339 466 /* No newline at end of file
340 467 * Esta funcion recibe un numero en formato char, el dato se transforma a su equivalente en No newline at end of file
341 468 * un numero entero, que sera usado para sacar un dato del buffer "buff_experimento", esta No newline at end of file
342 469 * dato es el valor que se enviara al sistema de conmutacion RF para el cambio de apunte a No newline at end of file
343 470 * traves del puerto GPIO. No newline at end of file
344 471 */ No newline at end of file
345 472 int cambia_apuntamiento(char *puntero_char){ No newline at end of file
346 473 No newline at end of file
347 474 /*MSB-UP-LSB MSB-DOWN-LSB*/ No newline at end of file
348 475 int desplazamiento[6]={30,28,26,24,22,20}; // Defino los dezplazamientos que se aplicara No newline at end of file
349 476 // al dato que ingresa para formar el nΓΊmero No newline at end of file
350 477 // entero que se le pasara al puerto GPIO No newline at end of file
351 478 // Estos nΓΊmeros son los pines del puerto GPIO No newline at end of file
352 479 // que se estan usando para el control No newline at end of file
353 480 No newline at end of file
354 481 int puntero= atoi(puntero_char); // Se convierte a entero la direccion del puntero No newline at end of file
355 482 No newline at end of file
356 483 int base= 7*puntero; // base= cantidad_bytes del dato x puntero No newline at end of file
357 484 // cantidad de bytes es el numero de bytes que No newline at end of file
358 485 printf("%s\n",puntero_char); // contiene cada dato, para este caso es 7 No newline at end of file
359 486 // porque es 6 bits de datos + 1 bit del cambio No newline at end of file
360 487 // de linea. No newline at end of file
361 488 char valor_char; No newline at end of file
362 489 unsigned long valor; No newline at end of file
363 490 unsigned long acumulado_ceros=0; No newline at end of file
364 491 unsigned long acumulado_unos=0; No newline at end of file
365 492 No newline at end of file
366 493 int offset; // Defino offset para el desplazamiento a traves No newline at end of file
367 494 for(offset=0;offset<6;offset++){ // de cada dato que se obtiene del "buff_experimento" No newline at end of file
368 495 No newline at end of file
369 496 valor_char= buff_experimento[base+offset]; // Obtengo el dato No newline at end of file
370 497 No newline at end of file
371 498 if (valor_char == '0'){ // Obtengo el nΓΊmero acumulado segun sea un cero o un uno No newline at end of file
372 499 valor= 0; No newline at end of file
373 500 acumulado_ceros= acumulado_ceros + (1 << desplazamiento[offset]); No newline at end of file
374 501 }else{ No newline at end of file
375 502 valor= 1; No newline at end of file
376 503 acumulado_unos= acumulado_unos + (1 << desplazamiento[offset]); No newline at end of file
377 504 } No newline at end of file
378 505 } No newline at end of file
379 506 pio_out(pioc, maskc_out, acumulado_unos, 1); No newline at end of file
380 507 pio_out(pioc, maskc_out, acumulado_ceros, 0); No newline at end of file
381 508 No newline at end of file
382 509 return 1; No newline at end of file
383 510 No newline at end of file
384 511 } No newline at end of file
385 512 No newline at end of file
386 513 /* No newline at end of file
387 514 * Esta funcion lee "n" veces el estado del APUNTE actual y lo guarda en el No newline at end of file
388 515 * archivo Verificacion. No newline at end of file
389 516 */ No newline at end of file
390 517
518 No newline at end of file
391 int chequeo_sistema(char *filename, char *numero_muestras){ No newline at end of file
392 519 No newline at end of file
393 520 char valor[7]; No newline at end of file
394 521 int i,cnt; No newline at end of file
395 522 unsigned int entradac= 0; No newline at end of file
396 523 FILE *fd; No newline at end of file
397 524 fd=fopen(filename,"w"); No newline at end of file
398 525 fprintf(fd,"%s\n","Verificacion");
526 No newline at end of file
399 fprintf(fd,"%s",parameters.ID); No newline at end of file
400 527 fprintf(fd,"%s\n","------------"); No newline at end of file
401 528 cnt=0; No newline at end of file
402 529 do No newline at end of file
403 530 { No newline at end of file
404 531 //Inicializando arreglo No newline at end of file
405 532 for(i=0;i<6;i++) No newline at end of file
406 533 valor[i]='0'; No newline at end of file
407 534 No newline at end of file
408 535 valor[6]='\0'; No newline at end of file
409 536 No newline at end of file
410 537 //Lectura de puerto No newline at end of file
411 538 entradac= pio_in(piob,maskb_in); No newline at end of file
412 539 No newline at end of file
413 540 //Dandole formato al dato No newline at end of file
414 541 if (!(entradac & bit_up_2)) No newline at end of file
415 542 valor[0] = '1'; No newline at end of file
416 543 if (!(entradac & bit_up_1)) No newline at end of file
417 544 valor[1] = '1'; No newline at end of file
418 545 if (!(entradac & bit_up_0)) No newline at end of file
419 546 valor[2] = '1'; No newline at end of file
420 547 if (!(entradac & bit_dow_2)) No newline at end of file
421 548 valor[3] = '1'; No newline at end of file
422 549 if (!(entradac & bit_dow_1)) No newline at end of file
423 550 valor[4] = '1'; No newline at end of file
424 551 if (!(entradac & bit_dow_0)) No newline at end of file
425 552 valor[5] = '1'; No newline at end of file
426 553 No newline at end of file
427 554 //Escribiendo en archivo No newline at end of file
428 555 fprintf(fd,"%s\n",valor); No newline at end of file
429 556 cnt=cnt+1; No newline at end of file
430 557 usleep(1*1000*1000); No newline at end of file
431 558 No newline at end of file
432 559 }while(cnt < atoi(numero_muestras)); No newline at end of file
433 560 No newline at end of file
434 561 fclose(fd); No newline at end of file
435 562 No newline at end of file
436 563 return 7*atoi(numero_muestras) + 26 + 4 + 1; //incluye eof No newline at end of file
437 564 } No newline at end of file
438 565 No newline at end of file
439 566 char* File2buffer(char *filename, int n){ No newline at end of file
440 567 FILE *fd; No newline at end of file
441 568 char* tx_data = (char *)malloc(n); No newline at end of file
442 569 fd = fopen(filename,"r"); No newline at end of file
443 570 fread(tx_data, 1, n-1, fd); No newline at end of file
444 571 fclose(fd); No newline at end of file
445 572 tx_data = tx_data + n - 1; No newline at end of file
446 573 *tx_data = '\0'; No newline at end of file
447 574 tx_data = tx_data - n + 1; No newline at end of file
448 575 return tx_data; No newline at end of file
449 576 } No newline at end of file
450 577 No newline at end of file
578 /*
No newline at end of file
579 * Esta funcion lee "n" veces el estado del APUNTE actual y reporta
No newline at end of file
580 * una cadena de Verificacion.
No newline at end of file
581 */
No newline at end of file
582 char* chequeo_sistema(char *filename, char *numero_muestras){
No newline at end of file
583
No newline at end of file
584 int i;
No newline at end of file
585 int cnt = 0;
No newline at end of file
586 unsigned int entradac= 0;
No newline at end of file
587
No newline at end of file
588 char page0[250];
No newline at end of file
589
No newline at end of file
590 strcpy(page0,"Verificacion\n");
No newline at end of file
591 strcat(page0,parameters.ID);
No newline at end of file
592 strcat(page0,"\n------------\n");
No newline at end of file
593
No newline at end of file
594 char page1[8];
No newline at end of file
595
No newline at end of file
596 do{
No newline at end of file
597 //Inicializando arreglo
No newline at end of file
598 for(i=0;i<6;i++)
No newline at end of file
599 page1[i]='0';
No newline at end of file
600 page1[6] = '\n';
No newline at end of file
601 page1[7] = '\0';
No newline at end of file
602 //Lectura de puerto
No newline at end of file
603 entradac= pio_in(piob,maskb_in);
No newline at end of file
604 //Dandole formato al dato
No newline at end of file
605 if (!(entradac & bit_up_2))
No newline at end of file
606 page1[0] = '1';
No newline at end of file
607 if (!(entradac & bit_up_1))
No newline at end of file
608 page1[1] = '1';
No newline at end of file
609 if (!(entradac & bit_up_0))
No newline at end of file
610 page1[2] = '1';
No newline at end of file
611 if (!(entradac & bit_dow_2))
No newline at end of file
612 page1[3] = '1';
No newline at end of file
613 if (!(entradac & bit_dow_1))
No newline at end of file
614 page1[4] = '1';
No newline at end of file
615 if (!(entradac & bit_dow_0))
No newline at end of file
616 page1[5] = '1';
No newline at end of file
617
No newline at end of file
618 strcat(page0, page1);
No newline at end of file
619 cnt=cnt+1;
No newline at end of file
620 usleep(1*1000*1000);
No newline at end of file
621
No newline at end of file
622 }while(cnt < atoi(numero_muestras));
No newline at end of file
623
No newline at end of file
624 page0[strlen(page0)] = '\0';
No newline at end of file
625
No newline at end of file
626 char *all_pages = malloc(strlen(page0)+1);
No newline at end of file
627 strcpy(all_pages, page0);
No newline at end of file
628 return all_pages;
No newline at end of file
629 } No newline at end of file
451 630 cmp inicializa_modulo(cmp p){ No newline at end of file
452 631 FILE *fd = fopen("configuration.txt","r"); No newline at end of file
453 632 fgets(p.ID,20,fd); No newline at end of file
633 p.ID[7]='\0'; No newline at end of file
454 634 fgets(p.param2,20,fd); No newline at end of file
635 p.param2[10]='\0'; No newline at end of file
455 636 fgets(p.param3,20,fd); No newline at end of file
637 p.param3[10]='\0'; No newline at end of file
456 638 fgets(p.param4,20,fd); No newline at end of file
639 p.param4[10]='\0'; No newline at end of file
457 640 fclose(fd); No newline at end of file
458 641 return p; No newline at end of file
459 642 } No newline at end of file
General Comments 0
You need to be logged in to leave comments. Login now