1 /*******************************************************************************
2 ################################################################################
3 # Copyright (c) [2020] [Radisys] #
5 # Licensed under the Apache License, Version 2.0 (the "License"); #
6 # you may not use this file except in compliance with the License. #
7 # You may obtain a copy of the License at #
9 # http://www.apache.org/licenses/LICENSE-2.0 #
11 # Unless required by applicable law or agreed to in writing, software #
12 # distributed under the License is distributed on an "AS IS" BASIS, #
13 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. #
14 # See the License for the specific language governing permissions and #
15 # limitations under the License. #
16 ################################################################################
17 *******************************************************************************/
18 /* Utility definitions to be used in du app */
19 #include "common_def.h"
24 #include "du_app_mac_inf.h"
25 #include "du_app_rlc_inf.h"
26 #include "du_e2ap_mgr.h"
31 /* Spec Ref-38.214-Table 5.1.2.1-1 */
32 uint8_t slivCfgIdxTable[MAX_SLIV_CONFIG_IDX][3] = {
34 { 0, 1, 0 },/* index0 */
35 { 0, 2, 14 },/* index1 */
36 { 0, 3, 28 },/* index2 */
37 { 0, 4, 42 },/* index3 */
38 { 0, 5, 56 },/* index4 */
39 { 0, 6, 70 },/* index5 */
40 { 0, 7, 84 },/* index6 */
41 { 0, 8, 98 },/* index7 */
42 { 0, 9, 97 },/* index8 */
43 { 0, 10, 83 },/* index9 */
44 { 0, 11, 69 },/* index10 */
45 { 0, 12, 55 },/* index11 */
46 { 0, 13, 41 },/* index12 */
47 { 0, 14, 27 },/* index13 */
48 { 1, 1, 1 },/* index14 */
49 { 1, 2, 15 },/* index15 */
50 { 1, 3, 29 },/* index16 */
51 { 1, 4, 43 },/* index17 */
52 { 1, 5, 57 },/* index18 */
53 { 1, 6, 71 },/* index19 */
54 { 1, 7, 85 },/* index20 */
55 { 1, 8, 99 },/* index21 */
56 { 1, 9, 96 },/* index22 */
57 { 1, 10, 82 },/* index23 */
58 { 1, 11, 68 },/* index24 */
59 { 1, 12, 54 },/* index25 */
60 { 1, 13, 40 },/* index26 */
61 { 2, 1, 2 },/* index27 */
62 { 2, 2, 16 },/* index28 */
63 { 2, 3, 30 },/* index29 */
64 { 2, 4, 44 },/* index30 */
65 { 2, 5, 58 },/* index31 */
66 { 2, 6, 72 },/* index32 */
67 { 2, 7, 86 },/* index33 */
68 { 2, 8, 100},/* index34 */
69 { 2, 9, 95 },/* index35 */
70 { 2, 10, 81 },/* index36 */
71 { 2, 11, 67 },/* index37 */
72 { 2, 12, 53 },/* index38 */
73 { 3, 1, 3 },/* index39 */
74 { 3, 2, 17 },/* index40 */
75 { 3, 3, 31 },/* index41 */
76 { 3, 4, 45 },/* index42 */
77 { 3, 5, 59 },/* index43 */
78 { 3, 6, 73 },/* index44 */
79 { 3, 7, 87 },/* index45 */
80 { 3, 8, 101},/* index46 */
81 { 3, 9, 94 },/* index47 */
82 { 3, 10, 80 },/* index48 */
83 { 3, 11, 66 },/* index49 */
84 { 4, 1, 4 },/* index50 */
85 { 4, 2, 18 },/* index51 */
86 { 4, 3, 32 },/* index52 */
87 { 4, 4, 46 },/* index53 */
88 { 4, 5, 60 },/* index54 */
89 { 4, 6, 74 },/* index55 */
90 { 4, 7, 88 },/* index56 */
91 { 4, 8, 102},/* index57 */
92 { 4, 9, 93 },/* index58 */
93 { 4, 10, 79 },/* index59 */
94 { 5, 1, 5 },/* index60 */
95 { 5, 2, 19 },/* index61 */
96 { 5, 3, 33 },/* index62 */
97 { 5, 4, 47 },/* index63 */
98 { 5, 5, 61 },/* index64 */
99 { 5, 6, 75 },/* index65 */
100 { 5, 7, 89 },/* index66 */
101 { 5, 8, 103},/* index67 */
102 { 5, 9, 92 },/* index68 */
103 { 6, 1, 6 },/* index69 */
104 { 6, 2, 20 },/* index70 */
105 { 6, 3, 34 },/* index71 */
106 { 6, 4, 48 },/* index72 */
107 { 6, 5, 62 },/* index73 */
108 { 6, 6, 76 },/* index74 */
109 { 6, 7, 90 },/* index75 */
110 { 6, 8, 104},/* index76 */
111 { 7, 1, 7 },/* index77 */
112 { 7, 2, 21 },/* index78 */
113 { 7, 3, 35 },/* index79 */
114 { 7, 4, 49 },/* index80 */
115 { 7, 5, 63 },/* index81 */
116 { 7, 6, 77 },/* index82 */
117 { 7, 7, 91 },/* index83 */
118 { 8, 1, 8 },/* index84 */
119 { 8, 2, 22 },/* index85 */
120 { 8, 3, 36 },/* index86 */
121 { 8, 4, 50 },/* index87 */
122 { 8, 5, 64 },/* index88 */
123 { 8, 6, 78 },/* index89 */
124 { 9, 1, 9 },/* index90 */
125 { 9, 2, 23 },/* index91 */
126 { 9, 3, 37 },/* index92 */
127 { 9, 4, 51 },/* index93 */
128 { 9, 5, 65 },/* index94 */
129 { 10, 1, 10 },/* index95 */
130 { 10, 2, 24 },/* index96 */
131 { 10, 3, 38 },/* index97 */
132 { 10, 4, 52 },/* index98 */
133 { 11, 1, 11 },/* index99 */
134 { 11, 2, 25 },/* index100*/
135 { 11, 3, 39 },/* index101*/
136 { 12, 1, 12 },/* index102*/
137 { 12, 2, 26 },/* index103*/
138 { 13, 1, 13 } /* index104*/
141 /*******************************************************************
143 * @brief Function to fill the start Symbol and Symbol Len from the
144 * sliv Config Idx Table
148 * Function : fillStartSymbolAndLen
150 * Functionality: Function to fill the start Symbol and Symbol Len
151 * from the sliv Config Idx Table
153 * @params[in] startSymbolIdx pointer,
158 * ****************************************************************/
159 void fillStartSymbolAndLen(uint8_t numRsrcAlloc, PdschConfig *pdschCfg, PuschCfg *puschCfg)
161 uint8_t slivIdx, timeDomIdx;
163 for(timeDomIdx = 0; timeDomIdx < numRsrcAlloc; timeDomIdx++)
165 for(slivIdx = 0; slivIdx < MAX_SLIV_CONFIG_IDX; slivIdx++)
167 if(pdschCfg)/* PDSCH Config */
169 if(pdschCfg->timeDomRsrcAllociList[timeDomIdx].startSymbolAndLength ==\
170 slivCfgIdxTable[slivIdx][2])
172 pdschCfg->timeDomRsrcAllociList[timeDomIdx].startSymbol = slivCfgIdxTable[slivIdx][0];
173 pdschCfg->timeDomRsrcAllociList[timeDomIdx].symbolLength = slivCfgIdxTable[slivIdx][1];
177 if(puschCfg)/* PUSCH Config */
179 if(puschCfg->timeDomRsrcAllocList[timeDomIdx].startSymbolAndLength ==\
180 slivCfgIdxTable[slivIdx][2])
182 puschCfg->timeDomRsrcAllocList[timeDomIdx].startSymbol = slivCfgIdxTable[slivIdx][0];
183 puschCfg->timeDomRsrcAllocList[timeDomIdx].symbolLength = slivCfgIdxTable[slivIdx][1];
192 /*******************************************************************
193 * @brief Function to add a node to a linked list
197 * Function: duAddNodeToLList
199 * This function adds a new node to the linked list
201 * @param[in] Pointer to the list
202 * Pointer to node to be added
203 * Pointer to current node
206 *******************************************************************/
207 uint8_t duAddNodeToLList(CmLListCp *llist, void *blockToAdd, CmLList *currNode)
209 CmLList *newNode = NULLP;
211 DU_ALLOC(newNode, sizeof(CmLList));
214 newNode->node = (PTR)blockToAdd;
216 if(currNode == NULLP)
217 cmLListAdd2Tail(llist, newNode);
220 llist->crnt = currNode;
221 cmLListInsAfterCrnt(llist, newNode);
228 /*******************************************************************
229 * @brief Function to delete a node from linked list
233 * Function: duDelNodeFromLList
235 * This function deletes a node from the linked list
237 * @param[in] Pointer to the list
238 * Pointer to node to be deleted
239 * @return Pointer to the deleted node
240 *******************************************************************/
242 uint8_t duDelNodeFromLList(CmLListCp *llist, CmLList *node)
244 node = cmLListDelFrm(llist, node);
245 DU_FREE(node, sizeof(CmLList));
250 /*******************************************************************
251 * @brief Handle the PageUe List
255 * Function : handlePageUeLL
257 * Functionality: Handling the (SEARCH,CREATE,DELETE) PageUeList
259 * @params[in] DuPagingMsg *pagingParam, CmLListCp *pageUeLL, ActionTypeLL
262 * @return DuPagUeRecord
264 * ****************************************************************/
265 DuPagUeRecord* handlePageUeLL(uint16_t pagUeId, uint64_t sTmsi, CmLListCp *pageUeLL, ActionTypeLL action)
267 CmLList *node = NULLP;
268 DuPagUeRecord *ueRecord = NULLP;
271 if((pageUeLL == NULLP) ||
272 ((pageUeLL->first == NULLP) && (action != CREATE)))
274 DU_LOG("\nERROR --> DU APP: UE Page Record LL is empty");
277 node = pageUeLL->first;
281 ueRecord = (DuPagUeRecord *)node->node;
284 DU_LOG("\n INFO --> DU APP ueId:%d, sTmsi:%lu",\
285 ueRecord->pagUeId, ueRecord->sTmsi);
287 else if(ueRecord && (ueRecord->pagUeId == pagUeId &&
288 ueRecord->sTmsi == sTmsi))
312 /*Need to add a new node for this LC*/
314 /*List is empty; Initialize the LL ControlPointer*/
315 if(pageUeLL->count == 0)
317 cmLListInit(pageUeLL);
321 /*Allocate the List*/
322 DU_ALLOC(ueRecord, sizeof(DuPagUeRecord));
325 ueRecord->pagUeId = pagUeId;
326 ueRecord->sTmsi = sTmsi;
330 DU_LOG("\nERROR --> DU APP : Allocation of UE Record failed,ueId:%d",pagUeId);
334 if(duAddNodeToLList(pageUeLL, ueRecord, NULLP) == RFAILED)
336 DU_LOG("\nERROR --> DU APP : failed to Add Ue Record Node,ueId:%d",pagUeId);
337 DU_FREE(ueRecord, sizeof(DuPagUeRecord));
344 if(!found || ueRecord == NULLP)
346 DU_LOG("\nERROR --> DU APP: UeId:%d not found; thus Deletion unsuccessful",pagUeId);
350 if(duDelNodeFromLList(pageUeLL, node) == ROK)
351 DU_FREE(ueRecord, sizeof(DuPagUeRecord));
362 DU_LOG("\nERROR --> DU APP: Incorrect ActionType:%d on UeRecord",action);
368 /*******************************************************************
369 * @brief Handle the PageInfo List
373 * Function : handlePageInfoLL
375 * Functionality: Handling the (SEARCH,CREATE,DELETE) PageInfoList
377 * @params[in] uint8_t i_s, CmLListCp *pagInfoLL, ActionTypeLL action
379 * @return DuPagUeList
381 * ****************************************************************/
382 DuPagUeList* handlePageInfoLL(uint16_t pf, uint8_t i_s, CmLListCp *pagInfoLL, ActionTypeLL action)
384 CmLList *node = NULLP, *next = NULLP;
385 DuPagUeList *pagInfo = NULLP;
388 if((pagInfoLL == NULLP) ||
389 ((pagInfoLL->first == NULLP) && (action != CREATE)))
391 DU_LOG("\nERROR --> DU APP: PagInfo LL is empty");
394 node = pagInfoLL->first;
399 pagInfo = (DuPagUeList *)node->node;
402 DU_LOG("\n INFO --> DU APP: Paging Index (i_s):%d",pagInfo->i_s);
403 handlePageUeLL(NULLD, NULLD, &(pagInfo->pagUeList), PRINT);
405 else if(action == TRAVERSE_ALL)
409 else if(pagInfo->i_s == i_s)
433 /*Need to add a new node for this LC*/
435 /*List is empty; Initialize the LL ControlPointer*/
436 if(pagInfoLL->count == 0)
438 cmLListInit(pagInfoLL);
442 /*Allocate the List*/
443 DU_ALLOC(pagInfo, sizeof(DuPagUeList));
450 DU_LOG("\nERROR --> DU APP : Allocation of List failed,i_s:%d",i_s);
454 if(duAddNodeToLList(pagInfoLL, pagInfo, NULLP) == RFAILED)
456 DU_LOG("\nERROR --> DU APP : failed to Add Node,i_s:%d",i_s);
457 DU_FREE(pagInfo, sizeof(DuPagUeList));
464 if(!found || pagInfo == NULLP)
466 DU_LOG("\nERROR --> DU APP: i_s:%d not found; thus Deletion unsuccessful",i_s);
470 if(duDelNodeFromLList(pagInfoLL, node) == ROK)
471 DU_FREE(pagInfo, sizeof(DuPagUeList));
482 DU_LOG("\nERROR --> DU APP: Incorrect ActionType:%d on PageInfo List",action);
488 /*******************************************************************
489 * @brief Find the PageInfo List from HashMap
493 * Function : findPagingInfoFromMap
495 * Functionality: Search for the PageInfoList for a PF from HashMap
497 * @params[in] uint16_t pf, CmHashListCp *pagingInfoMap
499 * @return DuPagInfoList
501 * ****************************************************************/
502 DuPagInfoList* findPagingInfoFromMap(uint16_t pf, CmHashListCp *pagingInfoMap)
504 DuPagInfoList *pagInfoLL = NULLP;
506 cmHashListFind(pagingInfoMap, (uint8_t *)&(pf), sizeof(uint16_t), 0, (PTR *)&pagInfoLL);
511 /*Below function for printing will be used in future so disabling it for now*/
513 /*******************************************************************
514 * @brief Print the Page Info List and UE Records
518 * Function : printPageList
520 * Functionality: Print the Page Info List and UE Records
522 * @params[in] CmHashListCp *pagingInfoMap
526 * ****************************************************************/
527 void printPageList(CmHashListCp *pagingInfoMap)
530 DuPagInfoList *pagInfoLLFromPF = NULLP, *prevPageInfoLL = NULLP;
534 ret = cmHashListGetNext(pagingInfoMap, (PTR)prevPageInfoLL, (PTR *)&pagInfoLLFromPF);
537 DU_LOG("\nDEBUG --> DUAPP: Page List for PF:%d",pagInfoLLFromPF->pf);
538 handlePageInfoLL(NULLD, NULLD, &(pagInfoLLFromPF->pagInfoList), PRINT);
539 prevPageInfoLL = pagInfoLLFromPF;
546 /**********************************************************************
548 **********************************************************************/