<p>pespin <strong>submitted</strong> this change.</p><p><a href="https://gerrit.osmocom.org/c/osmo-pcu/+/20990">View Change</a></p><div style="white-space:pre-wrap">Approvals:
  Jenkins Builder: Verified
  fixeria: Looks good to me, approved
  laforge: Looks good to me, but someone else must approve

</div><pre style="font-family: monospace,monospace; white-space: pre-wrap;">pcuif: Improve BTS-supported CS/MCS handling<br><br>Take into account the MCS values supported by the BTS. In osmo-bts,<br>in general all MCS are enabled if "mode egprs" is selected in BSC,<br>and none otherwise.<br><br>Change-Id: Ie8f0215ba17da1e545e98bec9325c02f1e8efaea<br>---<br>M src/bts.cpp<br>M src/bts.h<br>M src/gprs_bssgp_pcu.cpp<br>M src/pcu_l1_if.cpp<br>M tests/emu/pcu_emu.cpp<br>5 files changed, 50 insertions(+), 40 deletions(-)<br><br></pre><pre style="font-family: monospace,monospace; white-space: pre-wrap;"><span>diff --git a/src/bts.cpp b/src/bts.cpp</span><br><span>index 6a7960c..359f2d5 100644</span><br><span>--- a/src/bts.cpp</span><br><span>+++ b/src/bts.cpp</span><br><span>@@ -210,7 +210,7 @@</span><br><span>  bts->fc_interval = 1;</span><br><span>     bts->initial_cs_dl = bts->initial_cs_ul = 1;</span><br><span>   bts->initial_mcs_dl = bts->initial_mcs_ul = 1;</span><br><span style="color: hsl(0, 100%, 40%);">-    bts->cs1 = 1;</span><br><span style="color: hsl(120, 100%, 40%);">+      bts->cs_mask = 1 << 0;  /* CS-1 always enabled by default */</span><br><span>        bts->n3101 = 10;</span><br><span>  bts->n3103 = 4;</span><br><span>   bts->n3105 = 8;</span><br><span>diff --git a/src/bts.h b/src/bts.h</span><br><span>index a3fa975..7335483 100644</span><br><span>--- a/src/bts.h</span><br><span>+++ b/src/bts.h</span><br><span>@@ -110,10 +110,8 @@</span><br><span>   uint32_t fc_bvc_leak_rate;</span><br><span>   uint32_t fc_ms_bucket_size;</span><br><span>  uint32_t fc_ms_leak_rate;</span><br><span style="color: hsl(0, 100%, 40%);">-       uint8_t cs1;</span><br><span style="color: hsl(0, 100%, 40%);">-    uint8_t cs2;</span><br><span style="color: hsl(0, 100%, 40%);">-    uint8_t cs3;</span><br><span style="color: hsl(0, 100%, 40%);">-    uint8_t cs4;</span><br><span style="color: hsl(120, 100%, 40%);">+  uint8_t cs_mask; /* Allowed CS mask from BTS */</span><br><span style="color: hsl(120, 100%, 40%);">+       uint16_t mcs_mask;  /* Allowed MCS mask from BTS */</span><br><span>  uint8_t initial_cs_dl, initial_cs_ul;</span><br><span>        uint8_t initial_mcs_dl, initial_mcs_ul;</span><br><span>      uint8_t max_cs_dl, max_cs_ul;</span><br><span>diff --git a/src/gprs_bssgp_pcu.cpp b/src/gprs_bssgp_pcu.cpp</span><br><span>index 671629b..4b5582d 100644</span><br><span>--- a/src/gprs_bssgp_pcu.cpp</span><br><span>+++ b/src/gprs_bssgp_pcu.cpp</span><br><span>@@ -738,40 +738,49 @@</span><br><span> </span><br><span> static enum CodingScheme max_coding_scheme_dl(struct gprs_rlcmac_bts *bts)</span><br><span> {</span><br><span style="color: hsl(0, 100%, 40%);">-       int num;</span><br><span style="color: hsl(120, 100%, 40%);">+      int num = 0;</span><br><span style="color: hsl(120, 100%, 40%);">+  int i;</span><br><span> </span><br><span>   if (bts->egprs_enabled) {</span><br><span>                 if (!bts->cs_adj_enabled) {</span><br><span style="color: hsl(0, 100%, 40%);">-                  if (bts->initial_mcs_dl)</span><br><span style="color: hsl(120, 100%, 40%);">+                   if (bts->initial_mcs_dl) {</span><br><span>                                num = bts->initial_mcs_dl;</span><br><span style="color: hsl(0, 100%, 40%);">-                   else</span><br><span style="color: hsl(0, 100%, 40%);">-                            num = 1;</span><br><span style="color: hsl(120, 100%, 40%);">+                      } else {</span><br><span style="color: hsl(120, 100%, 40%);">+                              for (i = 8; i >= 0; i--) {</span><br><span style="color: hsl(120, 100%, 40%);">+                                 if (bts->mcs_mask & (1 << i)) {</span><br><span style="color: hsl(120, 100%, 40%);">+                                          num = i + 1;</span><br><span style="color: hsl(120, 100%, 40%);">+                                          break;</span><br><span style="color: hsl(120, 100%, 40%);">+                                        }</span><br><span style="color: hsl(120, 100%, 40%);">+                             }</span><br><span style="color: hsl(120, 100%, 40%);">+                     }</span><br><span>            } else if (bts->max_mcs_dl) {</span><br><span>                     num = bts->max_mcs_dl;</span><br><span>            } else {</span><br><span>                     num = 9;</span><br><span>             }</span><br><span> </span><br><span style="color: hsl(0, 100%, 40%);">-           return mcs_get_egprs_by_num(num);</span><br><span style="color: hsl(120, 100%, 40%);">+             if (num)</span><br><span style="color: hsl(120, 100%, 40%);">+                      return mcs_get_egprs_by_num(num);</span><br><span>    }</span><br><span> </span><br><span>        if (!bts->cs_adj_enabled) {</span><br><span style="color: hsl(0, 100%, 40%);">-          if (bts->initial_cs_dl)</span><br><span style="color: hsl(120, 100%, 40%);">+            if (bts->initial_cs_dl) {</span><br><span>                         num = bts->initial_cs_dl;</span><br><span style="color: hsl(0, 100%, 40%);">-            else if (bts->cs4)</span><br><span style="color: hsl(0, 100%, 40%);">-                   num = 4;</span><br><span style="color: hsl(0, 100%, 40%);">-                else if (bts->cs3)</span><br><span style="color: hsl(0, 100%, 40%);">-                   num = 3;</span><br><span style="color: hsl(0, 100%, 40%);">-                else if (bts->cs2)</span><br><span style="color: hsl(0, 100%, 40%);">-                   num = 2;</span><br><span style="color: hsl(0, 100%, 40%);">-                else</span><br><span style="color: hsl(0, 100%, 40%);">-                    num = 1;</span><br><span style="color: hsl(120, 100%, 40%);">+              } else {</span><br><span style="color: hsl(120, 100%, 40%);">+                      for (i = 3; i >= 0; i--) {</span><br><span style="color: hsl(120, 100%, 40%);">+                         if (bts->cs_mask & (1 << i)) {</span><br><span style="color: hsl(120, 100%, 40%);">+                                   num = i + 1;</span><br><span style="color: hsl(120, 100%, 40%);">+                                  break;</span><br><span style="color: hsl(120, 100%, 40%);">+                                }</span><br><span style="color: hsl(120, 100%, 40%);">+                     }</span><br><span style="color: hsl(120, 100%, 40%);">+             }</span><br><span>    } else if (bts->max_cs_dl) {</span><br><span>              num = bts->max_cs_dl;</span><br><span style="color: hsl(0, 100%, 40%);">-        } else {</span><br><span style="color: hsl(0, 100%, 40%);">-                num = 4;</span><br><span>     }</span><br><span> </span><br><span style="color: hsl(120, 100%, 40%);">+ if (!num)</span><br><span style="color: hsl(120, 100%, 40%);">+             num = 4;</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span>   return mcs_get_gprs_by_num(num);</span><br><span> }</span><br><span> </span><br><span>diff --git a/src/pcu_l1_if.cpp b/src/pcu_l1_if.cpp</span><br><span>index 8a825a1..7e51763 100644</span><br><span>--- a/src/pcu_l1_if.cpp</span><br><span>+++ b/src/pcu_l1_if.cpp</span><br><span>@@ -551,7 +551,7 @@</span><br><span>     struct gprs_bssgp_pcu *pcu;</span><br><span>  int rc = 0;</span><br><span>  unsigned int trx_nr, ts_nr;</span><br><span style="color: hsl(0, 100%, 40%);">-     int i;</span><br><span style="color: hsl(120, 100%, 40%);">+        unsigned int i;</span><br><span> </span><br><span>  if (info_ind->version != PCU_IF_VERSION) {</span><br><span>                fprintf(stderr, "PCU interface version number of BTS (%u) is "</span><br><span>@@ -613,16 +613,32 @@</span><br><span>     LOGP(DL1IF, LOGL_DEBUG, " dl_tbf_ext=%d\n", info_ind->dl_tbf_ext);</span><br><span>      LOGP(DL1IF, LOGL_DEBUG, " ul_tbf_ext=%d\n", info_ind->ul_tbf_ext);</span><br><span>      bts->bsic = info_ind->bsic;</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+   bts->cs_mask = 1 << 0; /* We need at least 1 CS, let's enable CS1 */</span><br><span>    for (i = 0; i < 4; i++) {</span><br><span style="color: hsl(0, 100%, 40%);">-            if ((info_ind->flags & (PCU_IF_FLAG_CS1 << i)))</span><br><span style="color: hsl(0, 100%, 40%);">-                    LOGP(DL1IF, LOGL_DEBUG, " Use CS%d\n", i+1);</span><br><span style="color: hsl(120, 100%, 40%);">+                uint8_t allowed = !!(info_ind->flags & (PCU_IF_FLAG_CS1 << i));</span><br><span style="color: hsl(120, 100%, 40%);">+          bts->cs_mask |= allowed << i;</span><br><span style="color: hsl(120, 100%, 40%);">+                if (allowed)</span><br><span style="color: hsl(120, 100%, 40%);">+                  LOGP(DL1IF, LOGL_DEBUG, " Use CS%d\n",  i + 1);</span><br><span>    }</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span style="color: hsl(120, 100%, 40%);">+   bts->mcs_mask = 0;</span><br><span>        for (i = 0; i < 9; i++) {</span><br><span style="color: hsl(0, 100%, 40%);">-            if ((info_ind->flags & (PCU_IF_FLAG_MCS1 << i)))</span><br><span style="color: hsl(0, 100%, 40%);">-                   LOGP(DL1IF, LOGL_DEBUG, " Use MCS%d\n", i+1);</span><br><span style="color: hsl(120, 100%, 40%);">+               uint8_t allowed = !!(info_ind->flags & (PCU_IF_FLAG_MCS1 << i));</span><br><span style="color: hsl(120, 100%, 40%);">+         bts->mcs_mask |= allowed << i;</span><br><span style="color: hsl(120, 100%, 40%);">+               if (allowed)</span><br><span style="color: hsl(120, 100%, 40%);">+                  LOGP(DL1IF, LOGL_DEBUG, " Use MCS%d\n", i + 1);</span><br><span>    }</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span>  LOGP(DL1IF, LOGL_DEBUG, " initial_cs=%d\n", info_ind->initial_cs);</span><br><span>      LOGP(DL1IF, LOGL_DEBUG, " initial_mcs=%d\n", info_ind->initial_mcs);</span><br><span style="color: hsl(120, 100%, 40%);">+     if (!bts->force_cs) {</span><br><span style="color: hsl(120, 100%, 40%);">+              if (info_ind->initial_cs < 1 || info_ind->initial_cs > 4)</span><br><span style="color: hsl(120, 100%, 40%);">+                 bts->initial_cs_dl = 1;</span><br><span style="color: hsl(120, 100%, 40%);">+            else</span><br><span style="color: hsl(120, 100%, 40%);">+                  bts->initial_cs_dl = info_ind->initial_cs;</span><br><span style="color: hsl(120, 100%, 40%);">+              bts->initial_cs_ul = bts->initial_cs_dl;</span><br><span style="color: hsl(120, 100%, 40%);">+        }</span><br><span> </span><br><span>        pcu = gprs_bssgp_init(</span><br><span>                       bts,</span><br><span>@@ -640,12 +656,6 @@</span><br><span>          goto bssgp_failed;</span><br><span>   }</span><br><span> </span><br><span style="color: hsl(0, 100%, 40%);">-   bts->cs1 = !!(info_ind->flags & PCU_IF_FLAG_CS1);</span><br><span style="color: hsl(0, 100%, 40%);">-     bts->cs2 = !!(info_ind->flags & PCU_IF_FLAG_CS2);</span><br><span style="color: hsl(0, 100%, 40%);">-     bts->cs3 = !!(info_ind->flags & PCU_IF_FLAG_CS3);</span><br><span style="color: hsl(0, 100%, 40%);">-     bts->cs4 = !!(info_ind->flags & PCU_IF_FLAG_CS4);</span><br><span style="color: hsl(0, 100%, 40%);">-     if (!bts->cs1 && !bts->cs2 && !bts->cs3 && !bts->cs4)</span><br><span style="color: hsl(0, 100%, 40%);">-               bts->cs1 = 1;</span><br><span>     if (info_ind->t3142) { /* if timer values are set */</span><br><span>              osmo_tdef_set(bts->T_defs_bts, 3142, info_ind->t3142, OSMO_TDEF_S);</span><br><span>            osmo_tdef_set(bts->T_defs_bts, 3169, info_ind->t3169, OSMO_TDEF_S);</span><br><span>@@ -656,13 +666,6 @@</span><br><span>             bts->n3103 = info_ind->n3103;</span><br><span>          bts->n3105 = info_ind->n3105;</span><br><span>  }</span><br><span style="color: hsl(0, 100%, 40%);">-       if (!bts->force_cs) {</span><br><span style="color: hsl(0, 100%, 40%);">-                if (info_ind->initial_cs < 1 || info_ind->initial_cs > 4)</span><br><span style="color: hsl(0, 100%, 40%);">-                   bts->initial_cs_dl = 1;</span><br><span style="color: hsl(0, 100%, 40%);">-              else</span><br><span style="color: hsl(0, 100%, 40%);">-                    bts->initial_cs_dl = info_ind->initial_cs;</span><br><span style="color: hsl(0, 100%, 40%);">-                bts->initial_cs_ul = bts->initial_cs_dl;</span><br><span style="color: hsl(0, 100%, 40%);">-  }</span><br><span> </span><br><span>        for (trx_nr = 0; trx_nr < ARRAY_SIZE(bts->trx); trx_nr++) {</span><br><span>            bts->trx[trx_nr].arfcn = info_ind->trx[trx_nr].arfcn;</span><br><span>diff --git a/tests/emu/pcu_emu.cpp b/tests/emu/pcu_emu.cpp</span><br><span>index 41231a3..2b86457 100644</span><br><span>--- a/tests/emu/pcu_emu.cpp</span><br><span>+++ b/tests/emu/pcu_emu.cpp</span><br><span>@@ -68,7 +68,7 @@</span><br><span>     struct gprs_rlcmac_bts *bts = bts_main_data();</span><br><span>       bts->fc_interval = 100;</span><br><span>   bts->initial_cs_dl = bts->initial_cs_ul = 1;</span><br><span style="color: hsl(0, 100%, 40%);">-      bts->cs1 = 1;</span><br><span style="color: hsl(120, 100%, 40%);">+      bts->cs_mask = 1 << 0; /* CS-1 always enabled by default */</span><br><span>         bts->n3101 = 10;</span><br><span>  bts->n3103 = 4;</span><br><span>   bts->n3105 = 8;</span><br><span></span><br></pre><p>To view, visit <a href="https://gerrit.osmocom.org/c/osmo-pcu/+/20990">change 20990</a>. To unsubscribe, or for help writing mail filters, visit <a href="https://gerrit.osmocom.org/settings">settings</a>.</p><div itemscope itemtype="http://schema.org/EmailMessage"><div itemscope itemprop="action" itemtype="http://schema.org/ViewAction"><link itemprop="url" href="https://gerrit.osmocom.org/c/osmo-pcu/+/20990"/><meta itemprop="name" content="View Change"/></div></div>

<div style="display:none"> Gerrit-Project: osmo-pcu </div>
<div style="display:none"> Gerrit-Branch: master </div>
<div style="display:none"> Gerrit-Change-Id: Ie8f0215ba17da1e545e98bec9325c02f1e8efaea </div>
<div style="display:none"> Gerrit-Change-Number: 20990 </div>
<div style="display:none"> Gerrit-PatchSet: 3 </div>
<div style="display:none"> Gerrit-Owner: pespin <pespin@sysmocom.de> </div>
<div style="display:none"> Gerrit-Reviewer: Jenkins Builder </div>
<div style="display:none"> Gerrit-Reviewer: fixeria <vyanitskiy@sysmocom.de> </div>
<div style="display:none"> Gerrit-Reviewer: laforge <laforge@osmocom.org> </div>
<div style="display:none"> Gerrit-Reviewer: pespin <pespin@sysmocom.de> </div>
<div style="display:none"> Gerrit-CC: lynxis lazus <lynxis@fe80.eu> </div>
<div style="display:none"> Gerrit-MessageType: merged </div>