laforge has submitted this change. ( 
https://gerrit.osmocom.org/c/libosmocore/+/34984?usp=email )

Change subject: LAPD: Always update N(R) in pending TX frames if V(R) is 
incremented
......................................................................

LAPD: Always update N(R) in pending TX frames if V(R) is incremented

The outcome of the update function is still used to indicate if an RR
frame must be sent or not. Only if there is no I frame in the TX queue,
RR frame must be sent.

Related: OS#4074
Change-Id: I71676c709878105bfd18b9370fecc61b92796a6f
---
M src/gsm/lapdm.c
M src/isdn/lapd_core.c
2 files changed, 25 insertions(+), 8 deletions(-)

Approvals:
  Jenkins Builder: Verified
  fixeria: Looks good to me, but someone else must approve
  laforge: Looks good to me, approved




diff --git a/src/gsm/lapdm.c b/src/gsm/lapdm.c
index 86dc242..43f5662 100644
--- a/src/gsm/lapdm.c
+++ b/src/gsm/lapdm.c
@@ -658,7 +658,8 @@
                                        LAPDm_CTRL_PF_BIT(msg->l2h[1]));
                        rc = 0;
                } else if (LAPDm_CTRL_is_S(msg->l2h[1])) {
-                       LOGDL(dl, LOGL_ERROR, "Supervisory frame in queue, this 
shouldn't happen\n");
+                       msg->l2h[1] = LAPDm_CTRL_S(dl->v_recv, 
LAPDm_CTRL_S_BITS(msg->l2h[1]),
+                                                  
LAPDm_CTRL_PF_BIT(msg->l2h[1]));
                }
        }

diff --git a/src/isdn/lapd_core.c b/src/isdn/lapd_core.c
index e352189..57a0225 100644
--- a/src/isdn/lapd_core.c
+++ b/src/isdn/lapd_core.c
@@ -1525,6 +1525,7 @@
        uint8_t ns = lctx->n_send;
        int length = lctx->length;
        int rc;
+       bool i_frame_in_queue = false;

        LOGDL(dl, LOGL_INFO, "I received in state %s on SAPI(%u)\n",
              lapd_state_name(dl->state), lctx->sapi);
@@ -1615,6 +1616,13 @@
        dl->v_recv = inc_mod(dl->v_recv, dl->v_range);
        LOGDL(dl, LOGL_INFO, "incrementing V(R) to %u\n", dl->v_recv);

+       /* Update all pending frames in the queue to the new V(R) state. */
+       if (dl->update_pending_frames) {
+               rc = dl->update_pending_frames(lctx);
+               if (!rc)
+                       i_frame_in_queue = true;
+       }
+
        /* 5.5.3.1: Acknowlege all transmitted frames up the the N(R)-1 */
        lapd_acknowledge(lctx); /* V(A) is also set here */

@@ -1680,13 +1688,7 @@
                if (!dl->own_busy) {
                        /* NOTE: V(R) is already set above */
                        rc = lapd_send_i(dl, __LINE__, false);
-
-                       /* if update_pending_iframe returns 0 it updated
-                        * the lapd header of an iframe in the tx queue */
-                       if (rc && dl->update_pending_frames)
-                               rc = dl->update_pending_frames(lctx);
-
-                       if (rc) {
+                       if (rc && !i_frame_in_queue) {
                                LOGDL(dl, LOGL_INFO, "we are not busy and have 
no pending data, "
                                      "send RR\n");
                                /* Send RR with F=0 */

--
To view, visit https://gerrit.osmocom.org/c/libosmocore/+/34984?usp=email
To unsubscribe, or for help writing mail filters, visit 
https://gerrit.osmocom.org/settings

Gerrit-Project: libosmocore
Gerrit-Branch: master
Gerrit-Change-Id: I71676c709878105bfd18b9370fecc61b92796a6f
Gerrit-Change-Number: 34984
Gerrit-PatchSet: 5
Gerrit-Owner: jolly <[email protected]>
Gerrit-Reviewer: Jenkins Builder
Gerrit-Reviewer: fixeria <[email protected]>
Gerrit-Reviewer: laforge <[email protected]>
Gerrit-MessageType: merged

Reply via email to