comparison src/g23m-gprs/grlc/grlc.h @ 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 : GRLC
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 : Definitions for entity GRLC.
18 +-----------------------------------------------------------------------------
19 */
20
21 #ifndef GRLC_H
22 #define GRLC_H
23
24 /*
25 * defines the user of the vsi interface
26 */
27 #define VSI_CALLER GRLC_handle,
28 #define VSI_CALLER_SINGLE GRLC_handle
29
30 /*
31 * Macros
32 */
33
34 #define ENCODE_OFFSET 0 /* PALLOC SDU*/
35
36 /*
37 * Bit and byte length for encoding/decoding
38 */
39
40 #define BIT_UL_CTRL_BLOCK_MAC_HEADER 8
41 #define BIT_UL_CTRL_BLOCK_CONTENTS 176
42 #define BIT_UL_CTRL_BLOCK (BIT_UL_CTRL_BLOCK_MAC_HEADER+BIT_UL_CTRL_BLOCK_CONTENTS)
43
44 #define BYTE_UL_CTRL_BLOCK (BIT_UL_CTRL_BLOCK/BITS_PER_BYTE)
45
46
47 /*
48 * The following definitions are used for the management of single block
49 * sending without TBF establishment.
50 *
51 * TC holds a queue of size MSG_OWNER_MAX_NUM to buffer the single blocks
52 * requested by the services. Only services MEAS and CS can request single
53 * blocks in parallel. In case service CTRL has requested a single block,
54 * services MEAS and CS are not allowed to request any single blocks.
55 *
56 * Service CS uses the same buffer as the service CTRL. Only one single block
57 * can be stored for both services. The service MEAS has an individual buffer.
58 * At this time only one single block can be stored for this service but we are
59 * free to increase the size just by increasing the value of MAX_CTRL_BLK_NUM.
60 */
61 #define MAX_CTRL_BLK_NUM 5 /* number of single blocks that can be stored at */
62 /* the same time */
63
64 #define BLK_INDEX_CTRL 0 /* Packet Cell Change Failure */
65 #define BLK_INDEX_CS 0 /* Packet Measurement Report (NC Measurements) */
66 #define BLK_INDEX_TM 1 /* Packet Resource Request (Reallocation) */
67 #define BLK_INDEX_MEAS 2 /* Packet Measurement Report (EXT Measurements) */
68
69
70 typedef UBYTE T_BLK_OWNER;
71
72 #define BLK_STATE_NONE 0 /* no control message associated */
73 #define BLK_STATE_ALLOCATED 1 /* control message is allocated */
74 #define BLK_STATE_SENT_REQ 2 /* control message is sent, waiting for response */
75
76 typedef UBYTE T_BLK_STATE;
77
78 /*
79 * Constants
80 */
81
82 /*
83 * Disable Get State traces only for target enviroment
84 */
85
86 #ifdef _TARGET_
87 #undef GET_STATE
88 #define GET_STATE(P) (ENTITY_DATA->P state)
89 #endif
90
91
92 /*
93 * Define the size of the GRLC queue in frame
94 */
95 #define PEI_PRIM_QUEUE_SIZE 32
96
97 /*
98 * Defines the size of the queue which do a tempory save of llc primitives
99 */
100
101 #ifdef _TARGET_
102 #define PRIM_QUEUE_SIZE 20
103 #else
104 #define PRIM_QUEUE_SIZE 10
105 #endif/*TARGET*/
106
107
108 #define GMM_PRIM_QUEUE_SIZE 2
109 #define MAX_WINDOW_SIZE 64
110
111
112 #define PRIM_QUEUE_SIZE_TOTAL (PRIM_QUEUE_SIZE+GMM_PRIM_QUEUE_SIZE)
113
114 #define MAX_LLC_PDU_SIZE 1560
115 #define MAX_GRLC_USER_DATA (MAX_WINDOW_SIZE * 50) /* window size * user data with CS4 */
116 #define FN_MAX 0x297000
117
118 /* MAC HEADER TYPE*/
119 #define RLC_DATA_BLOCK 0
120 #define CTRL_BLK_NO_OPT 1
121 #define CTRL_BLK_OPT 2
122
123 /*
124 * Size of Next Poll Array
125 */
126 #define NEXT_POLL_ARRAY_SIZE 8
127 #define WIN_SIZE 64 /*window size of rlc*/
128 /*
129 * Size of Poll Type Array
130 */
131 #define POLL_TYPE_ARRAY_SIZE 8
132
133
134
135
136 /*
137 TBF BSN RANGE
138 */
139 #define NR_OF_PDUS_PER_RLCMAC_BLOCK 8 /* max. number of pdus in one rlc mac block */
140 #define TLLI_SIZE 4 /* tlli size in UBYTE */
141
142 #define WIN_MOD 63
143 #define BSN_MAX 127
144
145 #define RD_LI_CNT_MAX 8 /* max. number of pdus in one rlc mac block in downlink direction*/
146
147
148 #define OFFSET_CTRL_BLOCK_IDX 200
149
150 /*
151 end constants for RU
152 */
153 #define MAX_UL_TN 4 /* max. number of timeslots supported in uplink */
154
155 /*
156 start constants for RD
157 */
158
159
160 #define RD_NEXT_ARRAY_DATA_SIZE 50 /* valid for all coding schemes */
161
162 #define ACK_CNT_MEAS_RPT_FIRST 2
163 #define ACK_CNT_NORMAL 1
164
165 /*
166 end constants for RD
167 */
168
169 /*
170 start constants for TM
171 */
172 #define RADIO_PRIO_4 3
173
174 /*
175 end constants for TM
176 */
177
178 /*
179 start constants for TPC
180 */
181 #define MIN_PCL_DCS1800 28 /* minimum power control level DCS 1800 */
182 #define MAX_PCL_DCS1800 29 /* maximum power control level DCS 1800 */
183 #define MIN_PCL_GSM900 31 /* minimum power control level GSM 900 */
184 #define MAX_PCL_GSM900 0 /* maximum power control level GSM 900 */
185 #define MIN_PCL_PCS1900 21 /* minimum power control level PCS 1900 */
186 #define MAX_PCL_PCS1900 22 /* maximum power control level PCS 1900 */
187
188 #define GAMMA_0_DCS1800 36
189 #define GAMMA_0_GSM900 39
190 #define GAMMA_0_PCS1900 36
191
192 #define TPC_SWITCHED_ON 0xFF /* normal TPC process is applied */
193 #define TPC_ALFGAM_NOT_PRESENT 0xFF /* the ALPHA and GAMMA values are */
194 /* marked as not present */
195
196 #define CLIP_T_AVG(x) ( (x) > 25 ? 25 : (x) )
197 #define CLIP_ALPHA(x) ( (x) > 10 ? 10 : (x) )
198 #define CLIP_BS_PAG_BLKS_RES(x) ( (x) > 12 ? 0 : (x) )
199 #define CLIP_BS_PRACH_BLKS(x) ( (x) > 12 ? 0 : (x) )
200
201 #define M_TPC_TRACE_STATIC 0x01 /* trace TPC parameter everytime tpc_update_pch is called */
202 #define M_TPC_TRACE_CHANGE 0x02 /* trace TPC parameter only in case at least one PCL changes */
203 #define M_TPC_TRACE_FUNCTION 0x04 /* trace mask for parameters of maca_power_control */
204 /*
205 end constants for TPC
206 */
207
208 /*
209 start constants for MEAS
210 */
211 #define MEAS_ACRCY 1000 /* accuracy */
212 /*
213 end constants for MEAS
214 */
215
216
217 #define NOT_SET 255
218
219 /*
220 * Service definitions. Used to access service data with GET/SET_STATE.
221 */
222
223
224 #define TM tm.
225 #define RD rd.
226 #define RU ru.
227 #define GFF gff.
228
229
230
231
232 /*
233 * Timer definitions (also used by GRLC_PEI.C)
234 */
235
236 typedef enum
237 {
238 T3164 = 0, /* handled by service RU */
239 T3166, /* handled by service RU */
240 T3168, /* handled by service TM */
241 T3180, /* handled by service RU */
242 T3182, /* handled by service RU */
243 T3184, /* handled by service RU */
244 T3188, /* handled by service TM */
245 T3190, /* handled by service RD */
246 T3192, /* handled by service RD */
247 T3314, /* handled by service RU */
248
249 TIMER_COUNT /* !!! always the last entry !!! */
250
251 } T_TIMER_INDEX;
252
253 /*#define T3198 no timer */ /* handled by service RU: used relative to fn, defined in T_RLC_DATA_BLOCK: T3198 = BS_CV_MAX * block periods: not timer is used */
254
255
256 #define T3164_VALUE 5000 /* ms */
257 #define T3166_VALUE 5000 /* ms */
258 /* T3168_VALUE - assigned in system info (in GPRS Cell Options)
259 range 500,1000,...4000ms */
260 #define T3180_VALUE 5000 /* ms */
261 #define T3182_VALUE 5000 /* ms */
262 #define T3184_VALUE 5000 /* ms */
263 #define T3188_VALUE 5000 /* ms */
264 #define T3190_VALUE 5000 /* ms */
265
266 /*#define T3192_VALUE - assigned in system info (in GPRS Cell Options)
267 range 500,1000,...4000ms */
268 /* T3198_VALUE - value depends BS_CV_MAX, there may be some inctances of this timer,
269 how many? the duration is not very long (asumption) - how long?
270 handling with rlc_uplink/downlink functions and a table? */
271
272 /*
273 * Service name definitions for trace purposes. The service abbrevation
274 * (e.g. RU) has to be the same as above for the service definitions.
275 */
276 #ifndef NTRACE
277
278 #define SERVICE_NAME_TM "TM"
279 #define SERVICE_NAME_RU "RU"
280 #define SERVICE_NAME_RD "RD"
281 #define SERVICE_NAME_GFF "GFF"
282
283
284 #endif /* !NTRACE */
285
286
287
288 /*
289 * Service TM
290 */
291 #define TM_ACCESS_DISABLED 0
292 #define TM_ACCESS_PREPARED 1
293 #define TM_PIM 2
294 #define TM_PAM 3
295 #define TM_PTM 4
296 #define TM_WAIT_4_PIM 5
297
298 /*
299 * Service RD
300 */
301
302 #define RD_NULL 0
303 #define RD_ACK 1
304 #define RD_REL_ACK 2
305 #define RD_UACK 3
306 #define RD_REL_UACK 4
307 #define RD_NET_REL 5
308 #define RD_WAIT_FOR_STARTING_TIME_ACK 6
309 #define RD_WAIT_FOR_STARTING_TIME_UACK 7
310 #define RU_NET_REL 8
311
312 /*
313 * Service RU
314 */
315
316 #define RU_NULL 0 /* not active state of RU */
317 #define RU_ACK 1 /* acknowledged mode state of RU */
318 #define RU_REL_ACK 2 /* release state in acknowledged mode of RU, i.e. cv=0 is transmitted but not acked */
319 #define RU_SEND_PCA 3 /* send packet control acknowledgment state of RU in acknowledged and unacknowledged mode,
320 i.e all blocks are transmitted and acked, waiting for of FN for transmiitng the packet control ack message */
321 #define RU_UACK 4 /* unacknowledged mode state of RU */
322 #define RU_REL_UACK 5 /* release state in unacknowledged mode of RU, i.e. cv=0 is transmitted but not acked
323 (i.e receiving of packet uplink ack/nack with fbi=1) */
324 #define RU_WAIT_FOR_FIRST_CALL_ACK 6
325 #define RU_WAIT_FOR_FIRST_CALL_UACK 7
326
327 /*
328 * Service GFF
329 */
330
331
332 #define GFF_ACTIVE 0
333 #define GFF_DEACTIVE 1
334 #if defined REL99 AND defined TI_PS_FF_TBF_EST_PACCH
335 #define GFF_TWO_PHASE 2
336 #endif
337
338
339 /*
340 * states for grlc_data->tc.send_grlc_ready_ind
341 */
342 #define SEND_A_GRLC_READY_IND 0
343 #define WAIT_FOR_LLC_DATA_REQ 1
344 #define PRIM_QUEUE_FULL 2
345
346 /*
347 * states for Ready Timer
348 */
349 #define STANDBY_STATE 0
350 #define READY_STATE 1
351
352 typedef UBYTE T_READY_TIMER_STATE;
353
354 #define READY_TIMER_HANDLING_DISABLED 0
355 #define READY_TIMER_HANDLING_ENABLED 1
356
357 typedef UBYTE T_READY_TIMER_HANDLING;
358
359 /*==== TYPES ======================================================*/
360
361 /*
362 * GRLC global typedefs
363 */
364
365 /* enums */
366
367 typedef UBYTE T_PRIM_TYPE;
368
369
370 typedef enum
371 {
372 CS_ZERO = 255,
373 CS_1 = 0,
374 CS_2 = 1,
375 CS_3 = 2,
376 CS_4 = 3
377 } T_CODING_SCHEME;
378
379
380
381 typedef enum
382 {
383 TFI_CHANGE_NULL, /* no tfi modification needed after starting time is elapsed */
384 TFI_CHANGE_UL, /* uplink tfi shall modified after starting time is elapsed */
385 TFI_CHANGE_DL, /* downlink tfi shall modified after starting time is elapsed */
386 TFI_CHANGE_ALL /* uplink and downlink tfi shall modified after starting time is elapsed */
387 } T_TFI_CHANGE;
388
389 typedef enum
390 {
391 TBF_TYPE_NULL,
392 #if defined REL99 AND defined TI_PS_FF_TBF_EST_PACCH
393 TBF_TYPE_TP_ACCESS,
394 #endif
395 TBF_TYPE_UL,
396 TBF_TYPE_DL,
397 TBF_TYPE_CONC
398 } T_TBF_TYPE;
399
400 /*
401 * Please keep the numbering scheme, so that bit operations can be used.
402 */
403 #define REL_TYPE_NULL 0 /* no release of TBF requested */
404 #define REL_TYPE_DL 1 /* release of DL TBF requested */
405 #define REL_TYPE_UL 2 /* release of UL TBF requested */
406 #define REL_TYPE_DL_UL 3 /* release of DL and UL TBF requested */
407
408 typedef UBYTE T_REL_TYPE;
409
410
411
412
413 /*start enum for rd*/
414 typedef enum /* T_NEXT_POLL_BLOCK_TYPE*/
415 {
416 NEXT_POLL_BLOCK_NONE,
417 NEXT_POLL_BLOCK_DL_DATA,
418 NEXT_POLL_BLOCK_CTRL
419 }T_NEXT_POLL_BLOCK_TYPE;
420
421 /*
422 * used by rd : vn array (enum is using ulong)
423 */
424 #define VN_RECEIVED 1
425 #define VN_INVALID 255
426
427 /*start enum for ru*/
428 typedef enum /* T_PAN_CNT*/
429 {
430 PAN_INC,
431 PAN_DEC
432 }T_PAN_CNT;
433
434 #define VB_NACKED 0 /* negative acknowledged */
435 #define VB_ACKED 1 /* positive acknowledged */
436 #define VB_PENDING_ACK 2 /* not jet acknowledged */
437 #define VB_FIRST_SEG_TXD 3
438 #define VB_INVALID 255 /* outside window */
439
440
441 typedef enum /* T_LAST_BSN*/
442 {
443 LAST_BSN_IS_SENT, /* final uplink data block(cv=0) is sent(confirmed by l1)*/
444 LAST_BSN_STALL_CONDITION, /* stall indication in uplink, ack or uack mode */
445 LAST_BSN_RESUME_UACK_MODE_AFTER_SI, /* in rlc uack, data transfer is allowed after SI */
446 LAST_BSN_NOT_BULIT =255 /* final data block is not sent */
447 }T_LAST_BSN;
448
449 /*end um for ru*/
450
451 /*start enum for GFF*/
452
453 typedef enum /* RLC_STATUS_TYPE*/
454 {
455 RLC_STATUS_NULL = 0,
456 RLC_STATUS_UL = 1,
457 RLC_STATUS_DL = 2,
458 RLC_STATUS_BOTH = 3
459 }T_RLC_STATUS_TYPE;
460 /*end um for GFF*/
461
462
463 /*
464 * Structure
465 */
466
467 typedef enum /* T_FA_TYPE*/
468 {
469 FA_NO_CURRENT,
470 FA_NO_NEXT,
471 FA_BITMAP,
472 FA_REPEAT
473 }T_FA_TYPE;
474
475 typedef struct /* parameterts of one fixed alloction*/
476 {
477 T_CGRLC_fix_alloc_struct alloc;
478 USHORT ul_res_sum; /* number of uplink resources during this fixed allocation*/
479 ULONG alloc_start_fn;
480 ULONG alloc_end_fn;
481 } T_FA_ALLOC;
482
483
484 typedef struct /* T_FA_MANAG*/
485 {
486 T_FA_TYPE fa_type;
487 T_FA_ALLOC current_alloc;
488 T_FA_ALLOC next_alloc;
489 BOOL repeat_alloc;
490 USHORT tbf_oct_cnt; /* number of octets, to be transmitted during the current tbf*/
491 USHORT tbf_oct_cap_remain; /* remainig capacity in octetes of current fix allocation*/
492 USHORT ul_res_used; /* number of used uplink resources(timeslots) used in fixed allocation*/
493 USHORT ul_res_remain; /* number of REMAINING uplink resources(timeslots) in fixed allocation*/
494 USHORT ul_res_sum; /* number of total uplink resources in fix alloc mode during one tbf*/
495 } T_FA_MANAG;
496
497
498
499
500 typedef struct /* T_UL_TBF */
501 {
502 ULONG tlli; /* tlli that is valid for activ TBF */
503 UBYTE access_type; /* access type of the current tbf*/
504 UBYTE mac_mode;
505 UBYTE rlc_mode; /* is estimated in tc_start_access */
506 T_CODING_SCHEME cs_type;
507 UBYTE ti; /* =1 tlli field present in data block, else not present*/
508 BOOL tlli_cs_type; /* coding scheme for rlc data blocks including TLLI*/
509 UBYTE prio; /* Radio Prioritity from grlc_data_req or
510 grlc_unitdata_req; should be set in tm_start_access */
511 UBYTE ac_class; /* access class and radio priority of the network */
512 UBYTE nr_blocks; /* set in ts_start_access; CS_1 is used */
513 /* 4 Access Burst or RLCMAC-Block,
514 maybe storing is not necessary*/
515 UBYTE nts; /* number of timeslots allocated for tbf */
516 UBYTE ts_mask; /* timeslot mask */
517 UBYTE bs_cv_max;
518 USHORT rlc_db_granted; /* indicates if close ended or open ended tbf is used */
519
520 T_FA_MANAG fa_manag; /* contains all fixed alloction parameters*/
521 } T_UL_TBF;
522
523
524 typedef struct /* T_DL_TBF */
525 {
526 ULONG tlli; /* tlli that is valid for activ TBF */
527 UBYTE mac_mode;
528 UBYTE rlc_mode; /* is estimated in tc_start_access */
529 T_CODING_SCHEME cs_type;
530 UBYTE nts; /* number of timeslots allocated for tbf */
531 UBYTE ts_mask; /* timeslot mask */
532 UBYTE t3192_val;
533 UBYTE trans_id; /* transaction id */
534 } T_DL_TBF;
535
536
537 typedef struct /* T_TBF_CTRL */
538 {
539 T_TBF_TYPE tbf_type;
540 ULONG start_fn;
541 ULONG end_fn;
542 ULONG rlc_oct_cnt;
543 UBYTE pdu_cnt;
544 UBYTE vs_vr;
545 UBYTE va_vq;
546 USHORT cnt_ts;
547 UBYTE tfi;
548 UBYTE ack_cnt;
549 UBYTE fbi;
550 UBYTE ret_bsn;
551 } T_TBF_CTRL;
552
553
554
555
556 typedef struct /* T_PRIM_QUEUE */
557 {
558 UBYTE next; /* index of following entry; 0xff if no primitive follows */
559 UBYTE previous; /* index of previous entry; 0xff first primitive */
560 T_GRLC_DATA_REQ * prim_ptr; /* pointer to primitive */
561 T_PRIM_TYPE prim_type; /* GRLC_UNITDATAreq or GRLC_DATAreq*/
562 BOOL cv_status; /* is set if pdu is included in the count down procedure */
563 BOOL rlc_status; /* is set if transmission of the pdu has started*/
564 BOOL re_allocation;/* in front of this pdu is a reallocation necessary */
565 BOOL start_new_tbf;/* marks the first llc of a new tbf*/
566 UBYTE last_bsn; /* indicates the last bsn of th rlc data block, which belongs to the pdu */
567 } T_PRIM_QUEUE;
568
569
570
571 typedef struct /* T_NEXT_POLL_ARRAY */
572 {
573 UBYTE cnt;
574 UBYTE next;
575 UBYTE ctrl_ack;
576 ULONG fn;
577 UBYTE poll_type[POLL_TYPE_ARRAY_SIZE];
578 }T_NEXT_POLL_ARRAY;
579
580 typedef struct /* T_TM_B_DATA : used in Testmode B */
581 {
582 USHORT block_status; /* stores the block_status received on downlink */
583 UBYTE e_bit; /* stores the e_bit received on downlink */
584 UBYTE payload[50]; /* stores the payload received on downlink */
585 }T_TM_B_DATA;
586
587 typedef struct /* T_TESTMODE "test mode" */
588 {
589 UBYTE mode; /* test mode, where
590 * 0x00 means no test mode
591 * 0x01 means type A
592 * 0x02 means type B
593 */
594 ULONG n_pdu; /* number of PDUs which are to be transmitted */
595 UBYTE dl_ts_offset; /* Downlink Timeslot Offset, only for CGRLC_LOOP */
596 USHORT prbs_shift_reg; /* pseudo random bit sequence(prbs)
597 * shift register
598 */
599 UBYTE * ptr_test_data; /*
600 * reference to data which are callaculated for
601 * the current framenumber. All slots related to the same
602 * frame number have to have the same data.
603 */
604 UBYTE no_data_calculation; /*
605 * Is set when the prbs for the current
606 * frame number is already calculated
607 */
608 T_TM_B_DATA rec_data[2]; /* for Testmode B: received data is stored. Only 2 timeslots
609 * are supported. The data will be stored sequentialy depending upon
610 * Downlink Timeslot Offset value
611 */
612 } T_TESTMODE;
613
614
615
616
617
618
619
620 typedef struct /* saves all downlink data blocks*/
621 {
622 USHORT rx_no;
623 T_dl_data dl_data[MAC_MAX_DL_DATA_BLCKS];
624 } T_dl_struct;
625
626
627
628 typedef struct /* saves struct of downlink data blocks*/
629 {
630 T_dl_struct data_ptr;
631 ULONG fn;
632 } T_FUNC_DL_BLOCKS;
633
634
635 typedef struct /* functional interface: RLC_UPLINK, RLC_DOWNLINK, MACA_POWER_CONTROL */
636 {
637 T_FUNC_DL_BLOCKS dl_blocks;
638 T_MAC_DATA_IND mac_data_ind;
639 T_MAC_READY_IND mac_ready_ind;
640 T_MAC_PWR_CTRL_IND mac_pwr_ctrl_ind;
641 } T_FUNC_INTERFACE;
642
643
644
645
646
647 /* structure for service internal data */
648
649
650
651
652
653 /*start of structs for RU*/
654
655
656 typedef struct
657 {
658 U8 mac; /*< mac header */
659 U8 ti; /*< TLLI Indicator (TI) bit */
660 U8 e_bit; /*< Extended bit */
661 U8 li_cnt; /*< Number of LIs */
662 U8 li_me[NR_OF_PDUS_PER_RLCMAC_BLOCK]; /*< LI, M and e-Bit */
663 } T_U_DATA;
664
665
666 typedef struct /* T_RLC_DATA*/
667 {
668 T_sdu * ptr_data;
669 USHORT l_buf;
670 USHORT o_buf;
671 } T_RLC_DATA;
672
673 typedef struct /* T_RLC_DATA_BLOCK*/
674 {
675 USHORT block_status;
676 T_U_DATA header; /*stores the header of the rlc data block*/
677 UBYTE data_cnt; /*number of pdus in the rlc data block*/
678 T_RLC_DATA data[NR_OF_PDUS_PER_RLCMAC_BLOCK]; /*stores the pointers of the sdus*/
679 ULONG T3198; /*timer T3198, value= BS_CV_MAX block periods*/
680 UBYTE cnt_pl_trans; /* counts the number of transmissions over physical link*/
681 } T_RLC_DATA_BLOCK;
682
683 typedef struct /* T_PL_RETRANS*/
684 {
685 UBYTE cnt; /* number of transmitted rlc/mac blocks */
686 UBYTE blk[MAX_UL_TN]; /* stores the bsn(data block) or ctrl block nr */
687 } T_PL_RETRANS;
688
689
690
691 /*end of structs for RU*/
692
693 /*start of structs for RD*/
694
695
696
697
698 typedef struct /*T_NEXT_ARRAY*/
699 {
700 ULONG * next; /*zeig auf next struct vom typ T_NEXT_ARRAY*/
701 USHORT len;
702 UBYTE data[RD_NEXT_ARRAY_DATA_SIZE];
703 } T_NEXT_ARRAY;
704
705 typedef struct /* T_DATA_ARRAY */ /*for received data blocks*/
706 {
707 BOOL pdu_complete; /* indicates if the last part of the data block is a complete pdu*/
708 UBYTE pdu_cnt; /* nr of complete pdus in the current data block*/
709 T_NEXT_ARRAY * first; /* indicates the first element(first next_array) of the pdu */
710 } T_DATA_ARRAY;
711
712
713 /*end of structs for RD*/
714
715
716
717 /*start of structs for GFF*/
718
719
720
721
722 typedef struct /* T_RLC_VALUES*/
723 {
724 USHORT sdu_len;
725 USHORT cnt_ts;
726 } T_RLC_VALUES;
727
728
729 /*end of structs for GFF*/
730
731
732
733 /* data base for control messages */
734 typedef struct /* T_UL_CTRL_BLOCK */
735 {
736 T_BLK_OWNER owner;
737 T_BLK_STATE state;
738 UBYTE data[BYTE_UL_CTRL_BLOCK];
739 } T_UL_CTRL_BLOCK;
740
741 typedef UBYTE T_BLK_INDEX;
742
743
744
745 typedef struct /* T_UL_CTRL_BLOCK_ARRAY */
746 {
747 T_UL_CTRL_BLOCK blk[MAX_CTRL_BLK_NUM];
748 T_BLK_INDEX seq[MAX_CTRL_BLK_NUM];
749 } T_UL_CTRL_BLOCK_ARRAY;
750
751
752 typedef struct
753 {
754 USHORT l_buf;
755 USHORT o_buf;
756 UBYTE buf [2 * BYTE_UL_CTRL_BLOCK];
757 /* CAN's suggestion never more then 2 blocks */
758 /* or 8 blocks? ID's suggestion 'B_SIZE_D_PAGING_REQ\8+1' */
759
760 } T_CTRLBUF;
761
762
763
764 typedef struct /* T_TM_DATA */
765 {
766 UBYTE state;
767 UBYTE disable_class; /* tm_grlc_init sets it to CR, updated with cgrlc_disable_req*/
768 UBYTE n_res_req; /* number of sended packet resource request */
769 UBYTE n_acc_req_procedures; /* number of started access procedures */
770 T_UL_CTRL_BLOCK_ARRAY ul_ctrl_blk; /* holds all relevant information for */
771 /* sending uplink control blocks */
772
773 UBYTE start_of_new_tbf; /* index where the new TBF starts
774 0xff means not used */
775 BOOL send_grlc_ready_ind; /* GRLC_READY_IND have to be sent if this variable is TRUE
776 when a internal signal sig_ru_tm_prim_delete
777 was received by TM. */
778 UBYTE change_mark; /* received from GRR, needed for sending in packet resource request*/
779 #if defined REL99 AND defined TI_PS_FF_TBF_EST_PACCH
780 BOOL pacch_prr_pca_sent; /* Use during release , Prr,pca was sent */
781 #endif
782
783 T_CGRLC_freq_param freq_param; /* frequency parameter of the current TBF */
784
785 USHORT max_grlc_user_data; /* maximum nr of byte which can be stored in uplink in the LLC data queue*/
786
787 #ifndef NTRACE
788 char *name;
789 char *state_name;
790 #endif
791 } T_TM_DATA;
792
793 typedef struct /* T_ACK_CTRL */
794 {
795 UBYTE cnt_meas_rpt;
796 UBYTE cnt_other;
797 } T_ACK_CTRL;
798
799 typedef struct /* T_RD_DATA */
800 {
801 /*UBYTE*/
802 UBYTE state;
803 UBYTE vq;
804 UBYTE vr;
805 UBYTE li_cnt;
806 UBYTE rlc_data_len;
807 UBYTE f_ack_ind;
808 UBYTE ssn;
809 UBYTE last_bsn;
810 UBYTE bsn_pdu_start;
811 UBYTE cnt_sent_f_ack; /* counts number of sent final downlink ack nacks*/
812
813 /*USHORT*/
814 USHORT pdu_len;
815 /*ULONG*/
816 ULONG fn_p_tbf_rel;
817 /*POINTER*/
818 /*BOOL*/
819 BOOL ch_req_in_ack_prog; /*indicates weather the channel request is programmed in the last packet downlink ack/nack or not*/
820 BOOL channel_req; /*indicates weather the channel request is sent in packet downlink ack/naok or not*/
821 BOOL pdu_complete;
822 BOOL inSequence;
823 BOOL release_tbf;
824 BOOL v_next_tbf_params; /* indicates if next_tbf_params is valid or not*/
825 BOOL ignore_pdu; /* if true pdu shall be ignored, max_pdu_size reached and until next pdu bound every thing is discarded */
826
827 /*Type*/
828 UBYTE rlc_mode;
829 T_DATA_ARRAY data_array[WIN_SIZE];
830 T_NEXT_ARRAY *ptr_grlc;
831 T_GRLC_DATA_IND grlc_data_ind;
832 T_NEXT_POLL_BLOCK_TYPE next_poll_block;
833 T_CODING_SCHEME cs_type;
834 T_DL_TBF next_tbf_params; /* stores downlink parameters in case of tbf starting time*/
835
836 /*array*/
837 UBYTE vn[WIN_SIZE];
838 USHORT li[RD_LI_CNT_MAX];
839 UBYTE m[RD_LI_CNT_MAX];
840 T_ACK_CTRL ack_ctrl;
841
842 #ifndef NTRACE
843 char *name;
844 char *state_name;
845 #endif
846 } T_RD_DATA;
847
848 typedef struct /* T_RU_DATA */
849 {
850 /*DECLARATIONS*/
851 /*UBYTE*/
852 UBYTE state;
853 UBYTE nts;
854 UBYTE nts_max;
855 UBYTE ti;
856 UBYTE next_prim;
857 UBYTE active_prim;
858 UBYTE vs;
859 UBYTE va;
860 UBYTE bsn_ret;
861 UBYTE last_si_block;
862 UBYTE cv;
863 UBYTE N3104;
864 UBYTE N3104_MAX;
865 UBYTE count_cv_0;
866 UBYTE nr_nacked_blks; /*number of negative acked blocks*/
867 UBYTE pdu_cnt; /* nr of pdus per tbf*/
868 UBYTE pdu_sent; /* nr of sent pdus per tbf, but stil not acknowlegded*/
869 UBYTE pdu_rem; /* nr of remaining pdus per tbf*/
870 UBYTE pdu_boundaries; /*nr of need boundaries*/
871 /*USHORT*/
872 USHORT block_status;
873 USHORT poll_tn;
874 USHORT rlc_data_size;
875 USHORT sdu_len;
876 USHORT sdu_off;
877 USHORT rlc_octet_cnt;
878 USHORT tbc; /*number of rlc data blocks during the tbf, which is requested to send*/
879 USHORT cnt_ts;
880 /*ULONG*/
881 ULONG poll_fn;
882 /*BOOL*/
883 BOOL tlli_cs_type;
884 BOOL cd_active; /*indicates if the countdown procedure is active*/
885 BOOL reorg_l1_needed; /* set to true if data blocks in l1 queue must be recalculated*/
886 BOOL v_next_tbf_params; /* indicates if next_tbf_params is valid or not*/
887 BOOL first_usf; /* true: wait for the first valid usf. FALSE: first usf was read*/
888 /*Type*/
889 UBYTE rlc_mode;
890 T_CODING_SCHEME cs_type;
891 T_PL_RETRANS pl_retrans_current; /*status of current block, requested blocks to be send by PL*/
892 T_LAST_BSN last_bsn; /* needed for starting timer t3182 */
893 /*array*/
894 T_RLC_DATA_BLOCK rlc_data[WIN_SIZE]; /*contains the rlc data block, including header and pointer to the data*/
895 UBYTE vb[WIN_SIZE];
896 T_UL_TBF next_tbf_params; /* stores uplink parameters in case of tbf starting time*/
897
898
899 UBYTE write_pos_index;
900 T_ul_data ul_data[MAX_UL_TN];
901 BOOL release_tbf;
902 #if defined REL99 AND defined TI_PS_FF_TBF_EST_PACCH
903 BOOL tbf_re_est; /*TBF Re-establish on PACCH*/
904 #endif
905
906 #ifndef NTRACE
907 char *name;
908 char *state_name;
909 #endif
910 } T_RU_DATA;
911
912
913
914
915 typedef struct /* T_GFF_DATA */
916 {
917 UBYTE state;
918 T_RLC_STATUS_TYPE rlc_status;
919
920 #ifndef NTRACE
921 char *name;
922 char *state_name;
923 #endif
924 } T_GFF_DATA;
925
926 typedef ULONG T_SIGN_VAR_VALUE;
927 typedef USHORT T_SIGN_VAR_INDEX;
928
929 typedef struct /* T_SIGN_VAR */
930 {
931 T_SIGN_VAR_VALUE value; /* current signal variance */
932 T_SIGN_VAR_INDEX index; /* mean index */
933 } T_SIGN_VAR;
934
935 typedef USHORT T_C_INDEX;
936 typedef USHORT T_C_VALUE;
937
938 typedef struct /* T_C_FILTER */
939 {
940 T_C_VALUE value; /* current C value */
941 T_C_INDEX index; /* iteration index */
942 } T_C_FILTER;
943
944 typedef struct
945 {
946 USHORT total; /* Total number of bits */
947 USHORT fault; /* Number of faulty bits */
948 } T_BE_INFO;
949
950 typedef struct
951 {
952 UBYTE num_dl_blck; /* Number of downlink data blocks */
953 T_BE_INFO be_info[MAC_MAX_DL_DATA_BLCKS];
954 /* Bit error information */
955 } T_BER_IND;
956
957 typedef ULONG T_BER_VALUE;
958 typedef USHORT T_BER_INDEX;
959
960 typedef struct /* T_BER_AVG */
961 {
962 T_BER_VALUE value; /* current BER value in % */
963 T_BER_INDEX index; /* iteration index */
964 } T_BER_AVG;
965
966 #if ( ! ( MAC_MAX_TIMESLOTS == CGRLC_MAX_TIMESLOTS ) )
967 #error MAC_MAX_TIMESLOTS == CGRLC_MAX_TIMESLOTS required
968 #endif
969
970 #if ( ! ( MAC_RXLEV_NONE == CGRLC_RXLEV_NONE ) )
971 #error MAC_RXLEV_NONE == CGRLC_RXLEV_NONE required
972 #endif
973
974 #if ( ! ( MAC_RXLEV_MIN == CGRLC_RXLEV_MIN ) )
975 #error MAC_RXLEV_MIN == CGRLC_RXLEV_MIN required
976 #endif
977
978 #if ( ! ( MAC_RXLEV_MAX == CGRLC_RXLEV_MAX ) )
979 #error MAC_RXLEV_MAX == CGRLC_RXLEV_MAX required
980 #endif
981
982 typedef enum /* T_PCH_IDX */
983 {
984 PCH_IDX_A = 0,
985 PCH_IDX_B = 1,
986
987 PCH_IDX_MAX = 2
988 } T_PCH_IDX;
989
990 typedef struct /* T_PCH_ARRAY */
991 {
992 UBYTE pch[MAC_MAX_TIMESLOTS];
993 } T_PCH_ARRAY;
994
995 typedef struct /* T_PCH_BUFFER */
996 {
997 T_PCH_IDX pch_idx;
998 T_PCH_ARRAY pch_array[PCH_IDX_MAX];
999 } T_PCH_BUFFER;
1000
1001 typedef struct /* T_MS_PWR_CAP */
1002 {
1003 const UBYTE *p_control; /* power control level -> output power */
1004 SHORT pwr_min; /* minimum nominal output power in the cell */
1005 SHORT gamma_0; /* GAMMA 0 */
1006 } T_MS_PWR_CAP;
1007
1008 typedef struct /* T_TPC_DATA */
1009 {
1010 UBYTE fix_pcl; /* fixed PCL */
1011
1012 BOOL v_fix_pwr_par;
1013 T_CGRLC_pwr_ctrl_param fix_pwr_par; /* fixed power parameter */
1014
1015 T_CGRLC_pwr_ctrl_param pwr_par; /* power control parameter */
1016 T_CGRLC_glbl_pwr_ctrl_param glbl_pwr_par; /* global power control parameter */
1017
1018 T_PCH_BUFFER pch_buffer; /* power control level buffer */
1019
1020 #if !defined (NTRACE)
1021
1022 UBYTE n_tpc_trace;
1023
1024 #endif /* #if !defined (NTRACE) */
1025
1026 #ifndef NTRACE
1027 char *name;
1028 char *state_name;
1029 #endif
1030 } T_TPC_DATA;
1031
1032 typedef struct /* T_GRLC_MEAS_DATA */
1033 {
1034 T_CGRLC_INT_LEVEL_REQ ilev;
1035 T_C_FILTER c_filter;
1036 T_SIGN_VAR sign_var;
1037 T_BER_AVG ber_avg;
1038 BOOL sq_restart;
1039
1040 #if !defined (NTRACE)
1041
1042 UBYTE v_im_trace;
1043
1044 #endif /* #if !defined (NTRACE) */
1045
1046 #ifndef NTRACE
1047 char *name;
1048 char *state_name;
1049 #endif
1050 } T_GRLC_MEAS_DATA;
1051
1052 typedef struct /* T_GRLC_READY_TIMER */
1053 {
1054 T_READY_TIMER_HANDLING handling;
1055 T_READY_TIMER_STATE state;
1056 ULONG value;
1057 } T_GRLC_READY_TIMER;
1058
1059 typedef struct /* T_GRLC_DATA */
1060 {
1061 T_GRLC_READY_TIMER ready_timer;
1062
1063 UBYTE burst_type;
1064 UBYTE ab_type;
1065 T_CGRLC_pan_struct pan_struct;
1066 UBYTE t3168_val;
1067
1068
1069 T_UL_TBF uplink_tbf; /* This structure is used by TM,RU
1070 during uplink-tbf */
1071 T_DL_TBF downlink_tbf; /* This structure is used by TM,RD
1072 during downlink-tbf */
1073 T_TBF_TYPE tbf_type;
1074 T_REL_TYPE rel_type; /* indicates the type of TBF currently being released */
1075 UBYTE prim_start_free; /* index of first free prim queue entry */
1076 UBYTE prim_start_tbf ; /* index of first tbf prim queue entry */
1077
1078 UBYTE save_prim_start_free; /* save value during rau request */
1079 UBYTE save_prim_start_tbf ; /* save value during rau request */
1080 BOOL gmm_procedure_is_running; /* inidcates if gmm procedure is rnnig or not*/
1081
1082 USHORT prim_user_data; /* user data which is current in the prim_queue */
1083 T_PRIM_QUEUE prim_queue[PRIM_QUEUE_SIZE_TOTAL];
1084 /* queueing of llc-pdu's */
1085 UBYTE ta_value;
1086
1087 UBYTE ul_tn_mask; /* current uplink timeslot mask */
1088 UBYTE dl_tn_mask; /* current downlink timeslot mask */
1089
1090 UBYTE ul_tfi;
1091 UBYTE dl_tfi;
1092 UBYTE r_bit; /* current r-bit value - set by TC - read by RU/RD*/
1093 UBYTE poll_start_free;
1094 UBYTE poll_start_tbf;
1095 ULONG ul_fn; /* framenumber for the current radio block, needed for transmission*/
1096 ULONG dl_fn; /* framenumber of the last radio block, where a block is received*/
1097 T_NEXT_POLL_ARRAY next_poll_array[NEXT_POLL_ARRAY_SIZE] ;
1098 UBYTE N3102;
1099 T_chan_req_des chan_req_des; /* this will be included in next Packet Downlink AckNack
1100 write by TC, read by RD */
1101 T_TESTMODE testmode; /* this structure contains all GPRS test mode related data */
1102
1103 /* only for tracing*/
1104 ULONG grlc_data_req_cnt;
1105 ULONG dl_tbf_start_time;
1106 ULONG ul_tbf_start_time;
1107 UBYTE ul_index;
1108 UBYTE dl_index;
1109 T_TBF_CTRL tbf_ctrl[2];
1110
1111 /*handling of gaps*/
1112 ULONG missed_poll_fn;
1113
1114 UBYTE t3164_to_cnt; /* conunts the timeouts of timer t3164 in sequence */
1115 UBYTE start_fn_ul_tfi; /* stores the uplink tfi, which becomes valid after starting time*/
1116 UBYTE start_fn_dl_tfi; /* stores the downlink tfi, which becomes valid after starting time*/
1117 T_ul_poll_resp ul_poll_resp[2];//MULTISLOT
1118 UBYTE ul_poll_pos_index; /* index of ul_poll_response, need for polling */
1119 ULONG next_poll_fn; /*indicates the next poll fn */
1120 T_FUNC_INTERFACE func;
1121
1122 ULONG nr_of_crc_errors;
1123 T_TFI_CHANGE tfi_change;
1124 BOOL ul_tfi_changed;
1125 UBYTE grlc_wo_ccd; /*=0 ccd is used for en/decoding, =1 messages are decoded wo ccd */
1126 #ifdef REL99
1127 BOOL pfi_support;
1128 U8 pfi_value;
1129 U8 nw_rel;
1130 #endif
1131
1132 #if defined (_TARGET_) /*target debugging*/
1133 ULONG last_ul_fn;
1134 ULONG last_dl_fn;
1135 #define CALL_ERROR_NR_OF_ST_FN 9
1136 ULONG ul_fn_store[CALL_ERROR_NR_OF_ST_FN+1];
1137 ULONG ul_fn_errors[CALL_ERROR_NR_OF_ST_FN+1];
1138 ULONG dl_fn_store[CALL_ERROR_NR_OF_ST_FN+1];
1139 ULONG dl_fn_errors[CALL_ERROR_NR_OF_ST_FN+1];
1140 UBYTE ul_cnt_syn; /*for target, count calls in rlc uplink*/
1141 UBYTE ul_cnt_asyn; /*for target, count calls in gffp mac_ready_ind*/
1142 UBYTE dl_cnt_syn; /*for target, count calls in rlc downlink*/
1143 UBYTE dl_cnt_asyn; /*for target, count calls in gffp mac_data_ind*/
1144 UBYTE ul_call_errors; /*for target, count calls in rlc uplink during grlc is active*/
1145 UBYTE dl_call_errors; /*for target, count calls in rlc downlink during grlc is active*/
1146 #endif /*(_TARGET_) */
1147
1148 /*
1149 * Service data
1150 */
1151 T_GFF_DATA gff;
1152 T_TM_DATA tm;
1153 T_RD_DATA rd;
1154 T_RU_DATA ru;
1155 T_TPC_DATA tpc;
1156 T_GRLC_MEAS_DATA meas;
1157 }T_GRLC_DATA;
1158
1159
1160
1161
1162
1163
1164
1165
1166 /*==== EXPORT =====================================================*/
1167
1168 /*
1169 * data base
1170 */
1171 #ifdef GRLC_PEI_C
1172 T_GRLC_DATA grlc_data_base, *grlc_data;
1173 #else
1174 EXTERN T_GRLC_DATA grlc_data_base, *grlc_data;
1175 #endif
1176
1177 #define ENTITY_DATA grlc_data
1178
1179
1180 /*
1181 * Communication handles (see also GRLC_PEI.C)
1182 */
1183 #define hCommL1 grlc_hCommMAC
1184 #define hCommGRR grlc_hCommGRR
1185 #define hCommGRLC grlc_hCommGRLC
1186 #define hCommGMM grlc_hCommGMM
1187 #define hCommLLC grlc_hCommLLC
1188 #define hCommPL grlc_hCommPL
1189 #ifdef FF_WAP
1190 #define hCommWAP grlc_hCommWAP /*In future an own FMM Entity is planned*/
1191 #endif
1192
1193 #define _decodedMsg grlc__decodedMsg
1194
1195
1196 #ifdef GRLC_PEI_C
1197 T_HANDLE hCommL1 = VSI_ERROR;
1198 T_HANDLE hCommGRLC = VSI_ERROR;
1199 T_HANDLE hCommGRR = VSI_ERROR;
1200 T_HANDLE hCommGMM = VSI_ERROR;
1201 T_HANDLE hCommLLC = VSI_ERROR;
1202 T_HANDLE hCommPL = VSI_ERROR;
1203 #ifdef FF_WAP
1204 T_HANDLE hCommWAP = VSI_ERROR;
1205 #endif
1206 T_HANDLE GRLC_handle;
1207
1208
1209
1210 GLOBAL UBYTE _decodedMsg [MAX_MSTRUCT_LEN_GRLC];
1211
1212 /*
1213 * make the pei_create function unique
1214 */
1215 #define pei_create grlc_pei_create
1216
1217 /*
1218 * make the pei_func_primitive function unique
1219 */
1220 #define pei_func_primitive grlc_pei_func_primitive
1221
1222 #else /* !GRLC_PEI_C */
1223 EXTERN T_HANDLE hCommL1;
1224 EXTERN T_HANDLE hCommGRLC;
1225 EXTERN T_HANDLE hCommGRR;
1226 EXTERN T_HANDLE hCommGMM;
1227 EXTERN T_HANDLE hCommLLC;
1228 EXTERN T_HANDLE hCommPL;
1229 #ifdef FF_WAP
1230 EXTERN T_HANDLE hCommWAP;
1231 #endif
1232 EXTERN T_HANDLE GRLC_handle;
1233 #endif /* GRLC_PEI_C */
1234
1235
1236 EXTERN UBYTE _decodedMsg [MAX_MSTRUCT_LEN_GRLC];
1237
1238 #ifdef _TARGET_
1239
1240 #undef TRACE_FUNCTION
1241 #define TRACE_FUNCTION(a)
1242 #undef TRACE_ISIG
1243 #define TRACE_ISIG(a)
1244
1245 #endif /* _TARGET_ */
1246
1247 #endif /* GRLC_H */