[svn-commits] branch 1.2 r201 - in /branches/1.2/asterisk-ooh323c: ./ ooh323c/src/ src/

svn-commits at lists.digium.com svn-commits at lists.digium.com
Thu Mar 2 15:21:23 MST 2006


Author: objsys
Date: Thu Mar  2 16:21:17 2006
New Revision: 201

URL: http://svn.digium.com/view/asterisk-addons?rev=201&view=rev
Log:
trunk version changes

Modified:
    branches/1.2/asterisk-ooh323c/ChangeLog
    branches/1.2/asterisk-ooh323c/README
    branches/1.2/asterisk-ooh323c/ooh323c/src/eventHandler.c
    branches/1.2/asterisk-ooh323c/ooh323c/src/ooCalls.c
    branches/1.2/asterisk-ooh323c/ooh323c/src/ooCalls.h
    branches/1.2/asterisk-ooh323c/ooh323c/src/ooCapability.c
    branches/1.2/asterisk-ooh323c/ooh323c/src/ooCapability.h
    branches/1.2/asterisk-ooh323c/ooh323c/src/ooCmdChannel.c
    branches/1.2/asterisk-ooh323c/ooh323c/src/ooGkClient.c
    branches/1.2/asterisk-ooh323c/ooh323c/src/ooGkClient.h
    branches/1.2/asterisk-ooh323c/ooh323c/src/ooLogChan.c
    branches/1.2/asterisk-ooh323c/ooh323c/src/ooSocket.c
    branches/1.2/asterisk-ooh323c/ooh323c/src/ooSocket.h
    branches/1.2/asterisk-ooh323c/ooh323c/src/ooStackCmds.c
    branches/1.2/asterisk-ooh323c/ooh323c/src/ooTimer.c
    branches/1.2/asterisk-ooh323c/ooh323c/src/ooTimer.h
    branches/1.2/asterisk-ooh323c/ooh323c/src/ooUtils.c
    branches/1.2/asterisk-ooh323c/ooh323c/src/ooUtils.h
    branches/1.2/asterisk-ooh323c/ooh323c/src/oochannels.c
    branches/1.2/asterisk-ooh323c/ooh323c/src/ooh245.c
    branches/1.2/asterisk-ooh323c/ooh323c/src/ooh245.h
    branches/1.2/asterisk-ooh323c/ooh323c/src/ooh323.c
    branches/1.2/asterisk-ooh323c/ooh323c/src/ooh323ep.c
    branches/1.2/asterisk-ooh323c/ooh323c/src/ooh323ep.h
    branches/1.2/asterisk-ooh323c/ooh323c/src/ooports.c
    branches/1.2/asterisk-ooh323c/ooh323c/src/ooq931.c
    branches/1.2/asterisk-ooh323c/ooh323c/src/ootrace.c
    branches/1.2/asterisk-ooh323c/ooh323c/src/ootypes.h
    branches/1.2/asterisk-ooh323c/ooh323c/src/printHandler.c
    branches/1.2/asterisk-ooh323c/ooh323c/src/printHandler.h
    branches/1.2/asterisk-ooh323c/src/chan_h323.c
    branches/1.2/asterisk-ooh323c/src/ooh323cDriver.c
    branches/1.2/asterisk-ooh323c/src/ooh323cDriver.h

Modified: branches/1.2/asterisk-ooh323c/ChangeLog
URL: http://svn.digium.com/view/asterisk-addons/branches/1.2/asterisk-ooh323c/ChangeLog?rev=201&r1=200&r2=201&view=diff
==============================================================================
--- branches/1.2/asterisk-ooh323c/ChangeLog (original)
+++ branches/1.2/asterisk-ooh323c/ChangeLog Thu Mar  2 16:21:17 2006
@@ -1,3 +1,10 @@
+Release 0.4
+* Fixed 4 deadlocks conditions in onAlerting, onReceivedDigit and 
+  onCallExstablished funtions
+* Added Thread/Mutex debugging option, for debug build
+* Fixed bug causing dialed digits alias being set as a char string
+
+
 Release 0.2
 Added support for gsm, g729a, g723.1
 Added call end cause conversion logic from H323 cause to asterisk cause

Modified: branches/1.2/asterisk-ooh323c/README
URL: http://svn.digium.com/view/asterisk-addons/branches/1.2/asterisk-ooh323c/README?rev=201&r1=200&r2=201&view=diff
==============================================================================
--- branches/1.2/asterisk-ooh323c/README (original)
+++ branches/1.2/asterisk-ooh323c/README Thu Mar  2 16:21:17 2006
@@ -8,11 +8,11 @@
  H.323 stack from Objective Systems(www.obj-sys.com/open), to be used with 
  asterisk, an open source IP-PBX solution, from Digium, Inc.(www.asterisk.org)
 
- Capabilities supported: ulaw, gsm, g729a, g723.1, rfc2833
+ Capabilities supported: ulaw, gsm, g729, g729a, g723.1, rfc2833
 
  Package Contents:
 
-    asterisk-ooh323c-0.3
+    asterisk-ooh323c-0.4
     |
     |-src [H323 channel driver code]
     |
@@ -20,54 +20,67 @@
 
 
  How to build:
- 1. To build this package successfully, you have to have latest cvs version of 
-    asterisk installed on your system.
-       To get asterisk sources from cvs:
-       cvs -d:pserver:anoncvs at cvs.digium.com:/usr/cvsroot login
-       CVS Password:anoncvs
+ -------------
+ 1. If you hadn't installed asterisk yet, To build this package successfully, 
+    you have to have latest version of asterisk installed on your system. 
+    You can skip to step 2, if you have already installed the asterisk.
 
-       cvs -d:pserver:anoncvs at cvs.digium.com:/usr/cvsroot co asterisk
+      Following precedure help you download and install asterisk
 
-       To install asterisk.(You will have to be in super user mode for this)
-       >cd asterisk
-       >make install
-       >make samples
+      To get latest asterisk sources from svn:
+      >svn checkout http://svn.digium.com/svn/asterisk/trunk asterisk
 
- 2. To build asterisk-ooh323c-0.3
-      >cd asterisk-oh323c-0.3
+      To install asterisk.(You will have to be in 'super user' mode for this)
+      >cd asterisk
+      >make install
+      >make samples
+
+ 2. To build asterisk-ooh323c addons
+
+      To update or if you hadn't downloaded the asterisk-ooh323c channel driver
+      code, you can do so using following command (To get the latest 
+      asterisk-addons source from svn):
+      >svn checkout http://svn.digium.com/svn/asterisk-addons/trunk asterisk-addons
+
+      To build & install:
+      >cd asterisk-addons/asterisk-ooh323c
       >./configure
       >make
+
+      For debugging purpose, instead of "make", run "make debug"
+
+      The library will be generated at 
+      asterisk-addons/asterisk-ooh323c/.libs/libchan_h323.so.1.0.1 
  
- 3. To install chan_h323.so in /usr/libs/modules/ change to super user mode
-    and then run:
-
+      To install libchan_h323.so in /usr/libs/modules/ directory, change to 
+      'super user' mode and then run:
       >make install
 
- 4. Open h323.conf.sample in asterisk-ooh323c-0.3 directory. Under [general] 
-    you will see global configuration setting. Modify ip addresses of asterisk 
+ 3. Open h323.conf.sample in asterisk-ooh323c-0.4 directory. Under [general] 
+    you will see global configuration setting. Modify IP addresses of asterisk 
     server "bindaddr" to match your configuration.
 
- 5. To install sample h323.conf in /etc/asterisk
+ 4. To install sample h323.conf in /etc/asterisk
       >make sample
 
- 6. Now run asterisk as
-    /usr/sbin/asterisk -vvvc
+ 5. Now run asterisk as
+      >/usr/sbin/asterisk -vvvc
 
- 7. From asterisk console
+ 6. From asterisk console
     To check whether H323 channel is registered properly
        CLI>show channeltypes
 
     To see all the defined H323 users.
-       CLI>h323 show users
+       CLI>ooh323 show users
    
     To see details of a specific user
-       CLI>h323 show user myuser1
+       CLI>ooh323 show user myuser1
 
     To see all the defined peers
-       CLI>h323 show peers
+       CLI>ooh323 show peers
     
     To see details of a specific peer
-       CLI>h323 show peer mypeer1
+       CLI>ooh323 show peer mypeer1
 
 
 Getting Started with some simple examples:
@@ -76,7 +89,7 @@
       CLI>stop now
 
  Now to run tests, you will have to copy extensions.conf.sample in 
- asterisk-ooh323c-0.3 directory to /etc/asterisk as extensions.conf. Make
+ asterisk-ooh323c-0.4 directory to /etc/asterisk as extensions.conf. Make
  sure to save a backup copy of your existing extensions.conf. Now restart
  the pbx as follows:
       >/usr/sbin/asterisk -vvvc
@@ -136,7 +149,7 @@
 
  6. Check details of peer for ip/port
     
-     CLI>h323 show peer mypeer1
+     CLI>ooh323 show peer mypeer1
 
  7. Now use phone1 to make a call to asterisk at extension 101 as follows.
 

Modified: branches/1.2/asterisk-ooh323c/ooh323c/src/eventHandler.c
URL: http://svn.digium.com/view/asterisk-addons/branches/1.2/asterisk-ooh323c/ooh323c/src/eventHandler.c?rev=201&r1=200&r2=201&view=diff
==============================================================================
--- branches/1.2/asterisk-ooh323c/ooh323c/src/eventHandler.c (original)
+++ branches/1.2/asterisk-ooh323c/ooh323c/src/eventHandler.c Thu Mar  2 16:21:17 2006
@@ -62,7 +62,7 @@
 }
 
 void invokeBitStrValue (OOCTXT* pctxt, ASN1UINT numbits, 
-			const ASN1OCTET* data)
+                        const ASN1OCTET* data)
 {
    if (0 != pctxt->pEventHandler) {
       pctxt->pEventHandler->bitStrValue (numbits, data);
@@ -70,7 +70,7 @@
 }
 
 void invokeOctStrValue (OOCTXT* pctxt, ASN1UINT numocts, 
-			const ASN1OCTET* data)
+                        const ASN1OCTET* data)
 {
    if (0 != pctxt->pEventHandler) {
       pctxt->pEventHandler->octStrValue (numocts, data);
@@ -85,7 +85,7 @@
 }
 
 void invokeCharStr16BitValue (OOCTXT* pctxt, ASN1UINT nchars, 
-			      ASN116BITCHAR* data)
+                              ASN116BITCHAR* data)
 {
    if (0 != pctxt->pEventHandler) {
       pctxt->pEventHandler->charStr16BitValue (nchars, data);
@@ -114,7 +114,7 @@
 }
 
 void invokeOpenTypeValue (OOCTXT* pctxt, ASN1UINT numocts, 
-			  const ASN1OCTET* data)
+                          const ASN1OCTET* data)
 {
    if (0 != pctxt->pEventHandler) {
       pctxt->pEventHandler->openTypeValue (numocts, data);

Modified: branches/1.2/asterisk-ooh323c/ooh323c/src/ooCalls.c
URL: http://svn.digium.com/view/asterisk-addons/branches/1.2/asterisk-ooh323c/ooh323c/src/ooCalls.c?rev=201&r1=200&r2=201&view=diff
==============================================================================
--- branches/1.2/asterisk-ooh323c/ooh323c/src/ooCalls.c (original)
+++ branches/1.2/asterisk-ooh323c/ooh323c/src/ooCalls.c Thu Mar  2 16:21:17 2006
@@ -52,11 +52,13 @@
    sprintf(call->callToken, "%s", callToken);
    sprintf(call->callType, "%s", type);
    call->callReference = 0;
-   if(gH323ep.callerid){
+   if(gH323ep.callerid) {
      strncpy(call->ourCallerId, gH323ep.callerid, sizeof(call->ourCallerId)-1);
      call->ourCallerId[sizeof(call->ourCallerId)-1] = '\0';
-   }else
+   }
+   else {
       call->ourCallerId[0] = '\0';
+   }
    
    memset(&call->callIdentifier, 0, sizeof(H225CallIdentifier));
    memset(&call->confIdentifier, 0, sizeof(H225ConferenceIdentifier));
@@ -84,17 +86,20 @@
    if(!strcmp(call->callType, "incoming"))
    {
       call->callingPartyNumber = NULL;
-   }else{      
+   }
+   else{      
       if(ooUtilsIsStrEmpty(gH323ep.callingPartyNumber))
       {
          call->callingPartyNumber = NULL;
-      }else{
+      }
+      else{
          call->callingPartyNumber = (char*) memAlloc(call->pctxt, 
                                          strlen(gH323ep.callingPartyNumber)+1);
          if(call->callingPartyNumber)
          {
             strcpy(call->callingPartyNumber, gH323ep.callingPartyNumber);
-         }else{
+         }
+         else{
             OOTRACEERR3("Error:Memory - ooCreateCall - callingPartyNumber"
                         ".(%s, %s)\n", call->callType, call->callToken);
             freeContext(pctxt);
@@ -199,7 +204,8 @@
    if(!call->pH225Channel || call->pH225Channel->sock ==0)
    {
       call->callState = OO_CALL_CLEARED;
-   }else{
+   }
+   else{
       if(!OO_TESTFLAG(call->flags, OO_M_RELEASE_BUILT))   
       {
          if(call->callState == OO_CALL_CLEAR || 
@@ -243,7 +249,7 @@
    OOCTXT *pctxt;
 
    OOTRACEWARN4 ("Cleaning Call (%s, %s)- reason:%s\n", 
-		 call->callType, call->callToken, 
+                 call->callType, call->callToken, 
                  ooGetReasonCodeText (call->callEndReason));
 
    /* First clean all the logical channels, if not already cleaned. */
@@ -299,7 +305,8 @@
          OOTRACEERR3("Error:Failed to forward call (%s, %s)\n", call->callType,
                      call->callToken);
       }
-   }else {
+   }
+   else {
       if(gH323ep.h323Callbacks.onCallCleared)
          gH323ep.h323Callbacks.onCallCleared(call);
    }
@@ -328,7 +335,8 @@
    if(call->callingPartyNumber)
    {
      strcpy(call->callingPartyNumber, number);
-   }else{
+   }
+   else{
       OOTRACEERR3("Error:Memory - ooCallSetCallingPartyNumber - "
                   "callingPartyNumber.(%s, %s)\n", call->callType, 
                   call->callToken);
@@ -366,7 +374,8 @@
    if(call->calledPartyNumber)
    {
      strcpy(call->calledPartyNumber, number);
-   }else{
+   }
+   else{
       OOTRACEERR3("Error:Memory - ooCallSetCalledPartyNumber - "
                   "calledPartyNumber.(%s, %s)\n", call->callType, 
                   call->callToken);
@@ -424,7 +433,8 @@
    {
       psNewAlias->next = call->ourAliases;
       call->ourAliases = psNewAlias;
-   }else {
+   }
+   else {
      psNewAlias->next = call->remoteAliases;
      call->remoteAliases = psNewAlias;
    }
@@ -686,7 +696,7 @@
          if(call->masterSlaveState == OO_MasterSlave_Master)
             sessionID = call->nextSessionID++;
          else{
-	   OOTRACEDBGC4("Session id for %s channel of type audio has to be "
+            OOTRACEDBGC4("Session id for %s channel of type audio has to be "
                         "provided by remote.(%s, %s)\n", dir, call->callType, 
                          call->callToken);
             sessionID = 0; /* Will be assigned by remote */
@@ -770,6 +780,7 @@
       "OO_CALL_WAITING_ADMISSION",
       "OO_CALL_CONNECTING",
       "OO_CALL_CONNECTED",
+      "OO_CALL_PAUSED",
       "OO_CALL_CLEAR",
       "OO_CALL_CLEAR_RELEASERECVD",
       "OO_CALL_CLEAR_RELEASESENT",

Modified: branches/1.2/asterisk-ooh323c/ooh323c/src/ooCalls.h
URL: http://svn.digium.com/view/asterisk-addons/branches/1.2/asterisk-ooh323c/ooh323c/src/ooCalls.h?rev=201&r1=200&r2=201&view=diff
==============================================================================
--- branches/1.2/asterisk-ooh323c/ooh323c/src/ooCalls.h (original)
+++ branches/1.2/asterisk-ooh323c/ooh323c/src/ooCalls.h Thu Mar  2 16:21:17 2006
@@ -62,6 +62,7 @@
    OO_CALL_WAITING_ADMISSION,     /*!< Call waiting for admission by GK */
    OO_CALL_CONNECTING,            /*!< Call in process of connecting */
    OO_CALL_CONNECTED,             /*!< Call currently connected. */
+   OO_CALL_PAUSED,                /*!< Call Paused for hold/transfer. */
    OO_CALL_CLEAR,                 /*!< Call marked for clearing */
    OO_CALL_CLEAR_RELEASERECVD,    /*!< Release command received. */
    OO_CALL_CLEAR_RELEASESENT,     /*!< Release sent */
@@ -73,6 +74,7 @@
  */
 typedef enum {
    OO_H245SESSION_IDLE,
+   OO_H245SESSION_PAUSED,
    OO_H245SESSION_ACTIVE,
    OO_H245SESSION_ENDSENT, 
    OO_H245SESSION_ENDRECVD,
@@ -111,9 +113,9 @@
  * a particular call.
  */
 typedef struct OOH323Channel {
-   OOSOCKET	sock;      /*!< Socket connection for the channel */
-   int		port;      /*!< Port assigned to the channel */
-   DList	outQueue;  /*!< Output message queue */
+   OOSOCKET sock;      /*!< Socket connection for the channel */
+   int      port;      /*!< Port assigned to the channel */
+   DList    outQueue;  /*!< Output message queue */
 } OOH323Channel;
 
 /**
@@ -142,8 +144,8 @@
    OOMediaInfo          *mediaInfo;
    OOCallFwdData        *pCallFwdData;
    char                 localIP[20];/* Local IP address */
-   OOH323Channel*	pH225Channel;
-   OOH323Channel*	pH245Channel;
+   OOH323Channel*       pH225Channel;
+   OOH323Channel*       pH245Channel;
    OOSOCKET             *h245listener;
    int                  *h245listenport;
    char                 remoteIP[20];/* Remote IP address */
@@ -170,7 +172,7 @@
    int                  logicalChanNoMax;
    int                  logicalChanNoCur;
    unsigned             nextSessionID; /* Note by default 1 is audio session, 2 is video and 3 is data, from 3 onwards master decides*/
-   DList		timerList;
+   DList                timerList;
    ASN1UINT             msdRetries;
    void                 *usrData; /*!<User can set this to user specific data*/
    struct OOH323CallData* next;
@@ -530,7 +532,7 @@
                                   cb_StartReceiveChannel startReceiveChannel,
                                   cb_StartTransmitChannel startTransmitChannel,
                                   cb_StopReceiveChannel stopReceiveChannel,
-				  cb_StopTransmitChannel stopTransmitChannel);
+                                  cb_StopTransmitChannel stopTransmitChannel);
 
 
 

Modified: branches/1.2/asterisk-ooh323c/ooh323c/src/ooCapability.c
URL: http://svn.digium.com/view/asterisk-addons/branches/1.2/asterisk-ooh323c/ooh323c/src/ooCapability.c?rev=201&r1=200&r2=201&view=diff
==============================================================================
--- branches/1.2/asterisk-ooh323c/ooh323c/src/ooCapability.c (original)
+++ branches/1.2/asterisk-ooh323c/ooh323c/src/ooCapability.c Thu Mar  2 16:21:17 2006
@@ -30,7 +30,8 @@
    {
       gH323ep.dtmfmode |= OO_CAP_DTMF_RFC2833;
       OOTRACEINFO1("Enabled RFC2833 DTMF capability for end-point\n");
-   }else{
+   }
+   else{
       call->dtmfmode |= OO_CAP_DTMF_RFC2833;
       OOTRACEINFO3("Enabled RFC2833 DTMF capability for (%s, %s) \n", 
                    call->callType, call->callToken);
@@ -50,7 +51,8 @@
    if(!call){
       gH323ep.dtmfmode ^= OO_CAP_DTMF_RFC2833;
       OOTRACEINFO1("Disabled RFC2833 DTMF capability for end-point\n");
-   }else{
+   }
+   else{
       call->dtmfmode ^= OO_CAP_DTMF_RFC2833;
       OOTRACEINFO3("Disabled RFC2833 DTMF capability for (%s, %s)\n", 
                     call->callType, call->callToken);
@@ -64,7 +66,8 @@
    if(!call){
       gH323ep.dtmfmode |= OO_CAP_DTMF_H245_alphanumeric;
       OOTRACEINFO1("Dtmf mode set to H.245(alphanumeric) for endpoint\n");
-   }else {
+   }
+   else {
       call->dtmfmode |= OO_CAP_DTMF_H245_alphanumeric;
       OOTRACEINFO3("Dtmf mode set to H.245(alphanumeric) for (%s, %s)\n", 
                     call->callType, call->callToken);
@@ -77,7 +80,8 @@
    if(!call){
       gH323ep.dtmfmode ^= OO_CAP_DTMF_H245_alphanumeric;
       OOTRACEINFO1("Dtmf mode H.245(alphanumeric) disabled for endpoint\n");
-   }else {
+   }
+   else {
       call->dtmfmode ^= OO_CAP_DTMF_H245_alphanumeric;
       OOTRACEINFO3("Dtmf mode H.245(alphanumeric) disabled for (%s, %s)\n", 
                     call->callType, call->callToken);
@@ -90,7 +94,8 @@
    if(!call){
       gH323ep.dtmfmode |= OO_CAP_DTMF_H245_signal;
       OOTRACEINFO1("Dtmf mode set to H.245(signal) for endpoint\n");
-   }else {
+   }
+   else {
       call->dtmfmode |= OO_CAP_DTMF_H245_signal;
       OOTRACEINFO3("Dtmf mode set to H.245(signal) for (%s, %s)\n", 
                     call->callType, call->callToken);
@@ -103,7 +108,8 @@
    if(!call){
       gH323ep.dtmfmode ^= OO_CAP_DTMF_H245_signal;
       OOTRACEINFO1("Dtmf mode H.245(signal) disabled for endpoint\n");
-   }else {
+   }
+   else {
       call->dtmfmode ^= OO_CAP_DTMF_H245_signal;
       OOTRACEINFO3("Dtmf mode H.245(signal) disabled for (%s, %s)\n", 
                     call->callType, call->callToken);
@@ -116,7 +122,8 @@
    if(!call){
       gH323ep.dtmfmode |= OO_CAP_DTMF_Q931;
       OOTRACEINFO1("Dtmf mode set to Q.931(keypad) for the endpoint\n");
-   }else {
+   }
+   else {
       call->dtmfmode |= OO_CAP_DTMF_Q931;
       OOTRACEINFO3("Dtmf mode set to Q.931(keypad) for the call (%s, %s)\n", 
                     call->callType, call->callToken);
@@ -129,7 +136,8 @@
    if(!call){
       gH323ep.dtmfmode ^= OO_CAP_DTMF_Q931;
       OOTRACEINFO1("Dtmf mode Q.931(keypad) disabled for the endpoint\n");
-   }else {
+   }
+   else {
       call->dtmfmode ^= OO_CAP_DTMF_Q931;
       OOTRACEINFO3("Dtmf mode Q.931(keypad) disabled for the call (%s, %s)\n", 
                     call->callType, call->callToken);
@@ -280,7 +288,8 @@
    {
       epCap->dir = OORX;
       epCap->dir |= OOTX;
-   }else
+   }
+   else
       epCap->dir = dir;
    
    epCap->cap = OO_H263VIDEO;
@@ -305,18 +314,20 @@
       }
       ooAppendCapToCapPrefs(NULL, cap);
       gH323ep.noOfCaps++;
-   }else{
+   }
+   else{
       if(remote)
       {
          /*Add as remote capability */
          if(!call->remoteCaps)
             call->remoteCaps = epCap;
          else{
-	    cur = call->remoteCaps;
+            cur = call->remoteCaps;
             while(cur->next) cur = cur->next;
             cur->next = epCap;
          }
-     }else{
+     }
+     else{
         /*Add as our capability */
         OOTRACEDBGC4("Adding call specific H263 video capability %s. "
                      "(%s, %s)\n", pictureType, call->callType, 
@@ -326,7 +337,7 @@
            ooResetCapPrefs(call);
         }
         else{
-	   cur = call->ourCaps;
+           cur = call->ourCaps;
            while(cur->next) cur = cur->next;
            cur->next = epCap;
         }
@@ -357,7 +368,7 @@
    params = (OOCapParams*) memAlloc(pctxt, sizeof(OOCapParams));
    if(!epCap || !params)
    {
-      OOTRACEERR1("Error:Memory - ooCapabilityAddSimpleCapability - "
+      OOTRACEERR1("ERROR: Memory - ooCapabilityAddSimpleCapability - "
                   "epCap/params\n");
       return OO_FAILED;
    }
@@ -371,12 +382,13 @@
    else
       params->silenceSuppression = FALSE; /* Set to false for g711 and g729*/
 
-   if(dir & OORXANDTX)
-   {
+   if(dir & OORXANDTX) {
       epCap->dir = OORX;
       epCap->dir |= OOTX;
-   }else
+   }
+   else {
       epCap->dir = dir;
+   }
    
    epCap->cap = cap;
    epCap->capType = OO_CAP_TYPE_AUDIO;
@@ -388,11 +400,13 @@
    epCap->next = NULL;
 
    if(!call)
-   {/*Add as local capability */
+   {
+      /* Add as local capability */
       OOTRACEDBGC2("Adding endpoint capability %s. \n", 
                      ooGetCapTypeText(epCap->cap));
-      if(!gH323ep.myCaps)
+      if(!gH323ep.myCaps) {
          gH323ep.myCaps = epCap;
+      }
       else{
          cur = gH323ep.myCaps;
          while(cur->next) cur = cur->next;
@@ -400,33 +414,36 @@
       }
       ooAppendCapToCapPrefs(NULL, cap);
       gH323ep.noOfCaps++;
-   }else{
+   }
+   else{
       if(remote)
       {
-         /*Add as remote capability */
-         if(!call->remoteCaps)
+         /* Add as remote capability */
+         if(!call->remoteCaps) {
             call->remoteCaps = epCap;
+         }
          else{
-	    cur = call->remoteCaps;
+            cur = call->remoteCaps;
             while(cur->next) cur = cur->next;
             cur->next = epCap;
          }
-     }else{
-        /*Add as our capability */
-        OOTRACEDBGC4("Adding call specific capability %s. (%s, %s)\n", 
-                     ooGetCapTypeText(epCap->cap), call->callType, 
-                     call->callToken);
-        if(!call->ourCaps){
-           call->ourCaps = epCap;
-           ooResetCapPrefs(call);
-        }
-        else{
-	   cur = call->ourCaps;
-           while(cur->next) cur = cur->next;
-           cur->next = epCap;
-        }
-        ooAppendCapToCapPrefs(call, cap);
-     }
+      }
+      else{
+         /* Add as our capability */
+         OOTRACEDBGC4("Adding call specific capability %s. (%s, %s)\n", 
+                      ooGetCapTypeText(epCap->cap), call->callType, 
+                      call->callToken);
+         if(!call->ourCaps){
+            call->ourCaps = epCap;
+            ooResetCapPrefs(call);
+         }
+         else{
+            cur = call->ourCaps;
+            while(cur->next) cur = cur->next;
+            cur->next = epCap;
+         }
+         ooAppendCapToCapPrefs(call, cap);
+      }
    }
            
    return OO_OK;
@@ -468,7 +485,8 @@
    {
       epCap->dir = OORX;
       epCap->dir |= OOTX;
-   }else
+   }
+   else
       epCap->dir = dir;
 
    epCap->cap = cap;
@@ -492,18 +510,20 @@
       }
       ooAppendCapToCapPrefs(NULL, cap);
       gH323ep.noOfCaps++;
-   }else{
+   }
+   else{
       if(remote)
       {
          /*Add as remote capability */
          if(!call->remoteCaps)
             call->remoteCaps = epCap;
          else{
-	    cur = call->remoteCaps;
+            cur = call->remoteCaps;
             while(cur->next) cur = cur->next;
             cur->next = epCap;
          }
-      }else{
+      }
+      else{
          OOTRACEDBGC4("Adding call specific capability %s. (%s, %s)\n", 
                      ooGetCapTypeText(epCap->cap), call->callType, 
                      call->callToken);
@@ -513,7 +533,7 @@
             ooResetCapPrefs(call);
          }
          else{
-	    cur = call->ourCaps;
+            cur = call->ourCaps;
             while(cur->next) cur = cur->next;
             cur->next = epCap;
          }
@@ -558,7 +578,7 @@
    case OO_EXTELEMVIDEO:
    default:
       OOTRACEERR2("ERROR: Don't know how to create video capability %s\n",
-		  ooGetCapTypeText(epCap->cap));
+                  ooGetCapTypeText(epCap->cap));
    }
    return NULL;
 }
@@ -597,7 +617,7 @@
       return ooCapabilityCreateGSMFullRateCapability(epCap, pctxt, dir);
    default:
       OOTRACEERR2("ERROR: Don't know how to create audio capability %d\n",
-		  epCap->cap);
+                  epCap->cap);
    }
    return NULL;
 }
@@ -691,24 +711,23 @@
    pVideo->u.h263VideoCapability = pH263Cap;
 
 
-   if(params->picFormat ==  OO_PICFORMAT_SQCIF)
-   {
+   if(params->picFormat ==  OO_PICFORMAT_SQCIF) {
       pH263Cap->m.sqcifMPIPresent = TRUE;
       pH263Cap->sqcifMPI = params->MPI;
-   }else if(params->picFormat == OO_PICFORMAT_QCIF)
-   {
+   }
+   else if(params->picFormat == OO_PICFORMAT_QCIF) {
       pH263Cap->m.qcifMPIPresent = TRUE;
       pH263Cap->qcifMPI = params->MPI;
-   }else if(params->picFormat == OO_PICFORMAT_CIF)
-   {
+   }
+   else if(params->picFormat == OO_PICFORMAT_CIF) {
       pH263Cap->m.cifMPIPresent = TRUE;
       pH263Cap->cifMPI = params->MPI;
-   }else if(params->picFormat == OO_PICFORMAT_CIF4)
-   {
+   }
+   else if(params->picFormat == OO_PICFORMAT_CIF4) {
       pH263Cap->m.cif4MPIPresent  = TRUE;
       pH263Cap->cif4MPI = params->MPI;
-   }else if(params->picFormat == OO_PICFORMAT_CIF16)
-   {
+   }
+   else if(params->picFormat == OO_PICFORMAT_CIF16) {
       pH263Cap->m.cif16MPIPresent = TRUE;
       pH263Cap->cif16MPI = params->MPI;
    }
@@ -857,7 +876,7 @@
    return NULL;
 }
 
-/*Used for g711 ulaw/alaw, g729, g729a, g7231 */
+/* Used for g711 ulaw/alaw, g729, g729a, g7231 */
 ASN1BOOL ooCapabilityCheckCompatibility_Simple
    (OOH323CallData *call, ooH323EpCapability* epCap, 
     H245AudioCapability* audioCap, int dir)
@@ -897,18 +916,34 @@
       return FALSE;
    }
 
-   /* can we receive this capability */
+   if(cap != epCap->cap) { return FALSE; }
+
+   /* Can we receive this capability */
    if(dir & OORX)
    {
-      if(((OOCapParams*)epCap->params)->rxframes >= noofframes)
+      //if(cap == OO_G7231) {
+      //   if(((OOCapParams*)epCap->params)->rxframes <= noofframes) {
+      //      return TRUE;
+      //   }
+      //}
+      //else
+      if(((OOCapParams*)epCap->params)->rxframes >= noofframes) {
          return TRUE;
+      }
    }
 
    /* Can we transmit compatible stream */
    if(dir & OOTX)
    {
-      if(((OOCapParams*)epCap->params)->txframes <= noofframes)
+      //if(cap == OO_G7231) {
+      //   if(((OOCapParams*)epCap->params)->txframes >= noofframes) {
+      //      return TRUE;
+      //   }
+      //}
+      //else 
+      if(((OOCapParams*)epCap->params)->txframes <= noofframes) {
          return TRUE;
+      }
    }
    return FALSE;
 
@@ -982,10 +1017,11 @@
    {
       if(pH263Cap->m.sqcifMPIPresent)
       {
-	if(params->picFormat != OO_PICFORMAT_SQCIF)
+         if(params->picFormat != OO_PICFORMAT_SQCIF)
          {
             return FALSE;
-         }else{
+         }
+         else{
             if(pH263Cap->sqcifMPI >= params->MPI)
                return TRUE;
             else
@@ -997,7 +1033,8 @@
          if(params->picFormat != OO_PICFORMAT_QCIF)
          {
             return FALSE;
-         }else{
+         }
+         else{
             if(pH263Cap->qcifMPI >= params->MPI)
                return TRUE;
             else
@@ -1009,7 +1046,8 @@
          if(params->picFormat != OO_PICFORMAT_CIF)
          {
             return FALSE;
-         }else{
+         }
+         else{
             if(pH263Cap->cifMPI >= params->MPI)
                return TRUE;
             else
@@ -1021,7 +1059,8 @@
          if(params->picFormat != OO_PICFORMAT_CIF4)
          {
             return FALSE;
-         }else{
+         }
+         else{
             if(pH263Cap->cif4MPI >= params->MPI)
                return TRUE;
             else
@@ -1033,7 +1072,8 @@
          if(params->picFormat != OO_PICFORMAT_CIF16)
          {
             return FALSE;
-         }else{
+         }
+         else{
             if(pH263Cap->cif16MPI >= params->MPI)
                return TRUE;
             else
@@ -1050,7 +1090,8 @@
          if(params->picFormat != OO_PICFORMAT_SQCIF)
          {
             return FALSE;
-         }else{
+         }
+         else{
             if(pH263Cap->sqcifMPI <= params->MPI)
                return TRUE;
             else
@@ -1062,7 +1103,8 @@
          if(params->picFormat != OO_PICFORMAT_QCIF)
          {
             return FALSE;
-         }else{
+         }
+         else{
             if(pH263Cap->qcifMPI <= params->MPI)
                return TRUE;
             else
@@ -1074,7 +1116,8 @@
          if(params->picFormat != OO_PICFORMAT_CIF)
          {
             return FALSE;
-         }else{
+         }
+         else{
             if(pH263Cap->cifMPI <= params->MPI)
                return TRUE;
             else
@@ -1086,7 +1129,8 @@
          if(params->picFormat != OO_PICFORMAT_CIF4)
          {
             return FALSE;
-         }else{
+         }
+         else{
             if(pH263Cap->cif4MPI <= params->MPI)
                return TRUE;
             else
@@ -1098,7 +1142,8 @@
          if(params->picFormat != OO_PICFORMAT_CIF16)
          {
             return FALSE;
-         }else{
+         }
+         else{
             if(pH263Cap->cif16MPI <= params->MPI)
                return TRUE;
             else
@@ -1154,7 +1199,7 @@
 /*
    Note: In faststart if we sent transmit rate (x>y) and remote
          can receive only y, then we can't reduce our transmit rate
- */
+*/
 OOBOOL ooCapabilityCheckCompatibility
    (struct OOH323CallData *call, ooH323EpCapability* epCap, 
     H245DataType* dataType, int dir)
@@ -1400,7 +1445,7 @@
          cap = OO_G7231;
          break;
       default:
-	return NULL;
+         return NULL;
    }
 
    OOTRACEDBGC4("Determined Simple audio data type to be of type %s. Searching"
@@ -1418,7 +1463,7 @@
    while(cur)
    {
       OOTRACEDBGC4("Local cap being compared %s. (%s, %s)\n", 
-              ooGetCapTypeText(cur->cap),call->callType, call->callToken);
+         ooGetCapTypeText(cur->cap),call->callType, call->callToken);
       
       if(cur->cap == cap && (cur->dir & dir))
          break;
@@ -1593,8 +1638,8 @@
       
       if(cur->cap == cap && (cur->dir & dir))
       {
-	 if(((OOH263CapParams*)cur->params)->picFormat == picFormat)
-           break;
+         if(((OOH263CapParams*)cur->params)->picFormat == picFormat)
+            break;
       }
       cur = cur->next;
    }
@@ -1609,16 +1654,16 @@
       if(mpi < ((OOH263CapParams*)cur->params)->MPI)
          return NULL;
       else{
-	 epCap = (ooH323EpCapability*)memAlloc(call->pctxt, 
+         epCap = (ooH323EpCapability*)memAlloc(call->pctxt, 
                                                    sizeof(ooH323EpCapability));
          params = (OOH263CapParams*) memAlloc(call->pctxt, 
                                                       sizeof(OOH263CapParams));
          if(!epCap || !params)
          {
-	   OOTRACEERR3("Error:Memory - ooIsVideoDataTypeH263Supported - "
+            OOTRACEERR3("Error:Memory - ooIsVideoDataTypeH263Supported - "
                        "epCap/params. (%s, %s)\n", call->callType, 
                         call->callToken);
-           return NULL;
+            return NULL;
          }
          epCap->params = params;
          epCap->cap = cur->cap;
@@ -1734,7 +1779,7 @@
       return ooIsVideoDataTypeSupported(call, data->u.videoData, dir);
    case T_H245DataType_audioData:
       OOTRACEDBGC3("Looking for audio dataType support. (%s, %s)\n",
-		   call->callType, call->callToken);
+                    call->callType, call->callToken);
       return ooIsAudioDataTypeSupported(call, data->u.audioData, dir);
    case T_H245DataType_data:
      OOTRACEDBGC3("Data type not supported.(%s, %s)\n", 
@@ -1888,7 +1933,7 @@
 }
 
 int ooAddRemoteAudioCapability(OOH323CallData *call, 
-			       H245AudioCapability *audioCap,
+                               H245AudioCapability *audioCap,
                                int dir)
 {
    int rxframes=0, txframes=0;
@@ -2025,9 +2070,10 @@
       {
          call->jointDtmfMode |= OO_CAP_DTMF_H245_alphanumeric;
          return OO_OK;
-      }else if((cap->u.receiveUserInputCapability->t ==
-                                         T_H245UserInputCapability_dtmf) &&
-	       (call->dtmfmode & OO_CAP_DTMF_H245_signal))
+      }
+      else if((cap->u.receiveUserInputCapability->t ==
+               T_H245UserInputCapability_dtmf) &&
+               (call->dtmfmode & OO_CAP_DTMF_H245_signal))
       {
          call->jointDtmfMode |= OO_CAP_DTMF_H245_signal;
          return OO_OK;
@@ -2055,7 +2101,7 @@
    }
 
    OOTRACEDBGC3("Not adding to joint capabilities. (%s, %s)\n", call->callType,
-		call->callToken);
+                call->callToken);
    return OO_OK;
 }
 

Modified: branches/1.2/asterisk-ooh323c/ooh323c/src/ooCapability.h
URL: http://svn.digium.com/view/asterisk-addons/branches/1.2/asterisk-ooh323c/ooh323c/src/ooCapability.h?rev=201&r1=200&r2=201&view=diff
==============================================================================
--- branches/1.2/asterisk-ooh323c/ooh323c/src/ooCapability.h (original)
+++ branches/1.2/asterisk-ooh323c/ooh323c/src/ooCapability.h Thu Mar  2 16:21:17 2006
@@ -37,12 +37,27 @@
    OO_G711ALAW56K         = 3,
    OO_G711ULAW64K         = 4,
    OO_G711ULAW56K         = 5,
+   OO_G722_64k            = 6,
+   OO_G722_56k            = 7,
+   OO_G722_48k            = 8,
    OO_G7231               = 9,
+   OO_G728                = 10,
    OO_G729                = 11,
    OO_G729A               = 12,
+   OO_IS11172_AUDIO       = 13,
+   OO_IS13818_AUDIO       = 14,
+   OO_G729B               = 15,
+   OO_G729AB              = 16,
+   OO_G7231C              = 17,
    OO_GSMFULLRATE         = 18,
    OO_GSMHALFRATE         = 19,
    OO_GSMENHANCEDFULLRATE = 20,
+   OO_GENERICAUDIO        = 21,
+   OO_G729EXT             = 22,
+   OO_AUDIO_VBD           = 23,
+   OO_AUDIOTELEPHONYEVENT = 24,
+   OO_AUDIO_TONE          = 25,
+   OO_EXTELEM1            = 26,
    OO_CAP_VIDEO_BASE      = 27,
    OO_NONSTDVIDEO         = 28,
    OO_H261VIDEO           = 29,
@@ -487,8 +502,8 @@
  */
 
 ASN1BOOL ooCapabilityCheckCompatibility(struct OOH323CallData *call, 
-				ooH323EpCapability *epCap, 
-				H245DataType *dataType, int dir);
+                                        ooH323EpCapability *epCap, 
+                                        H245DataType *dataType, int dir);
 
 
 /**

Modified: branches/1.2/asterisk-ooh323c/ooh323c/src/ooCmdChannel.c
URL: http://svn.digium.com/view/asterisk-addons/branches/1.2/asterisk-ooh323c/ooh323c/src/ooCmdChannel.c?rev=201&r1=200&r2=201&view=diff
==============================================================================
--- branches/1.2/asterisk-ooh323c/ooh323c/src/ooCmdChannel.c (original)
+++ branches/1.2/asterisk-ooh323c/ooh323c/src/ooCmdChannel.c Thu Mar  2 16:21:17 2006
@@ -68,9 +68,6 @@
    }
    else
    {
-
-     //TODO:Need to add support for multihomed to work with channel driver
-
       /*
          bind socket to a port before connecting. Thus avoiding
          implicit bind done by a connect call. Avoided on windows as 
@@ -156,14 +153,15 @@
       {
          OOTRACEINFO1("Ignoring stack command as Gk Client is not registered"
                       " yet\n");
-      }else {
+      }
+      else {
          switch(cmd.type) {
             case OO_CMD_MAKECALL: 
                OOTRACEINFO2("Processing MakeCall command %s\n", 
                                     (char*)cmd.param2);
  
                ooH323MakeCall ((char*)cmd.param1, (char*)cmd.param2, 
-                                                 (ooCallOptions*)cmd.param3);
+                               (ooCallOptions*)cmd.param3);
                break;
 
             case OO_CMD_MANUALRINGBACK:

Modified: branches/1.2/asterisk-ooh323c/ooh323c/src/ooGkClient.c
URL: http://svn.digium.com/view/asterisk-addons/branches/1.2/asterisk-ooh323c/ooh323c/src/ooGkClient.c?rev=201&r1=200&r2=201&view=diff
==============================================================================
--- branches/1.2/asterisk-ooh323c/ooh323c/src/ooGkClient.c (original)
+++ branches/1.2/asterisk-ooh323c/ooh323c/src/ooGkClient.c Thu Mar  2 16:21:17 2006
@@ -87,7 +87,8 @@
       {
          OOTRACEINFO2("Using local RAS Ip address %s\n", cur->addr);
          strcpy(pGkClient->localRASIP, cur->addr);
-      }else{
+      }
+      else{
          OOTRACEERR1("Error:Failed to assign a local RAS IP address\n");
          return OO_FAILED;
       }
@@ -153,10 +154,11 @@
       OOTRACEINFO1("\tGatekeeper mode - UseSpecificGatekeeper\n");
       OOTRACEINFO3("\tGatekeeper To Use - %s:%d\n", pGkClient->gkRasIP, 
                                                     pGkClient->gkRasPort);
-   }else if(pGkClient->gkMode == RasDiscoverGatekeeper)
-   {
+   }
+   else if(pGkClient->gkMode == RasDiscoverGatekeeper) {
       OOTRACEINFO1("\tGatekeeper mode - UseSpecificGatekeeper\n");
-   }else{
+   }
+   else {
       OOTRACEERR1("Invalid GatekeeperMode\n");
    }
 }
@@ -213,7 +215,7 @@
       OOTRACEINFO1("Gatekeeper Mode - RasUseSpecificGatekeeper\n");
       if(szGkAddr)
       {
-	 if(strlen(szGkAddr)>MAX_IP_LEN)
+         if(strlen(szGkAddr)>MAX_IP_LEN)
          { 
             OOTRACEERR2("Error:Invalid IP address specified - %s\n", szGkAddr);
             return OO_FAILED;
@@ -227,11 +229,11 @@
 
       OOTRACEINFO3("Gatekeeper IP:port set to - %s:%d\n", 
                     szGkAddr,  pGkClient->gkRasPort);
-   }else if(eGkMode == RasDiscoverGatekeeper)
-   {
+   }
+   else if(eGkMode == RasDiscoverGatekeeper) {
       OOTRACEINFO1("Gatekeeper Mode - RasDiscoverGatekeeper\n");
-   }else if(eGkMode == RasNoGatekeeper)
-   {
+   }
+   else if(eGkMode == RasNoGatekeeper) {
       OOTRACEINFO1("Gatekeeper Mode - RasNoGatekeeper\n");
    }
    return OO_OK;
@@ -412,7 +414,7 @@
       if(iRet != OO_OK)
       {
          OOTRACEERR1("Error: Failed to handle received RAS message\n");
-	 //pGkClient->state = GkClientFailed;
+         //pGkClient->state = GkClientFailed;
       }
       memReset(pctxt);
    }
@@ -567,16 +569,17 @@
          OOTRACEERR1("Error sending RAS message\n");
          return OO_FAILED;
       }
-   }else if(pGkClient->gkMode == RasDiscoverGatekeeper && 
-            !pGkClient->discoveryComplete)
-   { 
+   }
+   else if(pGkClient->gkMode == RasDiscoverGatekeeper && 
+           !pGkClient->discoveryComplete) { 
       if(ASN_OK != ooSocketSendTo(pGkClient->rasSocket, msgPtr, iLen, 
                                        MULTICAST_GKADDRESS, MULTICAST_GKPORT))
       {
          OOTRACEERR1("Error sending multicast RAS message\n" );
          return OO_FAILED;
       }
-   }else {/* should never go here */ 
+   }
+   else {/* should never go here */ 
       OOTRACEERR1("Error: GkClient in invalid state.\n");
       return OO_FAILED;
    }
@@ -1072,7 +1075,8 @@
    {
       ooGkClientUpdateRegisteredAliases(pGkClient, 
                                    &pRegistrationConfirm->terminalAlias, TRUE);
-   }else{/* Everything registered*/
+   }
+   else{/* Everything registered*/
      ooGkClientUpdateRegisteredAliases(pGkClient, NULL, TRUE);
    }
 
@@ -1109,7 +1113,8 @@
          return OO_FAILED;
       }    
       
-   }else{
+   }
+   else{
       pGkClient->regTimeout = 0;
       OOTRACEINFO1("Gatekeeper does not support KeepAlive.\n");
    }
@@ -1379,7 +1384,8 @@
       OOTRACEINFO1("Gatekeeper requested a list of aliases be unregistered\n");
       ooGkClientUpdateRegisteredAliases(pGkClient, 

[... 4275 lines stripped ...]


More information about the svn-commits mailing list