[svn-commits] rmudgett: tag 1.4.11.5 r2133 - in /tags/1.4.11.5:	q921.c q931.c
    SVN commits to the Digium repositories 
    svn-commits at lists.digium.com
       
    Wed Nov 17 15:20:53 CST 2010
    
    
  
Author: rmudgett
Date: Wed Nov 17 15:20:48 2010
New Revision: 2133
URL: http://svnview.digium.com/svn/libpri?view=rev&rev=2133
Log:
Merged revision 1962 from
https://origsvn.digium.com/svn/libpri/branches/1.4
..........
  r1962 | rmudgett | 2010-09-07 19:13:24 -0500 (Tue, 07 Sep 2010) | 21 lines
  Made Q.921 delay events to Q.931 if the event could immediately generate response frames.
  Q.921 was passing a q931_dl_indication(up) event to Q.931 before it was
  finished processing the frame.  The q931_dl_indication(up) event could
  immediately send STATUS messages in the Q.921 intermediate state that
  would then get stuck in the tx queue with an invalid N(S).
  Q.921 was passing i-frames to Q.931 before it was finished processing the
  frame.  The i-frames could cause Q.931 to immediately generate a response
  message that may cause the peer to see the P/F bit as incorrect.
  Delayed passing q931_dl_indication(up) events and i-frames to Q.931 until
  Q.921 has completed processing the frame event.  (The Q.921 SDL diagrams
  were designed with this assumption.)
  (closes issue #17360)
  Reported by: shawkris
  Patches:
	issue17360_v1.4.patch uploaded by rmudgett (license 664)
  Tested by: shawkris, rmudgett
..........
Modified:
    tags/1.4.11.5/q921.c
    tags/1.4.11.5/q931.c
Modified: tags/1.4.11.5/q921.c
URL: http://svnview.digium.com/svn/libpri/tags/1.4.11.5/q921.c?view=diff&rev=2133&r1=2132&r2=2133
==============================================================================
--- tags/1.4.11.5/q921.c (original)
+++ tags/1.4.11.5/q921.c Wed Nov 17 15:20:48 2010
@@ -1280,6 +1280,7 @@
 static pri_event * q921_sabme_rx(struct pri *ctrl, q921_h *h)
 {
 	pri_event *res = NULL;
+	int delay_q931_dl_indication;
 
 	switch (ctrl->q921_state) {
 	case Q921_TIMER_RECOVERY:
@@ -1292,25 +1293,36 @@
 		if (ctrl->v_s != ctrl->v_a) {
 			q921_discard_iqueue(ctrl);
 			/* DL-ESTABLISH indication */
-			q931_dl_indication(ctrl, PRI_EVENT_DCHAN_UP);
+			delay_q931_dl_indication = 1;
+		} else {
+			delay_q931_dl_indication = 0;
 		}
 		stop_t200(ctrl);
 		start_t203(ctrl);
 		ctrl->v_s = ctrl->v_a = ctrl->v_r = 0;
 		q921_setstate(ctrl, Q921_MULTI_FRAME_ESTABLISHED);
+		if (delay_q931_dl_indication) {
+			/* Delayed because Q.931 could send STATUS messages. */
+			q931_dl_indication(ctrl, PRI_EVENT_DCHAN_UP);
+		}
 		break;
 	case Q921_TEI_ASSIGNED:
 		q921_send_ua(ctrl, h->u.p_f);
 		q921_clear_exception_conditions(ctrl);
 		ctrl->v_s = ctrl->v_a = ctrl->v_r = 0;
 		/* DL-ESTABLISH indication */
-		q931_dl_indication(ctrl, PRI_EVENT_DCHAN_UP);
+		//delay_q931_dl_indication = 1;
 		if (PTP_MODE(ctrl)) {
 			ctrl->ev.gen.e = PRI_EVENT_DCHAN_UP;
 			res = &ctrl->ev;
 		}
 		start_t203(ctrl);
 		q921_setstate(ctrl, Q921_MULTI_FRAME_ESTABLISHED);
+		//if (delay_q931_dl_indication)
+		{
+			/* Delayed because Q.931 could send STATUS messages. */
+			q931_dl_indication(ctrl, PRI_EVENT_DCHAN_UP);
+		}
 		break;
 	case Q921_AWAITING_ESTABLISHMENT:
 		q921_send_ua(ctrl, h->u.p_f);
@@ -1347,7 +1359,7 @@
 	case Q921_TIMER_RECOVERY:
 		q921_discard_iqueue(ctrl);
 		q921_send_ua(ctrl, h->u.p_f);
-		/* DL-RELEASE Indication */
+		/* DL-RELEASE indication */
 		q931_dl_indication(ctrl, PRI_EVENT_DCHAN_DOWN);
 		stop_t200(ctrl);
 		if (ctrl->q921_state == Q921_MULTI_FRAME_ESTABLISHED)
@@ -1696,7 +1708,8 @@
 
 static pri_event *q921_ua_rx(struct pri *ctrl, q921_h *h)
 {
-	pri_event * res = NULL;
+	pri_event *res = NULL;
+	int delay_q931_dl_indication;
 
 	if (ctrl->debug & PRI_DEBUG_Q921_STATE) {
 		pri_message(ctrl, "TEI=%d Got UA\n", ctrl->tei);
@@ -1718,15 +1731,16 @@
 			break;
 		}
 
+		delay_q931_dl_indication = 0;
 		if (!ctrl->l3initiated) {
 			if (ctrl->v_s != ctrl->v_a) {
 				q921_discard_iqueue(ctrl);
-				/* return DL-ESTABLISH-INDICATION */
-				q931_dl_indication(ctrl, PRI_EVENT_DCHAN_UP);
+				/* DL-ESTABLISH indication */
+				delay_q931_dl_indication = 1;
 			}
 		} else {
 			ctrl->l3initiated = 0;
-			/* return DL-ESTABLISH-CONFIRM */
+			/* DL-ESTABLISH confirm */
 		}
 
 		if (PTP_MODE(ctrl)) {
@@ -1740,12 +1754,16 @@
 		ctrl->v_r = ctrl->v_s = ctrl->v_a = 0;
 
 		q921_setstate(ctrl, Q921_MULTI_FRAME_ESTABLISHED);
+		if (delay_q931_dl_indication) {
+			/* Delayed because Q.931 could send STATUS messages. */
+			q931_dl_indication(ctrl, PRI_EVENT_DCHAN_UP);
+		}
 		break;
 	case Q921_AWAITING_RELEASE:
 		if (!h->u.p_f) {
 			q921_mdl_error(ctrl, 'D');
 		} else {
-			/* return DL-RELEASE-CONFIRM */
+			/* DL-RELEASE confirm */
 			stop_t200(ctrl);
 			q921_setstate(ctrl, Q921_TEI_ASSIGNED);
 		}
@@ -2047,10 +2065,12 @@
 {
 	pri_event * eres = NULL;
 	int res = 0;
+	int delay_q931_receive;
 
 	switch (ctrl->q921_state) {
 	case Q921_TIMER_RECOVERY:
 	case Q921_MULTI_FRAME_ESTABLISHED:
+		delay_q931_receive = 0;
 		/* FIXME: Verify that it's a command ... */
 		if (ctrl->own_rx_busy) {
 			/* XXX: Note: There's a difference in th P/F between both states */
@@ -2060,19 +2080,20 @@
 
 			ctrl->reject_exception = 0;
 
-			//res = q931_receive(PRI_MASTER(ctrl), ctrl->tei, (q931_h *)h->i.data, len - 4);
-			res = q931_receive(ctrl, ctrl->tei, (q931_h *)h->i.data, len - 4);
-			if (res != -1 && (res & Q931_RES_HAVEEVENT)) {
-				eres = &ctrl->ev;
-			}
+			/*
+			 * Dump Q.931 message where Q.921 says to queue it to Q.931 so if
+			 * Q.921 is dumping its frames they will be in the correct order.
+			 */
+			if (ctrl->debug & PRI_DEBUG_Q931_DUMP) {
+				q931_dump(ctrl, ctrl->tei, (q931_h *) h->i.data, len - 4, 0);
+			}
+			delay_q931_receive = 1;
 
 			if (h->i.p_f) {
 				q921_rr(ctrl, 1, 0);
 				ctrl->acknowledge_pending = 0;
 			} else {
-				if (!ctrl->acknowledge_pending) {
-					ctrl->acknowledge_pending = 1;
-				}
+				ctrl->acknowledge_pending = 1;
 			}
 		} else {
 			if (ctrl->reject_exception) {
@@ -2108,6 +2129,13 @@
 						}
 					}
 				}
+			}
+		}
+		if (delay_q931_receive) {
+			/* Q.921 has finished processing the frame so we can give it to Q.931 now. */
+			res = q931_receive(ctrl, ctrl->tei, (q931_h *) h->i.data, len - 4);
+			if (res != -1 && (res & Q931_RES_HAVEEVENT)) {
+				eres = &ctrl->ev;
 			}
 		}
 		break;
@@ -2342,6 +2370,9 @@
 			break;
 		case 0x00:
 			/* UI-frame */
+			if (ctrl->debug & PRI_DEBUG_Q931_DUMP) {
+				q931_dump(ctrl, ctrl->tei, (q931_h *) h->u.data, len - 3, 0);
+			}
 			res = q931_receive(ctrl, ctrl->tei, (q931_h *) h->u.data, len - 3);
 			if (res != -1 && (res & Q931_RES_HAVEEVENT)) {
 				ev = &ctrl->ev;
Modified: tags/1.4.11.5/q931.c
URL: http://svnview.digium.com/svn/libpri/tags/1.4.11.5/q931.c?view=diff&rev=2133&r1=2132&r2=2133
==============================================================================
--- tags/1.4.11.5/q931.c (original)
+++ tags/1.4.11.5/q931.c Wed Nov 17 15:20:48 2010
@@ -6014,8 +6014,6 @@
 	int allow_posthandle;
 
 	memset(last_ie, 0, sizeof(last_ie));
-	if (ctrl->debug & PRI_DEBUG_Q931_DUMP)
-		q931_dump(ctrl, tei, h, len, 0);
 #ifdef LIBPRI_COUNTERS
 	ctrl->q931_rxcount++;
 #endif
    
    
More information about the svn-commits
mailing list