MAC Clean-up [Issue-ID: ODUHIGH-212]
[o-du/l2.git] / src / 5gnrsch / sch_utils.h
index 1e33397..defdc54 100644 (file)
 #include <stdint.h>
 #include <math.h>
 
+/* Memory info */
+#define SCH_MEM_REGION     4
+#define SCH_POOL           1
+
 /* macros */
 #define MAX_CORESET_INDEX      16
 #define MAX_SEARCH_SPACE_INDEX 16
 #define MAX_PRACH_CONFIG_IDX   256
 #define MAX_MU_PUSCH           4
 #define TOTAL_TBSIZE_VALUES    93
+
 #define SET_BITS_MSB(_startBit, _numBits, _byte) \
 {                                                \
    _byte = (~((0xFF) >> _numBits));              \
-       _byte >>= _startBit;                          \
+   _byte >>= _startBit;                          \
 }
 
 #define SET_BITS_LSB(_startBit, _numBits, _byte) \
 {                                                \
    _byte = (~((0xFF) << _numBits));              \
-       _byte <<= _startBit;                          \
+   _byte <<= _startBit;                          \
+}
+
+/* allocate and zero out a static buffer */
+#define SCH_ALLOC(_datPtr, _size)                               \
+{                                                               \
+   int _ret;                                                    \
+   _ret = SGetSBuf(SCH_MEM_REGION, SCH_POOL,                    \
+          (Data **)&_datPtr, _size);                             \
+   if(_ret == ROK)                                              \
+   {                                                            \
+      cmMemset((U8*)_datPtr, 0, _size);                         \
+   }                                                            \
+   else                                                         \
+   {                                                            \
+      _datPtr = NULLP;                                          \
+   }                                                            \
+}
+
+/* free a static buffer */
+#define SCH_FREE(_datPtr, _size)                                \
+{                                                               \
+   if(_datPtr)                                                  \
+   {                                                            \
+      SPutSBuf(SCH_MEM_REGION, SCH_POOL,                        \
+            (Data *)_datPtr, _size);                            \
+   }                                                            \
+}
+                          
+/* Fill post structure for msg from SCH to MAC */
+#define FILL_PST_SCH_TO_MAC(_pst, _inst)                     \
+{                                                            \
+   _pst.srcProcId = SFndProcId();                            \
+   _pst.dstProcId = SFndProcId();                            \
+   _pst.srcEnt    = ENTRG;                                   \
+   _pst.dstEnt    = ENTRG;                                   \
+   _pst.srcInst   = 1;                                       \
+   _pst.dstInst   = 0;                                       \
+   _pst.selector  = ODU_SELECTOR_TC;                         \
 }
 
 /* functions declarations */
@@ -48,5 +91,5 @@ extern int8_t coresetIdxTable[MAX_CORESET_INDEX][4];
 extern int8_t searchSpaceIdxTable[MAX_SEARCH_SPACE_INDEX][4];
 
 /**********************************************************************
-         End of file
-**********************************************************************/
+  End of file
+ **********************************************************************/