The fast-connect procedure was introduced in H.323v2 to enable unidirectional or bi- directional media channels to be established immediately after the Q.931 SETUP message and eliminate any post-connect delay in the audio path.
The usefulness of the fast-connect procedure is questionable, as the early H.245 pro- cedure (described in Section 2.3.2) also solves these issues. In the early days of H.323 there was still some confusion on which was the best method to solve the delay issue, and all possible solutions were welcome. Fast connect has one little advantage over early H.245: it removes any post-connect audio delays even in the case of an immediate call connection. It also has major drawbacks compared with the early H.245 procedure: for instance, it does not allow the out-of-band transmission of DTMF information7and it does not provide a third-party call control feature before H.323v5 (this version adds this possi- bility in the H.460.6 extension). It is tempting to use both early H.245 andfastStart (see next paragraph) at the same time, which in fact many vendors are currently doing.
Since H.323v4, this is officially possible, but the actual H.245 communication should not transmit anything but the endpoint capabilities and master/slave information before the completion of the initial fast-connect negotiation.
An endpoint which decides to use the fast-connect procedure will include a new param- eter, calledfastStart, in the SETUP user-to-user information element. This parameter includes a description of all the media channels that the endpoint is prepared to receive
7RFC 2833 may be used, but does not allow feature servers to act on DTMF commands without also relaying the media stream.
and all the media channels that the endpoint offers to send. This description includes the codecs used, the receiving ports, etc.
If the called endpoint cannot or doesn’t want to use the fast-connect procedure, it will not return thefastStartelement in subsequent Q.931 messages. In this case the normal procedure involving H.245 will take place.
If the called endpoint supports the fast-connect procedure, then it will return, in the CALL PROCEEDING, PROGRESS, ALERTING or CONNECT Q.931 message, a fastStartelement that selects from among the media offered by the caller.
ThefastStartelement is always inserted in the H323-UU-PDU of the user-to-user element (its use with the SETUP message is shown in bold):
• Protocol discriminator field (08H).
• Call Reference Value (CRV).
• A Message Type (SETUP).
• . . .
• Called party number and subaddress.
• Calling party number and subaddress.
• The H.323 user-to-user element which contains the SETUP user-to-user information element in which we find:
• The protocol identifier.
• . . .
• The sender’s aliases.
• The destination address.
• The CID and CallID.
• fastStart: used only in the fast-connect procedure, fastStart is a se- quence of OpenLogicalChannel structures. Each OpenLogicalChannel structure (Figure 2.21) describes One media channel that the caller wants to send (for- wardLogicalChannelParameters within the OpenLogicalChannel structure) or receive (reverseLogicalChannelParameters). All proposedOpenLogicalChannels can be selected simultaneously, unless they share a common sessionID value in the H2250-LogicalChannelParameters of the OpenLogicalChannel structure, in which case they are considered alternative options for the same channel.
• ThemediaWaitForConnectboolean.
The calling terminal can select one or more acceptableOpenLogicalChannelstructures within the offered fastStart parameter and return them in a fastStart parame- ter within an H.225 CALL PROCEEDING, PROGRESS, ALERTING, or CONNECT message. The selected logical channels are considered open after this.
Note that the network can send media toany of the receiving channels mentioned in the SETUP message of the caller, immediately after the calling terminal has sent this message, unless MediaWaitForConnect is true. Therefore, even if the calling terminal
OpenLogicalChannel ::=SEQUENCE {
forwardLogicalChannelNumber LogicalChannelNumber,
...,
separateStack NetworkAccessParameters OPTIONAL,
encryptionSync EncryptionSync OPTIONAL -- used only by Master }
forwardLogicalChannelParameters SEQUENCE {
portNumber INTEGER (0..65535) OPTIONAL, dataType DataType,
multiplexParameters CHOICE {
h2250LogicalChannelParameters H2250LogicalChannelParameters,
none NULL
}, ...,
forwardLogicalChannelDependency LogicalChannelNumber OPTIONAL, },
reverseLogicalChannelParameters SEQUENCE {
dataType DataType, multiplexParameters CHOICE {
h2250LogicalChannelParameters H2250LogicalChannelParameters } OPTIONAL, -- Not present for H.222
reverseLogicalChannelDependency LogicalChannelNumber OPTIONAL, } OPTIONAL, --Not present foruni-directional channel request
replacementFor LogicalChannelNumber OPTIONAL
replacementFor LogicalChannelNumber OPTIONAL ...,
Figure 2.21 OpenLogicalChannel ASN.1 structure.
plans to use only one of these channels for regular conversation, as indicated in the fastStartresponse, itmust be prepared to receive media on any one of these channels (before the response). Although most H.323 vendors have implemented thefastStart procedure, many of them actually do not support this requirement and are not able to receive audio before the remote endpoint has selected a media channel proposal in its own fastStart element. This is because most implementations do not have enough memory to load multiple voice coders at the same time, and the vendor selects the right coder to load when it receives the remotefastStart. In the best implementations that fully support fastStart, the first RTP packet that is received can be used to load the codec, without waiting for the remotefastStartelement. An example of a case where supporting the full fastStart requirement is important is network-based redirection announcements: multiple announcement servers may have to send audio to the calling endpoint, before it connects to the party redirected to. In this case the fastStart element will be sent only by the last endpoint, but the announcement servers still need to stream audio toward the calling party before this happens.8
8Some vendors can receive multiple fastStart elements in sequence and always take into account the last one received. This greater flexibility makes it possible to activate media recep- tion only after having received afastStartresponse, without restricting the feasible services.
Unfortunately, this way of interpreting the fastStart response, which creates a form of third-party media control, is not yet taken into account in the standard.
TCP SYN TCP SYN ACK
SETUP
CONNECT RTP callee to caller
RTP caller to callee 2 R.T.
2.5 R.T.
Figure 2.22 Audio path delays with the fast-connect procedure.
Usually, in a normal ISDN call the called endpoint does not send media before the CON- NECT message has been sent. It is possible to force this behaviour with thefastStart procedure by setting themediaWaitForConnectelement of the Q.931 SETUP to true.
As shown in Figure 2.22, the fast-connect procedure dramatically improves the num- ber of round trips required to set up the conversation, and eliminates all post-connect audio delays.
Since the fast-connect procedure solves a major flaw of H.323v1 regarding interworking with the traditional TDM networks, it has been made a core feature in the H.323 profile of the ETSI TIPHON project.
Fast-connect procedure usage becomes a bit subtle in certain circumstances (e.g., when H.323 is used to provide class 5 services). The interactions between the call forward on no answer service and the use offastStartare extremely complex, and not well studied by the standard (see Chapter 6). In addition the mediaWaitForConnectBoolean is a bit too simple to fully account for the variety of call flows found in the PSTN. The sending of audio information before connect is controlled by the in-band audio indicator in Q.931 messages, including the PROGRESS message. Some call flows can become extremely complex, as in the following example where ring-back tones alternate with redirection prompts.
Such call flows today are possible (the previous scenario is currently used in Milan, Italy), but need prior vendor agreement on the exact handling of in-band audio indi- cators. Also, some call flows really would require the sending of multiplefastStart elements to update the RTP logical channel information before CONNECT. H.460.6 has refined the fastStart procedure and allows the refreshing of fastStart elements before CONNECT.
Using just the fast-connect procedure, DTMF transmission is not possible as H.245 UserInputIndication is not available (no H.245 channel is opened). Because of this lim- itation, early H.245 (establishing the H.245 channel before CONNECT) should be used in conjunction withfastStartin most cases, as it is officially allowed since H.323v4.
Many types of calls will require DTMF information before CONNECT. For instance, this is what would happen typically when calling an IN-based card telephony service. An IVR
OGW Gatekeeper
Announcement server
TGW1 TGW2
Setup (FS_O ) Setup (FS_O)
Alerting (PI = 8) Alerting (PI = 8, FS_S) Release complete
Setup (FS_O) Alerting (no PI) Progress (no PI, no FS forwarded)
Setup (FS_O)
Alerting (PI = 8, FS_S) Progress (PI = 8)
Release complete
Release complete Setup (FS_O)
Alerting Progress (no PI)
Connect Connect (FS_2)
Call is in alert state, so stop playing RTP and play local alert tone Alert with in-band tones is received,
Call proceeding (FS_1)
Call proceeding ( FS_2)
Call proceeding Call proceeding
Call proceeding Play
local ring-back
Timeout
Full Duplex Conversation Redirect announcement Pre connect announcement so start receiving RTP and do not
play local alert tone
Figure 2.23 Complex call flow with pre-connect audio. Note: there is no DTMF capability before connect.
server requests the card code before sending a CONNECT Q.931 message because the call is not yet charged. The CONNECT message is sent only after the code has been checked and the destination party has answered the call (as shown in Figure 2.23).
Caveat: The addition of fast-connect mode to H.323 has made it possible to manufacture a simpler, yet H.323-compliant terminal. In fact, this was one of the goals of the initial fastStartproposal, at a time when SIP began to claim simplicity compared with H.323.
By supporting only H.323 in fast-connect mode, developers can avoid implementing H.245 in simple appliances like IP phones in this way. However, most of the potential of H.323 comes from the conferencing and third-party call control features which are enabled only by H.245. Simple H.323 terminals without H.245 will not be able to participate in such conferences. Moreover, DTMF is normally carried using H.245: simple terminals will have to use in-band DTMF coding which does not work as soon as complex services like prepaid servers or contact centres are implemented. Overall, such ‘simplified’ terminals would not meet even the basic requirements for telephony and would make the design of services on networks with such endpoints extremely challenging. Interestingly, facing the same issues, SIP has become significantly more complex over time, notably adding third-party call control and out-of-band DTMF capabilities to the basic call, and is now virtually identical to the H.323 protocol, withfastStartand H.245 tunneling enabled.