SDLI

Section: Linux STREAMS Programmer's Manual (7)
Updated: $Date: 2008-11-01 06:55:04 $
Index Return to Main Contents
 

NAME

sdli - Signalling System No. 7 Signalling Data Link (SDL) Interface  

SYNOPSIS

#include <ss7/sdli.h>
#include <ss7/sdli_ioctl.h>

fd = open("/dev/sdl", flags);
ret = ioctl(fd, cmd, ... /* arg */ );
 

DESCRIPTION

This man page describes the STREAMS interface which is used to configure and exchange data with an SS7 Signalling Data Link Interface (SDLI) for all SS7 devices conforming to the OpenSS7 Signalling Data Link Interface (SDLI) specification.

SDLI drivers are normally linked using streamio(7) I_PUSH ioctl under a Signalling Data Terminal (SDT) STREAMS module conforming to the Signalling Data Terminal Interface specification sdti(7) such as sdt(8), by the SS7 Configuration Daemon ss7d(8). Yet, this interface is available for the purpose of ferry-clip conformance and diagnostic testing of the SS7 Signalling Data Link.

SDLI Style 1 or Style 2 drivers may be configured to autopush the sdt(8) module and appear as sdti(7) drivers. Not all SS7 drivers need be written to the SDL interface: drivers may be written to the sdti(7), sli(7), slsi(7) and even mtpi(7) interfaces.

The SDLI interface consists of three subcomponents:

LOCAL MANAGEMENT INTERFACE
SDLI provides a local management interface which utilizes M_PROTO and M_PCPROTO messages which can be exchanged with the interface using putmsg(2) and getmsg(2) system calls on the stream head once the interface is opened. The local management interface controls local management (STREAMS configuration functions) which are normally used by the SS7 Configuration Daemon ss7d(8) on the driver interface before pushing an sdt(8) module onto the stream head. The local management interface is described in detail in section "LOCAL MANAGEMENT INTERFACE".
PROTOCOL (SERVICE) INTERFACE
SDLI provides a protocol interface which utilizes M_DATA, M_PROTO and M_PCPROTO messages which can be exchanged with write(2), read(2), putmsg(2) or getmsg(2) system calls on the stream head, or which can be exchanged with the driver by upstream pushed or linked modules. The protocol interface exchanges SS7 protocol primitives between the Signalling Data Terminal (SDT) and the Signaling Data Link (SDL), but may also be used for ferry-clip conformance testing or diagnostics. The protocol interface is described in detail in section "PROTOCOL INTERFACE".
PROTOCOL MANAGEMENT INTERFACE
SDLI provides a protocol management interface which utilizes M_CTL message between modules or M_IOCTL I_STR messages from a stream head formatted per the SS7 Management Interface smi(7). The protocol management interface provides protocol configuration, state inquiry, statistics and event management (SNMP functions). This interface is normally used by the SS7 Configuration Daemon ss7d(8) on the stream after opening or during operation. The protocol management interface is described in smi(7) and detailed in section "PROTOCOL MANAGEMENT INTERFACE" below.
CONTROL INTERFACE
SDLI provides a control interface which utilizes ioctl(2) transparent calls or an I_STR ioctl from streamio(2) from a stream head to the driver, or M_CTL messages between modules. The control interface controls specific aspects of the SDL driver which are outside the scop of the SS7 protocol. These controls are normally used by the SS7 Configuration Daemon ss7d(8) on the driver interface or multiplexor control channel before or after the protocol stack has been assembled. The control interface is described in the section "CONTROL INTERFACE".

 

LOCAL MANAGEMENT INTERFACE

PPA Style

From the local management view, the SDLI can support two styles for Point of Physical Address (PPA) selection. These styles are as follows:

SDT_STYLE1
A Style 1 driver is a driver whose Signalling Data Link (SDL) is associated with the stream at open time. These drivers open in the SDL_DISABLED state and do not require a SDL_ATTACH_REQ local management primitive to association them with a specific transmission channel. Style 1 drivers do not require PPA addresses.
SDT_STYLE2
A Style 2 driver is a driver whose Signalling Data Link (SDL) must be attached to the stream after open. These drivers open in the SDL_UNATTACHED state an must be attached with a SDL_ATTACH_REQ local management primitive to associate them with an SDL before then can be enabled for use. Style 2 drivers required a PPA (Physical Point of Attachment) address to indicate the physical transmission channel to which the stream is to be attached. The PPA Address is an opaque address which is meaningful only to a specific driver implementation of the SDLI.

Local Management States

From the perspective of local management, the SDL provider can be in a number of management states. Some local management primitives are applicable only in specific states. The SDL provider can be moved through the states wih local management primitives.

The management states of the SDL provider are as follows:

SDL_UNATTACHED
The SDL provider is not attached to a SDL PPA. This state is only applicable to Style 2 drivers which must be explicitly attached to a specific transmission channel. Style 2 drivers open in this state.
SDL_UNUSABLE
The SDL provider is unusable. This state occurs when the streams module is no longer able to perform local management actions on the SDL provider. This may be due to the failure, removal or failure to communicate with, some component in the system.
SDL_DISABLED
The SDL provider is attached but has not yet been enabled for use. The provider must be enabled with a SDL_ENABLE_REQ local management primitive before data or protocol primitives may be exchanged with the SDL user.
SDL_ENABLE_PENDING
The SDL provider has accepted a SDL_ENABLE_REQ request on the interface, but the provider must wait until some event occurs before the provider can be considered enabled. The provider will respond with a SDL_ENABLE_CON confirmation once the enabling is successful, or a SDL_ERROR_ACK if unsuccessful.
SDL_ENABLED
The SDL provider is enabled and ready for use (to provide SDL protocol services).
SDL_DISABLE_PENDING
The SDL provider has accepted a SDL_DISABLE_REQ request on the interface, but the provider must wait until some event occurs before the provider can be considered disabled. The provider will response with a SDL_DISABLE_CON confirmation once the disabling is successful, or a SDL_ERROR_ACK if unsuccessful.

Local Management Primitives

Local management primitive can be exchanged with the device driver as M_PROTO or M_PCPROTO primitives using the putmsg(2) or getmsg(2) system calls on the stream head after opening the device. This interface is normally used only by the SS7 Configuration Daemon ss7d(2) during STREAMS configuration, or by the upstream protocol modules during streamio(7) I_PUSH and I_POP operations. It is possible, however, for a user-level program to use this interface directly on an open SDLI driver stream head for special purposes and testing.

Only M_PROTO local management primitives will be deferred during congestion or overload of the SDL provider. Local management primitives sent as M_PCPROTO will be discarded and return a SDL_ERROR_ACK in response should it not be possible to execute them immediately.

Local management primitives provided by the SDLI are as follows:

SDL_INFO_REQ, SDL_INFO_ACK, SDL_ERROR_ACK

Invoked by the SDL user to request and return information about the SDL provider which is of interest to local configuration management. These requests are normally performed by the SS7 Configuration Daemon ss7d(8) on the newly opened stream head for the SDLI driver before pushing it under the Signalling Data Terminal sdt(8) module.

SDL_INFO_REQ
SDL_INFO_REQ uses a sdt_info_req_t structure which contains the request primitive in member sdt_primitive.
SDL_INFO_ACK
SDL_INFO_ACK uses a sdt_info_ack_t structure as follows:

typedef struct {
    sdl_ulong   sdl_primitive;  /* SDL_INFO_ACK */
    sdl_ulong   sdl_version;
    sdl_ulong   sdl_state;
    sdl_ulong   sdl_max_sdu;
    sdl_ulong   sdl_min_sdu;
    sdl_ulong   sdl_ppa_style;
    sdl_uchar   sdl_ppa_addr[8];
} sdt_info_ack_t;
sdl_version
The version of the SDLI interface specification to which the device conforms with one byte per vesion number in host order. The current (and only) version of the SDLI is 1.0.0.0 or 0x01000000.
sdl_state
The current local management state of the SDL provider.
sdl_min_sdu
The minimum data unit size which may be transferred to and from the transmission channel. For some Signalling Data Links this may be zero.
sdl_max_sdu
The maximum data unit size which may be transferred to and from the transmission channel. For some Signalling Data Links this size may be unlimited, in which case the value returned here is 0xffffffff.
sdl_ppa_style
The style of the driver which may be one of the following:
SDL_STYLE1
A Style 1 device which is implicitly associated with a transmission channel at the time that the device is opened. These devices open in the SDL_DISABLED state.
SDL_STYLE2
A Style 2 device which must be explicitly attached to a transmission channel identified by a sdl_ppa_addr in a SDL_ATTACH_REQ local management primitive after opening. These devices open in the SDL_UNATTACHED state.
sdl_ppa_addr
The PPA address that a Style 2 device is attached to. If the device is a Style 1 device or an unattached Style 2 device, this member will return all zeros.
SDL_ERROR_ACK
SDL_ERROR_ACK containing the error number in sdl_errno and an error explanation in sdl_reason will be returned by the SDL provider in the rare event that an error occurs while attempting to retrieve the information requested by a SDL_INFO_REQ.

SDL_ATTACH_REQ, SDL_OK_ACK, SDL_ERROR_ACK

Invoked by the SDL user to attach a Style 2 SDL provider to a PPA using a PPA Address. This primitive is normally used by the SS7 Configuration Daemon ss7d(8) when assembling the SS7 protocol stack.

SDL_ATTACH_REQ
Requests that the SDL provider attach to the PPA address specified in the request. The SDL_ATTACH_REQ primitive is only valid from the SDL_UNATTACHED state for a Style 2 interface. SDL_ATTACH_REQ uses the sdl_attach_req_t structure as follows:

typedef struct {
    sdl_ulong   sdl_primitive;  /* SDL_ATTACH_REQ */
    sdl_uchar   sdl_ppa_addr[8];
} sdl_attach_req_t;
sdl_ppa_addr
Specifies the PPA (Physical Point of Appearance) of the transmission channel to which the SDT provider should attach. This is an opaque address to the interface and is only meaningful to a specific driver implementation.
SDL_OK_ACK
Returned if the attach request is successful.
SDL_ERROR_ACK
Returned with the error number and explanation set if the attach request fails.

SDL_DETACH_REQ, SDL_OK_ACK, SDL_ERROR_ACK

Invoked by the SDL user to detach a Style 2 SDL provider from its PPA. This primitive is normally used by the SS7 Configuration Daemon ss7d(8) when disassembling or reconfiguring the SS7 protocol stack.

SDL_DETACH_REQ
Requests that the SDL provider detach itself from the current attached PPA. SDL_DETACH_REQ is only valid for Style 2 SDL providers in the SDL_DISABLED state. The DL_DETACH_REQ uses the sdt_detach_req_t structure which contains only the sdl_primitive.
SDL_OK_ACK
Returned if the detach request is successful.
SDL_ERROR_ACK
Returned with the error number and explanation set if the detach request fails.

SDL_ENABLE_REQ, SDL_ENABLE_CON, SDL_ERROR_ACK

SDL_DISABLE_REQ, SDL_DISABLE_CON, SDL_ERROR_ACK  

PROTOCOL MANAGEMENT INTERFACE

Protocol management primitives are provided to allow for protocol-specific configuration, state examination, statistical and event reporting. These primitives use the configuration structure sdl_conf_t, the state machine structure sdl_statem_t, statistics structure sdl_stats_t and event categories described above.

Protocol management primitives are exchanged using M_PROTO and M_PCPROTO messages in the same manner as protocol primtives, using putmsg(2) and Bgetmsg(2) system calls at the stream head or using the pass through mechanism provided by the control channel of an open multiplexor (see sls(8) and mtp(8)). These primitives are normally only used by ss7d(8) during configuration and operation, but may be used for testing and special purposes by user-level programs from the stream head.  

Protocol Configuration

Protocol management primitives are invoked by SDL management to configure or request configuration information from the SDL provider. Any M_DATA block attached to the primitives contains a sdl_conf_t structure (see below) which represents the configuration parameters. Configuration requests should normally be sent as M_PCPROTO messages.

SDL_CONFIG_SETUP
Test if the configuration parameters provided in the attached M_DATA block are settable and correct. Any values set to 0xffffffff in the configuration parameters should not be tested for change by the SDL provider. When successful, this request also write locks the configuration until a successful SDL_CONFIG_COMMIT is executed.
SLD_CONFIG_COMMIT
Commits the changes of a previous successful SDL_CONFIG_TEST operation. No configuration data is associated with this request and any attached M_DATA is ignored. When successful, this request also releases the write locks on the configuration.
SDL_CONFIG_SET
Set the configuration parameters to the values provided in the attached M_DATA block. This request will fail if the configuration is write locked.
SDL_CONFIG_GET
Get the configuration parameters. Any attached M_DATA is ignored. If the configuration is write locked, this request will only return the values which have been setup for a commit and not necessarily the current values.
Responses
Upon success, the SDL provider will return a SDL_OK_ACK to confirm a successful configuration request. The provider attaches a M_DATA block which contains a sdt_conf_t structure with the results of the configuration request.

Upon failure, the SDL provider will return a SDL_ERROR_ACK to reject the configuration request due to an error. The provider attaches a M_DATA block which contains a sdt_conf_t structure with 0xffffffff in any values which are in error. Error numbers which are specific to a configuration request rejection are as follows:

SDL_CONFLOCKED
The request attempted to perform an illegal operation on a locked configuration.
SDL_NOCONFDATA
The request was missing configuration data (i.e. missing M_DATA block or M_DATA block too short.
SDL_BADCONFDATA
Some configuration data was invalid. The attached M_DATA block contains 0xffffffff in the data elements which are considered invalid.
Datastructures
Configuration of the SDL provider uses the sdl_conf_t structure as follows:

typedef struct sdl_conf {
    sdl_ulong   pvar;   /* protocol variant */
    sdl_ulong   popt;   /* protocol options */
    sdl_ulong   N;      /* octet count      */
} sdl_conf_t;
pvar
(Protocol Variant) Default: SS7_PVAR_ITUT_96

Protocol variant which will be used for the SDT provider. When the protocol variant is set, all configuration parameters, options and state machine procedures must conform to the Signalling Data Link sections of the applicable standards. Modifications to this configuration can be made by changing other parameters in the configuration. When the value of pvar is changed, protocol variant specific default values for the rest of the configuration members, unless specified, will be used. pvar can be any of the protocol variant values specified in ss7(7).

popt
(Protocol Options) Default: 0

Options to modify the main specification as determined by pvar. popt is a bit-wise OR of the folloing option bitmasks:

SDL_POPT_HSL
When this bit is set, the SDL provider will use the High-Speed Link (HSL) version of the DAEDR as specified in Q.703 Annex A which does not perform octet counting mode but only reports single SDL_DAEDR_SU_IN_ERROR for loss of synchronization.

When this bit is clear, it indicates that normal Q.703 DAEDR behaviour should be used and SDL_DAEDR_SU_IN_ERROR reported once for every N octets during loss of syncrhonization.

N
(Octets Per SU) Default: 16

The number of octets representing an SU in octet counting mode per Q.703. This value is ignored if popt includes SDL_POPT_HSL.

 

Protocol State

Protocol management primitives may be invoked by SDL management to request and return state information about the SDL provider. This may be useful for resynchronization between protocol modules as well as for testing and diagnostic purposes. Any M_DATA block attached to the primitive or acknowledgement contains a sdl_statem_t structure (see below) which represents the current state of the protocol state machines. State requests may be sent as M_PROTO or M_PCPROTO messages from the stream head. Upstream modules may send a M_CTL message if desired.

SDL_STATE_REQ
Requests that the SDL provider return the current state variables associated with the SDL state machines. This primitive uses a sdl_state_req_t structure which contains only the sdl_primitive.
Responses
Upon success, the SDL provider will return a SDL_OK_ACK to confirm the successful state request. The provider attaches a M_DATA block which contains a sdl_statem_t structure (see "PROTOCOL STATE") containing the state variables.

Upon failure, the SDL provider will return a SDL_ERROR_ACK to reject the state request. Normally the request is successful and only the general error codes (see "ERROR HANDLING") will be returned.

Datastructures
For communicating state information, the SDL provider uses the sdl_statem_t structure as follows:

typedef struct sdl_statem {
    sdl_ulong   daedt_state;
    sdl_ulong   daedr_state;
    sdl_ulong       octet_counting_mode;
} sdl_statem_t;
daedt_state
Total state of the DAEDT state machine per Q.703. This member can take on the value SDL_STATE_IDLE or SDL_STATE_IN_SERVICE.s
daedr_state
Primary state of the DAEDR state machine per Q.703. This member can take on the values SDL_STATE_IDLE or SDL_STATE_IN_SERVICE.
octet_counting_mode
Flag of the DAEDR per Q.703. Indicates that the DAEDR is in octet counting mode per Q.703 when non-zero and in normal mode when zero. The values of this flag is undefined if the SDL_POPT_HSL protocol option is set.
 

Protocol Statistics

Protocol management primitives may be invoked by the SDL management to request and return statistical information collected during the operation of the SDL provider.

Any M_DATA block attached to the primitive or acknowledgement contains a sdl_stats_t structure (see below) which represents the statistics collected during the collection interval by the provider.

Statistics requests should be sent as low priority band M_PROTO messages. The SDLI provider will respond with low priority band M_PROTO messages for all but error conditions, which are sent as M_PCPROTO. SDL_STATS_IND messages will all be sent a low priority band M_PROTO messages. This avoids congestion resulting from syncrhonized data collection intervals across a large number of managed objects in the SS7 stack.

SDL_STATS_SET
Sets the statistics collection and aggregation parameters.
SDL_STATS_GET
Gets the statistics collection and aggrepation parameters as well as the
SDL_STATS_IND
Delivers an indication of the aggregated statistics for a collection period.
Responses
Upon success, SDL_OK_ACK acknowledges a successful statistics request and returns a M_DATA which contains the sdl_stats_t structure returning the statistics and collection and aggregation parameters. Upon failure, SDL_ERROR_ACK rejects a failed statistics request and returns a M_DATA which contains the sdl_stats_t structure returning the statistics, collection and aggregation parameters. Upon autonomous failure, SDL_ERROR_IND indicates a spontaneous failure in statistic collection or aggregation.

In error indications and acknowledgements, sdl_errno values can be a general error value (see "ERROR HANDLING") or one of:

SDL_STATSOOM
Statistics collection ran out of memory.
SDL_STATSSUSPEND
Statistics collection is congested and has been suspended.
SDL_STATSRESUME
Statistics collection congestion has cleared and has been resumed.
Datastructures
The SDL provider communicates statistics using the sdl_stats_t structure as follows:

typedef struct sdl_stats {
    sdl_ulong   octets_transmitted;
    sdl_ulong   octets_received;
} sdl_stats_t;
octets_transmitted
Provides a count (in bytes) of the octets transmitted through the DAEDT for the collection interval.
octets_received
Provides a count (in bytes) of the octets received through the DEADR for the collection interval.
 

Protocol Events

Protocol management primitives may be used by the SDL provider to indicate significant protocol management events or errors.
SDL_EVENT_REQ, SDL_EVENT_IND
Indicates a protocol management event has occured. The event indication uses the sdl_event_int_t structure as follows:

typedef struct {
    sdl_ulong   sdl_primitive; /* SDL_EVENT_IND */
    sdl_ulong   sdl_event_id;
} sdl_event_int_t;
sdl_type
The type of event which has occured. This indicates what may be the structure of any attached M_DATA block. It is one of the following values:

 

PROTOCOL INTERFACE

Protocol Primitives

Protocol primitives are as follows:

SDL_BITS_FOR_TRANSMISSION, SDL_RECEIVED_BITS
SDL_DAEDT_START_REQ
SDL_DAEDR_START_REQ
SDL_DAEDR_CORRECT_SU_IND
SDL_DAEDR_SU_IN_ERROR_IND

 

PROTOCOL MANAGEMENT INTERFACE

SDLI providers recognize the SMI M_CTL interface for protocol layer configuration, state, statistics and event management (see smi(7)) utilizing the following structures:  

Configuration

The control interface uses the sdl_conifig_t structure for configuration requests and responses as follows:

typedef struct sdl_config {
    sdl_ulong   pvar;   /* protocol variant */
    sdl_ulong   popt;   /* protocol options */
    sdl_ulong   N;      /* octets per su    */
    sdl_ulong   type;   /* interface type   */
    sdl_ulong   gtype;  /* group type       */
    sdl_ulong   rate;   /* interface rate   */
    sdl_ulong   mode;   /* interface mode   */
    sdl_ulong   clock;  /* interface clock  */
    sdl_ulong   coding; /* interface coding */
} sdl_config_t;
pvar
Protocol variant which can take on one of the values described in smi(7).
popt
Protocol options which contains a bit vector with any of the following bits set:
SDL_POPT_HSL
High speed links. When this bit is set it indicates that the SDL is a high speed link and will only deliver the first occurence of SDL_DAEDR_SU_IN_ERROR and not to enter octet_counting_mode.
SDL_POPT_XSN
Extended sequence numbers. When this bit is set it indicates that the L2 header consists of 6 octets instead of the normal 3.
N
The number of octets after which to deliver a SDL_DAEDR_SU_IN_ERROR when in octet_counting_mode. This number is meaningless when popt is has bit SDL_OPT_HSL set.

SDLI provides the following common SMI IOCTLS for protocol configuration management:

SDL_IOCTCONFIG [WR] (SMI_CONFIG_SETUP)
arg provides a pointer to a sdl_config_t structure which contains the configuration to setup and returns the results of the setup. This also locks the current configuration if successful.
SDL_IOCCCONFIG [-R] (SMI_CONFIG_COMMIT)
arg provides a pointer to a sdl_config_t structure which will contain the resulting configuration after commiting the last setup configuration. This also unlocks the current configuration if successful.
SDL_IOCSCONFIG [WR] (SMI_CONFIG_SET)
arg provides a pointer to a sdl_config_t structure which contains the configuration to set as well as returning the results of the settings.
SDL_IOCGCONFIG [-R] (SMI_CONFIG_GET)
arg provides a pointer to a sdl_config_t structure which will contain the current configuration when successful.

 

State

The control interface uses the sdl_statem_t structure for protocol state requests and responses as follows:

typedef struct sdl_statem {
    sdl_ulong   daedt_state;
    sdl_ulong   daedr_state;
    sdl_ulong   octet_counting_mode;
} sdl_statem_t;
daedt_state
State of the DAEDT state machine. This state may be either SDL_STATE_IDLE or SDL_STATE_IN_SERVICE.
daedr_state
State of the DAEDR state machine. This state may be either SDL_STATE_IDLE or SDL_STATE_IN_SERVICE.
octet_counting_mode
Flag indicating whether the DAEDR is in octet counting mode.

SDLI provides the following common SMI IOCTLS for protocol state management:

SDL_IOCCMRESET [-R] (SMI_RESET_REQ)
Performs a master reset of the SDL protocol state, placing it into the power-on condition and returns the state of the SDL. arg provides a pointer to a sdl_statem_t structure which will contain the state after master reset.
SDL_IOCGSTATEM [-R] (SMI_STATE_REQ)
Gets the current protocol state of the SDL. arg provides a pointer to a sdl_statem_t structure which will contain the state when successful.

 

Statistics

The control interface uses the sdl_stats_t structure for protocol statistics requests and responses as follows:

typedef struct sdl_stats {
    sdl_ulong   octets_transmitted;
    sdl_ulong   octets_received;
    sdl_ulong   sus_transmitted;
    sdl_ulong   sus_received;
    sdl_ulong   sus_in_error;
    sdl_ulong   breaks;
    sdl_ulong   aborts;
    sdl_ulong   residue_errors;
    sdl_ulong   framing_errors;
    sdl_ulong   frame_too_long;
    sdl_ulong   frame_too_short;
    sdl_ulong   lost_sync;
    sdl_ulong   rx_overruns;
    sdl_ulong   tx_underruns;
    sdl_ulong   dsr_transitions;
    sdl_ulong   cts_transitions;
    sdl_ulong   spurious_interrupts;
    /* others */
} sdl_stats_t;
octets_transmitted
octets_received
sus_transmitted
sus_received
sus_in_error
breaks
aborts
residue_errors
framing_errors
frame_too_long
frame_too_short
lost_sync
rx_overruns
tx_underruns
dsr_transitions
cts_transitions
spurious_interrupts

SDLI provides the following common SMI IOCTLS for protocol statistics management:

SDL_IOCSSTATSP [WR] (SMI_STATSP_SET)
SDL_IOCGSTATSP [R] (SMI_STATSP_GET)
SDL_IOCCSTATS [W] (SMI_STATS_CLR)
SDL_IOCGSTATS [R] (SMI_STATS_GET)

 

Events

 

CONTROL INTERFACE

The SDL provider is expected to support some standard ioctls to configure the SS7 Signalling Data Link driver. They may be used on a stream which is attached to the deivce to which the ioctl applies, or passed through a multiplexor using the pass through IOCTLs of the multiplexor (see mtpi(7) and slsi(7)).

If an ioctl is indicated as privileged, then using it requires sufficient access credentials. If this is not the case, EPERM will be returned.

For the following ioctls, it might not be possible to perform the set operations on all drivers implementations. For some drivers, it might not be possible to perform set operations while the interface is running. Set operations on running interfaces might result in line disruptions. Pseudo-devices should return the null value on get operations.

The ioctls provided by the SDTI are as follows:

SDL_IOCSIFRATE, SDL_IOCGIFRATE
Sets or gets the bit rate associated with the SDL interface. It may not be possible to set the bit rate on all devices (some device have a fixed bit rate). arg points to the bit rate of the line in bits per second at or above 56kbps, and the baud rate of the line in baud below 56kbps.
SDL_IOCSIFTYPE, SDL_IOCGIFTYPE
Sets or gets the interface type associated with the SDL interface. arg is a pointer to an sdl_ulong which contains one of the following values:

SDL_TYPE_NONE Unknown or unspecified. This may be used by some pseudo-devices.
SDL_TYPE_V35 Sychronous serial V.35 channel.
SDL_TYPE_DS0 64kbps DS0 channel.
SDL_TYPE_DS0A 56kbps (robbed bit) DS0A channel.
SDL_TYPE_E1 Full E1.
SDL_TYPE_T1 Full T1.
SDL_TYPE_J1 Full J1.
SDL_TYPE_ATM ATM channel.
SDL_TYPE_PACKET Packet channel.

SDL_IOCSGRPTYPE, SDL_IOCGGRPTYPE
Sets or gets the channel group (span) type associated with the current SDL interface. arg is a pointer to an sdl_ulong which contains one of the following values:

SDL_GTYPE_NONE There is no transmission channel group (span) associated with the device (i.e. the device is a Style 1 device).
SDL_GTYPE_T1 Channel within a T1 span (1 of 24 channels).
SDL_GTYPE_E1 Channel within a E1 span (1 of 30/32 channels).
SDL_GTYPE_J1 Channel within a J1 span (1 of 24 channels).
SDL_GTYPE_ATM VC within an ATM.

SDL_IOCSIFMODE, SDL_IOCGIFMODE
Sets or sets the mode associated with the SDL interface. Valid modes may depend upon interface type. arg is a pointer to an sdl_ulong which contains one of the following values:

SDL_MODE_NONE There is no mode associated with the device. This may be returned by pseudo-devices.
SDL_MODE_DSU DSU mode of serial interface.
SDL_MODE_CSU CSU mode of serial interface.
SDL_MODE_DTE DTE mode of V.35 interface.
SDL_MODE_DCE DCE mode of V.35 interface.
SDL_MODE_CLIENT Client mode (connecting) connection.
SDL_MODE_SERVER Server mode (listening) connection.
SDL_MODE_PEER Peer in peer-to-peer connections.
SDL_MODE_REM_LB Remote Loopback mode (for testing).
SDL_MODE_LOC_LB Local Loopback mode (for testing).
SDL_MODE_LB_ECHO Loopback and Echo mode (for testing).
SDL_MODE_TEST Special purpose test mode.

SDL_IOCSIFCLOCK, SDL_IOCGIFCLOCK
Sets or gets the clocking source associated with the SDL interface. Valid sources may depend upon interface type. arg is a pointer to an sdl_ulong which contains one of the following values:

SDL_CLOCK_NONE No clocking. This may be used for clockless pseudo-devices.
SDL_CLOCK_ASYNC Data stream is asynchronous.
SDL_CLOCK_INT Internally generated clock.
SDL_CLOCK_EXT External clock attached.
SDL_CLOCK_LOOP Tx clock generated from rx clock.
SDL_CLOCK_MASTER Inteface generates tx and rx clocks.
SDL_CLOCK_SLAVE Interface accepts rx and tx clocks.
SDL_CLOCK_DPLL Interface regenerates tx to rx clock w/ DPLL.

SDL_IOCSIFCODING, SDL_IOCGIFCODING
Sets or gets the line coding associated with the SDL interface. Valid codings may depend upon interface type. arg is a pointer to an sdl_ulong which contains one of the following values:

SDL_CODING_NONE No line coding or link coding unspecified. This will be used by pseudo-devices.
SDL_CODING_NRZ Non-return to zero line coding.
SDL_CODING_NRZI Manchester line coding.
SDL_CODING_AMI AMI frame coding.
SDL_CODING_B6ZS B6ZS frame coding.
SDL_CODING_B8ZS B8ZS frame coding.
SDL_CODING_ESF Extended Super Frame coding.
SDL_CODING_AAL1 ATN Adaption Layer 1 coding.
SDL_CODING_AAL2 ATN Adaption Layer 2 coding.
SDL_CODING_AAL5 ATN Adaption Layer 5 coding.

SDL_IOCDEVPRIVATE

ERRROR HANDLING
In addition to the normal errno values returned in an M_IOCNAK message (see ioctl(2) and streamio(2)), the following error codes may also be returned:
EOPNOTSUPP
The set operation will return this error number if the driver does not support setting the object of the command. The get operation returning this error number should be considered the same as a return value of NONE.
EINVAL
The set operation will return this error number if the driver does not support the selected value of the argument in its current mode.
 

ERROR HANDLING

Errors

 

IMPLEMENTATIONS

SDLI drivers which are included in the OpenSS7 release are all pseudo-devices and include:

sdl_eth(8)
SDL emulation using raw Ethernet (802.2).
sdl_ip(8)
SDL emulation using raw Internet Protocol (IP).
sdl_upd(8)
SDL emulation using User Datagram Protocol (UDP).
sdl_tcp(8)
SDL emulation using Transmission Control Protocol (TCP).
sdl_rtp(8)
SDL emulation using Real-Time Transport Protocol (RTP).
sdl_sctp(8)
SDL emulation using Stream Control Transmission Protocol (SCTP).
 

SEE ALSO

 

CAVEATS

 

AUTHOR

Brian F. G. Bidulock, <bidulock@openss7.org>.  

HISTORY

This STREAMS interface for SS7 is an original part of the OpenSS7 package.  

REFERENCES

[Q702] ITU-T Recommendation Q.702 Signalling Data Link
[Q703] ITU-T Recommendation Q.703 Signalling Link
[Q704] ITU-T Recommendation Q.704 Message Transfer Part
 

COPYRIGHT

Copyright (C) 2000 Brian Bidulock. All Rights Reserved.

PUBLIC LICENSE

This license is provided without fee, provided that the above copyright notice and this public license must be retained on all copies, extracts, compilations and derivative works. Use or distribution of this work in a manner that restricts its use except as provided here will render this license void.

The author(s) hereby waive any and all other restrictions in respect of their copyright in this software and its associated documentation. The authors(s) of this software place in the public domain any novel methods or processes which are embodied in this software.

The author(s) undertook to write it for the sake of the advancement of the Arts and Sciences, but it is provided as is, and the author(s) will not take any responsibility in it.


 

Index

NAME
SYNOPSIS
DESCRIPTION
LOCAL MANAGEMENT INTERFACE
PROTOCOL MANAGEMENT INTERFACE
Protocol Configuration
Protocol State
Protocol Statistics
Protocol Events
PROTOCOL INTERFACE
PROTOCOL MANAGEMENT INTERFACE
Configuration
State
Statistics
Events
CONTROL INTERFACE
ERROR HANDLING
IMPLEMENTATIONS
SEE ALSO
CAVEATS
AUTHOR
HISTORY
REFERENCES
COPYRIGHT

This document was created by man2html, using the manual pages.
Time: 05:12:10 GMT, January 08, 2001