FreeCalypso > hg > fc-tourmaline
comparison src/gpf/tst/drv/mux_pei.c @ 0:4e78acac3d88
src/{condat,cs,gpf,nucleus}: import from Selenite
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Fri, 16 Oct 2020 06:23:26 +0000 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
-1:000000000000 | 0:4e78acac3d88 |
---|---|
1 /* | |
2 +------------------------------------------------------------------------------ | |
3 | File: mux_pei.c | |
4 +------------------------------------------------------------------------------ | |
5 | Copyright 2002 Texas Instruments Berlin, AG | |
6 | All rights reserved. | |
7 | | |
8 | This file is confidential and a trade secret of Texas | |
9 | Instruments Berlin, AG | |
10 | The receipt of or possession of this file does not convey | |
11 | any rights to reproduce or disclose its contents or to | |
12 | manufacture, use, or sell anything it may describe, in | |
13 | whole, or in part, without the specific written consent of | |
14 | Texas Instruments Berlin, AG. | |
15 +----------------------------------------------------------------------------- | |
16 | Purpose : This module implements the process body interface | |
17 | for the entity mux (used by tst for multiplexer driver). | |
18 +----------------------------------------------------------------------------- | |
19 */ | |
20 | |
21 #ifndef MUX_PEI_C | |
22 #define MUX_PEI_C | |
23 #endif | |
24 | |
25 #ifndef ENTITY_MUX | |
26 #define ENTITY_MUX | |
27 #endif | |
28 | |
29 #define ENTITY_UART /* test only */ | |
30 | |
31 /*==== INCLUDES =============================================================*/ | |
32 | |
33 | |
34 #include "stdlib.h" | |
35 #include <stdio.h> | |
36 #include "string.h" | |
37 #include "typedefs.h" | |
38 | |
39 #include "tools.h" | |
40 #include "os.h" | |
41 #include "gdi.h" | |
42 #include "vsi.h" | |
43 #include "glob_defs.h" | |
44 #include "frame.h" | |
45 #include "prim.h" /* to get the definitions of used SAP and directions */ | |
46 #include "gsm.h" | |
47 #include "pei.h" | |
48 #include "route.h" | |
49 #include "dti.h" /* functionality of the dti library */ | |
50 #include "mux.h" /* to get the global entity definitions */ | |
51 | |
52 /*==== CONSTS ================================================================*/ | |
53 | |
54 #undef VSI_CALLER | |
55 #define VSI_CALLER m_handle, | |
56 | |
57 /* | |
58 * Wait as long as possible. This is the time in ms that is waited for a | |
59 * message in the input queue in the active variant. | |
60 * It can be decreased by the customer. | |
61 */ | |
62 #define MUX_TIMEOUT 0xffffffff | |
63 | |
64 /*==== TYPES =================================================================*/ | |
65 | |
66 typedef struct | |
67 { | |
68 char *version; | |
69 } T_MONITOR; | |
70 | |
71 /*==== GLOBAL VARIABLES ======================================================*/ | |
72 /*==== LOCALS ================================================================*/ | |
73 | |
74 static int m_first = 1; | |
75 static T_MONITOR m_mon; | |
76 | |
77 static int m_uart_ready = 0; | |
78 | |
79 static T_desc2 * m_send_data=NULL; | |
80 static USHORT m_send_len=0; | |
81 | |
82 T_HANDLE m_handle; | |
83 T_DRV_SIGNAL m_signal; | |
84 | |
85 GLOBAL DTI_HANDLE mtst_hDTI; /* handle for DTI library */ | |
86 T_QMSG QueueMsg; | |
87 /*==== EXTERNAL DEFINED FUNCTIONS ==========================================*/ | |
88 | |
89 /*==== PRIMITIVE HANDLER FUNCTIONS ==========================================*/ | |
90 | |
91 static void primitive_not_supported (T_PRIM_HEADER *data); | |
92 static void dti_data_req (T_DTI2_DATA_REQ *ptr); | |
93 | |
94 /* | |
95 * Jumptables to primitive handler functions. One table per SAP. | |
96 * | |
97 * Use MAK_FUNC_0 for primitives which contains no SDU. | |
98 * Use MAK_FUNC_S for primitives which contains a SDU. | |
99 */ | |
100 | |
101 LOCAL const T_FUNC dti_ul_table[] = { | |
102 MAK_FUNC_0( primitive_not_supported , DTI2_CONNECT_REQ ), /* 3700x */ | |
103 MAK_FUNC_0( primitive_not_supported , DTI2_CONNECT_RES ), /* 3701x */ | |
104 MAK_FUNC_0( primitive_not_supported , DTI2_DISCONNECT_REQ ), /* 3702x */ | |
105 MAK_FUNC_0( primitive_not_supported , DTI2_GETDATA_REQ ), /* 3703x */ | |
106 MAK_FUNC_0( dti_data_req , DTI2_DATA_REQ ) /* 3704x */ | |
107 #if defined (_SIMULATION_) | |
108 , | |
109 MAK_FUNC_S( primitive_not_supported , DTI2_DATA_TEST_REQ ) | |
110 #endif /* _SIMULATION_ */ | |
111 }; | |
112 | |
113 LOCAL const T_FUNC dti_dl_table[] = { | |
114 MAK_FUNC_0( pei_dti_dti_connect_ind , DTI2_CONNECT_IND ), /* 7700x */ | |
115 MAK_FUNC_0( pei_dti_dti_connect_cnf , DTI2_CONNECT_CNF ), /* 7701x */ | |
116 MAK_FUNC_0( pei_dti_dti_disconnect_ind , DTI2_DISCONNECT_IND ), /* 7702x */ | |
117 MAK_FUNC_0( pei_dti_dti_ready_ind , DTI2_READY_IND ), /* 7703x */ | |
118 MAK_FUNC_0( pei_dti_dti_data_ind , DTI2_DATA_IND ) /* 7704x */ | |
119 #if defined (_SIMULATION_) | |
120 , | |
121 MAK_FUNC_S( pei_dti_dti_data_test_ind , DTI2_DATA_TEST_IND ) | |
122 #endif /* _SIMULATION_ */ | |
123 }; | |
124 | |
125 | |
126 /*==== PRIVATE FUNCTIONS ====================================================*/ | |
127 | |
128 /* | |
129 +------------------------------------------------------------------------------ | |
130 | Function : primitive_not_supported | |
131 +------------------------------------------------------------------------------ | |
132 | Description : This function handles unsupported primitives. | |
133 | | |
134 | Parameters : data - not used | |
135 | | |
136 | Return : void | |
137 +------------------------------------------------------------------------------ | |
138 */ | |
139 static void primitive_not_supported (T_PRIM_HEADER *data) | |
140 { | |
141 //TRACE_FUNCTION ("primitive_not_supported"); | |
142 | |
143 PFREE (data); | |
144 } | |
145 | |
146 /* | |
147 +------------------------------------------------------------------------------ | |
148 | Function : pei_primitive | |
149 +------------------------------------------------------------------------------ | |
150 | Description : Process protocol specific primitive. | |
151 | | |
152 | Parameters : prim - pointer to the received primitive | |
153 | | |
154 | Return : PEI_OK - function succeeded | |
155 | PEI_ERROR - function failed | |
156 +------------------------------------------------------------------------------ | |
157 | |
158 | | | |
159 TST UART UPLINK | |
160 | | | |
161 +------v-----------v-------+ | |
162 | | | |
163 | MUX | | |
164 | | | |
165 +-------------^------------+ | |
166 | | |
167 UART DOWNLINK | |
168 | | |
169 | |
170 */ | |
171 static short pei_primitive (void *ptr) | |
172 { | |
173 /* | |
174 * the following line of code causes a warning on tms470 compiler, that cannot be avoided | |
175 * without changing the PEI interface. Warning will not cause a problem | |
176 */ | |
177 T_PRIM * prim=(T_PRIM*)ptr; | |
178 | |
179 //TRACE_FUNCTION ("pei_primitive"); | |
180 | |
181 if (prim != NULL) | |
182 { | |
183 unsigned short opc = (unsigned short)prim->custom.opc; | |
184 unsigned short n; | |
185 const T_FUNC *table; | |
186 | |
187 /* | |
188 * This must be called for Partition Pool supervision. Will be replaced | |
189 * by another macro some time. | |
190 */ | |
191 VSI_PPM_REC (&prim->custom, __FILE__, __LINE__); | |
192 | |
193 //PTRACE_IN (opc); | |
194 | |
195 switch (opc & OPC_MASK) | |
196 { | |
197 case DTI_DL: /* defined in prim.h */ | |
198 table = dti_dl_table; | |
199 n = TAB_SIZE (dti_dl_table); | |
200 /* | |
201 * to be able to distinguish DTI1/DTI2 opcodes, | |
202 * the ones for DTI2 start at 0x50 | |
203 */ | |
204 opc -= 0x50; | |
205 break; | |
206 case DTI_UL: /* defined in prim.h */ | |
207 table = dti_ul_table; | |
208 n = TAB_SIZE (dti_ul_table); | |
209 /* | |
210 * to be able to distinguish DTI1/DTI2 opcodes, | |
211 * the ones for DTI2 start at 0x50 | |
212 */ | |
213 opc -= 0x50; | |
214 break; | |
215 default: | |
216 table = NULL; | |
217 n = 0; | |
218 break; | |
219 } | |
220 | |
221 if (table != NULL) | |
222 { | |
223 if ((opc & PRM_MASK) < n) | |
224 { | |
225 table += opc & PRM_MASK; | |
226 P_SDU(prim) = table->soff ? | |
227 (T_sdu*) (((char*)&prim->data) + table->soff) : 0; | |
228 P_LEN(prim) = table->size + sizeof (T_PRIM_HEADER); | |
229 JUMP (table->func) (P2D(prim)); | |
230 } | |
231 else | |
232 { | |
233 primitive_not_supported (P2D(prim)); | |
234 } | |
235 return PEI_OK; | |
236 } | |
237 | |
238 /* | |
239 * primitive is not a GSM primitive - forward it to the environment | |
240 */ | |
241 if (opc & SYS_MASK) | |
242 vsi_c_primitive (VSI_CALLER prim); | |
243 else | |
244 { | |
245 PFREE (P2D(prim)); | |
246 return PEI_ERROR; | |
247 } | |
248 } | |
249 return PEI_OK; | |
250 } | |
251 | |
252 /* | |
253 +------------------------------------------------------------------------------ | |
254 | Function : pei_init | |
255 +------------------------------------------------------------------------------ | |
256 | Description : Initialize Protocol Stack Entity | |
257 | | |
258 | Parameters : handle - task handle | |
259 | | |
260 | Return : PEI_OK - entity initialised | |
261 | PEI_ERROR - entity not (yet) initialised | |
262 +------------------------------------------------------------------------------ | |
263 */ | |
264 static short pei_init (T_HANDLE handle) | |
265 { | |
266 /* Initialize task handle */ | |
267 m_handle = handle; | |
268 mux_data.dti_state = CLOSED; | |
269 | |
270 /* | |
271 * initialize dtilib for this entity | |
272 */ | |
273 mtst_hDTI = dti_init( | |
274 1, /* max simultaneous connections */ | |
275 handle, | |
276 DTI_NO_TRACE, | |
277 pei_sig_callback | |
278 ); | |
279 if(!mtst_hDTI) | |
280 return PEI_ERROR; | |
281 | |
282 /* set no suspend for us and TST */ | |
283 vsi_trcsuspend ( VSI_CALLER vsi_c_open (0,"MTST"), 0); | |
284 vsi_trcsuspend ( VSI_CALLER vsi_c_open (0,"TST"), 0); | |
285 | |
286 return (PEI_OK); | |
287 } | |
288 | |
289 /* | |
290 +------------------------------------------------------------------------------ | |
291 | Function : pei_timeout | |
292 +------------------------------------------------------------------------------ | |
293 | Description : Process timeout. | |
294 | | |
295 | Parameters : index - timer index | |
296 | | |
297 | Return : PEI_OK - timeout processed | |
298 | PEI_ERROR - timeout not processed | |
299 +------------------------------------------------------------------------------ | |
300 */ | |
301 static short pei_timeout (unsigned short index) | |
302 { | |
303 //TRACE_FUNCTION ("pei_timeout"); | |
304 | |
305 /* Process timeout */ | |
306 switch (index) | |
307 { | |
308 case 0: | |
309 /* Call of timeout routine */ | |
310 break; | |
311 default: | |
312 //TRACE_ERROR("Unknown Timeout"); | |
313 return PEI_ERROR; | |
314 } | |
315 | |
316 return PEI_OK; | |
317 } | |
318 | |
319 /* | |
320 +------------------------------------------------------------------------------ | |
321 | Function : pei_signal | |
322 +------------------------------------------------------------------------------ | |
323 | Description : Process signal. | |
324 | | |
325 | Parameters : opc - signal operation code | |
326 | data - pointer to primitive | |
327 | | |
328 | Return : PEI_OK - signal processed | |
329 | PEI_ERROR - signal not processed | |
330 +------------------------------------------------------------------------------ | |
331 */ | |
332 static short pei_signal (unsigned long opc, void* data) | |
333 { | |
334 //TRACE_FUNCTION ("pei_signal"); | |
335 | |
336 /* Process signal */ | |
337 switch (opc) | |
338 { | |
339 default: | |
340 //TRACE_ERROR("Unknown Signal OPC"); | |
341 return PEI_ERROR; | |
342 } | |
343 | |
344 return PEI_OK; | |
345 } | |
346 | |
347 /* | |
348 +------------------------------------------------------------------------------ | |
349 | Function : pei_exit | |
350 +------------------------------------------------------------------------------ | |
351 | Description : Close Resources and terminate. | |
352 | | |
353 | Parameters : - | |
354 | | |
355 | Return : PEI_OK - exit sucessful | |
356 +------------------------------------------------------------------------------ | |
357 */ | |
358 static short pei_exit (void) | |
359 { | |
360 //TRACE_FUNCTION ("pei_exit"); | |
361 | |
362 /* | |
363 * Close communication channels | |
364 */ | |
365 | |
366 if (mux_data.dti_state NEQ CLOSED) | |
367 { | |
368 dti_close | |
369 ( | |
370 mtst_hDTI, | |
371 MTST_DTI_DN_INSTANCE, | |
372 MTST_DTI_DN_INTERFACE, | |
373 MTST_DTI_DN_CHANNEL, | |
374 FALSE | |
375 ); | |
376 mux_data.dti_state = CLOSED; | |
377 } | |
378 | |
379 /* | |
380 * Shut down dtilib | |
381 */ | |
382 dti_deinit(mtst_hDTI); | |
383 | |
384 return PEI_OK; | |
385 } | |
386 | |
387 | |
388 /* for test only - begin */ | |
389 #define MTST_TRACE 0x4f20 | |
390 typedef struct { | |
391 char str[80]; | |
392 } T_MTST_TRACE; | |
393 | |
394 void trace_aci(const char* str) | |
395 { | |
396 PALLOC(ptr,MTST_TRACE); | |
397 strcpy(ptr->str,str); | |
398 | |
399 PSEND(vsi_c_open(VSI_CALLER "MMI"), ptr); | |
400 } | |
401 /* for test only - end */ | |
402 | |
403 /* | |
404 +------------------------------------------------------------------------------ | |
405 | Function : pei_config | |
406 +------------------------------------------------------------------------------ | |
407 | Description : Dynamic Configuration. | |
408 | | |
409 | Parameters : Buffer - configuration string ( | |
410 | to start: "<DTI-partner> <tui> <c_id>" | |
411 | to stop: "STOP") | |
412 | | |
413 | Return : PEI_OK - sucessful | |
414 | PEI_ERROR - not successful | |
415 +------------------------------------------------------------------------------ | |
416 */ | |
417 static short pei_config (char *Buffer) | |
418 { | |
419 char token [10]; | |
420 char peer_name [10]; | |
421 | |
422 USHORT len; | |
423 | |
424 ULONG link_id; | |
425 | |
426 //TRACE_FUNCTION ("pei_config"); | |
427 //TRACE_FUNCTION (Buffer); | |
428 | |
429 if ( ConfigTimer ( VSI_CALLER Buffer, NULL ) == VSI_OK ) | |
430 return PEI_OK; | |
431 | |
432 /* | |
433 * further dynamic configuration | |
434 */ | |
435 | |
436 /* interprete configuration string */ | |
437 if (!(len = GetNextToken (Buffer, token, " #"))) | |
438 { | |
439 return DRV_INVALID_PARAMS; | |
440 } | |
441 else | |
442 { | |
443 Buffer += (len+1); | |
444 } | |
445 if (strcmp(token,"STOP")==0) | |
446 { | |
447 dti_close | |
448 ( | |
449 mtst_hDTI, | |
450 MTST_DTI_DN_INSTANCE, | |
451 MTST_DTI_DN_INTERFACE, | |
452 MTST_DTI_DN_CHANNEL, | |
453 FALSE | |
454 ); | |
455 mux_data.dti_state=CLOSED; | |
456 mux_data.h_comm_mtst=VSI_ERROR; | |
457 m_uart_ready=0; | |
458 if (mux_data.send_data_buf_count>0) { | |
459 /* clear send_buffer */ | |
460 T_desc2 *d_new; | |
461 T_desc2 *d=m_send_data; | |
462 while (d) | |
463 { | |
464 d_new=(T_desc2 *)d->next; | |
465 MFREE(d); | |
466 d=d_new; | |
467 } | |
468 | |
469 mux_data.send_data_buf_count=0; | |
470 } | |
471 | |
472 return PEI_OK; | |
473 } | |
474 strcpy(peer_name, token); | |
475 | |
476 if (!(len = GetNextToken (Buffer, token, " #"))) | |
477 { | |
478 return DRV_INVALID_PARAMS; | |
479 } | |
480 else | |
481 { | |
482 Buffer += (len+1); | |
483 } | |
484 link_id=atoi(token); | |
485 | |
486 if( | |
487 dti_open ( | |
488 mtst_hDTI, | |
489 MTST_DTI_DN_INSTANCE, | |
490 MTST_DTI_DN_INTERFACE, | |
491 MTST_DTI_DN_CHANNEL, | |
492 0, | |
493 DTI_CHANNEL_TO_LOWER_LAYER, | |
494 DTI_QUEUE_UNUSED, | |
495 DTI_VERSION_10, | |
496 (U8*)peer_name, | |
497 link_id | |
498 ) EQ FALSE) | |
499 return DRV_INVALID_PARAMS; | |
500 | |
501 /* reset send_data_buf counter */ | |
502 mux_data.send_data_buf_count=0; | |
503 | |
504 /* set internal communication handle */ | |
505 while ( (mux_data.h_comm_mtst=vsi_c_open (0, "MTST")) == VSI_ERROR) | |
506 { | |
507 vsi_t_sleep(0,100); | |
508 }; | |
509 | |
510 /* inform UART that we are ready to receive next data package */ | |
511 { | |
512 dti_start | |
513 ( | |
514 mtst_hDTI, | |
515 MTST_DTI_DN_INSTANCE, | |
516 MTST_DTI_DN_INTERFACE, | |
517 MTST_DTI_DN_CHANNEL | |
518 ); | |
519 } | |
520 | |
521 return PEI_OK; | |
522 } | |
523 | |
524 /* | |
525 +------------------------------------------------------------------------------ | |
526 | Function : pei_monitor | |
527 +------------------------------------------------------------------------------ | |
528 | Description : Monitoring of physical Parameters. | |
529 | | |
530 | Parameters : out_monitor - return the address of the data to be monitored | |
531 | | |
532 | Return : PEI_OK - sucessful (address in out_monitor is valid) | |
533 | PEI_ERROR - not successful | |
534 +------------------------------------------------------------------------------ | |
535 */ | |
536 static short pei_monitor (void ** out_monitor) | |
537 { | |
538 //TRACE_FUNCTION ("pei_monitor"); | |
539 | |
540 /* | |
541 * Version = "0.S" (S = Step). | |
542 */ | |
543 m_mon.version = "MTST 1.0"; | |
544 *out_monitor = &m_mon; | |
545 | |
546 return PEI_OK; | |
547 } | |
548 | |
549 /*==== PUBLIC FUNCTIONS =====================================================*/ | |
550 | |
551 /* | |
552 +------------------------------------------------------------------------------ | |
553 | Function : pei_create | |
554 +------------------------------------------------------------------------------ | |
555 | Description : Create the Protocol Stack Entity. | |
556 | | |
557 | Parameters : info - Pointer to the structure of entity parameters | |
558 | | |
559 | Return : PEI_OK - entity created successfully | |
560 | | |
561 +------------------------------------------------------------------------------ | |
562 */ | |
563 SHORT pei_create (T_PEI_INFO const **info) | |
564 { | |
565 static T_PEI_INFO pei_info = | |
566 { | |
567 "MTST", /* name */ | |
568 { /* pei-table */ | |
569 pei_init, | |
570 pei_exit, | |
571 pei_primitive, | |
572 pei_timeout, | |
573 pei_signal, | |
574 0, | |
575 pei_config, | |
576 pei_monitor | |
577 }, | |
578 1024, /* stack size */ | |
579 10, /* queue entries */ | |
580 100, /* priority (1->low, 255->high) */ | |
581 0, /* number of timers */ | |
582 PASSIVE_BODY|COPY_BY_REF|TRC_NO_SUSPEND | |
583 /* flags: bit 0 active(0) body/passive(1) */ | |
584 }; /* bit 1 com by copy(0)/reference(1) */ | |
585 | |
586 //TRACE_FUNCTION ("pei_create"); | |
587 | |
588 /* | |
589 * Close Resources if open | |
590 */ | |
591 if (!m_first) | |
592 { | |
593 pei_exit(); | |
594 } | |
595 | |
596 m_first=0; | |
597 | |
598 /* | |
599 * Export startup configuration data | |
600 */ | |
601 *info = &pei_info; | |
602 | |
603 return PEI_OK; | |
604 } | |
605 /***********+++++-----------------+++++++*******++----++**********/ | |
606 | |
607 /* | |
608 +------------------------------------------------------------------------------ | |
609 | Function : sig_dti_pei_tx_buffer_ready_ind | |
610 +------------------------------------------------------------------------------ | |
611 | Description : sent from UART to indicate that it is ready to | |
612 | receive new data via DTI_DATA_REQ | |
613 | | |
614 | Parameters : | |
615 | | |
616 | Return : | |
617 | | |
618 +------------------------------------------------------------------------------ | |
619 */ | |
620 GLOBAL const void sig_dti_pei_tx_buffer_ready_ind () | |
621 { | |
622 m_uart_ready++; | |
623 } | |
624 | |
625 /***********+++++-----------------+++++++*******++----++**********/ | |
626 | |
627 /* | |
628 +------------------------------------------------------------------------------ | |
629 | Function : dti_data_req | |
630 +------------------------------------------------------------------------------ | |
631 | Description : sent from TST to deliver new data to MTST | |
632 | | |
633 | Parameters : ptr - Pointer to the structure of the primitive | |
634 | | |
635 | Return : | |
636 | | |
637 +------------------------------------------------------------------------------ | |
638 */ | |
639 static void dti_data_req (T_DTI2_DATA_REQ *ptr) | |
640 { | |
641 T_desc2 *d=0; | |
642 | |
643 /* PPASS without traces */ | |
644 T_DTI2_DATA_IND *prim = (T_DTI2_DATA_IND*)ptr; | |
645 D_OPC(prim) = (DTI2_DATA_IND); | |
646 | |
647 if (!m_uart_ready) | |
648 { | |
649 if (mux_data.send_data_buf_count > MAX_SEND_BUF_COUNT-2) | |
650 { | |
651 /* free data */ | |
652 T_desc2 *d_new; | |
653 T_desc2 *d=(T_desc2 *)prim->desc_list2.first; | |
654 while (d) | |
655 { | |
656 d_new=(T_desc2 *)d->next; | |
657 MFREE(d); | |
658 d=d_new; | |
659 } | |
660 | |
661 if (mux_data.send_data_buf_count == MAX_SEND_BUF_COUNT) | |
662 { | |
663 /* buffer full -> free prim and exit */ | |
664 PFREE(prim); | |
665 return; | |
666 } | |
667 else | |
668 { | |
669 /* buffer almost full -> send SYST information */ | |
670 char infostr[]="\x02T0036001FMTSTPCO ERROR: SEND-BUFFER FULL\x0a"; | |
671 USHORT len=sizeof(infostr)-1; | |
672 MALLOC(d,(USHORT)(sizeof(T_desc2)+len-1)); | |
673 prim->desc_list2.first=(ULONG)d; | |
674 prim->desc_list2.list_len=len; | |
675 d->next = 0; | |
676 d->len = len; | |
677 d->size = len; | |
678 d->offset = 0; | |
679 memcpy(d->buffer,infostr,len); | |
680 } | |
681 } | |
682 | |
683 if (m_send_data) | |
684 { | |
685 /* find last send_data descriptor */ | |
686 d=m_send_data; | |
687 while (d->next) | |
688 { | |
689 d=(T_desc2 *)d->next; | |
690 } | |
691 /* concat new data */ | |
692 d->next=prim->desc_list2.first; | |
693 m_send_len+=prim->desc_list2.list_len; | |
694 } | |
695 else | |
696 { | |
697 m_send_data=(T_desc2 *)prim->desc_list2.first; | |
698 d=m_send_data; | |
699 while (d) | |
700 { | |
701 m_send_len+=d->len; | |
702 d=(T_desc2 *)d->next; | |
703 } | |
704 } | |
705 mux_data.send_data_buf_count++; | |
706 | |
707 /* free prim */ | |
708 PFREE(prim); | |
709 return; | |
710 } | |
711 | |
712 m_uart_ready--; | |
713 mux_data.send_data_buf_count=0; | |
714 | |
715 if (m_send_data) | |
716 { | |
717 /* find last data descriptor in stored data */ | |
718 d=m_send_data; | |
719 while (d->next) | |
720 { | |
721 d=(T_desc2 *)d->next; | |
722 } | |
723 /* concat new data to stored data */ | |
724 d->next=prim->desc_list2.first; | |
725 prim->desc_list2.first=(ULONG)m_send_data; | |
726 prim->desc_list2.list_len+=m_send_len; | |
727 | |
728 /* clear send_data */ | |
729 m_send_data=(T_desc2 *)0; | |
730 m_send_len=0; | |
731 } | |
732 | |
733 /* send prim */ | |
734 dti_send_data | |
735 ( | |
736 mtst_hDTI, | |
737 MTST_DTI_DN_INSTANCE, | |
738 MTST_DTI_DN_INTERFACE, | |
739 MTST_DTI_DN_CHANNEL, | |
740 prim | |
741 ); | |
742 } | |
743 | |
744 /***********+++++-----------------+++++++*******++----++**********/ | |
745 | |
746 /* | |
747 +------------------------------------------------------------------------------ | |
748 | Function : sig_dti_pei_data_received_ind | |
749 +------------------------------------------------------------------------------ | |
750 | Description : sent from UART to deliver new data | |
751 | | |
752 | Parameters : ptr - Pointer to the structure of the primitive | |
753 | | |
754 | Return : | |
755 | | |
756 +------------------------------------------------------------------------------ | |
757 */ | |
758 GLOBAL const void sig_dti_pei_data_received_ind (T_DTI2_DATA_IND *ptr) | |
759 { | |
760 T_DTI2_DATA_IND *prim = ptr; | |
761 | |
762 /* prevent dtilib from automatically sending flow control primitives */ | |
763 dti_stop | |
764 ( | |
765 mtst_hDTI, | |
766 MTST_DTI_DN_INSTANCE, | |
767 MTST_DTI_DN_INTERFACE, | |
768 MTST_DTI_DN_CHANNEL | |
769 ); | |
770 | |
771 if ( mux_data.EnabledSignalType & DRV_SIGTYPE_READ ) | |
772 { | |
773 m_signal.SignalType = DRV_SIGTYPE_READ; | |
774 m_signal.DrvHandle = mux_data.Handle; | |
775 | |
776 mux_data.recv_data=(T_desc2 *)prim->desc_list2.first; | |
777 | |
778 (mux_data.Callback)( &m_signal ); | |
779 } | |
780 PFREE(prim); | |
781 } | |
782 | |
783 /***********+++++-----------------+++++++*******++----++**********/ | |
784 | |
785 /* | |
786 * dtilib wrapping and support functions | |
787 */ | |
788 | |
789 /* | |
790 +------------------------------------------------------------------------------ | |
791 | Function : pei_dti_dti_connect_req | |
792 +------------------------------------------------------------------------------ | |
793 | PURPOSE : Call the process function dti_dti_connect_req | |
794 +------------------------------------------------------------------------------ | |
795 */ | |
796 | |
797 GLOBAL const void pei_dti_dti_connect_req ( | |
798 T_DTI2_CONNECT_REQ *dti_connect_req | |
799 ) | |
800 { | |
801 dti_dti_connect_req (mtst_hDTI, dti_connect_req); | |
802 } | |
803 | |
804 /* | |
805 +------------------------------------------------------------------------------ | |
806 | Function : pei_dti_dti_connect_cnf | |
807 +------------------------------------------------------------------------------ | |
808 | PURPOSE : Call the process function dti_dti_connect_cnf | |
809 +------------------------------------------------------------------------------ | |
810 */ | |
811 | |
812 GLOBAL const void pei_dti_dti_connect_cnf ( | |
813 T_DTI2_CONNECT_CNF *dti_connect_cnf | |
814 ) | |
815 { | |
816 dti_dti_connect_cnf(mtst_hDTI, dti_connect_cnf); | |
817 } | |
818 | |
819 /* | |
820 +------------------------------------------------------------------------------ | |
821 | Function : pei_dti_dti_connect_ind | |
822 +------------------------------------------------------------------------------ | |
823 | PURPOSE : Call the process function dti_dti_connect_ind | |
824 +------------------------------------------------------------------------------ | |
825 */ | |
826 | |
827 GLOBAL const void pei_dti_dti_connect_ind ( | |
828 T_DTI2_CONNECT_IND *dti_connect_ind | |
829 ) | |
830 { | |
831 dti_dti_connect_ind(mtst_hDTI, dti_connect_ind); | |
832 } | |
833 | |
834 /* | |
835 +------------------------------------------------------------------------------ | |
836 | Function : pei_dti_dti_connect_res | |
837 +------------------------------------------------------------------------------ | |
838 | PURPOSE : Call the process function dti_dti_connect_res | |
839 +------------------------------------------------------------------------------ | |
840 */ | |
841 | |
842 GLOBAL const void pei_dti_dti_connect_res ( | |
843 T_DTI2_CONNECT_RES *dti_connect_res | |
844 ) | |
845 { | |
846 dti_dti_connect_res(mtst_hDTI, dti_connect_res); | |
847 } | |
848 | |
849 /* | |
850 +------------------------------------------------------------------------------ | |
851 | Function : pei_dti_dti_disconnect_req | |
852 +------------------------------------------------------------------------------ | |
853 | PURPOSE : Call the process function dti_dti_disconnect_req | |
854 +------------------------------------------------------------------------------ | |
855 */ | |
856 | |
857 GLOBAL const void pei_dti_dti_disconnect_req ( | |
858 T_DTI2_DISCONNECT_REQ *dti_disconnect_req | |
859 ) | |
860 { | |
861 dti_dti_disconnect_req (mtst_hDTI, dti_disconnect_req); | |
862 } | |
863 | |
864 /* | |
865 +------------------------------------------------------------------------------ | |
866 | Function : pei_dti_dti_disconnect_ind | |
867 +------------------------------------------------------------------------------ | |
868 | PURPOSE : Call the process function dti_dti_disconnect_ind | |
869 +------------------------------------------------------------------------------ | |
870 */ | |
871 | |
872 GLOBAL const void pei_dti_dti_disconnect_ind ( | |
873 T_DTI2_DISCONNECT_IND *dti_disconnect_ind | |
874 ) | |
875 { | |
876 dti_dti_disconnect_ind (mtst_hDTI, dti_disconnect_ind); | |
877 } | |
878 | |
879 /* | |
880 +------------------------------------------------------------------------------ | |
881 | Function : pei_dti_dti_data_req | |
882 +------------------------------------------------------------------------------ | |
883 | PURPOSE : Call the process function dti_dti_data_req | |
884 +------------------------------------------------------------------------------ | |
885 */ | |
886 | |
887 GLOBAL const void pei_dti_dti_data_req ( | |
888 T_DTI2_DATA_REQ *dti_data_req | |
889 ) | |
890 { | |
891 dti_dti_data_req (mtst_hDTI, dti_data_req); | |
892 } | |
893 | |
894 /* | |
895 +------------------------------------------------------------------------------ | |
896 | Function : pei_dti_dti_getdata_req | |
897 +------------------------------------------------------------------------------ | |
898 | PURPOSE : Call the process function dti_dti_data_req | |
899 +------------------------------------------------------------------------------ | |
900 */ | |
901 | |
902 GLOBAL const void pei_dti_dti_getdata_req ( | |
903 T_DTI2_GETDATA_REQ *dti_getdata_req | |
904 ) | |
905 { | |
906 dti_dti_getdata_req (mtst_hDTI, dti_getdata_req); | |
907 } | |
908 | |
909 /* | |
910 +------------------------------------------------------------------------------ | |
911 | Function : pei_dti_dti_data_ind | |
912 +------------------------------------------------------------------------------ | |
913 | PURPOSE : Call the process function dti_dti_data_ind | |
914 +------------------------------------------------------------------------------ | |
915 */ | |
916 | |
917 GLOBAL const void pei_dti_dti_data_ind ( | |
918 T_DTI2_DATA_IND *dti_data_ind | |
919 ) | |
920 { | |
921 dti_dti_data_ind (mtst_hDTI, dti_data_ind); | |
922 } | |
923 | |
924 /* | |
925 +------------------------------------------------------------------------------ | |
926 | Function : pei_dti_dti_ready_ind | |
927 +------------------------------------------------------------------------------ | |
928 | PURPOSE : Call the process function dti_dti_ready_ind | |
929 +------------------------------------------------------------------------------ | |
930 */ | |
931 | |
932 GLOBAL const void pei_dti_dti_ready_ind ( | |
933 T_DTI2_READY_IND *dti_ready_ind | |
934 ) | |
935 { | |
936 dti_dti_ready_ind (mtst_hDTI, dti_ready_ind); | |
937 } | |
938 | |
939 #ifdef _SIMULATION_ | |
940 | |
941 /* | |
942 +------------------------------------------------------------------------------ | |
943 | Function : pei_dti_dti_data_test_req | |
944 +------------------------------------------------------------------------------ | |
945 | PURPOSE : Call the process function dti_dti_data_test_req | |
946 +------------------------------------------------------------------------------ | |
947 */ | |
948 | |
949 GLOBAL const void pei_dti_dti_data_test_req ( | |
950 T_DTI2_DATA_TEST_REQ *dti_data_test_req | |
951 ) | |
952 { | |
953 dti_dti_data_test_req (mtst_hDTI, dti_data_test_req); | |
954 } | |
955 | |
956 /* | |
957 +------------------------------------------------------------------------------ | |
958 | Function : pei_dti_dti_data_test_ind | |
959 +------------------------------------------------------------------------------ | |
960 | PURPOSE : Call the process function dti_dti_data_test_ind | |
961 +------------------------------------------------------------------------------ | |
962 */ | |
963 | |
964 GLOBAL const void pei_dti_dti_data_test_ind ( | |
965 T_DTI2_DATA_TEST_IND *dti_data_test_ind | |
966 ) | |
967 { | |
968 dti_dti_data_test_ind (mtst_hDTI, dti_data_test_ind); | |
969 } | |
970 | |
971 #endif /* _SIMULATION_ */ | |
972 | |
973 | |
974 /* | |
975 +------------------------------------------------------------------------------ | |
976 | Function: pei_sig_callback | |
977 +------------------------------------------------------------------------------ | |
978 | PURPOSE : Callback function for DTILIB | |
979 +------------------------------------------------------------------------------ | |
980 */ | |
981 | |
982 GLOBAL void pei_sig_callback(U8 instance, U8 interfac, U8 channel, | |
983 U8 reason, T_DTI2_DATA_IND *dti_data_ind) | |
984 { | |
985 TRACE_FUNCTION("pei_sig_callback"); | |
986 | |
987 #ifdef _SIMULATION_ | |
988 if(instance NEQ MTST_DTI_UP_INSTANCE || | |
989 interfac NEQ MTST_DTI_UP_INTERFACE || | |
990 channel NEQ MTST_DTI_UP_CHANNEL) | |
991 { | |
992 TRACE_ERROR("[PEI_SIG_CALLBACK] invalid parameters!"); | |
993 return; /* error, not found */ | |
994 } | |
995 #endif /* _SIMULATION_ */ | |
996 | |
997 if (mtst_hDTI NEQ D_NO_DATA_BASE) | |
998 { | |
999 switch (reason) | |
1000 { | |
1001 case DTI_REASON_CONNECTION_OPENED: | |
1002 sig_dti_pei_connection_opened_ind(); | |
1003 break; | |
1004 | |
1005 case DTI_REASON_CONNECTION_CLOSED: | |
1006 sig_dti_pei_connection_closed_ind(); | |
1007 break; | |
1008 | |
1009 case DTI_REASON_DATA_RECEIVED: | |
1010 | |
1011 /* | |
1012 * DTI2_DATA_IND is interpreted as DTI2_DATA_REQ | |
1013 */ | |
1014 PACCESS (dti_data_ind); | |
1015 sig_dti_pei_data_received_ind(dti_data_ind); | |
1016 break; | |
1017 | |
1018 case DTI_REASON_TX_BUFFER_FULL: | |
1019 sig_dti_pei_tx_buffer_full_ind(); | |
1020 break; | |
1021 | |
1022 case DTI_REASON_TX_BUFFER_READY: | |
1023 sig_dti_pei_tx_buffer_ready_ind(); | |
1024 break; | |
1025 | |
1026 default: | |
1027 TRACE_ERROR("unknown DTILIB reason parameter"); | |
1028 break; | |
1029 } /* end switch */ | |
1030 } /* end if */ | |
1031 else | |
1032 { | |
1033 TRACE_ERROR("Pointer to DTILIB database not existing"); | |
1034 } | |
1035 } /* pei_sig_callback() */ | |
1036 | |
1037 /*==== END OF FILE ==========================================================*/ | |
1038 |