tbf: Move the check if the window is stalled to a separate method
diff --git a/src/tbf.cpp b/src/tbf.cpp
index 747678c..a279fcc 100644
--- a/src/tbf.cpp
+++ b/src/tbf.cpp
@@ -906,8 +906,7 @@
 
 	/* if the window has stalled, or transfer is complete,
 	 * send an unacknowledged block */
-	if (state_is(GPRS_RLCMAC_FINISHED)
-	 || ((dir.dl.v_s - dir.dl.v_a) & mod_sns) == m_ws) {
+	if (state_is(GPRS_RLCMAC_FINISHED) || dl_window_stalled()) {
 	 	int resend = 0;
 
 		if (state_is(GPRS_RLCMAC_FINISHED)) {
@@ -1859,3 +1858,9 @@
 		tbf_name(this));
 	bts->trigger_dl_ass(this, this, NULL);
 }
+
+bool gprs_rlcmac_tbf::dl_window_stalled() const
+{
+	const uint16_t mod_sns = m_sns - 1;
+	return ((dir.dl.v_s - dir.dl.v_a) & mod_sns) == m_ws;
+}
diff --git a/src/tbf.h b/src/tbf.h
index ad13183..1250b40 100644
--- a/src/tbf.h
+++ b/src/tbf.h
@@ -241,6 +241,7 @@
 protected:
 	void reuse_tbf(const uint8_t *data, const uint16_t len);
 	gprs_rlcmac_bts *bts_data() const;
+	bool dl_window_stalled() const;
 
 	int append_data(const uint8_t ms_class,
 			const uint16_t pdu_delay_csec,