[svn-commits] mattf: branch 1.4 r1445 - /branches/1.4/q921.c

SVN commits to the Digium repositories svn-commits at lists.digium.com
Fri Jan 29 11:27:48 CST 2010


Author: mattf
Date: Fri Jan 29 11:27:43 2010
New Revision: 1445

URL: http://svnview.digium.com/svn/libpri?view=rev&rev=1445
Log:
Fix bug in which an event was lost if an I-frame was received during a timer recovery state (related to #16713)

Modified:
    branches/1.4/q921.c

Modified: branches/1.4/q921.c
URL: http://svnview.digium.com/svn/libpri/branches/1.4/q921.c?view=diff&rev=1445&r1=1444&r2=1445
==============================================================================
--- branches/1.4/q921.c (original)
+++ branches/1.4/q921.c Fri Jan 29 11:27:43 2010
@@ -56,10 +56,7 @@
 	(hf).h.tei = (pri)->tei; \
 } while(0)
 
-//static void reschedule_t203(struct pri *pri);
 static void reschedule_t200(struct pri *pri);
-//static void q921_restart(struct pri *pri, int now);
-//static void q921_tei_release_and_reacquire(struct pri *master);
 static void q921_dump_pri(struct pri *pri);
 static void q921_establish_data_link(struct pri *pri);
 static void q921_mdl_error(struct pri *pri, char error);
@@ -1633,6 +1630,14 @@
 			//res = q931_receive(PRI_MASTER(pri), pri->tei, (q931_h *)h->i.data, len - 4);
 			res = q931_receive(pri, pri->tei, (q931_h *)h->i.data, len - 4);
 
+			if (res == -1) {
+				eres = NULL;
+			}
+
+			if (res & Q931_RES_HAVEEVENT) {
+				eres = &pri->ev;
+			}
+
 			if (h->i.p_f) {
 				q921_rr(pri, 1, 0);
 				pri->acknowledge_pending = 0;
@@ -1662,7 +1667,6 @@
 		} else {
 			if (pri->q921_state == Q921_TIMER_RECOVERY) {
 				update_v_a(pri, h->i.n_r);
-				break;
 			} else {
 				if (pri->peer_rx_busy) {
 					update_v_a(pri, h->i.n_r);
@@ -1682,15 +1686,7 @@
 			}
 		}
 
-		if (res == -1) {
-			return NULL;
-		}
-
-		if (res & Q931_RES_HAVEEVENT) {
-			return &pri->ev;
-		} else {
-			return NULL;
-		}
+		break;
 	default:
 		pri_error(pri, "Don't know what to do with an I frame in state %d\n", pri->q921_state);
 		break;




More information about the svn-commits mailing list