Communication Mode

This chapter describes the communication modes supported by Tmax.

1. Overview

Tmax supports three client-to-server communication modes: synchronous, asynchronous, and interactive.

  • Synchronous/Asynchronous communication

    • Synchronous communication is most widely used. During synchronous communication, the client sends one request and awaits a reply one at a time, and the server similarly processes one request one at a time before moving onto another.

    • Services are requested by tpcall() and tpacall(). The transmit/receive buffer must be allocated by tpalloc() before data is transmitted. The service routine on the server side is completed by tpreturn() or tpforward().

    • In synchronous mode, a client sends a request to the server by calling tpcall() and waits in the blocking status for the response from the server.

      In asynchronous mode, a client issues a request to the server by calling tpcall(). The client conducts other tasks without waiting for the response from the server. When the client is ready to receive the response from the server, the client calls tpgetrply() and receives the response from the server.

  • Interactive communication

    • Unlike synchronous or asynchronous mode, server programs must be developed only with interactive service functions. Interactive mode is rarely used because of its long connection maintenance time.

    • Service requests are initialized by tpconnect(). Data is sent by using tpsend() and received by using tprecv(). The transmit/receive buffer must be allocated by tpalloc() before data is sent.

    • In interactive mode, you cannot use tpforward().

2. Synchronous Communication

In synchronous mode, a client requests a service and waits for a response in the blocking status.

chap5 1
Synchronous Communication

The following is how the client and the server communicate in synchronous mode.

chap4 1
Synchronous Mode

For more information about functions related to synchronous communication, refer to Synchronous Communication or Tmax Reference Guide.

3. Asynchronous Communication

In asynchronous mode, the client can request a service and proceed with another task without awaiting a reply. This is because tpacall() immediately returns after it is called. However, tpgetrply(), which is called to receive a response, waits in the blocking status until a reply arrives or timeout occurs.

chap5 2
Asynchronous Communication

The following is how the client and the server communicate in asynchronous mode.

chap4 2
Asynchronous Mode

For more information about functions related to asynchronous communication, refer to Asynchronous Communication or Tmax Reference Guide.

4. Interactive Communication

During interactive communication, a half-duplex connection is established between the client and server, where messages are sent in only one direction. When a client initially connects to a server, communication control is given to either the client or the server. The side with control can send a message while the other side can receive a message. Control can be passed by using a flag from the side with control. The other side learns of control change through an event value.

The following is the process of passing communication control and disconnecting a connection.

chap7 1
Interactive Communication

In interactive mode, tpconnect() is used to make a connection, tpsend() is used to send data, and tprecv() is used to receive data. To send data, the client or the server must have connection control, which operates by setting a flag value in tpconnect() and tpsend.

The following is how the client and the server communicate in interactive mode.

chap4 3
Interactive Mode
  • Interactive communication is initiated by calling tpconnect(), which selectively sends data to services and determines which program holds control. If tpconnect() is executed successfully, it returns the connection descriptor (cd), which distinguishes message transmissions and receptions from those for other connections.

  • Interactive communication is used when additional information is required depending on context. However, compared to other communication modes, an interactive connection stays connected for a long period of time: from the point of connection (tpconnect()) to the point of disconnection (tpdiscon() or tpreturn()). Synchronous/asynchronous communication is recommended because an interactive connection has greater network load.

  • tpreturn() is generally called in the server to terminate an interactive communication. In this case, the receiving side receives both the data and the TPEV_SVCSUCC event. If the control side calls tpdiscon(), interactive communication is forcibly terminated. When the function is called, data being transmitted may be lost and transactions being processed are rolled back.

  • Only the program that has communication control can give the control to the counterpart using the TPRECVONLY flag in tpsend(). The counterpart receives data and the TPEV_SENDONLY event and takes control.

  • To pass the control to the counterpart, set the flags parameter to TPRECVONLY and call tpconnect() or tpsend(). The TPEV_SENDONLY event occurs to the counterpart to let the counterpart know control was received. After control is passed, data can be sent by calling tpsend().

  • Like synchronous or asynchronous communication, interactive mode uses buffers, which must be allocated in advance by tpalloc(). All buffers used in Tmax communication must be allocated by tpalloc().

For more information about functions related to interactive communication, refer to Interactive Communication or Tmax Reference Guide.

The following lists the five events of interactive communication.

Event Receiving Function Description

TPEV_SENDONLY

(0x0020)

tprecv()

Indicates the location of the connection control.

TPEV_DISCONIMM

(0x0001)

tesend()

tprecv()

tpreturn()

Abnormal disconnection, which occurs when tpdiscon() is called or tpreturn() is called while sub-services are still open.

TPEV_SVCERR

(0x0002)

tpsend()

tprecv()

Service function error, which occurs when the receiver has called tpreturn() without having control or when the argument of tpreturn() is valid but an error is generated.

TPEV_SVCFAIL

(0x0004)

tpsend()

tprecv()

Service function failed, which occurs when tpreturn() is called by a party that does not have control of the connection or tpreturn() is called with its flags set to TPFAIL or TPEXIT.

TPEV_SVCSUCC

(0x0008)

tprecv()

Service function successfully completed. tpreturn() is called with the flag set to TPSUCCES.

For more information about functions, refer to Tmax Reference Guide.