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);
37 /* Events in Lower Mac */
55 typedef struct lwrMacGlobalCb
59 bool clCfgDone; /* CL configuration done */
60 LwrMacCellCb cellCb[MAX_NUM_CELL]; /* List of Cells configured */
61 uint8_t numCell; /* Number of Cells configured */
62 PhyState phyState; /* State of PHY */
63 EventState event; /* State of Event */
79 NORMAL_CYCLIC_PREFIX_MASK,
80 EXTENDED_CYCLIC_PREFIX_MASK
110 CCE_MAPPING_INTERLEAVED_MASK,
111 CCE_MAPPING_NONINTERLVD_MASK
137 VRB_TO_PRB_MAP_NON_INTLV,
138 VRB_TO_PRB_MAP_INTLVD
155 DMRS_ADDITIONAL_POS_0,
156 DMRS_ADDITIONAL_POS_1,
157 DMRS_ADDITIONAL_POS_2,
158 DMRS_ADDITIONAL_POS_3
192 PRACH_FD_OCC_IN_A_SLOT_1 = 1,
193 PRACH_FD_OCC_IN_A_SLOT_2 = 2,
194 PRACH_FD_OCC_IN_A_SLOT_4 = 4,
195 PRACH_FD_OCC_IN_A_SLOT_8 = 8
204 typedef struct clCellParam
206 ReleaseCapab releaseCapability; /* Release Capability */
207 PhyState ParamPhystate;
208 ParamSupport skipBlankDlConfig;
209 ParamSupport skipBlankUlConfig;
210 ParamSupport numTlvsToReport;
211 CyclicPrefix cyclicPrefix;
212 SubCarrierSpacing supportedSubcarrierSpacingDl;
213 SupportedBandwidth supportedBandwidthDl;
214 SubCarrierSpacing supportedSubcarrierSpacingsUl;
215 SupportedBandwidth supportedBandwidthUl;
216 CCEMappingType cceMappingType;
217 ParamSupport coresetOutsideFirst3OfdmSymsOfSlot;
218 ParamSupport precoderGranularityCoreset;
219 ParamSupport pdcchMuMimo;
220 ParamSupport pdcchPrecoderCycling;
221 uint8_t maxPdcchsPerSlot;
222 Formats pucchFormats;
223 uint8_t maxPucchsPerSlot;
224 MappingType pdschMappingType;
225 AllocationType pdschAllocationTypes;
226 VrbToPrbMap pdschVrbToPrbMapping;
227 ParamSupport pdschCbg;
228 DmrsConfigType pdschDmrsConfigTypes;
229 DmrMaxLen pdschDmrsMaxLength;
230 DmrsPos pdschDmrsAdditionalPos;
231 uint8_t maxPdschsTBsPerSlot;
232 uint8_t maxNumberMimoLayersPdsch;
233 ModulationOrder supportedMaxModulationOrderDl;
234 uint8_t maxMuMimoUsersDl;
235 ParamSupport pdschDataInDmrsSymbols;
236 ParamSupport premptionSupport;
237 ParamSupport pdschNonSlotSupport;
238 ParamSupport uciMuxUlschInPusch;
239 ParamSupport uciOnlyPusch;
240 ParamSupport puschFrequencyHopping;
241 DmrsConfigType puschDmrsConfigTypes;
242 DmrMaxLen puschDmrsMaxLength;
243 DmrsPos puschDmrsAdditionalPos;
244 ParamSupport puschCbg;
245 MappingType puschMappingType;
246 AllocationType puschAllocationTypes;
247 VrbToPrbMap puschVrbToPrbMapping;
248 uint8_t puschMaxPtrsPorts;
249 uint8_t maxPduschsTBsPerSlot;
250 uint8_t maxNumberMimoLayersNonCbPusch;
251 ModulationOrder supportedModulationOrderUl;
252 uint8_t maxMuMimoUsersUl;
253 ParamSupport dftsOfdmSupport;
254 AggregationFactor puschAggregationFactor;
255 Formats prachLongFormats;
256 ShortFormat prachShortFormats;
257 ParamSupport prachRestrictedSets;
258 FdOccPerSlot maxPrachFdOccasionsInASlot;
259 RssiMeasurement rssiMeasurementSupport;
263 LwrMacCellCb * lwrMacGetCellCb ARGS((uint16_t cellId));
264 uint32_t reverseBits(uint32_t num, uint8_t numBits);
265 void fillDlDciPayload(uint8_t *buf, uint8_t *bytePos, uint8_t *bitPos,\
266 uint32_t val, uint8_t valSize);
271 /**********************************************************************
273 **********************************************************************/