aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/rlc.cpp7
-rw-r--r--src/rlc.h11
2 files changed, 18 insertions, 0 deletions
diff --git a/src/rlc.cpp b/src/rlc.cpp
index bafc56e7..227fa362 100644
--- a/src/rlc.cpp
+++ b/src/rlc.cpp
@@ -224,5 +224,12 @@ void gprs_rlc_ul_window::receive_bsn(const uint16_t bsn)
{
m_v_n.mark_received(bsn);
raise_v_r(bsn);
+}
+
+bool gprs_rlc_ul_window::invalidate_bsn(const uint16_t bsn)
+{
+ bool was_valid = m_v_n.is_received(bsn);
+ m_v_n.mark_missing(bsn);
+ return was_valid;
}
diff --git a/src/rlc.h b/src/rlc.h
index 081ba40e..81689945 100644
--- a/src/rlc.h
+++ b/src/rlc.h
@@ -194,6 +194,7 @@ struct gprs_rlc_ul_window {
const uint16_t ssn() const;
bool is_in_window(uint8_t bsn) const;
+ bool is_received(uint8_t bsn) const;
void update_rbb(char *rbb);
void raise_v_r_to(int moves);
@@ -203,6 +204,7 @@ struct gprs_rlc_ul_window {
void raise_v_q(int);
void receive_bsn(const uint16_t bsn);
+ bool invalidate_bsn(const uint16_t bsn);
uint16_t m_v_r; /* receive state */
uint16_t m_v_q; /* receive window state */
@@ -401,6 +403,15 @@ inline bool gprs_rlc_ul_window::is_in_window(uint8_t bsn) const
return offset_v_q < ws();
}
+inline bool gprs_rlc_ul_window::is_received(uint8_t bsn) const
+{
+ uint16_t offset_v_r;
+
+ /* Offset to the end of the received window */
+ offset_v_r = (m_v_r - 1 - bsn) & mod_sns();
+ return is_in_window(bsn) && m_v_n.is_received(bsn) && offset_v_r < ws();
+}
+
inline const uint16_t gprs_rlc_ul_window::sns() const
{
return RLC_MAX_SNS;