1 /*******************************************************************************
2 ################################################################################
3 # Copyright (c) [2017-2019] [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 *******************************************************************************/
19 /* Contains definitions for MAC CL modules */
24 #define LWR_MAC_ALLOC(_datPtr, _size) WLS_MEM_ALLOC(_datPtr, _size);
26 #define LWR_MAC_ALLOC(_datPtr, _size) MAC_ALLOC(_datPtr, _size);
30 #define LWR_MAC_FREE(_datPtr, _size) WLS_MEM_FREE(_datPtr, _size);
32 #define LWR_MAC_FREE(_datPtr, _size) MAC_FREE(_datPtr, _size);
43 /* Events in Lower Mac */
45 #ifdef INTEL_TIMER_MODE
64 typedef struct lwrMacGlobalCb
68 bool clCfgDone; /* CL configuration done */
69 uint8_t phySlotIndCntr;
70 LwrMacCellCb cellCb[MAX_NUM_CELL]; /* List of Cells configured */
71 uint8_t numCell; /* Number of Cells configured */
72 PhyState phyState; /* State of PHY */
73 EventState event; /* State of Event */
89 NORMAL_CYCLIC_PREFIX_MASK,
90 EXTENDED_CYCLIC_PREFIX_MASK
120 CCE_MAPPING_INTERLEAVED_MASK,
121 CCE_MAPPING_NONINTERLVD_MASK
147 VRB_TO_PRB_MAP_NON_INTLV,
148 VRB_TO_PRB_MAP_INTLVD
165 DMRS_ADDITIONAL_POS_0,
166 DMRS_ADDITIONAL_POS_1,
167 DMRS_ADDITIONAL_POS_2,
168 DMRS_ADDITIONAL_POS_3
202 PRACH_FD_OCC_IN_A_SLOT_1 = 1,
203 PRACH_FD_OCC_IN_A_SLOT_2 = 2,
204 PRACH_FD_OCC_IN_A_SLOT_4 = 4,
205 PRACH_FD_OCC_IN_A_SLOT_8 = 8
214 typedef struct clCellParam
216 ReleaseCapab releaseCapability; /* Release Capability */
217 PhyState ParamPhystate;
218 ParamSupport skipBlankDlConfig;
219 ParamSupport skipBlankUlConfig;
220 ParamSupport numTlvsToReport;
221 CyclicPrefix cyclicPrefix;
222 SubCarrierSpacing supportedSubcarrierSpacingDl;
223 SupportedBandwidth supportedBandwidthDl;
224 SubCarrierSpacing supportedSubcarrierSpacingsUl;
225 SupportedBandwidth supportedBandwidthUl;
226 CCEMappingType cceMappingType;
227 ParamSupport coresetOutsideFirst3OfdmSymsOfSlot;
228 ParamSupport precoderGranularityCoreset;
229 ParamSupport pdcchMuMimo;
230 ParamSupport pdcchPrecoderCycling;
231 uint8_t maxPdcchsPerSlot;
232 Formats pucchFormats;
233 uint8_t maxPucchsPerSlot;
234 MappingType pdschMappingType;
235 AllocationType pdschAllocationTypes;
236 VrbToPrbMap pdschVrbToPrbMapping;
237 ParamSupport pdschCbg;
238 DmrsConfigType pdschDmrsConfigTypes;
239 DmrMaxLen pdschDmrsMaxLength;
240 DmrsPos pdschDmrsAdditionalPos;
241 uint8_t maxPdschsTBsPerSlot;
242 uint8_t maxNumberMimoLayersPdsch;
243 ModulationOrder supportedMaxModulationOrderDl;
244 uint8_t maxMuMimoUsersDl;
245 ParamSupport pdschDataInDmrsSymbols;
246 ParamSupport premptionSupport;
247 ParamSupport pdschNonSlotSupport;
248 ParamSupport uciMuxUlschInPusch;
249 ParamSupport uciOnlyPusch;
250 ParamSupport puschFrequencyHopping;
251 DmrsConfigType puschDmrsConfigTypes;
252 DmrMaxLen puschDmrsMaxLength;
253 DmrsPos puschDmrsAdditionalPos;
254 ParamSupport puschCbg;
255 MappingType puschMappingType;
256 AllocationType puschAllocationTypes;
257 VrbToPrbMap puschVrbToPrbMapping;
258 uint8_t puschMaxPtrsPorts;
259 uint8_t maxPduschsTBsPerSlot;
260 uint8_t maxNumberMimoLayersNonCbPusch;
261 ModulationOrder supportedModulationOrderUl;
262 uint8_t maxMuMimoUsersUl;
263 ParamSupport dftsOfdmSupport;
264 AggregationFactor puschAggregationFactor;
265 Formats prachLongFormats;
266 ShortFormat prachShortFormats;
267 ParamSupport prachRestrictedSets;
268 FdOccPerSlot maxPrachFdOccasionsInASlot;
269 RssiMeasurement rssiMeasurementSupport;
273 LwrMacCellCb * lwrMacGetCellCb ARGS((uint16_t cellId));
274 uint32_t reverseBits(uint32_t num, uint8_t numBits);
275 void fillDlDciPayload(uint8_t *buf, uint8_t *bytePos, uint8_t *bitPos,\
276 uint32_t val, uint8_t valSize);
280 /**********************************************************************
282 **********************************************************************/