FreeCalypso > hg > fc-selenite
comparison src/g23m-fad/rlp/rlp_kerp.c @ 1:d393cd9bb723
src/g23m-*: initial import from Magnetite
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Sun, 15 Jul 2018 04:40:46 +0000 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
0:b6a5e36de839 | 1:d393cd9bb723 |
---|---|
1 /* | |
2 +----------------------------------------------------------------------------- | |
3 | Project : CSD (8411) | |
4 | Modul : Rlp_kerp.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 defines the functions for processing | |
18 | of incomming primitives for the component | |
19 | Radio Link Protocol of the base station | |
20 +----------------------------------------------------------------------------- | |
21 */ | |
22 | |
23 #ifndef RLP_KERP_C | |
24 #define RLP_KERP_C | |
25 #endif | |
26 | |
27 #define ENTITY_RLP | |
28 | |
29 /*==== INCLUDES ===================================================*/ | |
30 | |
31 #include <string.h> | |
32 #include "typedefs.h" | |
33 #include "vsi.h" | |
34 #include "macdef.h" | |
35 #include "custom.h" | |
36 #include "gsm.h" | |
37 #include "cus_rlp.h" | |
38 #include "prim.h" | |
39 #include "tok.h" | |
40 #include "rlp.h" | |
41 | |
42 /*==== CONST =======================================================*/ | |
43 | |
44 /*==== TYPES =======================================================*/ | |
45 | |
46 /*==== VAR EXPORT ==================================================*/ | |
47 | |
48 /*==== VAR LOCAL ===================================================*/ | |
49 | |
50 /*==== FUNCTIONS ===================================================*/ | |
51 | |
52 /* | |
53 +------------------------------------------------------------------------------ | |
54 | Function : ker_rlp_attach_req | |
55 +------------------------------------------------------------------------------ | |
56 | Description : Process primitive RLP_ATTACH_REQ received from L2R. | |
57 | | |
58 | Parameters : rlp_attach_req - | |
59 | | |
60 | | |
61 | Return : - | |
62 +------------------------------------------------------------------------------ | |
63 */ | |
64 | |
65 | |
66 GLOBAL void ker_rlp_attach_req | |
67 ( | |
68 T_RLP_ATTACH_REQ *rlp_attach_req | |
69 ) | |
70 { | |
71 TRACE_FUNCTION ("ker_rlp_attach_req()"); | |
72 PACCESS (rlp_attach_req); | |
73 | |
74 /*******************************/ | |
75 /* | |
76 * Initialize Shared Fax/Data memory | |
77 */ | |
78 memset (rlp_data, 0, sizeof (T_RLP_DATA)); | |
79 | |
80 ker_init (); | |
81 snd_init (&rlp_data->snd); | |
82 rcv_init (); | |
83 | |
84 rlp_data->uplink_frame_trace = FALSE; | |
85 rlp_data->downlink_frame_trace = FALSE; | |
86 | |
87 rbm_reset(&rlp_data->rbm); | |
88 rlp_data_magic_num = RLP_DATA_MAGIC_NUM; /* memory is initialized */ | |
89 | |
90 /*******************************/ | |
91 | |
92 switch (GET_STATE (KER)) | |
93 { | |
94 case RLP_ADM_AND_DETACHED: | |
95 /* | |
96 * processing for state RLP_ADM_AND_DETACHED | |
97 */ | |
98 | |
99 rlp_data->ker.Poll_xchg = IW_IDLE; | |
100 rlp_data->ker.SABM_State = ISW_IDLE; | |
101 rlp_data->ker.T1 = GEN_TO; | |
102 rlp_data->ker.T_ul = (USHORT)UL_TO; | |
103 rlp_data->ker.BytesPerPrim = rlp_attach_req->bytes_per_prim; | |
104 | |
105 ker_set_frame_size (rlp_attach_req->rate); | |
106 | |
107 ker_get_frame_desc (rlp_data->ker.UI_Frame, | |
108 &rlp_data->ker.UI_FrameDesc); | |
109 | |
110 ker_get_frame_desc (rlp_data->ker.XID_C_Frame, | |
111 &rlp_data->ker.XID_C_FrameDesc); | |
112 | |
113 ker_get_frame_desc (rlp_data->ker.XID_R_Frame, | |
114 &rlp_data->ker.XID_R_FrameDesc); | |
115 | |
116 ker_get_frame_desc (rlp_data->ker.TEST_R_Frame, | |
117 &rlp_data->ker.TEST_R_FrameDesc); | |
118 | |
119 ker_get_frame_desc (rlp_data->ker.REMAP_Frame, | |
120 &rlp_data->ker.REMAP_FrameDesc); | |
121 | |
122 rlp_data->ker.TEST_R_State = IS_IDLE; | |
123 rlp_data->ker.UA_State = IS_IDLE; | |
124 rlp_data->ker.UI_State = IS_IDLE; | |
125 rlp_data->ker.XID_R_State = IS_IDLE; | |
126 | |
127 ker_init_xid_data(rlp_attach_req); | |
128 | |
129 SET_STATE (KER, RLP_ADM_AND_ATTACHED); | |
130 break; | |
131 | |
132 default: | |
133 break; | |
134 } | |
135 PFREE (rlp_attach_req); | |
136 } | |
137 | |
138 /* | |
139 +------------------------------------------------------------------------------ | |
140 | Function : ker_rlp_detach_req | |
141 +------------------------------------------------------------------------------ | |
142 | Description : Process primitive RLP_DETACH_REQ received from L2R. | |
143 | | |
144 | Parameters : rlp_detach_req - | |
145 | | |
146 | | |
147 | Return : - | |
148 +------------------------------------------------------------------------------ | |
149 */ | |
150 | |
151 | |
152 GLOBAL void ker_rlp_detach_req(T_RLP_DETACH_REQ *rlp_detach_req) | |
153 { | |
154 TRACE_FUNCTION ("ker_rlp_detach_req()"); | |
155 PACCESS (rlp_detach_req); | |
156 | |
157 /* | |
158 * processing for any kernel state | |
159 */ | |
160 rlp_data->ker.DM_State = IS_IDLE; | |
161 ker_deinit_link_vars (); | |
162 SET_STATE (KER, RLP_ADM_AND_DETACHED); | |
163 { | |
164 PPASS (rlp_detach_req, rlp_detach_cnf, RLP_DETACH_CNF); | |
165 PSENDX (L2R, rlp_detach_cnf); | |
166 } | |
167 rlp_data_magic_num = 0; /* memory is no more initialized */ | |
168 } | |
169 | |
170 /* | |
171 +------------------------------------------------------------------------------ | |
172 | Function : ker_rlp_connect_req | |
173 +------------------------------------------------------------------------------ | |
174 | Description : Process primitive RLP_CONNECT_REQ received from L2R. | |
175 | | |
176 | Parameters : rlp_connect_req - | |
177 | | |
178 | | |
179 | Return : - | |
180 +------------------------------------------------------------------------------ | |
181 */ | |
182 | |
183 | |
184 GLOBAL void ker_rlp_connect_req | |
185 ( | |
186 T_RLP_CONNECT_REQ *rlp_connect_req | |
187 ) | |
188 { | |
189 TRACE_FUNCTION ("ker_rlp_connect_req()"); | |
190 PACCESS (rlp_connect_req); | |
191 | |
192 switch (GET_STATE (KER)) | |
193 { | |
194 case RLP_ADM_AND_ATTACHED: | |
195 /* | |
196 * processing for state RLP_ADM_AND_ATTACHED | |
197 */ | |
198 rlp_data->ker.SABM_State = ISW_SEND; | |
199 rlp_data->ker.SABM_Count = 0; | |
200 rlp_data->ker.DM_State = IS_IDLE; | |
201 | |
202 SET_STATE (KER, RLP_PENDING_CONNECT_REQ); | |
203 break; | |
204 | |
205 default: | |
206 break; | |
207 } | |
208 PFREE (rlp_connect_req); | |
209 } | |
210 | |
211 /* | |
212 +------------------------------------------------------------------------------ | |
213 | Function : ker_rlp_connect_res | |
214 +------------------------------------------------------------------------------ | |
215 | Description : Process primitive RLP_CONNECT_RES received from L2R. | |
216 | | |
217 | Parameters : rlp_connect_res - | |
218 | | |
219 | | |
220 | Return : - | |
221 +------------------------------------------------------------------------------ | |
222 */ | |
223 | |
224 | |
225 GLOBAL void ker_rlp_connect_res | |
226 ( | |
227 T_RLP_CONNECT_RES *rlp_connect_res | |
228 ) | |
229 { | |
230 TRACE_FUNCTION ("ker_rlp_connect_res()"); | |
231 PACCESS (rlp_connect_res); | |
232 | |
233 switch (GET_STATE (KER)) | |
234 { | |
235 case RLP_PENDING_CONNECT_IND: | |
236 { | |
237 /* | |
238 * processing for state RLP_PENDING_CONNECT_IND | |
239 */ | |
240 rlp_data->ker.ABit = rlp_connect_res->ack_flg; | |
241 | |
242 switch (rlp_data->ker.ABit) | |
243 { | |
244 case RLP_NAK: | |
245 rlp_data->ker.DM_State = IS_SEND; | |
246 rlp_data->ker.DM_FBit = 1; | |
247 SET_STATE (KER, RLP_ADM_AND_ATTACHED); | |
248 break; | |
249 | |
250 case RLP_ACK: | |
251 rlp_data->ker.UA_State = IS_SEND; | |
252 rlp_data->ker.UA_FBit = 1; | |
253 ker_init_link_vars (); | |
254 SET_STATE (KER, RLP_CONNECTION_ESTABLISHED); | |
255 break; | |
256 } | |
257 } | |
258 } | |
259 PFREE (rlp_connect_res); | |
260 } | |
261 | |
262 /* | |
263 +------------------------------------------------------------------------------ | |
264 | Function : ker_rlp_disc_req | |
265 +------------------------------------------------------------------------------ | |
266 | Description : Process primitive RLP_DISC_REQ received from L2R. | |
267 | | |
268 | Parameters : rlp_disc_req - | |
269 | | |
270 | | |
271 | Return : - | |
272 +------------------------------------------------------------------------------ | |
273 */ | |
274 | |
275 | |
276 GLOBAL void ker_rlp_disc_req | |
277 ( | |
278 T_RLP_DISC_REQ *rlp_disc_req | |
279 ) | |
280 { | |
281 TRACE_FUNCTION ("ker_rlp_disc_req()"); | |
282 PACCESS (rlp_disc_req); | |
283 | |
284 switch (GET_STATE (KER)) | |
285 { | |
286 case RLP_ADM_AND_DETACHED: | |
287 case RLP_ADM_AND_ATTACHED: | |
288 /* | |
289 * processing for state RLP_ADM_AND_DETACHED | |
290 */ | |
291 break; | |
292 | |
293 default: | |
294 /* | |
295 * processing for any other state | |
296 */ | |
297 TIMERSTOP (TT_HANDLE); | |
298 | |
299 rlp_data->ker.DISC_State = ISW_SEND; | |
300 rlp_data->ker.DISC_Count = 0; | |
301 | |
302 switch (rlp_data->ker.Poll_xchg) | |
303 { | |
304 case IW_IDLE: | |
305 rlp_data->ker.DISC_PBit = 1; | |
306 break; | |
307 | |
308 default: | |
309 rlp_data->ker.DISC_PBit = 0; | |
310 break; | |
311 } | |
312 | |
313 ker_deinit_link_vars (); | |
314 rlp_data->ker.DISC_Ind = FALSE; | |
315 | |
316 SET_STATE (KER, RLP_DISCONNECT_INITIATED); | |
317 TRACE_EVENT("#1"); | |
318 break; | |
319 } | |
320 PFREE (rlp_disc_req); | |
321 } | |
322 | |
323 /* | |
324 +------------------------------------------------------------------------------ | |
325 | Function : ker_rlp_reset_req | |
326 +------------------------------------------------------------------------------ | |
327 | Description : Process primitive RLP_RESET_REQ received from L2R. | |
328 | | |
329 | Parameters : rlp_reset_req - | |
330 | | |
331 | | |
332 | Return : - | |
333 +------------------------------------------------------------------------------ | |
334 */ | |
335 | |
336 | |
337 GLOBAL void ker_rlp_reset_req | |
338 ( | |
339 T_RLP_RESET_REQ *rlp_reset_req | |
340 ) | |
341 { | |
342 TRACE_FUNCTION ("ker_rlp_reset_req()"); | |
343 PACCESS (rlp_reset_req); | |
344 | |
345 switch (GET_STATE (KER)) | |
346 { | |
347 case RLP_CONNECTION_ESTABLISHED: | |
348 /* | |
349 * processing for state RLP_CONNECTION_ESTABLISHED | |
350 */ | |
351 TIMERSTOP (TT_HANDLE); | |
352 TIMERSTOP (TRCVR_HANDLE); | |
353 ker_reset_all_t_rcvs (); | |
354 | |
355 rlp_data->ker.SABM_State = ISW_SEND; | |
356 rlp_data->ker.SABM_Count = 0; | |
357 | |
358 ker_deinit_link_vars (); | |
359 | |
360 SET_STATE (KER, RLP_PENDING_RESET_REQ); | |
361 break; | |
362 } | |
363 PFREE (rlp_reset_req); | |
364 } | |
365 | |
366 /* | |
367 +------------------------------------------------------------------------------ | |
368 | Function : ker_rlp_reset_res | |
369 +------------------------------------------------------------------------------ | |
370 | Description : Process primitive RLP_RESET_RES received from L2R. | |
371 | | |
372 | Parameters : rlp_reset_res - | |
373 | | |
374 | | |
375 | Return : - | |
376 +------------------------------------------------------------------------------ | |
377 */ | |
378 | |
379 | |
380 GLOBAL void ker_rlp_reset_res | |
381 ( | |
382 T_RLP_RESET_RES *rlp_reset_res | |
383 ) | |
384 { | |
385 TRACE_FUNCTION ("ker_rlp_reset_res()"); | |
386 PACCESS (rlp_reset_res); | |
387 | |
388 switch (GET_STATE (KER)) | |
389 { | |
390 case RLP_PENDING_RESET_IND: | |
391 /* | |
392 * processing for state RLP_PENDING_RESET_IND | |
393 */ | |
394 rlp_data->ker.UA_State = IS_SEND; | |
395 rlp_data->ker.UA_FBit = 1; | |
396 | |
397 ker_init_link_vars (); | |
398 SET_STATE (KER, RLP_CONNECTION_ESTABLISHED); | |
399 break; | |
400 } | |
401 PFREE (rlp_reset_res); | |
402 } | |
403 | |
404 /* | |
405 +------------------------------------------------------------------------------ | |
406 | Function : ker_rlp_data_req | |
407 +------------------------------------------------------------------------------ | |
408 | Description : Process primitive RLP_ATTACH_REQ received from L2R. | |
409 | | |
410 | Parameters : rlp_data_req - | |
411 | | |
412 | | |
413 | Return : - | |
414 +------------------------------------------------------------------------------ | |
415 */ | |
416 | |
417 | |
418 GLOBAL void ker_rlp_data_req | |
419 ( | |
420 T_RLP_DATA_REQ *rlp_data_req | |
421 ) | |
422 { | |
423 TRACE_FUNCTION ("ker_rlp_data_req()"); | |
424 PACCESS (rlp_data_req); | |
425 | |
426 switch (GET_STATE (KER)) | |
427 { | |
428 case RLP_CONNECTION_ESTABLISHED: | |
429 switch (rlp_data->ker.UL_Snd_State) | |
430 { | |
431 case IW_WAIT: | |
432 sbm_store_prim (rlp_data_req); | |
433 rlp_data->ker.UL_Snd_State = IW_IDLE; | |
434 return; | |
435 } | |
436 break; | |
437 } | |
438 PFREE (rlp_data_req); | |
439 } | |
440 | |
441 /* | |
442 +------------------------------------------------------------------------------ | |
443 | Function : ker_rlp_getdata_req | |
444 +------------------------------------------------------------------------------ | |
445 | Description : Process primitive RLP_GETDATA_REQ received from L2R. | |
446 | | |
447 | Parameters : rlp_getdata_req - | |
448 | | |
449 | | |
450 | Return : - | |
451 +------------------------------------------------------------------------------ | |
452 */ | |
453 | |
454 | |
455 GLOBAL void ker_rlp_getdata_req | |
456 ( | |
457 T_RLP_GETDATA_REQ *rlp_getdata_req | |
458 ) | |
459 { | |
460 TRACE_FUNCTION ("ker_rlp_getdata_req()"); | |
461 PACCESS (rlp_getdata_req); | |
462 | |
463 switch (GET_STATE (KER)) | |
464 { | |
465 case RLP_CONNECTION_ESTABLISHED: | |
466 case RLP_PENDING_REMAP_REQ: | |
467 case RLP_REMAP_DATA: | |
468 { | |
469 T_RLP_DATA_IND *rlp_data_ind; | |
470 /* | |
471 * processing for states RLP_CONNECTION_ESTABLISHED | |
472 * RLP_PENDING_REMAP_REQ: | |
473 * RLP_REMAP_DATA: | |
474 */ | |
475 | |
476 if (rbm_get_prim | |
477 ( | |
478 &rlp_data_ind, | |
479 &rlp_data->ker.LRReady, | |
480 &rlp_data->ker.LRFull | |
481 )) | |
482 { | |
483 /* | |
484 * primitive is ready for sending to L2R | |
485 */ | |
486 PSENDX (L2R, rlp_data_ind); | |
487 rlp_data->ker.UL_Rcv_State = IW_IDLE; | |
488 TIMERSTOP (TUL_RCV_HANDLE); | |
489 } | |
490 else | |
491 { | |
492 /* | |
493 * no primitive is ready for sending to L2R | |
494 */ | |
495 TIMERSTART(TUL_RCV_HANDLE, rlp_data->ker.T_ul); | |
496 rlp_data->ker.UL_Rcv_State = IW_WAIT; | |
497 } | |
498 break; | |
499 } | |
500 } | |
501 PFREE (rlp_getdata_req); | |
502 } | |
503 | |
504 /* | |
505 +------------------------------------------------------------------------------ | |
506 | Function : ker_rlp_ui_req | |
507 +------------------------------------------------------------------------------ | |
508 | Description : Process primitive RLP_UI_REQ received from L2R. | |
509 | | |
510 | Parameters : rlp_ui_req - | |
511 | | |
512 | | |
513 | Return : | |
514 +------------------------------------------------------------------------------ | |
515 */ | |
516 | |
517 | |
518 GLOBAL void ker_rlp_ui_req | |
519 ( | |
520 T_RLP_UI_REQ *rlp_ui_req | |
521 ) | |
522 { | |
523 TRACE_FUNCTION ("ker_rlp_ui_req()"); | |
524 PACCESS (rlp_ui_req); | |
525 | |
526 switch (GET_STATE (KER)) | |
527 { | |
528 case RLP_ADM_AND_DETACHED: | |
529 /* | |
530 * processing for state RLP_ADM_AND_DETACHED | |
531 */ | |
532 break; | |
533 | |
534 default: | |
535 ker_copy_sdu_to_frame | |
536 ( | |
537 &rlp_ui_req->sdu, | |
538 rlp_data->ker.UI_Frame, | |
539 0 | |
540 ); | |
541 | |
542 rlp_data->ker.UI_State = IS_SEND; | |
543 rlp_data->ker.UI_PBit = 0; | |
544 break; | |
545 } | |
546 PFREE (rlp_ui_req); | |
547 } | |
548 | |
549 /* | |
550 +------------------------------------------------------------------------------ | |
551 | Function : ker_rlp_remap_req | |
552 +------------------------------------------------------------------------------ | |
553 | Description : Process primitive RLP_REMAP_REQ received from L2R. | |
554 | | |
555 | Parameters : rlp_remap_req - | |
556 | | |
557 | | |
558 | Return : | |
559 +------------------------------------------------------------------------------ | |
560 */ | |
561 | |
562 | |
563 GLOBAL void ker_rlp_remap_req | |
564 ( | |
565 T_RLP_REMAP_REQ *rlp_remap_req | |
566 ) | |
567 { | |
568 T_FRAME_NUM vr; | |
569 USHORT oldFrameSize; | |
570 | |
571 TRACE_FUNCTION ("ker_rlp_remap_req()"); | |
572 PACCESS (rlp_remap_req); | |
573 | |
574 switch (GET_STATE (KER)) | |
575 { | |
576 case RLP_CONNECTION_ESTABLISHED: | |
577 /* | |
578 * processing for state RLP_CONNECTION_ESTABLISHED | |
579 */ | |
580 rlp_data->ker.OldFrameSize = rlp_data->ker.FrameSize; | |
581 | |
582 ker_set_frame_size(rlp_remap_req->rate); | |
583 | |
584 if (rlp_data->ker.OldFrameSize NEQ rlp_data->ker.FrameSize) | |
585 { | |
586 ker_get_frame_desc (rlp_data->ker.UI_Frame, | |
587 &rlp_data->ker.UI_FrameDesc); | |
588 | |
589 ker_get_frame_desc (rlp_data->ker.XID_C_Frame, | |
590 &rlp_data->ker.XID_C_FrameDesc); | |
591 | |
592 ker_get_frame_desc (rlp_data->ker.XID_R_Frame, | |
593 &rlp_data->ker.XID_R_FrameDesc); | |
594 | |
595 ker_get_frame_desc (rlp_data->ker.TEST_R_Frame, | |
596 &rlp_data->ker.TEST_R_FrameDesc); | |
597 | |
598 ker_get_frame_desc (rlp_data->ker.REMAP_Frame, | |
599 &rlp_data->ker.REMAP_FrameDesc); | |
600 rlp_data->ker.Poll_xchg = IW_IDLE; | |
601 | |
602 TIMERSTOP (TT_HANDLE); | |
603 TIMERSTOP (TRCVR_HANDLE); | |
604 ker_reset_all_t_rcvs (); | |
605 rbm_reset_all_r_states(); | |
606 TIMERSTOP (TXID_HANDLE); | |
607 | |
608 SET_STATE(KERXID_C, ISW_IDLE); | |
609 | |
610 rlp_data->ker.DTX_SF = DTX_N; | |
611 | |
612 vr = rbm_prepare_remap (rlp_data->ker.FrameSize); | |
613 | |
614 ker_fill_remap_frame(vr); | |
615 | |
616 SET_STATE (KER, RLP_PENDING_REMAP_REQ); | |
617 } | |
618 break; | |
619 | |
620 case RLP_PENDING_REMAP_REQ: | |
621 case RLP_REMAP_DATA: | |
622 /* | |
623 * processing for state RLP_PENDING_REMAP_REQ | |
624 */ | |
625 oldFrameSize = rlp_data->ker.FrameSize; | |
626 | |
627 ker_set_frame_size(rlp_remap_req->rate); | |
628 | |
629 if (oldFrameSize NEQ rlp_data->ker.FrameSize) | |
630 { | |
631 ker_get_frame_desc (rlp_data->ker.UI_Frame, | |
632 &rlp_data->ker.UI_FrameDesc); | |
633 | |
634 ker_get_frame_desc (rlp_data->ker.XID_C_Frame, | |
635 &rlp_data->ker.XID_C_FrameDesc); | |
636 | |
637 ker_get_frame_desc (rlp_data->ker.XID_R_Frame, | |
638 &rlp_data->ker.XID_R_FrameDesc); | |
639 | |
640 ker_get_frame_desc (rlp_data->ker.TEST_R_Frame, | |
641 &rlp_data->ker.TEST_R_FrameDesc); | |
642 | |
643 ker_get_frame_desc (rlp_data->ker.REMAP_Frame, | |
644 &rlp_data->ker.REMAP_FrameDesc); | |
645 rlp_data->ker.Poll_xchg = IW_IDLE; | |
646 | |
647 TIMERSTOP (TT_HANDLE); | |
648 | |
649 vr = rbm_prepare_remap (rlp_data->ker.FrameSize); | |
650 | |
651 ker_fill_remap_frame(vr); | |
652 | |
653 if (GET_STATE (KER) EQ RLP_REMAP_DATA) | |
654 { | |
655 SET_STATE (KER, RLP_PENDING_REMAP_REQ); | |
656 } | |
657 } | |
658 break; | |
659 } | |
660 PFREE (rlp_remap_req); | |
661 } | |
662 | |
663 /* | |
664 +------------------------------------------------------------------------------ | |
665 | Function : ker_rlp_remap_data_res | |
666 +------------------------------------------------------------------------------ | |
667 | Description : Process primitive RLP_REMAP_DATA_RES received from L2R. | |
668 | | |
669 | Parameters : rlp_remap_data_res - | |
670 | | |
671 | | |
672 | Return : - | |
673 +------------------------------------------------------------------------------ | |
674 */ | |
675 | |
676 | |
677 GLOBAL void ker_rlp_remap_data_res | |
678 ( | |
679 T_RLP_REMAP_DATA_RES *rlp_remap_data_res | |
680 ) | |
681 { | |
682 TRACE_FUNCTION ("ker_rlp_remap_data_res()"); | |
683 PACCESS (rlp_remap_data_res); | |
684 | |
685 switch (GET_STATE (KER)) | |
686 { | |
687 case RLP_REMAP_DATA: | |
688 /* | |
689 * processing for state RLP_PENDING_REMAP_REQ | |
690 */ | |
691 if (!ker_send_remap_data ()) | |
692 { | |
693 PALLOC (rlp_remap_cnf, RLP_REMAP_CNF); | |
694 | |
695 sbm_reset_after_remap | |
696 ( | |
697 rlp_data->ker.FrameSize, | |
698 rlp_data->ker.RemapNr | |
699 ); | |
700 | |
701 PSENDX (L2R, rlp_remap_cnf); | |
702 SET_STATE (KER, RLP_CONNECTION_ESTABLISHED); | |
703 } | |
704 break; | |
705 } | |
706 PFREE (rlp_remap_data_res); | |
707 } | |
708 |