comparison src/g23m-fad/l2r/tra_upf.c @ 1:fa8dc04885d8

src/g23m-*: import from Magnetite
author Mychaela Falconia <falcon@freecalypso.org>
date Fri, 16 Oct 2020 06:25:50 +0000
parents
children
comparison
equal deleted inserted replaced
0:4e78acac3d88 1:fa8dc04885d8
1 /*
2 +-----------------------------------------------------------------------------
3 | Project : CSD (8411)
4 | Modul : tra_upf.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 procedures and functions for
18 | the component TRA
19 +-----------------------------------------------------------------------------
20 */
21
22 #ifndef TRA_UPF_C
23 #define TRA_UPF_C
24 #endif
25
26 #define ENTITY_L2R
27
28 /*==== INCLUDES ===================================================*/
29
30 #include <string.h>
31 #include "typedefs.h"
32 #include "pconst.cdg"
33 #include "vsi.h"
34 #include "macdef.h"
35 #include "custom.h"
36 #include "gsm.h"
37 #include "prim.h"
38 #include "pei.h"
39 #include "tok.h"
40 #include "dti.h"
41
42 #include "cl_ribu.h"
43 #include "tra_pei.h"
44 #include "tra.h"
45
46 #ifdef _TARGET_
47 #include "ra_l1int.h"
48 #endif
49
50 /*==== CONST =======================================================*/
51
52 /*==== TYPES =======================================================*/
53
54 /*==== VAR EXPORT ==================================================*/
55
56 /*==== VAR LOCAL ===================================================*/
57
58 /*==== FUNCTIONS ===================================================*/
59
60 /*
61 +------------------------------------------------------------------------------
62 | Function : up_init
63 +------------------------------------------------------------------------------
64 | Description : initialise the tra data for the uplink process
65 |
66 | Parameters : -
67 |
68 |
69 | Return : -
70 +------------------------------------------------------------------------------
71 */
72
73 GLOBAL void ul_init(T_TRA_UP *dul)
74 {
75 TRACE_FUNCTION ("ul_init()");
76
77 dul->sa = FL_INACTIVE;
78 dul->sb = FL_INACTIVE;
79 dul->x = FL_INACTIVE;
80 dul->List_off = 0;
81
82 INIT_STATE (UP, UP_INACTIVE);
83 }
84
85 /*
86 +------------------------------------------------------------------------------
87 | Function : snd_break_to_RA
88 +------------------------------------------------------------------------------
89 | Description :
90 |
91 | Parameters : -
92 |
93 |
94 | Return :
95 +------------------------------------------------------------------------------
96 */
97
98 GLOBAL void snd_break_to_RA(USHORT break_len)
99 {
100 #ifndef _SIMULATION_
101
102 T_RA_BREAK_REQ RA_break_req;
103 RA_break_req.break_len = break_len;
104
105 #endif
106
107 TRACE_FUNCTION ("snd_break_to_RA()");
108
109 #ifndef _SIMULATION_
110
111 l1i_ra_break_req (&RA_break_req);
112
113 #else
114 {
115 PALLOC (ra_break_req, RA_BREAK_REQ);
116 ra_break_req->break_len = break_len;
117 PSENDX (RA, ra_break_req);
118 }
119 #endif
120 }
121
122 /*
123 +------------------------------------------------------------------------------
124 | Function : snd_data_to_RA
125 +------------------------------------------------------------------------------
126 | Description :
127 |
128 | Parameters : -
129 |
130 |
131 | Return :
132 +------------------------------------------------------------------------------
133 */
134
135 GLOBAL void snd_data_to_RA(void)
136 {
137 T_TRA_UP *dul = &tra_data->up;
138 T_FD *pFD = &dul->fd;
139
140 T_desc2 *desc = (T_desc2*)dul->Prim->desc_list2.first;
141
142 USHORT data_off = dul->List_off; /* offset within current data block */
143 USHORT data_len = dul->Prim->desc_list2.list_len; /* local mark for overall data size to be copied */
144
145 TRACE_FUNCTION ("snd_data_to_RA()");
146
147 pFD->type = FR_TRANS;
148 pFD->status = 0;
149 pFD->len = 0; /* to mark current sdu fill status */
150
151 if (dul->req_frames)
152 {
153 while (desc)
154 {
155 if (desc->len <= (dul->req_frames - pFD->len)) /* DTI data size less than SDU space*/
156 {
157 T_desc2 *desc_im = (T_desc2*)desc->next;
158 memcpy(&dul->to_ra[pFD->len], desc->buffer + data_off, desc->len);
159 pFD->len += desc->len;
160 data_len -= desc->len;
161 data_off = 0; /* list is copied completely! */
162 MFREE (desc);
163 desc = (T_desc2*) desc_im;
164 }
165 else /* more DTI data than SDU space*/
166 {
167 memcpy(&dul->to_ra[pFD->len], desc->buffer + data_off, dul->req_frames - pFD->len);
168 data_off += (dul->req_frames - pFD->len); /* remember for next copying! */
169 desc->len -= (dul->req_frames - pFD->len);
170 desc->size = desc->len;
171 data_len -= (dul->req_frames - pFD->len);
172 pFD->len = dul->req_frames; /* the SDU is full */
173 break;
174 }
175 }
176 /*
177 * write back current standings
178 */
179 dul->Prim->desc_list2.first = (ULONG)desc;
180 dul->Prim->desc_list2.list_len = data_len;
181 dul->List_off = data_off;
182 }
183
184 if (dul->sa EQ DTI_SA_OFF)
185 pFD->status |= ST_SA;
186 if (dul->sb EQ DTI_SB_OFF)
187 pFD->status |= ST_SB;
188 if (dul->x EQ DTI_FLOW_OFF)
189 pFD->status |= ST_X;
190
191 #ifdef _TARGET_
192
193 l1i_ra_data_req_new(pFD);
194
195 #else
196 {
197 PALLOC_SDU (ra_data_req, RA_DATA_REQ, (USHORT)(dul->req_frames<<3));
198
199 if (hCommRA < VSI_OK)
200 {
201 hCommRA = vsi_c_open (VSI_CALLER RA_NAME);
202 }
203 ra_data_req->fr_type = pFD->type;
204 ra_data_req->status = pFD->status;
205 ra_data_req->dtx_flg = DTX_DIS;
206 ra_data_req->sdu.l_buf = pFD->len << 3;
207 ra_data_req->sdu.o_buf = 0;
208 memcpy(&ra_data_req->sdu.buf[0], &dul->to_ra[0], pFD->len);
209 PSENDX (RA, ra_data_req);
210 }
211 #endif
212 }
213
214 /*
215 +------------------------------------------------------------------------------
216 | Function : up_start_dti_flow
217 +------------------------------------------------------------------------------
218 | Description :
219 |
220 | Parameters : -
221 |
222 |
223 | Return : -
224 +------------------------------------------------------------------------------
225 */
226
227 GLOBAL void up_start_dti_flow(void)
228 {
229 TRACE_FUNCTION ("up_start_dti_flow()");
230
231 dti_start(l2r_hDTI, TRA_DTI_UP_INSTANCE, TRA_DTI_UP_INTERFACE, TRA_DTI_UP_CHANNEL);
232 }