IrDA disconnection is a fairly complex procedure but is much simplified using the Symbian OS IrDA Sockets API.
To disconnect a MUX connection, a call to the asynchronous function RSocket::Shutdown()
is made. The detailed behaviour resulting from a call to RSocket::Shutdown()
depends on the currently loaded protocol set. To the application programmer, there is no difference.
An IrTinyTP shutdown sends any outstanding data before initiating a MUX level disconnect.
An IrMUX shutdown throws away all outstanding data and then initiates the MUX level disconnect.
If more than one socket is open, a MUX level disconnection is all that occurs upon shutting down a socket. If, however, only one MUX connection is up, both MUX and IrLAP level disconnections are necessary and completion of the shutdown request occurs when both disconnect operations have completed.
On successful completion of a shutdown, a call to RSocket::Close()
can be made. The close operation is queued as an synchronous request so no wait for completion is necessary. If a call to
RSocket::Close()
is made without a prior call to RSocket::Shutdown()
, an IrTinyTP socket initiates an immediate disconnection discarding any buffered data it may be holding.