![]() |
![]() |
|
|
![]() |
![]() |
X25/9000: X.25/9000 Programmer's Guide > Chapter 6 Extended Features![]() Using Fast Select |
|
The use of fast select in X.25 is described in X.25: The PSN Connection. This section describes how to access this Facility through X.25. The fast select Facility allows processes to specify up to 128 bytes of call user data in the CALL REQUEST, CALL ACCEPTED, and CLEAR REQUEST packets. Usually, only 16 bytes are permitted in the CALL REQUEST packet and no user data in the CALL ACCEPTED and CLEAR REQUEST packets. This Facility is called "fast" because it allows programmers to specify user data in the same packet which is requesting or acknowledging a connection request. Usually, the CALL REQUEST packet contains all of the information the server side needs to service the request, and it terminates the connection and places all the information that the client needs regarding the results of its request in the CLEAR REQUEST packet. The circuit is never fully set up, but is then quickly torn down, hence the term "fast select". The ioctl() calls used for fast select are listed below: A summary of the steps needed to enable fast select on the calling and receiving side of a connection appears in the next two subsections. To implement fast select on the calling side, issue the ioctl(X25_WR_FACILITIES) call with the fast select Facilities code defined in CCITT X.25 recommendations. Specify the call user data for the packet with the ioctl(X25_WR_USER_DATA). These calls must be executed before issuing the connect() call. If the calling side is using protocol IDs for address matching, the protocol ID must be specified in the call user data field before any other call user data is added with the ioctl(X25_WR_USER_DATA) call. These data may be specified in separate ioctl() calls, or combined into one, but the protocol ID must come first. Remember that the protocol ID length is not defined by the CCITT. Programmers of the two processes must agree on the number of bits of the call user data field to use for the protocol ID before connection establishment begins. When the Facilities and call user data fields have been specified for the fast select call, the calling side issues a connection request with connect() and waits for the response from the remote server. The called side may respond in three ways:
The maximum length for the user data field in the CLEAR REQUEST packet is 128 bytes. The server may execute the ioctl(X25_WR_USER_DATA) more than once to write the entire user data field. If more than 128 bytes must be transmitted, the called side (server) of the connection should respond with a CALL ACCEPTED packet and transmit the entire response with normal DATA packets, or the called side must simply clear the connection completely by calling close(). Details regarding fast select are defined in the CCITT X.25 Recommendations, and X.25 configuration information is presented in your X.25/9000 User's Guide. A server can respond to a fast select call in any of three ways:
Which of these alternatives are available depends on the design of the client and server processes. This section is written with the assumption that interfaces for both the client and the server are configured to permit fast select, and the network provider allows fast select. The actions to be taken are shown in the three scenarios below. The initial steps for sending and receiving fast select is the same for all scenarios. These initial steps are shown in Table 6-1 “Steps for Fast Select”. Depending on the design of the application, the server may take any of three actions that are described later. The initial steps performed by the client and server when configured to permit fast select are described below and shown in Table 6-1 “Steps for Fast Select” on the following page.
Table 6-1 Steps for Fast Select
After the above steps have been done, the server has the information it needs to process the fast select. Three actions are possible. They are discussed individually in the next three subsections. If the server detects that it cannot handle the fast select call for any reason, it can clear the circuit immediately. Steps for this are described below and in Table 6-2 “Clearing a Fast Select Call Immediately”. Steps shown in Table 6-1 “Steps for Fast Select” are assumed to have already occurred.
Table 6-2 Clearing a Fast Select Call Immediately
The server can respond to a fast select call by sending a CLEAR REQUEST packet that contains a user data field. Steps for this are described below and shown in Table 6-3 “Sending Clear User Data for a Fast Select”. Steps shown in Table 6-1 “Steps for Fast Select” are assumed to have already occurred.
Table 6-3 Sending Clear User Data for a Fast Select
The server can establish an SVC in response to a fast select call. Steps for this are described below and in Table 6-4 “Fast Select Connection Establishment”. Steps shown in Table 6-1 “Steps for Fast Select” are assumed to have already occurred. The fast select Facility must be set for no restrictions on response for this option to be used.
Table 6-4 Fast Select Connection Establishment
|
![]() |
||
![]() |
![]() |
![]() |
|||||||||
|