comparison src/g23m-gprs/sndcp/sndcp_nuf.c @ 183:219afcfc6250

src/g23m-gprs: initial import from TCS3.2/LoCosto
author Mychaela Falconia <falcon@freecalypso.org>
date Thu, 13 Oct 2016 04:24:13 +0000
parents
children
comparison
equal deleted inserted replaced
182:f02d0a0e1849 183:219afcfc6250
1 /*
2 +-----------------------------------------------------------------------------
3 | Project : GPRS (8441)
4 | Modul : sndcp_nuf.c
5 +-----------------------------------------------------------------------------
6 | Copyright 2002 Texas Instruments Berlin, AG
7 | All rights reserved.
8 |
9 | This file is confidential and a trade secret of Texas
10 | Instruments Berlin, AG
11 | The receipt of or possession of this file does not convey
12 | any rights to reproduce or disclose its contents or to
13 | manufacture, use, or sell anything it may describe, in
14 | whole, or in part, without the specific written consent of
15 | Texas Instruments Berlin, AG.
16 +-----------------------------------------------------------------------------
17 | Purpose : This modul is part of the entity SNDCP and implements all
18 | procedures and functions as described in the
19 | SDL-documentation (NU-statemachine)
20 +-----------------------------------------------------------------------------
21 */
22
23 /*---- HISTORY --------------------------------------------------------------*/
24 #define ENTITY_SNDCP
25
26 /*==== INCLUDES =============================================================*/
27
28 #include "typedefs.h" /* to get Condat data types */
29 #include "vsi.h" /* to get a lot of macros */
30 #include "macdef.h"
31 #include "gsm.h" /* to get a lot of macros */
32 #include "prim.h" /* to get the definitions of used SAP and directions */
33
34 #include "dti.h"
35
36 #include "sndcp.h" /* to get the global entity definitions */
37 #include "sndcp_f.h" /* to get the functions to access the global arrays*/
38
39 #ifndef NCONFIG
40 #include "sndcp_nuf.h"
41 #include "sndcp_suas.h"
42 #include "sndcp_sus.h"
43 #endif
44
45 /*==== CONST ================================================================*/
46
47 /*==== LOCAL VARS ===========================================================*/
48
49 /*==== PRIVATE FUNCTIONS ====================================================*/
50
51 LOCAL void nu_delete (T_NPDU_BUFFER* npdu_buffer);
52
53
54 /*
55 +------------------------------------------------------------------------------
56 | Function : nu_delete
57 +------------------------------------------------------------------------------
58 | Description : The function nu_delete() deletes one buffered N-PDU.
59 | It is used to delete one N-PDU in form of an SN_DATA_REQ
60 | pointer.
61 | It will be useful when one N-PDU is deleted in case of
62 | LL_DATA_CNF orwhen every N-PDU for one NSAPI is deleted in case
63 | of SIG_MG_DELETE_NPDUS.
64 | First every descriptor in the SN_DATA_REQ is deleted, then the
65 | primitive is deleted, then the T_NPDU_BUFFER* is deleted. (This
66 | type is only specified in the code.)
67 | Parameter : the one N-PDU to be deleted.
68 |
69 +------------------------------------------------------------------------------
70 */
71 LOCAL void nu_delete (T_NPDU_BUFFER* npdu_buffer)
72 {
73
74 TRACE_FUNCTION( "nu_delete" );
75
76 if (npdu_buffer == NULL) {
77 return;
78 }
79 /*
80 * Free the SN_DATA_REQ.
81 */
82 #ifdef _SNDCP_DTI_2_
83 if (npdu_buffer->sn_data_req != NULL) {
84 MFREE_PRIM(npdu_buffer->sn_data_req);
85 npdu_buffer->sn_data_req = NULL;
86 }
87 #else /*_SNDCP_DTI_2_*/
88 if (npdu_buffer->sn_data_req != NULL) {
89 PFREE_DESC(npdu_buffer->sn_data_req);
90 npdu_buffer->sn_data_req = NULL;
91 }
92 #endif /*_SNDCP_DTI_2_*/
93 /*
94 * If this was the next to send in recovery state, move to next now.
95 */
96 if (npdu_buffer == sndcp_data->nu->next_resend) {
97 sndcp_data->nu->next_resend = npdu_buffer->next;
98 }
99 if (npdu_buffer == sndcp_data->nu->first_buffered_npdu) {
100 sndcp_data->nu->first_buffered_npdu = npdu_buffer->next;
101 }
102 /*
103 * Free the T_NPDU_BUFFER
104 */
105 MFREE(npdu_buffer);
106 npdu_buffer = NULL;
107 } /* nu_delete() */
108
109
110 /*==== PUBLIC FUNCTIONS =====================================================*/
111
112
113
114
115 /*
116 +------------------------------------------------------------------------------
117 | Function : nu_buffer_npdu
118 +------------------------------------------------------------------------------
119 | Description : The function nu_buffer_npdu() buffers the given SN_DATA_REQ
120 | together with the given N-PDU number.
121 |
122 | Parameters : N-PDU number, SN_DATA_REQ primitive.
123 |
124 +------------------------------------------------------------------------------
125 */
126 GLOBAL void nu_buffer_npdu (UBYTE npdu_number, T_SN_DATA_REQ* sn_data_req)
127 {
128 T_NPDU_BUFFER* npdu_buffer = 0;
129
130 TRACE_FUNCTION( "nu_buffer_npdu" );
131
132 /*
133 * Allocate the T_NPDU_BUFFER struct for
134 */
135 MALLOC(npdu_buffer, sizeof(T_NPDU_BUFFER));
136 /*
137 * Insert the given values.
138 */
139 npdu_buffer->npdu_number = npdu_number;
140 npdu_buffer->sn_data_req = sn_data_req;
141 npdu_buffer->next = NULL;
142 if (sndcp_data->nu->first_buffered_npdu == NULL) {
143 sndcp_data->nu->first_buffered_npdu = npdu_buffer;
144 sndcp_data->nu->next_resend = npdu_buffer;
145 } else {
146 T_NPDU_BUFFER* help = sndcp_data->nu->first_buffered_npdu;
147
148 if (help->next == NULL) {
149 help->next = npdu_buffer;
150 } else {
151 while (help->next != NULL) {
152 help = help->next;
153 }
154 help->next = npdu_buffer;
155 }
156
157 }
158
159
160 } /* nu_buffer_npdu() */
161
162 #ifndef NCONFIG
163
164 /*
165 +------------------------------------------------------------------------------
166 | Function : nu_config_discard
167 +------------------------------------------------------------------------------
168 | Description : reaction to config prim
169 |
170 | Parameters : nsapi
171 |
172 +------------------------------------------------------------------------------
173 */
174 GLOBAL void nu_config_discard (UBYTE nsapi)
175 {
176 TRACE_FUNCTION( "nu_config_discard" );
177
178 sndcp_data->nu = &sndcp_data->nu_base[nsapi];
179 sndcp_data->nu->discard = TRUE;
180 }
181
182 /*
183 +------------------------------------------------------------------------------
184 | Function : nu_config_resume
185 +------------------------------------------------------------------------------
186 | Description : reaction to config prim
187 |
188 | Parameters : nsapi
189 |
190 +------------------------------------------------------------------------------
191 */
192 GLOBAL void nu_config_resume (UBYTE nsapi)
193 {
194 TRACE_FUNCTION( "nu_config_resume" );
195
196 sndcp_data->nu = &sndcp_data->nu_base[nsapi];
197 sndcp_data->nu->discard = FALSE;
198 }
199
200 /*
201 +------------------------------------------------------------------------------
202 | Function : nu_config_send
203 +------------------------------------------------------------------------------
204 | Description : reaction to config prim
205 |
206 | Parameters : nsapi, number of octets
207 |
208 +------------------------------------------------------------------------------
209 */
210 GLOBAL void nu_config_send (UBYTE nsapi, U32 octets)
211 {
212 U32 *data_count = NULL;
213
214 TRACE_FUNCTION( "nu_config_send" );
215
216 sndcp_data->nu = &sndcp_data->nu_base[nsapi];
217
218 data_count = &sndcp_data->data_count[nsapi];
219
220 if (*data_count == 0) {
221 *data_count = octets;
222 } else {
223 *data_count += octets;
224 return;
225 }
226
227 switch( GET_STATE( NU ) )
228 {
229 case NU_ACK_SUA_RECEPTIVE:
230 case NU_SEND_ACK_SUA_RECEPTIVE:
231 SET_STATE(NU, NU_SEND_ACK_SUA_NOT_RECEPTIVE);
232 nu_config_send_next(nsapi);
233 sndcp_data->nu->sn_ready_ind_pending = FALSE;
234 break;
235 case NU_ACK_SUA_NOT_RECEPTIVE:
236 SET_STATE(NU, NU_SEND_ACK_SUA_NOT_RECEPTIVE);
237 break;
238 case NU_SEND_ACK_SUA_NOT_RECEPTIVE:
239 SET_STATE(NU, NU_SEND_ACK_SUA_NOT_RECEPTIVE);
240 *data_count += octets;
241 sndcp_data->nu->sn_ready_ind_pending = FALSE;
242 break;
243 case NU_UNACK_SU_NOT_RECEPTIVE:
244 SET_STATE(NU, NU_SEND_UNACK_SU_NOT_RECEPTIVE);
245 break;
246 case NU_SEND_UNACK_SU_NOT_RECEPTIVE:
247 SET_STATE(NU, NU_SEND_UNACK_SU_NOT_RECEPTIVE);
248 *data_count += octets;
249 sndcp_data->nu->sn_unitready_ind_pending = FALSE;
250 break;
251 case NU_UNACK_SU_RECEPTIVE:
252 case NU_SEND_UNACK_SU_RECEPTIVE:
253 SET_STATE(NU, NU_SEND_UNACK_SU_NOT_RECEPTIVE);
254 nu_config_send_next(nsapi);
255 sndcp_data->nu->sn_unitready_ind_pending = FALSE;
256 break;
257 case NU_REC_SUA_NOT_RECEPTIVE:
258 SET_STATE(NU, NU_SEND_REC_SUA_NOT_RECEPTIVE);
259 break;
260 case NU_SEND_REC_SUA_NOT_RECEPTIVE:
261 break;
262 case NU_SUS_SUA_NOT_RECEPTIVE:
263 SET_STATE(NU, NU_SEND_SUS_SUA_NOT_RECEPTIVE);
264 break;
265 case NU_SEND_SUS_SUA_NOT_RECEPTIVE:
266 break;
267 case NU_SUS_SUA_RECEPTIVE:
268 SET_STATE(NU, NU_SEND_SUS_SUA_RECEPTIVE);
269 break;
270 case NU_SEND_SUS_SUA_RECEPTIVE:
271 break;
272
273 default:
274 TRACE_ERROR( "config prim SEND unexpected" );
275 break;
276 }
277
278
279 } /* nu_config_send() */
280
281 /*
282 +------------------------------------------------------------------------------
283 | Function : nu_config_send_next
284 +------------------------------------------------------------------------------
285 | Description : sends data with 'data_count' octets. State is not changed.
286 |
287 | Parameters : nsapi
288 | Pre : data_count > 0
289 |
290 +------------------------------------------------------------------------------
291 */
292 GLOBAL void nu_config_send_next (UBYTE nsapi)
293 {
294 BOOL ack = FALSE;
295 /*
296 * Index and number in pattern.
297 */
298 USHORT i = 0;
299 USHORT r = 0;
300 UBYTE sapi = 0;
301 USHORT k = 0;
302 UBYTE sapi_index = 0;
303 USHORT send_size = 0;
304 U16 ip_size = 0;
305 U32 length;
306 U32* data_count = NULL;
307 #ifdef _SNDCP_DTI_2_
308 T_desc2* desc = NULL,*help;
309 #else /*_SNDCP_DTI_2_*/
310 T_desc* desc = NULL;
311 #endif /*_SNDCP_DTI_2_*/
312
313 T_SN_DATA_REQ* sn_data_req = NULL;
314 T_SN_UNITDATA_REQ* sn_unitdata_req = NULL;
315
316 data_count = &sndcp_data->data_count[nsapi];
317 length = *data_count;
318
319 TRACE_FUNCTION( "nu_config_send_next" );
320
321 if (length == 0) {
322 sndcp_get_nsapi_ack(nsapi, &ack);
323 if (ack) {
324 SET_STATE(NU, NU_SEND_ACK_SUA_RECEPTIVE);
325 } else {
326 SET_STATE(NU, NU_SEND_UNACK_SU_RECEPTIVE);
327 }
328 return;
329 }
330
331 sndcp_get_nsapi_sapi(sndcp_data->nu->nsapi, &sapi);
332 sndcp_get_sapi_index(sapi, &sapi_index);
333
334 sndcp_data->nu = &sndcp_data->nu_base[nsapi];
335 sndcp_get_nsapi_ack(nsapi, &ack);
336
337 if (ack) {
338 send_size =
339 sndcp_data->sua_base[sapi_index].n201_i - SN_DATA_PDP_HDR_LEN_BIG;
340 TRACE_EVENT_P1("send_size: %d", send_size);
341 } else {
342 send_size =
343 sndcp_data->su_base[sapi_index].n201_u - SN_UNITDATA_PDP_HDR_LEN_BIG;
344 TRACE_EVENT_P1("send_size: %d", send_size);
345 }
346
347 /*
348 * The amount of data to be segmented
349 * shall be a multiple of N201_I or N201_U respectively
350 */
351 if(ack)
352 {
353 ip_size = 2 * sndcp_data->sua_base[sapi_index].n201_i + 100;
354 if (length > ip_size)
355 {
356 if ( sndcp_data->sua_base[sapi_index].n201_i < ip_size)
357 {
358 k = (ip_size - (ip_size %
359 sndcp_data->sua_base[sapi_index].n201_i))/
360 sndcp_data->sua_base[sapi_index].n201_i;
361 length = k * (sndcp_data->sua_base[sapi_index].n201_i)
362 -(k-1)- SN_DATA_PDP_HDR_LEN_BIG;
363 }
364 else
365 {
366 length = sndcp_data->sua_base[sapi_index].n201_i -
367 SN_DATA_PDP_HDR_LEN_BIG;
368 }
369 }
370 }
371 else
372 {
373 ip_size = 2 * sndcp_data->su_base[sapi_index].n201_u + 100;
374 if (length > ip_size)
375 {
376 if ( sndcp_data->su_base[sapi_index].n201_u < ip_size)
377 {
378 k = (ip_size - (ip_size %
379 sndcp_data->su_base[sapi_index].n201_u))/
380 sndcp_data->su_base[sapi_index].n201_u;
381 length = k * (sndcp_data->su_base[sapi_index].n201_u)
382 - (k * (SN_UNITDATA_PDP_HDR_LEN_BIG -1) +1);
383 }
384 else
385 {
386 length = sndcp_data->su_base[sapi_index].n201_u -
387 SN_UNITDATA_PDP_HDR_LEN_BIG;
388 }
389 }
390 }
391
392 TRACE_EVENT_P2("data to segment: %d, data to send: %d",
393 length, *data_count);
394
395 *data_count -= length;
396
397 /*
398 * Allocates small segments
399 */
400 k = (U16)(length / 100); /* Number of 'full' 100 byte descriptors*/
401 r = (U16)(length % 100); /* Number of rest bytes */
402
403 if(r > 0){
404 #ifdef _SNDCP_DTI_2_
405 MALLOC (desc, (USHORT)(sizeof(T_desc2) - 1 + r));
406 #else /*_SNDCP_DTI_2_*/
407 MALLOC (desc, (USHORT)(sizeof(T_desc) - 1 + r));
408 #endif /*_SNDCP_DTI_2_*/
409
410 desc->next = (ULONG)NULL;
411 desc->len = r;
412
413 #ifdef _SNDCP_DTI_2_
414 desc->offset = 0;
415 desc->size = r;
416 #endif
417 }
418
419 for ( i=0; i < k; i++){
420 /*
421 * Allocate memory for descriptor
422 */
423 MALLOC (help, (USHORT)(sizeof(T_desc2) - 1 + 100));
424
425
426
427
428 /*
429 * Fill descriptor control information.
430 */
431 help->next = (ULONG)desc;
432 help->len = 100;
433 help->offset = 0;
434 help->size = help->len;
435
436 desc = help;
437 } /* for k */
438
439
440
441 if (ack) {
442 #ifdef _SNDCP_DTI_2_
443 MALLOC(sn_data_req, sizeof(T_SN_DATA_REQ));
444 sn_data_req->desc_list2.first = (ULONG) desc;
445 sn_data_req->desc_list2.list_len = (U16)length;
446 #else /*_SNDCP_DTI_2_*/
447 PALLOC_DESC (sn_data_req, SN_DATA_REQ);
448 sn_data_req->desc_list.first = (ULONG) desc;
449 sn_data_req->desc_list.list_len = (U16)length;
450 #endif /*_SNDCP_DTI_2_*/
451
452
453 sn_data_req->nsapi = nsapi;
454 #ifdef SNDCP_UPM_INCLUDED
455 sn_data_req->p_id = DTI_PID_IP;
456 #else
457 sn_data_req->p_id = PPP_PID_IP;
458 #endif /*SNDCP_UPM_INCLUDED*/
459 /*
460 * Buffer the given N-PDU
461 */
462 nu_buffer_npdu(sndcp_data->nu->send_npdu_number_ack, sn_data_req);
463
464 sndcp_data->nu->send_npdu_number_ack =
465 (U8)((sndcp_data->nu->send_npdu_number_ack + 1) % MAX_NPDU_NUMBER_ACK);
466 sig_nu_sua_data_req(sn_data_req,
467 (U8)((sndcp_data->nu->send_npdu_number_ack - 1
468 + MAX_NPDU_NUMBER_ACK) % MAX_NPDU_NUMBER_ACK),
469 sn_data_req->nsapi,
470 sapi);
471
472
473 } else {
474 #ifdef _SNDCP_DTI_2_
475 MALLOC(sn_unitdata_req, sizeof(T_SN_UNITDATA_REQ));
476 sn_unitdata_req->desc_list2.first = (ULONG) desc;
477 sn_unitdata_req->desc_list2.list_len = (U16)length;
478 #else /*_SNDCP_DTI_2_*/
479 PALLOC_DESC (sn_unitdata_req, SN_UNITDATA_REQ);
480 sn_unitdata_req->desc_list.first = (ULONG) desc;
481 sn_unitdata_req->desc_list.list_len = (U16)length;
482 #endif /*_SNDCP_DTI_2_*/
483 sn_unitdata_req->nsapi = nsapi;
484 #ifdef SNDCP_UPM_INCLUDED
485 sn_unitdata_req->p_id = DTI_PID_IP;
486 #else
487 sn_unitdata_req->p_id = PPP_PID_IP;
488 #endif /*SNDCP_UPM_INCLUDED*/
489
490 sndcp_data->nu->send_npdu_number_unack =
491 (sndcp_data->nu->send_npdu_number_unack + 1) % MAX_NPDU_NUMBER_UNACK;
492 sig_nu_su_unitdata_req(sn_unitdata_req,
493 (U16)((sndcp_data->nu->send_npdu_number_unack - 1
494 + MAX_NPDU_NUMBER_UNACK) % MAX_NPDU_NUMBER_UNACK),
495 sndcp_data->nu->nsapi,
496 sapi);
497
498 }
499
500 } /* nu_config_send_next() */
501
502 #endif
503
504
505
506 /*
507 +------------------------------------------------------------------------------
508 | Function : nu_delete_npdu
509 +------------------------------------------------------------------------------
510 | Description : The function nu_delete_npdu() searches and deletes one
511 | buffered N-PDU.
512 | Parameter : nsapi, npdu_number.
513 | Pre : correct nu instance must be active, NPDU must exist.
514 |
515 +------------------------------------------------------------------------------
516 */
517 GLOBAL void nu_delete_npdu (UBYTE nsapi, UBYTE npdu_number)
518 {
519 T_NPDU_BUFFER* npdu_buffer = NULL;
520 T_NPDU_BUFFER* pre = NULL;
521 BOOL found = FALSE;
522
523 TRACE_FUNCTION( "nu_delete_npdu" );
524
525 /*
526 * Find the npdu.
527 */
528 npdu_buffer = sndcp_data->nu->first_buffered_npdu;
529 while (!found && npdu_buffer != NULL) {
530 if (sndcp_data->nu->nsapi == nsapi &&
531 npdu_buffer->npdu_number == npdu_number)
532 {
533 found = TRUE;
534 if (pre != NULL) {
535 pre->next = npdu_buffer->next;
536 }
537 } else {
538 pre = npdu_buffer;
539 npdu_buffer = npdu_buffer->next;
540 }
541 }
542 /*
543 * Delete it.
544 */
545 if (npdu_buffer != NULL) {
546 nu_delete(npdu_buffer);
547 }
548 } /* nu_delete_npdu() */
549
550
551
552 /*
553 +------------------------------------------------------------------------------
554 | Function : nu_delete_npdus
555 +------------------------------------------------------------------------------
556 | Description : The function nu_delete_npdus() deletes all buffered N-PDUs.
557 |
558 | Pre : The correct nu instance has to be "active".
559 |
560 +------------------------------------------------------------------------------
561 */
562 GLOBAL void nu_delete_npdus (void)
563 {
564 T_NPDU_BUFFER* help = NULL;
565
566 TRACE_FUNCTION( "nu_delete_npdus" );
567
568 while (sndcp_data->nu->first_buffered_npdu != NULL) {
569 help = sndcp_data->nu->first_buffered_npdu->next;
570 /*
571 * Delete the first one.
572 */
573 nu_delete(sndcp_data->nu->first_buffered_npdu);
574 /*
575 * Go to the next.
576 */
577 sndcp_data->nu->first_buffered_npdu = help;
578 }
579 sndcp_data->nu->next_resend = NULL;
580
581 } /* nu_delete_npdus() */
582
583
584 /*
585 +------------------------------------------------------------------------------
586 | Function : nu_init
587 +------------------------------------------------------------------------------
588 | Description : The function nu_init() ....
589 |
590 | Parameters :
591 |
592 +------------------------------------------------------------------------------
593 */
594 GLOBAL void nu_init (void)
595 {
596
597 UBYTE nsapi = 0;
598
599 TRACE_FUNCTION( "nu_init" );
600
601 sndcp_data->nu = & sndcp_data->nu_base[0];
602 INIT_STATE(NU_0, NU_UNACK_SU_RECEPTIVE);
603
604 sndcp_data->nu = & sndcp_data->nu_base[1];
605 INIT_STATE(NU_1, NU_UNACK_SU_RECEPTIVE);
606
607 sndcp_data->nu = & sndcp_data->nu_base[2];
608 INIT_STATE(NU_2, NU_UNACK_SU_RECEPTIVE);
609
610 sndcp_data->nu = & sndcp_data->nu_base[3];
611 INIT_STATE(NU_3, NU_UNACK_SU_RECEPTIVE);
612
613 sndcp_data->nu = & sndcp_data->nu_base[4];
614 INIT_STATE(NU_4, NU_UNACK_SU_RECEPTIVE);
615
616 sndcp_data->nu = & sndcp_data->nu_base[5];
617 INIT_STATE(NU_5, NU_UNACK_SU_RECEPTIVE);
618
619 sndcp_data->nu = & sndcp_data->nu_base[6];
620 INIT_STATE(NU_6, NU_UNACK_SU_RECEPTIVE);
621
622 sndcp_data->nu = & sndcp_data->nu_base[7];
623 INIT_STATE(NU_7, NU_UNACK_SU_RECEPTIVE);
624
625 sndcp_data->nu = & sndcp_data->nu_base[8];
626 INIT_STATE(NU_8, NU_UNACK_SU_RECEPTIVE);
627
628 sndcp_data->nu = & sndcp_data->nu_base[9];
629 INIT_STATE(NU_9, NU_UNACK_SU_RECEPTIVE);
630
631 sndcp_data->nu = & sndcp_data->nu_base[10];
632 INIT_STATE(NU_10, NU_UNACK_SU_RECEPTIVE);
633
634 sndcp_data->nu = & sndcp_data->nu_base[11];
635 INIT_STATE(NU_11, NU_UNACK_SU_RECEPTIVE);
636
637 sndcp_data->nu = & sndcp_data->nu_base[12];
638 INIT_STATE(NU_12, NU_UNACK_SU_RECEPTIVE);
639
640 sndcp_data->nu = & sndcp_data->nu_base[13];
641 INIT_STATE(NU_13, NU_UNACK_SU_RECEPTIVE);
642
643 sndcp_data->nu = & sndcp_data->nu_base[14];
644 INIT_STATE(NU_14, NU_UNACK_SU_RECEPTIVE);
645
646 sndcp_data->nu = & sndcp_data->nu_base[15];
647 INIT_STATE(NU_15, NU_UNACK_SU_RECEPTIVE);
648
649 for (nsapi = 0; nsapi < SNDCP_NUMBER_OF_NSAPIS; nsapi++) {
650 sndcp_data->nu = & sndcp_data->nu_base[nsapi];
651
652 sndcp_data->nu->nsapi = nsapi;
653 sndcp_data->nu->send_npdu_number_unack = 0;
654 sndcp_data->nu->send_npdu_number_ack = 0;
655 sndcp_data->nu->rec_npdu_number_ack = 0;
656 sndcp_data->nu->first_buffered_npdu = NULL;
657 sndcp_data->nu->next_resend = NULL;
658 sndcp_data->nu->sn_ready_ind_pending = FALSE;
659 sndcp_data->nu->sn_unitready_ind_pending = FALSE;
660 sndcp_data->nu->connection_is_opened = FALSE;
661 sndcp_data->nu->discard = FALSE;
662 sndcp_data->nu->discarded_data = 0;
663 sndcp_data->nu->sent_data = 0;
664 }
665 } /* nu_init() */
666
667
668 /*
669 +------------------------------------------------------------------------------
670 | Function : nu_ready_ind_if_nec
671 +------------------------------------------------------------------------------
672 | Description : Sends an SN_READY_IND if none is pending and DTI connection is
673 | opened.
674 |
675 | Parameters : nsapi
676 |
677 +------------------------------------------------------------------------------
678 */
679 GLOBAL void nu_ready_ind_if_nec (UBYTE nsapi)
680 {
681 BOOL used = FALSE;
682 USHORT stat = MG_IDLE;
683 UBYTE sapi = 0;
684
685 TRACE_FUNCTION( "nu_ready_ind_if_nec" );
686 #ifdef SNDCP_TRACE_ALL
687 if (sndcp_data->nu->sn_ready_ind_pending) {
688 TRACE_EVENT("sn_ready_ind_pending TRUE");
689 } else {
690 TRACE_EVENT("sn_ready_ind_pending FALSE");
691 }
692 if (sndcp_data->nu->connection_is_opened) {
693 TRACE_EVENT("connection_is_opened TRUE");
694 } else {
695 TRACE_EVENT("connection_is_opened FALSE");
696 }
697 #endif /* SNDCP_TRACE_ALL */
698
699 /*
700 * set service instance according to nsapi parameter
701 */
702 sndcp_data->nu = & sndcp_data->nu_base[nsapi];
703
704 sndcp_get_nsapi_sapi(nsapi, &sapi);
705 sndcp_get_sapi_state(sapi, &stat);
706 sndcp_is_nsapi_used(nsapi, &used);
707
708 if (! sndcp_data->nu->sn_ready_ind_pending
709 &&
710 sndcp_data->nu->connection_is_opened
711 &&
712 used
713 ) {
714
715 sndcp_data->nu->sn_ready_ind_pending = TRUE;
716
717 #ifdef SNDCP_UPM_INCLUDED
718 dti_start(sndcp_data->hDTI, 0, SNDCP_INTERFACE_UNACK, nsapi);
719 #else
720 dti_start(sndcp_data->hDTI, 0, SNDCP_INTERFACE_ACK, nsapi);
721 #endif
722 }
723
724 } /* nu_ready_ind_if_nec() */
725
726 /*
727 +------------------------------------------------------------------------------
728 | Function : nu_unitready_ind_if_nec
729 +------------------------------------------------------------------------------
730 | Description : Sends an SN_UNITREADY_IND if none is pending and DTI connection
731 | is opened.
732 |
733 | Parameters : nsapi
734 | Pre : The correct nu instance has to be "active".
735 |
736 +------------------------------------------------------------------------------
737 */
738 GLOBAL void nu_unitready_ind_if_nec (UBYTE nsapi)
739 {
740 BOOL used = FALSE;
741 USHORT stat = MG_IDLE;
742 UBYTE sapi = 0;
743
744 TRACE_FUNCTION( "nu_unitready_ind_if_nec" );
745 #ifdef SNDCP_TRACE_ALL
746 if (sndcp_data->nu->sn_unitready_ind_pending) {
747 TRACE_EVENT("sn_unitready_ind_pending TRUE");
748 } else {
749 TRACE_EVENT("sn_unitready_ind_pending FALSE");
750 }
751 if (sndcp_data->nu->connection_is_opened) {
752 TRACE_EVENT("connection_is_opened TRUE");
753 } else {
754 TRACE_EVENT("connection_is_opened FALSE");
755 }
756 #endif
757
758 sndcp_get_nsapi_sapi(nsapi, &sapi);
759 sndcp_get_sapi_state(sapi, &stat);
760 sndcp_is_nsapi_used(nsapi, &used);
761
762 if (! sndcp_data->nu->sn_unitready_ind_pending
763 &&
764 sndcp_data->nu->connection_is_opened
765 &&
766 used
767 ) {
768 #ifdef SNDCP_TRACE_ALL
769 TRACE_EVENT("trying to palloc/send SN_UNITREADY_IND");
770 #endif
771
772
773 sndcp_data->nu->sn_unitready_ind_pending = TRUE;
774
775 dti_start(sndcp_data->hDTI, 0, SNDCP_INTERFACE_UNACK, nsapi);
776
777 }
778 } /* nu_unitready_ind_if_nec() */