SmartWORKS Developers Guide
SmartWORKS Developers Guide
SmartWORKS Developers Guide
SmartWORKS
Developer's Guide
v. 3.5.0
404-0001-003 · Build 040928.01REVB
404-0001-003 · Build 050425.01REVA
TOC
Ai-Logix, Inc. · I
Table Of Contents
Chapter 1 · Welcome . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1
1
Legal Notice . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2
About This Documentation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2
Release Update History . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3
Document Version Control . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5
Contacting Ai-Logix . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6
Technical Support . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6
Sales and General Information . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6
Headquarters Mailing Address—USA . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7
SDK Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10
System Requirements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10
Developer’s Notes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10
Ensuring the SDK is Operational . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
SDK Contents . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
Ensuring User Application Compatibility with the SDK . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14
Plug and Play (PNP) Capabilities . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
Architecture Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
The SmartWORKS Logical Card Model . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
Board and Channel Numbering . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17
Physical Board Numbering . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17
Board and Channel Numbering . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17
Global Channel Index . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18
Definition of NI, DR, and Channel . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18
MVIP TimeSlot Allocation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20
API/DLL Structure . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22
SmartWORKS Function Types . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22
Resource Queues . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22
Parameters . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23
Function Completion Notification . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23
NULL Pointer Checking . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24
Return Codes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24
Event Control . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
UNICODE Support . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
Media Formats . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27
Wave File Support . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27
Media Format Naming . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28
Board Type Naming . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30
Windows Event Viewer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32
Getting Started . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
Table of Contents SmartWORKS Developer’s Guide · II
SmartWORKS Flowchart . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
Event Control . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37
System Wide Definitions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42
Return Codes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42
Event Codes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44
Using Data Structures . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52
MT_IO_CONTROL . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53
General Termination Control . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 54
Signal Termination Control . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 54
Digit Termination Control . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 58
Miscellaneous Control Data . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59
Play/Record Specific Data . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60
Data Portion . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60
MT_EVENT . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61
Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 686
Avaya Definity Event Sequences . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 686
Avaya Merlin Magix Event Sequences . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 687
Example Sequence . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 687
Ericsson Event Sequences . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 689
Example Sequence . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 689
Nortel Meridian Event Sequences . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 695
NEC Electra Elite Event Sequences . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 695
Example Sequence . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 695
NEC NEAX Event Sequences . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 697
Example Sequence . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 697
Siemens Event Sequences . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 699
Samsung Event Sequences . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 700
Example Sequence . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 700
Phone Map . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 702
Aspect Event Sequences . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 703
Table of Contents SmartWORKS Developer’s Guide · IV
Chapter 1
Welcome
Ai-Logix, Inc.
2 •
SmartWORKS Developer’s Guide
Legal Notice
No part of this publication may be reproduced, stored in a retrieval system, or
transmitted in any form or by any means, electronic, mechanical, photocopying,
recording, or otherwise, without the prior written consent of Ai-Logix, Inc.
Copyright © 2000 - 2005 Ai-Logix, Inc. All rights reserved.
Ai-Logix, and the Ai-Logix logo are trademarks or registered trademarks of Ai-Logix,
Inc.
Microsoft Windows is a registered trademarks of Microsoft Corporation.
All other trademarks or registered trademarks are the property of their respective
companies.
Ai-Logix reserves the right to make changes to its products and specifications at any
time in order to improve on performance, manufacturing, or reliability. Information
furnished by Ai-Logix is believed to be accurate. No responsibility is assumed by
Ai-Logix for the use of said information, nor for any infringement of patents or of
other third party rights that may result from said use. No license is granted by
implication or otherwise under any patent or patent rights of any Ai-Technology
Group.
NOTE: Retired boards can no longer be purchased, but are still supported by
the SmartWORKS software.
This documentation is intended for the developer of CTI application software. This
manual assumes the reader is fairly proficient in standard C++ programming,
computer telephony and voice processing.
SMARTWORKS 3.4
D-channel support has been added for the following PBXs - LG Starex, Toshiba
Strata Dk , Toshiba Strata CTX
SMARTWORKS 3.3
Enhanced CPM, improved buffer handling with the MT_EVENT structure, Voice/
Answering Machine detection, G.726 MSB first.
SMARTWORKS 3.2
Secondary input control for Activity detection and DTMF tone detection , Plug and
Play, board clock synchronization, Flash firmware using APIs, and MSI support. Beta
release of LD409H and the LD2409.
SMARTWORKS 3.0
Windows NT is no longer supported. Windows 2003 Server 32 Bit support has been
added.
SMARTWORKS 2.10.0
SmartTERM DT6409TE, and DT 3209TE plus SmartTAP LD809 introduced to product
line. Features added: multi-processor support, board identification, a signal
profiling utility - SmartWORKS Profiler. See Release Notes for more information.
SMARTWORKS 2.9.0
Beta Release of LD 409. Support added for media format G.723.1. Support for
terminate ISDN (SmartTerm DT). See Release Notes for more information.
SMARTWORKS 2.7.0
Minor changes. See release notes.
SMARTWORKS 2.6.0
Added D-Channel support for SmartTAP NGX
SMARTWORKS 2.4.2
2nd Beta release of SmartTAP NGX
SMARTWORKS 2.4.0
Beta release of SmartTAP NGX. G.729A support added (VR6409, PT1609).
SMARTWORKS 2.3.7
Alpha and Early Adopter release of SmartTAP NGX
SMARTWORKS 2.3.6
Early Adopter release of NFAS functionality
SMARTWORKS 2.3.5
Beta release of Windows 2000 WDM driver
Early Adopter release of H.100 functionality
Welcome
• 5
Document Version Control
SMARTWORKS 2.3.4
Beta release of SmartTERM AT and DT
SMARTWORKS 2.3.2
Release of SmartTAP PT series
SMARTWORKS 2.3.0
Beta release of SmartTAP PT series
SMARTWORKS 2.2.0
Release of SmartTAP DP series
SMARTWORKS 2.0.0
Release of SmartDSP VR series
Page Description
10 Section added in the Developer’s Notes: Preventing Errors
on Shutdown.
Page Description
26 A note was added explaining the SmartWORKS .wav
header support when using MTPlayFile().
Contacting Ai-Logix
Your feedback is important to maintain and improve the quality of our products.
Use the information below to request technical assistance, make general inquiries,
or to provide comments.
TECHNICAL SUPPORT
For programming, installation, or configuration assistance, use the following
contact methods:
• Call technical support at 732.469.0880 or call toll free in the USA at
800.648.3647.
• For technical support log onto our online help system. Be sure to include a
detailed description of the problem along with PC configuration, Ai-Logix
hardware, driver versions, firmware versions, a sample program that demon-
strates the issue, and any other pertinent information.
SDK Overview
The SmartWORKS SDK is comprised of many files. These files, along with pertinent
product documentation, are installed when you use the SmartWORKS universal
installer CD that shipped with your product. Installation instructions are provided in
the SmartWORKS User’s Guide.
SYSTEM REQUIREMENTS
The SmartWORKS Driver/DLL supports the following operating systems:
Microsoft® Windows® 2000, (Service Pack 3 is required)
Microsoft® Windows® XP, (Service Pack 1 is required)
Microsoft® Windows® Server 2003 32 bit
Linux (call for availability)
For detailed system and hardware requirements on a per product basis, please refer
to the SmartWORKS User’s Guide.
DEVELOPER’S NOTES
ENVIRONMENT
The SmartWORKS SDK has only been tested with Microsoft Visual C++ 6.0 (Service
pack 5).
SMARTCONTROL STATUS
Successful initialization of a SmartWORKS board can also be determined through
SmartControl. When a board fails to initialize the Board tab will be blank.
SDK CONTENTS
When the SmartWORKS SDK is loaded onto a system, various applications and
filesare copied onto the PC. This section explains what is installed when
SmartWORKS is installed.
APPLICATIONS
The following applications are installed when the SmartWORKS software is
installed:
Ai-Logix, Inc.
12 •
SmartWORKS Developer’s Guide
SmartView.exe
SmartView is a demonstration program that comes as part of Ai-Logix's
SmartWORKS SDK. SmartView is capable of exercising most functions in the
SmartWORKS SDK and serves as a quick test tool for SmartWORKS API functions and
board status. SmartView can also aid during the installation and configuration of
any system in the field by providing a quick and simple test of basic functionality.
SmartControl.exe
SmartControl is a Windows Control Panel utility designed to retrieve and configure
the SmartWORKS operating environment. SmartControl works on system and
board level configurations. Channel-related configuration is offered through API
function calls. Tones, CPM tones, etc. are available through the SmartControl utility.
New configurations will not take effect until the driver is reloaded. It is
recommended that you always reload the driver to ensure that any changes
become effective.
SmartWF.exe
All SmartWORKS products (except the SmartWORKS NGX) use on-board flash
memory to store the DSP and CPU firmware. Ai-Logix will release new versions of
this firmware from time to time and the user may want to update their boards. The
SmartWF utility is used to retrieve or update the flash image (.bin) of SmartWORKS
boards.
When using the SmartWF utility, you will see a complete list of all firmware options.
When using this tool you must select the correct firmware for your hardware. The
following naming convention is used to identify which firmware is required for each
board type:
Model Number
vr32_X.XX.X.X.bin
Documentation
Release Notes
General notes about the release installed.
SmartWORKS User’s Guide
The universal user’s guide for the SmartWORKS family of products.
SmartWORKS Developer's Guide
The developer’s guide for the SmartWORKS SDK. This manual details all of the
custom API functions included in the SmartWORKS SDK, theories of operation for
the SmartWORKS product family, and implementation instructions for SmartWORKS
features.
SmartWORKS Utilities Guide
A user guide explaining each of the SmartWORKS utilities: SmartWF, SmartView,
SmartProfiler and the SmartControl panel.
NGX Integration Guide
Provides useful information about integrating the SmartWORKS NGX board with
proprietary PBXs in environments where D-channel is supported.
Product Quick Installs
Each product in the SmartWORKS family has its own Quick Install guide in PDF
format that walks you through the basic installation of the product.
Firmware
All board firmware files are stored here. Firmware files are also required for PBX
integration (SmartWORKS NGX board only). Refer to NGX installation instructions
for more information.
Inc
The following files are present in the Inc folder:
Programming Interface
These files comprise the primary interface to the SmartWORKS API.
NtiApi.h contains the prototypes for entry points in NtiDrv.dll, which is the interface
to the device driver.
NtiWFAPI.h declares the APIs used to flash firmware
NtiData.h and NtiEvent.h contain all data structures and event definitions. Both the
NtiData.h and the NtiEvent.h also have files specific to Call Control and D-Channel
support. For example: NtiDataCC.h and NtiDataDCC.h.
NtiErr.h contains all the possible return codes.
Legends.h contains the declaration for the API interface. User applications should
include either windows.h or afxmt.h from the Microsoft Compiler before including
NtiAPI.h.
Miscellaneous Files
NtiAPINull.h lists APIs that are not supported by the current SmartWORKS API.
Ai-Logix, Inc.
14 •
SmartWORKS Developer’s Guide
Obsolete.h lists APIs that have been obsoleted and are no longer supported.
ToBeDeleted... shows the APIs that are scheduled for deletion. Developers should
update their applications before these APIs are they are no longer supported.
SysLimits.h - defines SmartWORKs system limits
NV_WRAP.h - declaration for backward compatibility for NVDSP definitions
MS_Types.h - maps data types from Windows to Linux
NTI_NV.h - declares data structures that are not declared in the NtiData.h file,
required for backward’s compatability. Header file NTI_NV.h contains declarations
that are also present in the NV.h header for the Ai-Logix NVDSP SDK. When planning
to use both the NVDSP and SmartWORKS SDKs, include NV.h first, define
NV_CO_RESIDE macro, and then include NtiAPI.h header.
MS_Wave.h - defines the Microsoft WAVE format, used only in Linux platform
Lib
Includes offset addresses for each function name that the DLL exports.
Samples
Sample code is provided to assist Developers integrate applications with
SmartWORKS boards.
DRIVERS
NtiWdmDrv.sys- the low-level interface between the application DLL and the
SmartWORKS hardware. The device driver provides the basic functionality for
managing all high-speed data I/O transfers with on-board resources.
The SmartWORKS driver must be installed before the user application can start.
When running Windows 2000 or XP, the drivers start automatically with system
startup.
NtiDrv.dll - A Dynamic Link Library (DLL), NtiDrv.dll, is provided as the primary
interface between the customer’s application and the Ai-Logix driver. All APIs are
declared as dll export and use the __stdcall calling convention.
Architecture Overview
All SmartWORKS series products are built around a core set of powerful DSP
algorithms. They also provide Industry standard codecs, echo cancellation,
automatic gain control, DTMF, MF, CID and activity detectors.
TDM BUS
Each logical channel uses a TDM switch as a means of communicating with other
devices in the system. Each logical channel has three distinct connections to the
TDM switch: two inputs and one output. SmartWORKS products use the primary
input as the main source of voice data. The secondary input is used for call
recording applications where access to both sides of the conversation is required
(e.g. T1/E1 trunks).
INPUT MIXER
Each logical channel has a two-way mixer that can be used to combine the Primary
and Secondary voice data inputs. These inputs are very useful when recording
digital trunks (T1 or E1) in which case the voice logger has to add (mix) both sides of
the conversation. Activity detection and DTMF/MF tone detection is configurable
on a per input basis.
AGC
Automatic Gain Control (AGC) optimizes voice data to facilitate a wide dynamic
range typically encountered when a voice logger is connected close to a PBX or
analog phone.
GAIN
A fixed gain stage is proved to adjust the overall amplitude of the received voice
data.
VOLUME
A fixed gain stage adjusts the overall amplitude of the transmit voice data.
AVC
Automatic Volume Control (AVC) adjusts playback levels of transmitted voice data,
which makes the listening volume more comfortable. Recorded data volume levels
are not affected.
LIVE MONITOR
A special signal path is provided which allows a user to monitor a recording in real
time. This feature allows incoming voice data to be routed to the TDM switch via the
output side of the logical channel. Here AVC and gain can be applied without
affecting the recorded signal.
SmartWORKS Overview
• 17
Board and Channel Numbering
ENCODERS/DECODERS
The SmartWORKS product line offers a wide range of voice encoders and decoders.
The selection of digitalization methods is user programmable on a per channel
basis.
HOST INTERFACE
The host interface is used to move voice data to and from the logical channel and
communicate control and event data. The host interface is a 33 MHz, PCI2.2
compliant bus.
TONE GENERATOR
Each logical channel has a programmable tone generator that can be used to play
tones to the TDM switch. User applications can generate standard DTMF tones of
programmable amplitude and duration.
are assigned sequentially starting from zero. Channel numbers are assigned
sequentially starting from either 0 or 1 (depending on how the user has configured
this setting in the Smart Control panel).
Certain API functions will allow the developer to reference all boards
simultaneously by using the nBoard = -1.
The relationship between one NI and one DR through the global timeslot is referred
to as Channel Mapping. In order to connect an NI with a DR, two global timeslots
are required: one for NI to transmit to and for DR to receive from, and one for DR to
transmit to and for NI to receive from.
TimeSlot x1
Channel # C1 NI #N1 TimeSlot y1 DR #D1
TimeSlot x2
Channel # C2 NI #N2 TimeSlot y2 DR #D2
TimeSlot x2
Channel # C2 NI #N2 TimeSlot y2 DR #D2
CHANNEL CONNECTION
By the same token, the connection between two channels is illustrated in this
section.
First, the connection between two DR-only channels is shown.
TimeSlot x1
Channel # C1 NI #N1 TimeSlot y1 DR #D1
TimeSlot x2
Channel # C2 NI #N2 TimeSlot y2 DR #D2
Ai-Logix, Inc.
20 •
SmartWORKS Developer’s Guide
Secondly, the connection between two NI-DR-paired channels. Note that the NI
paired DR will not have a transmit time slot assigned.
TimeSlot x1
Channel # C1 NI #N1 TimeSlot y1 DR #D1
TimeSlot x2
Channel # C2 NI #N2 TimeSlot y2 DR #D2
API/DLL Structure
This section provides a high level view of the SmartWORKS API.
IMMEDIATE FUNCTIONS
An Immediate API function is one that does not return until it is completed. This is
also referred to as a synchronous function.
BACKGROUND FUNCTIONS
A Background API function is one that is queued and will be completed when the
requested resource is available. Background functions are also referred to as
asynchronous as they respond with a return code before they are completed.
There are several functions, such as playing a file or dialing a number, that do not
complete immediately. The API does not wait for this type of function to finish, but
returns immediately after the function is queued. The function will be executed
when the channel resource is available, hence, running in the background and
allowing the application to perform other tasks.
Only one background function per channel can be active at a time. Background
functions can be queued any time. Background functions are stopped or flushed
with the channel stop APIs: MTStopCurrentFunction() or MTSTopChannel().
RESOURCE QUEUES
The SmartWORKS API supports three resource queues:
· Encode
· Decode
· DTMF collection queue
By definition, API functions that need access to the encode, decode, or DTMF queue
are background functions.
Any time a user application requests a value from the API, the following sequence
occurs:
1 · The application passes a data type pointer to the function.
2 · The API fills the referenced memory space with the value.
API Overview
• 23
API/DLL Structure
User
Data Type
Application
Request
API
Function
Memory Space
All API functions return a long integer describing the function’s execution status. It is
strongly suggested that the return value be checked to ensure successful operation.
The requested value can be guaranteed as valid only when the function is executed
successfully.
PARAMETERS
The following section highlights the behavior of the API.
CHANGING SETTINGS
There are also functions that change system and channel parameters on a per
application basis. These changes remain in effect until they are modified again by
the next call to that function. These functions usually require a pointer to a structure
with several parameters. Zero is a valid parameter value.
OVERLAPPED EVENTS
Any API that ends with the suffix "Ex" uses the Windows overlapped mechanism as
its function completion notification mechanism.
Ai-Logix, Inc.
24 •
SmartWORKS Developer’s Guide
ASYNCHRONOUS CALLBACKS
Any API that ends with the suffix Async uses asynchronous callback as its
completion notification method.
API function MTPlayBufferAsync() requires a completion routine from the user
application. The SmartWORKS function completion routine mechanism is
implemented in the same fashion as a Windows system function completion. In
addition to the completion routine address, the application passes a parameter of
type LPARAM to the
SmartWORKS DLL/Driver, which then passes the parameter back, without change,
to the user application when the function has completed.
RETURN CODES
All API functions respond with a return code indicating the status of the function’s
completion. All return codes are of type MT_RESULT.
For an immediate API function, the return code MT_RET_OK indicates that the
API has been completed successfully.
For a background API function, the return code MT_RET_IO_PENDING indicates
that the API task has been successfully queued for execution when a resource
becomes available.
NOTE: All return codes are passed to the user application as a hex value. To obtain a
text desciption use the API MTGetReturnCodeDescription().
API Overview
• 25
UNICODE Support
EVENT CONTROL
Each channel has a FIFO buffer or event queue, which is used to temporarily store
asynchronous messages from the board. These messages, or events, are used to
indicate channel status information such as line signaling, voice activity, or errors.
The event queue for each channel can store up to 64 messages. Regardless of which
method is used, the user application is responsible for monitoring the channel
status often enough to ensure that it does not overflow. If the event queue is full
new events are lost and are reported in the Windows Event Viewer.
There are two methods the application can use to retrieve a channel’s events: event
queuing, and call backs. The next chapter explains each method and provides a
sample.
UNICODE Support
SmartWORKS provides UNICODE support under Microsoft Windows® in the
following manner:
If UNICODE is defined in the user application, API functions that require a string
parameter as input or output will use the PCWSTR definition for the string instead of
the normal PCSTR definition. Following is a code segment from the ntiapi.h header
file which shows how this functionality has been implemented.
#ifdef UNICODE
#define MTCallString MTCallStringW
#else
#define MTCallString MTCallStringA
#endif /* !UNICODE */
The definitions for the functions above are as follows:
MT_RESULT MTCallStringA(const CHANNEL nChannel,
PCSTR pCall_string,
const PMT_IO_CONTROL pIoCtl );
Media Formats
SmartWORKS supports the following media formats:
Frame Size in
Voice Format Bits/sec. Description
Bytes
MT_PCM_uLaw
64000 µ-law 8 bit PCM 160
MT_PCM
MT_PCM_ALaw 64000 A-law 8 bit PCM 160
MT_PCM_Raw_8bit 64000 Raw 8 bit PCM, signed 160
MT_PCM_Linear_8bit
MT_PCM_Raw_u8bit 64000 Raw 8 bit PCM, unsigned 160
MT_PCM_Linear_u8bit
MT_PCM_Raw_16bit 128000 Raw 16 bit PCM, signed 320
MT_PCM_Linear_16bit
MT_Linear
MT_PCM_Raw_u16bit 128000 Raw 16 bit PCM, unsigned 320
MT_PCM_Linear_u16bit
MT_PCM_Raw6k_16bit 96000 Signed Linear 6 KHz 16-bit PCM 240
MT_PCM_Linear6k_16bit
MT_PCM_µLaw_Stereo 128000 µ-law 8 KHz 8-bit stereo PCM (record only) 160
MT_PCM_ALaw_Stereo A-law 8KHz 8-bit stereo PCM (record only) 160
MT_OKI_ADPCM_SR8 32000 Dialogic ADPCM 8 KHz sample rate 80
MT_OKI_ADPCM_SR6 24000 Dialogic ADPCM 6 KHz sample rate 60
MT_G729A_8K 8000 G.729A 20
MT_GSM610 13000 GSM 6.10 33
API Overview
• 29
Media Formats
Frame Size in
Voice Format Bits/sec. Description
Bytes
MT_MSGSM 13000 Microsoft GSM 65 (40 ms frames)
MT_G723_DOT1_5300_FIX 5300 G.723.1 fixed rate 5.3 K 20 (30 ms frames)
MT_G723_DOT1_6300_FIX 6400 G.723.1 fixed rate 6.3 K 24 (30 ms frames)
MT_G726_16K 16000 G.726 16K bps 40 (20 ms frames)
MT_G726_16K_µlaw 16000 G.726 16K bps for µ-law 40 (20 ms frames)
MT_G726_16K_Alaw 16000 G.726 16K bps for A-law 40 (20 ms frames)
MT_G726_24K 24000 G.726 24K bps 60 (20 ms frames)
MT_G726_24K_µlaw 24000 G.726 24K bps for µ-law 60 (20 ms frames)
MT_G726_24K_Alaw 24000 G.726 24K bps for A-law 60 (20 ms frames)
MT_G726_32K 32000 G.726 32K bps 80 (20 ms frames)
MT_G726_32K_µlaw 32000 G.726 32K bps for µ-law 80 (20 ms frames)
MT_G726_32K_Alaw 32000 G.726 32K bps for A-law 80 (20 ms frames)
MT_G726_40K 40000 G.726 40K bps 100 (20 ms frames)
MT_G726_40K_µlaw 40000 G.726 40K bps for µ-law 100 (20 ms frames)
MT_G726_40K_Alaw 40000 G.726 40K bps for A-law 100 (20 ms frames)
MT_G726_16K_MSb_1st 16000 G.726 16K bps MS-bit first 40 (20 ms frames)
MT_G726_16K_µlaw_MSb_1st* 16000 G.726 16K bps for µ-law MS-bit first 40 (20 ms frames)
MT_G726_16K_Alaw_MSb_1st* 16000 G.726 16K bps for A-law MS-bit first 40 (20 ms frames)
MT_G726_24K_MSb_1st 24000 G.726 24K bps MS-bit first 60 (20 ms frames)
MT_G726_24K_µlaw_MSb_1st* 24000 G.726 24K bps for µ-law MS-bit first 60 (20 ms frames)
MT_G726_24K_Alaw_MSb_1st* 24000 G.726 24K bps for A-law MS-bit first 60 (20 ms frames)
MT_G726_32K_MSb_1st 32000 G.726 32K bps MS-bit first 80 (20 ms frames)
MT_G726_32K_µlaw_MSb_1st* 32000 G.726 32K bps for µ-law MS-bit first 80 (20 ms frames)
MT_G726_32K_Alaw_MSb_1st* 32000 G.726 32K bps for A-law MS-bit first 80 (20 ms frames)
MT_G726_40K_MSb_1st 40000 G.726 40K bps MS-bit first 100 (20 ms frames)
MT_G726_40K_µlaw_MSb_1st* 40000 G.726 40K bps for µ-law MS-bit first 100 (20 ms frames)
MT_G726_40K_Alaw_MSb_1st* 40000 G.726 40K bps for A-law MS-bit first 100 (20 ms frames)
*Decode Only
Ai-Logix, Inc.
30 •
SmartWORKS Developer’s Guide
The next list of event messages stem from the NtiDrv.dll, the SmartWORKS API. API
issues can be API, Application, Firmware, or Hardware issues.
Getting Started
This section provides basic information about writing an application with the
SmartWORKS API.
SMARTWORKS FLOWCHART
Each application written for SmartWORKS follows the same basic processing
scheme. The following flowchart depicts this flow control.
YES
Optional:
Following Callback, the TDM Bus
If TDM routing is desired, it
should be verified for errors (if
should be configured now.
any) with MTArmCTAlarm()
Event Control
Three type of events are generated by Ai-Logix boards: board events, channel
events and system events.
Each channel has a FIFO buffer or event queue, which is used to temporarily store
asynchronous messages. These messages, or events, are used to indicate channel
status information such as line signaling, voice activity, or errors. The event queue
for each channel can store up to 64 messages. Regardless of which method is used,
the user application is responsible for monitoring the channel status often enough
to ensure that it does not overflow. If the event queue is full new events are lost and
are reported in the Windows Event Viewer.
With event queuing, the application can pull the messages off of the queue by
calling MTWaitForChannelEvent() in a polling routine. All event queue messages
must be pulled out of the FIFO in order to keep it from overflowing. Many of the
messages can be ignored if they are not important to the application.
The second and preferred method of reading the event queue is to use a call back
function. A call back function will be invoked by any event or by a specific event.
When a callback function is invoked, events are passed as parameters. There is no
need to call MTWaitForChannelEvent().
Following is a list of Event Information and Control API functions:
POLLING
The function MTWaitForChannelEvent() is used to get the first queued event. The
application passes a pointer to an empty MT_EVENT structure. If an event is
available, the DLL fills the event structure with information such as time stamp,
event code, or extended sub-reason codes. Should there be no event queued; the
DLL waits for either the expiration of the specified time-out period or the arrival of a
new event. Some common events that are unimportant to a specific channel can be
disabled so that the events are never queued for that channel. Function
MTSetEventFilters() uses a bit to enable or disable a number of common events.
Events with Extra Information
Some events, such as call control, EVT_CC_ events, pass over extra information to
the user application. The field ptrBuffer is set by the SmartWORKS DLL to identify the
buffer holding the extra information. The SmartWORKS DLL allocates a buffer to
hold this data. After the data is retrieved, the user application must invoke
MTReturnEventBuffer() to return this buffer.
As of release 2.8, events that are generated with extra information are handled
differently by the DLL. To enable this feature use MTSetSystemConfig() and set the
field ComplileWithSDK to a value that is greater than 0x0208660. Now the user
application is required to allocate a buffer for this extra information. Use the
ptrXtraBuffer field to identify the pointer for the extra information, and the
XtraBufferLength field to set the length of the buffer. If these fields are not set by the
user application, the extra data is not provided to the user application.
When data is returned to the user application, the SmartWORKS DLL sets the
XtraDataLength field with the actual data length returned to the user application. If
the actual length of data is larger than the allocated buffer, the data is truncated
and a flag in Bit 2 of the EventFlag field is set to 0x000000004.
The following is an example of a basic Polling method:
#include <windows.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <NTiAPI.H>
while (1)
{
// Note: MTWaitForChannelEvent may reset your size to 0
// if there is no event, therefore set the size everytime
// before calling MTWaitForChannelEvent
size = sizeof(event);
r=MTWaitForChannelEvent(chan,10,&event,&size);
if(r==MT_RET_OK)
{
Code = event.EventCode;
Reason = event.SubReason;
switch (Code)
{
case EVT_CALLID_STOP:
r=MTGetCallerID(chan, 128, callerIDBuf );
printf("Ch. %d Caller ID length %d data '%s'",
chan, strlen(callerIDBuf), callerIDBUf );
break;
case EVT_CALLID_DROPPED:
printf("Ch. %d Caller ID dropped ", chan);
break;
case EVT_MAX_SILENCE:
break;
case EVT_MAXTIME:
break;
case EVT_MAXBYTES:
break;
case EVT_MAXDIGITS:
break;
case EVT_DIGIT:
break;
case EVT_EOF:
break;
Ai-Logix, Inc.
40 •
SmartWORKS Developer’s Guide
case EVT_RINGS:
break;
}
}
chan++;
if (chan >totalChannels)
chan =1;
}
return 0;
}
// include files
#include<NTiAPI.h>
#include<NTiEvent.h>
// callback
CINTERFACE void APICallback(CHANNEL iCh,int EventCount,PMT_EVENT pMt,LPARAM
lParam)
{
int Code,Reason;
switch(Code)
{
case EVT_DIGIT:
break;
case EVT_CC_DISC_CONF:
break;
...
...
}
}
}
MTSetEventCallback(0,(MTCALLBACK)APICallback,0);
Ai-Logix, Inc.
42 •
SmartWORKS Developer’s Guide
EVENT CODES
Event codes can be found in the EventCode field of the MT_EVENT structure. They
are of the EVT_... type and are defined in NtiEvent.h. In the following, the type
has the X/Y format where X is an event and Y is an event type.
NOTE: All event codes are returned to the user application as a hex value. To
retrieve a text description use the API MTGetEventCodeDescription().
A block has been reserved for user defined event codes. Events can be created
using the hex value of 0x8000 through 0x8fff. Application developers can define event
codes and put them in the appropriate event queues using MTPutEvent() and
MTPutBoardEvent().
MT_IO_CONTROL
MT_IO_CONTROL is an important structure used by most background functions. It
specifies most termination conditions and contains pointers to buffers and a file
offset. Each MT_IO_CONTROL takes effect when the associated background
function is active. The channel setting is not affected.
TABLE 7: MT_IO_CONTROL
Type Name Purpose
ULONG PreACTDuration ms of data to record before triggering on ACTD
ULONG CtrlData # of activity events to trigger recording for START_ACTD control
GENERAL TERMINATION CONTROL
ULONG MaxTime Action timeout period in milliseconds
ULONG MaxBytes Action terminate on size of bytes
SIGNAL TERMINATION CONTROL
ULONG MaxSilence Max. silence time for termination
ULONG MaxActivity Max activity time for termination
ULONG CpmMode CPM Mode control
ULONG TermEnable Termination conditions
ULONG MoniEnable Monitoring conditions
DIGIT TERMINATION CONTROL
ULONG MaxDigits Number of digits for termination
MT_DIGIT_ENABLE DigitEnable Enable bits for termination digits
ULONG EndDigit Termination digit (@terminates on any digit)
ULONG DigitTime Inter-digit timeout when MaxDigits is not zero
MISCELLANEOUS CONTROL DATA
ULONG StartControl Start Control flag field
ULONG ToneDuration Prompt tone duration in milliseconds
ULONG TermControl Flush queued playback(s) on termination other than EVT_EOF,
EVT_MAXBYTE, EVT_MAXTIME
PLAY/RECORD SPECIFIC DATA
ULONG FileIndex File starting offset for play/record APIs (not required for index
APIs)
ULONG FileHandle file handle; Device handle for user specified media access
ULONG FileType Type of voice file
Data Portion
ULONG Length Length of the following data buffer
PUCHA Buffer Data buffer pointer
Ai-Logix, Inc.
54 •
SmartWORKS Developer’s Guide
MAXBYTES
The maximum number of bytes to read/write. This parameter causes an
EVT_MAXBYTES event. NOTE: This termination condition is not supported when
streaming.
MAXACTIVITY
This parameter specifies the maximum time for a continuous signal or activity
before the function terminates(play function only). It is similar to
MaxSilence. Like MaxSilence, MaxActivity can not be used for play
functions. An EVT_MAX_ACTIVITY event is generated if this termination
condition occurs.
CPMMODE
Users control the CPM mode for a particular background function. This field controls
whether monitoring events (EVT_MON_signalname) are reported to the user application or
whether this task is stopped because a termination condition is detected. The following
table lists each option when setting this field in the MT_IO_CONTROL structure:
Mode Description
MONI_USE_CHANNEL_ONLY Report monitoring events as set at the channel level using
MTSetMoni().
MONI_USE_NONE Do not report any monitoring events. Ignore the options
set at the channel level using MTSetMoni(). *
MONI_USE_TASK_ONLY Report only the options set using the MoniEnable field of
the IO_CONTROL structure. Ignore the options set at the
channel level using MTSetMoni().
MONI_USE_CHANNEL_AND_TASK Report the monitoring events set with the MoniEnable
field of the IO_CONTROL structure and at the channel
level using MTSetMoni().
TERM_USE_NONE To not terminate this function. Ignore the termination
conditions set at the channel level using MTSetTerm().
TERM_USE_CHANNEL_AND_TASK Terminate this function using the termination conditions
set with the TermEnable field of the IO_CONTROL
structure and at the channel level using MTSetTerm().
Writing An Application
• 55
Using Data Structures
Backwards Compatibility
To support older versions of the SmartWORKS API, (3.2 and earlier) the following modes are
still accepted:
TERM ENABLE
This field allows users to set the same termination conditions available using the
MTSetTerm() API. This bit field specifies line conditions that will behave as
termination conditions while this background function is running. Once this line
condition is detected, this task is automatically stopped by the SmartWORKS DLL.
This field can be used in combination with MTSetTerm() or configured to work
alone. The CPM_MODE field of the MT_IO_CONTROL structure controls whether the
channel, task or a combination of both settings are used.
When a condition is met, the event EVT_CPM_STOP is generated with the
Subreason and XtraInfo fields of the MT_EVENT structure identifying the line
condition, and the FuncCode field identifying the type of media function
terminated.
The table on the following page explains each optioin of the TermEnable field and
the respective subreason and XtraInfo field generated when EVT_CPM_STOP is
reported.
Ai-Logix, Inc.
56 •
SmartWORKS Developer’s Guide
MONIENABLE
This field allows users to set the same monitoring conditions available using the
MTSetMoni() API. This bit field controls the types of MON events that will be reported
while this background function is running. This field can be used in combination
with MTSetMoni() or configured to work alone. The CPM_MODE field of the
MT_IO_CONTROL structure controls this. The following table lists all options
available when setting the MoniEnable field:
DIGITENABLE
This 16-bit field specifies the termination digits. If a digit matches one of the
specified digits, an EVT_DIGITENABLE event is generated. The bits are assigned
as follows:
Bit: 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
Digit: C B A # * 0 9 8 7 6 5 4 3 2 1 D
Within the SmartWORKS API, these digits are defined with the prefix MT_DIGIT_. For
example, digit “1” is defined as MT_DIGIT_1, digit # is defined as MT_DIGIT_POUND.
ENDDIGIT
If one of the digits in the queue matches this character, the function terminates with
an EVT_TERMDIGIT event. If this character is set to @, any digit will terminate the
function. This field uses ASCII values such as '#' or ‘1’ and not the bit values defined
for the DigitEnable field.
DIGITTIME
This specifies the maximum time, in milliseconds, between digits received. If the
maximum time is exceeded, it causes an EVT_INTERDIGIT event.
TABLE 8: STARTCONTROL
0 Reserved Set to 0
11 Reserved Set to 0
13. WAVE_RIFFFMTDATA_CHUNK Add wave header, not available on streaming and DeviceIO
functions
Ai-Logix, Inc.
60 •
SmartWORKS Developer’s Guide
14. WAVE_DATACHUNK_ONLY Add wave data chunk descriptor only, not available on streaming
and DeviceIO functions
15. FRAME_HEADER (TBD)* (TBD) Add a 2-byte frame size header to each frame. Set to 0.
TONEDURATION
For a prompt tone to be played, the lowest four bits of this variable must specify the
length of the tone in milliseconds.
TERMCONTROL
If TermControl is set to "1," all commands in queue will be deleted when a PlayBack
task is terminated by any termination event set in MT_IO_CONTROL.
EVT_EOF is the only termination event which cannot clear the command queue
even if the TermControl field is set to "1."
This setting allows termination of the current MTPlayFile() command in the queue
when the current play command is terminated by an event like EVT_MAXDIGIT or
EVT_TERMDIGIT. This control avoids the use of the MTStopChannel() command
which resets all commands in the queue. EVT_TERMDIGIT immediately
terminates only the playback currently in progress.
FILEHANDLER
The user I/O access file descriptor for record/play.
FILETYPE
The media format.
DATA PORTION
LENGTH
This specifies the length of the data buffer.
BUFFER
This is required when using API functions that require a buffer from the user
application. Pointer to a data buffer for the media data in the format specified in the
FileType field.
Writing An Application
• 61
Using Data Structures
MT_EVENT
The EVENT structure is used to retrieve event information generated by the board.
Users have two options for retrieving event information: polling method or callback
method. When polling, data is retrieved from the event queue with
MTGetChannelEvent() or MTWaitForChannelEvent(). Another method is to rely on the
call back method to populate the MT_EVENT structure. Both of these methods are
discussed in detail in the section that explains Event Control.
The user application can insert an event into the event queue through
MTPutChannelEvent() or MTPutBoardEvent() with user application specific value
added to the UserEvent and UserData fields of this structure. The SmartWORKS API
leaves these values unmodified. This structure is declared in NtiEvent.h.
TABLE 9: MT_EVENT
* Used only with release 2.8 or later and the CompilewithSDK flag has been set to a
value greater than 0x02086600.
NOTE: All event codes are returned as a hex value. To retrieve a text
description use the API MTGetEventCodeDescription().
TIMESTAMP
The time stamp of when the event occurred. It is presented in FILETIME
format(WIN32) or gettimeofday() format (Linux). During system startup, the board is
synchronized with the system time. The board uses its TDM clock to generate the
TimeStamp. The TDM clock may be synchronized with a local oscillator (50 ppm
stability), the CT bus, or the T1/E1 clock. The TimeStamp and system time may differ
depending on the board’s clock source stability and system clock stability.
If an event is inserted by using MTPutChannelEvent() or MTPutBoardEvent() then
the user application is responsible for initialization of the time stamp.
USERSTATUS
User defines and maintains this field. The API does not use, change or maintain this
field. All events generated by the API have this field set to 0. A user-defined event
can be inserted with this field set for a special purpose defined by the user
application.
EVENTCODE
The event code is returned in EventCode and is defined as EVT_... defines in
NtiEvent.h.
SUBREASON
This field supplies additional information for a number of events.
For the EVT_CPM_STOP event, this field contains the extended termination code
of the type CPM_MONI_....
For digit termination events, this field contains the digit that terminated the
background function.
For EVT_CALLID_STOP event, this field contains the length of the caller ID packet.
Writing An Application
• 63
Using Data Structures
XTRAINFO
For the EVT_MFTONE event, this field contains the source of either primary or
secondary stream of the R2 tone.
For the EVT_CALLID_STOP event, this field contains the first 4 bytes of the caller
ID packet.
FUNCCODE
FuncCode is a code assigned to each I/O API. When the EVENT structure is used to
retrieve events, the name of the FuncCode generating the event is captured in the
FuncCode field. The FuncCode was designed to enhance the developer’s ability to
monitor encoding and decoding actions.
Each FuncCode is defined in the NtiEvent.h file.
Since the FuncCode is used to only monitor encoding or decoding actions, the
following is defined:
#define ENCODE_BASE 0x1000 // Record function
#define DECODE_BASE 0x2000 // Playback function
As a result, the following eight(8) FuncCode values can be returned. Each FuncCode
value is a combination an encode/decode value with a method value.
For example:
If data has been encoded (0x1000) to a buffer (0x0100) the structure
returns the hexadecimal value of (0x1100).
The following table illustrates the hexadecimal value of each FuncCode, as
well as a value that can be pulled into the developer’s GUI. Please note, the
FuncCode for Playback of file index is an exception.
BOARD
The board where the event occurred.
CHANNEL
The channel where event occurred.
PTRBUFFER
Pointer to data buffer on which the event happened (media control). If this field is
populated because of an event that contains extra information (such as a call
control event EVT_CC_ ) then this field contains the pointer to a buffer containing
the extra information. MTReturnEventBuffer() must be invoked when using the
polling method. This is further explained where MTReturnEventBuffer() is
discussed in the Functional Reference Library.
DATALENGTH
Length of exercised data in buffer when the event happened (22).
PTRXTRABUFFER
As of release 2.8, events with extra information such as call control events (EVT_CC)
are handled differently. NOTE: To use this method, use MTSetSystemConfig() to
set the CompiledWithSDK field to a value greater than 0x02086600.
When using the callback method to retrieve events, the ptrXxtraBuffer field provides
the pointer to the buffer containing the extra information and the XtraBufferLength
indicates the data length. When using the polling method: the ptrXtraBuffer field
must be set by the user application, along with the XtraBufferLength field.
MTReturnEventBuffer() should not be used. This is further explained where
MTReturnEventBuffer() is discussed in the Functional Reference Library.
XTRABUFFERLENGTH
Writing An Application
• 65
Using Data Structures
XTRADATALENGTH
Length of the actual data in the XtraBuffer. This value does not exceeded the value
set by XtraBufferLength. When the polling method is used, Bit 2 in the EventFlag
field is used to alert the user application when the actual data length exceeds the
allocated XtraBuffer.
EVENTFLAG
This field is informational only. All bits are managed by the SmartWORKS DLL.
This field contains two bit values:
Bit 0x000000001
1- application created the event (this event was put in queue by the user appli-
cation using MTPutChannelEvent() or MTPutBoardEvent().
0 - the DLL created the event
Bit 0x000000002
1- application allocated buffer for extra event information (MTReturnEvent-
Buffer() must be used)
0 - the SmartWORKS DLL allocated the buffer for extra event information
Bit 0x000000004
1 - data has been truncated
0 - data has not been truncated
Ai-Logix, Inc.
66 •
SmartWORKS Developer’s Guide
Chapter 5
Function Reference Library
Function Reference Library
• 68
SmartWORKS PCM
SmartWORKS NGX
API Function
SmartWORKS DP
SmartWORKS DT
SmartWORKS LD
SmartWORKS VR
SmartWORKS AT
SmartWORKS PT
Status Legend: F=Fully supported · O=To Be Obsolete
· P=Pending future release, beta · *= Board Supported
Status
MakeWaveGSMHeader() F * * * * * * * *
MakeWavePCMHeader() F * * * * * * * *
MTAddSummationInput() F * * *
MTAGCStatus() F * * * * * * * *
MTAJListen() F * * * *
MTAJTalk() F * * * *
MTArmCTAlarm() F * * * * * * * *
MTArmFramerAlarm() F * * * *
MTArmMasterAlarm() F * * * * * * * *
MTAVCControl() F * * * * * * * *
MTAVCStatus() F * * * * * * * *
MTBlinkBoard() F * * * * * * * *
MTBoardGetIdleCoding() F *
MTBoardGetTerminationImpedance() F *
MTBoardPCMGetSignalConfig() F *
MTBoardPCMSetSignalConfig() F *
MTBoardPCMTrunkFrameSyncControl() F *
MTBoardPCMTrunkFrameSyncStatus() F *
MTBoardPCMTrunkSlotTxControl() F *
MTBoardPCMTrunkSlotTxStatus() F *
MTBoardSetIdleCoding() F *
MTBoardSetTerminationImpedance() F *
MTCalculateFilterRange() F * * * * * * * *
MTCallstring() F * *1
Function Reference Library
• 69
SmartWORKS PCM
SmartWORKS NGX
API Function
SmartWORKS DP
SmartWORKS DT
SmartWORKS LD
SmartWORKS VR
SmartWORKS PT
SmartWORKS AT
Status Legend: F=Fully supported · O=To Be Obsolete
· P=Pending future release, beta · *= Board Supported
Status
MTCallStringAsync() F * *1
MTCallStringEx() F * *1
MTCC_ConnectRequest() F *
MTCC_ConnectResp() F *
MTCC_DiscRequest() F *
MTCC_FacilityRequest() F *
MTCC_GetStatusByCh() F *
MTCC_GetStatusByRef() F *
MTCC_ResumeRequest() F *
MTCC_SuspendRequest() F *
MTCC_UserInfoRequest() F *
MTChClearUsrSignalParams() F * * * * * * * *
MTChCPMControl() F * * * * * * * *
MTChCPMStatus() F * * * * * * * *
MTChCPMSignalControl() F * * * * * * * *
MTChCPMSignalStatus() F * * * * * * * *
MTChGetCPMSignalParams() F * * * * * * * *
MTChGetUsrSignalParams() F * * * * * * * *
MTChGetVoiceDetectParams() F * * * * * * * *
MTChInputACTDControl() F * * * * * * * *
MTChInputACTDStatus() F * * * * * * * *
MTChInputAGCControl() F * * * * * * * *
MTChInputAGCStatus() F * * * * * * * *
MTChInputGetACTDDetectPower() F * * * * * * * *
MTChInputGetACTDParams() F * * * * * * * *
MTChInputGetAGC() F * * * * * * * *
MTChInputGetDTMFDetectParams() F * * * * * * * *
MTChInputGetGain() F * * * * * * * *
Function Reference Library
• 70
SmartWORKS PCM
SmartWORKS NGX
API Function
SmartWORKS DP
SmartWORKS DT
SmartWORKS LD
SmartWORKS VR
SmartWORKS PT
SmartWORKS AT
Status Legend: F=Fully supported · O=To Be Obsolete
· P=Pending future release, beta · *= Board Supported
Status
MTChInputGetToneDetectParams() F * * * * * * * *
MTChInputSetACTDParams() F * * * * * * * *
MTChInputSetAGC() F * * * * * * * *
MTChInputSetDTMFDetectParams() F * * * * * * * *
MTChInputSetGain() F * * * * * * * *
MTChInputSetToneDetectParams() F * * * * * * * *
MTChInputStepGain() F * * * * * * * *
MTChInputToneDetectControl() F * * * * * * * *
MTChInputToneDetectStatus() F * * * * * * * *
MTChResetCPMSignalParams() F * * * * * * * *
MTChSetCPMSignalParams F * * * * * * * *
MTChSetUsrSignalParams() F * * * * * * * *
MTChSetVoiceDetectParams() F * * * * * * * *
MTChUsrSignalControl() F * * * * * * * *
MTChUsrSignalStatus() F * * * * * * * *
MTChVoiceDetectControl() F * * * * * * * *
MTChVoiceDetectStatus() F * * * * * * * *
MTClearBoardEventCallback() F * * * * * * * *
MTClearDTMFDigits() F * * * * * * * *
MTClearEventCallback() F * * * * * * * *
MTClearFramerStatistic() F * * * *
MTClearMFTones() F * * * * * * * *
MTClearPriorityEventCallback() F * * * * * * * *
MTClearUsrToneParams() P * * * * * * * *
MTCloseBoard() F * * * * * * * *
MTCloseChannel() F * * * * * * * *
SmartWORKS PCM
SmartWORKS NGX
API Function
SmartWORKS DP
SmartWORKS DT
SmartWORKS LD
SmartWORKS VR
SmartWORKS PT
SmartWORKS AT
Status Legend: F=Fully supported · O=To Be Obsolete
· P=Pending future release, beta · *= Board Supported
Status
MTDialString() F * * * * * * * *
MTDialStringAsync() F * * * * * * * *
MTDialStringEx() F * * * * * * * *
MTDisableCallerID() F * * * * * * * *
MTDisableFramerABCDSignalingEvent() F * *
MTDisableMixing() F * * * * * * * *
MTDisarmCTAlarm() F * * * * * * * *
MTDisarmFramerAlarm() F * * * *
MTEnableCallerID() F * * * * * * * *
MTEnableFramerABCDSignalingEvent() F * *
MTEnableMixing() F * * * * * * * *
MTEventControl() F * * * * * * * *
MTFlushCallerID() F * * * * * * * *
MTFlushEvents() F * * * * * * * *
MTGetACTDDetectPower() - O * * * * * * * *
see MTChInputACTDDetectPower()
MTGetAdapterConfig() F * * * * * * * *
MTGetAdapterDescription() F * * * * * * * *
MTGetAdapterEEPROMConfig() F * * * * * * * *
MTGetAdapterInfo() F * * * * * * * *
MTGetAdapterStatusDescription() F * * * * * * * *
MTGetAdapterXInfo() F * * * * * * * *
SmartWORKS PCM
SmartWORKS NGX
API Function
SmartWORKS DP
SmartWORKS DT
SmartWORKS LD
SmartWORKS VR
SmartWORKS PT
SmartWORKS AT
Status Legend: F=Fully supported · O=To Be Obsolete
· P=Pending future release, beta · *= Board Supported
Status
MTGetAJListen() F * * * *
MTGetAJMap() F * * * *
MTGetAJTalk() F * * * *
MTGetAlertToneParams() F * * * * * * * *
MTGetAVC() F * * * * * * * *
MTGetBoardAssemblyInfo() F * * * * * * * *
MTGetBoardOEMInfo() F * * * * * * * *
MTGetBoardOpenStatus() F * * * * * * * *
MTGetBoardStatistics() F * * * * * * * *
MTGetCallerID() F * * * * * * * *
MTGetCallerIDStatus() F * * * * * * * *
MTGetCallStatus() F * * * * * * * *
MTGetCCStatistics() F *
MTGetChannelEvent() F * * * * * * * *
MTGetChannelInfo() F * * * * * * * *
MTGetChannelOpenStatus() F * * * * * * * *
MTGetChannelOwner() F * * * * * * * *
MTGetChannelStatus() F * * * * * * * *
MTGetCpmMode() P * * * * * * * *
MTGetCPMSigSwitch() P * * * * * * * *
MTGetCpmToneParams() P * * * * * * * *
MTGetCTAlarmStatus() F * * * * * * * *
MTGetCTMasterClock() F * * * * * * * *
MTGetCTNetrefSource() F * * * * * * * *
MTGetCTRoute() F * * * * * *
MTGetCTSlaveClockMode() F * * * * * * * *
MTGetCTSlotConnection() F * * * * * * * *
MTGetReturnCodeDescription() F * * * * * * * *
Function Reference Library
• 73
SmartWORKS PCM
SmartWORKS NGX
API Function
SmartWORKS DP
SmartWORKS DT
SmartWORKS LD
SmartWORKS VR
SmartWORKS PT
SmartWORKS AT
Status Legend: F=Fully supported · O=To Be Obsolete
· P=Pending future release, beta · *= Board Supported
Status
MTGetStatistics() F *
MTGetDataLinkStatus() F *
MTGetDigits() F * * * * * * * *
MTGetDigitsAsync() F * * * * * * * *
MTGetDigitsEx() F * * * * * * * *
MTGetDLLVersion() F * * * * * * * *
MTGetDTMFDetectParams() - O * * * * * * * *
see MTChInputGetDTMFDetectParams)
MTGetE1FramerStatistic() F * *
MTGetECControl() F * * *
MTGetECParams() F * * *
MTGetECFreezeAdaptation() F * * *
MTGetEventCodeDescription() F * * * * * * * *
MTGetEventFilters() F * * * * * * * *
MTGetFramerABCDSignalingEventStatus() F * *
MTGetFramerAlarmArmStatus() F * * * *
MTGetFramerAlarmStatus() F * * *
MTGetFramerLoopbackMode() F *
MTGetFramerOutput F * * * *
MTGetFraming() F * * *
MTGetGCI() F * * * * * * * *
MTGetGCIMap() F * * * * * * * *
MTGetHookState() F * *
MTGetInputs() F * * * * * * * *
MTGetLastErrorA() F * * * * * * * *
MTGetLastErrorW() F * * * * * * * *
MTGetLastTerm() F * * * * * * * *
MTGetLCDetectState F * *
Function Reference Library
• 74
SmartWORKS PCM
SmartWORKS NGX
API Function
SmartWORKS DP
SmartWORKS DT
SmartWORKS LD
SmartWORKS VR
SmartWORKS PT
SmartWORKS AT
Status Legend: F=Fully supported · O=To Be Obsolete
· P=Pending future release, beta · *= Board Supported
Status
MTGetLVDetectState() F *
MTGetLVDetectValue() F *
MTGetLVParams() F *
MTGetMasterAlarmStatus() F * * * * * * * *
MTGetMixingDetectStatus() - O * * * * * * * *
see MTChInputToneDetectStatus() and
MTChInputACTDStatus()
MTGetMixingStatus() F * * * * * * * *
MTGetMoni() F * * * * * * * *
MTGetNET() F * * * *
MTGetNGXFramerStatistic() F *
MTGetOutput() F * * * * * * * *
MTGetOutputSource() F * * * * * * * *
MTGetPHYStatistics() F *
MTGetPSTNParams() F * * * * * * * *
MTGetPxdParams() F * * * * * * * *
MTGetReverseLoopPolarity() F *
MTGetRingDetectState() F * * *
MTGetSLIC() F *
MTGetStatistics() F * * * * * * * *
MTGetStreamingConfig() F * * * * * * * *
MTGetSummationAVC() F * * *
MTGetSummationGain() F * * *
MTGetSummationInfo() F * * *
MTGetSummationInputs() F * * *
MTGetSummationOutput() F * * *
MTGetSummationVolume() F * * *
MTGetSystemConfig() F * * * * * * * *
MTGetSystemInfo() F * * * * * * * *
Function Reference Library
• 75
SmartWORKS PCM
SmartWORKS NGX
API Function
SmartWORKS DP
SmartWORKS DT
SmartWORKS LD
SmartWORKS VR
SmartWORKS PT
SmartWORKS AT
Status Legend: F=Fully supported · O=To Be Obsolete
· P=Pending future release, beta · *= Board Supported
Status
MTGetT1FramerStatistic() F * *
MTGetTerm() F * * * * * * * *
MTGetTimeSlotRxSignaling() F * * *
MTGetTimeSlotTxSignaling() F * *
MTGetToneDetectParams() - O * * * * * * * *
MTChInputGetToneDetectParams()
MTGetToneGenParams() F * * * * * * * *
MTGetUsrToneParams() P * * * * * * * *
MTGetVersion() F * * * * * * * *
MTHighpassFilterControl() F * * * * * * * *
MTHighpassFilterStatus() F * * * * * * * *
MTLoadSignalProfile() F * * * * * * * *
MTOffHook() F * *
MTOnHook() F * *
MTOpenBoard() F * * * * * * *
MTOpenChannel() F * * * * * * * *
MTPlayBuffer() F * * * * * * * *
MTPlayBufferAsync() F * * * * * * * *
MTPlayBufferEx() F * * * * * * * *
MTPlayDevice() F * * * * * * * *
MTPlayDeviceAsync() F * * * * * * * *
MTPlayDeviceEx() F * * * * * * * *
MTPlayFile() F * * * * * * * *
MTPlayFileAsync() F * * * * * * * *
MTPlayFileEx() F * * * * * * * *
MTPlayIndex() F * * * * * * * *
MTPlayIndexEx() F * * * * * * * *
MTPlayIndexAsync() F * * * * * * * *
MTPlayTone() F * * * * * * * *
Function Reference Library
• 76
SmartWORKS PCM
SmartWORKS NGX
API Function
SmartWORKS DP
SmartWORKS DT
SmartWORKS LD
SmartWORKS VR
SmartWORKS PT
SmartWORKS AT
Status Legend: F=Fully supported · O=To Be Obsolete
· P=Pending future release, beta · *= Board Supported
Status
MTPlayToneAsync() F * * * * * * * *
MTPlayToneEx() F * * * * * * * *
MTPutBoardEvent() F * * * * * * * *
MTPutChannelEvent() F * * * * * * * *
MTReadDigit() F * * * * * * * *
MTReadDTMFTone() F * * * * * * * *
MTReadMFTone() F * * * * * * * *
MTRecBuffer() F * * * * * * * *
MTRecBufferAsync() F * * * * * * * *
MTRecBufferEx() F * * * * * * * *
MTRecDevice() F * * * * * * * *
MTRecDeviceAsync() F * * * * * * * *
MTRecDeviceEx() F * * * * * * * *
MTRecFile() F * * * * * * * *
MTRecFileAsync() F * * * * * * * *
MTRecFileEx() F * * * * * * * *
MTRemoveSummationInput() F * * *
MTResetAJListen() F * * * *
MTResetAJTalk() F * * * *
MTResetBoardStatistics() F * * * * * * * *
MTResetCpmToneParams() P * * * * * * * *
MTResetCTRoute() F * * * * * *
MTResetFramerLoopbackMode() F *
MTResetInputs() F * * * * * * * *
MTResetOutput() F * * * * * * * *
MTResetStatistics() F * * * * * * * *
MTResetSummation() F * * *
MTResyncTime() F * * * * * * * *
Function Reference Library
• 77
SmartWORKS PCM
SmartWORKS NGX
API Function
SmartWORKS DP
SmartWORKS DT
SmartWORKS LD
SmartWORKS VR
SmartWORKS PT
SmartWORKS AT
Status Legend: F=Fully supported · O=To Be Obsolete
· P=Pending future release, beta · *= Board Supported
Status
MTReturnEventBuffer() F * * * *
MTSetAdapterConfig() F * * * * * * * *
MTSetAdapterEEPROMConfig() F * * * * * * * *
MTSetAdapterToDefault() F * * * * * * * *
MTSetAlertToneParams() F * * * * * * * *
MTSetAVC() F * * * * * * * *
MTSetBoardEventCallback() F * * * * * * * *
MTSetChannelToDefault() F * * * * * * * *
MTSetCpmMode() P * * * * * * * *
MTSetCPMSigSwitch() P * * * * * * * *
MTSetCpmToneParams() P * * * * * * * *
MTSetCTMasterClock() F * * * * * * * *
MTSetCTNetrefSource() F * * * * * * * *
MTSetCTRoute() F * * * * * *
MTSetCTSlaveClockMode() F * * * * * * * *
MTSetDeviceIO() F * * * * * * * *
MTSetDTMFDetectParams() - F * * * * * * * *
see MTChInputSetDTMFDetectParams()
MTSetECControl() F * * *
MTSetECParams() F * * *
MTSetECFreezeAdaptation() F * * *
MTSetEventCallback() F * * * * * * * *
MTSetEventFilters() F * * * * * * * *
MTSetFramerLoopbackMode() F *
MTSetFramerOutput() F * * * *
MTSetInputs() F * * * * * * * *
Function Reference Library
• 78
SmartWORKS PCM
SmartWORKS NGX
API Function
SmartWORKS DP
SmartWORKS DT
SmartWORKS LD
SmartWORKS VR
SmartWORKS PT
SmartWORKS AT
Status Legend: F=Fully supported · O=To Be Obsolete
· P=Pending future release, beta · *= Board Supported
Status
MTSetLVParams() F *
MTSetMoni() F * * * * * * * *
MTSetNET() F * * * *
MTSetOutput() F * * * * * * * *
MTSetOutputSource() F * * * * * * * *
MTSetPriorityEventCallback() F * * * * * * * *
MTSetPSTNParams() F * * * * * * * *
MTSetReverseLoopPolarity() F *
MTSetSLIC() F *
MTSetStreamingConfig() F * * * * * * * *
MTSetSummationAVC() F * * *
MTSetSummationGain() F * * *
MTSetSummationVolume() F * * *
MTSetSystemConfig() F * * * * * * * *
MTSetTerm() F * * * * * * * *
MTSetTimeSlotTxSignaling() F *
MTSetToneDetectParams() F * * * * * * * *
MTSetToneGenParams() F * * * * * * * *
MTSetUsrToneParams() P * * * * * * * *
MTSetVolume() F * * * * * * * *
MTStartAlertTone() F * * * * * * * *
MTStartCurrentFunction() F * * * * * * * *
MTStartMUX() F * * * * * * * *
MTStartMUXOnChannel() F * * * * * * * *
MTStartStreaming() F * * * * * * * *
MTStartSummation() F * * *
MTStepVolume() F * * * * * * * *
Function Reference Library
• 79
SmartWORKS PCM
SmartWORKS NGX
API Function
SmartWORKS DP
SmartWORKS DT
SmartWORKS LD
SmartWORKS VR
SmartWORKS PT
SmartWORKS AT
Status Legend: F=Fully supported · O=To Be Obsolete
· P=Pending future release, beta · *= Board Supported
Status
MTStopAlertTone() F * * * * * * * *
MTStopBlinkBoard() F * * * * * * * *
MTStopChannel() F * * * * * * * *
MTStopCurrentFunction() F * * * * * * * *
MTStopMUX() F * * * * * * * *
MTStopMUXOnChannel() F * * * * * * * *
MTStopStreaming() F * * * * * * * *
MTStopSummation() F * * *
MTStreamBufIn() F * * * * * * * *
MTStreamBufOut() F * * * * * * * *
MTStreamBufPause() F * * * * * * * *
MTStreamBufResume() F * * * * * * * *
MTSummationAVCControl() F * * *
MTSummationAVCStatus() F * * *
MTSysClearEventCallback() F * * * * * * * *
MTSysGetVersion() F * * * * * * * *
MTSysSetEventCallback() F * * * * * * * *
MTSysShutdown() F * * * * * * * *
MTSysStartup() F * * * * * * * *
MTSysWaitForEvent() F * * * * * * * *
MTWaitForAdapterEvent() F * * * * * * * *
MTWaitForChannelEvent() F * * * * * * * *
MTWink() F * *
MTWFGetUpdatingStatus F * * * * * * *
MTWFInit() F * * * * * * *
MTWFUninit() F * * * * * * *
MTWFUpdateFirmware F * * * * * * *
Introduction
The following section provides information about some of the controls used by the
SmartWORKS API presented in logical order.
Function Reference Library
• 81
Introduction
MISC. FUNCTIONS
Function Reference Library
• 82
Introduction
MTGetLastErrorA()
Description
MTGetLastErrorA() is a function used to retrieve the last error code
and associated ASCII message in the system. The first parameter
points to the buffer to take the last error code. The second
parameter contains the size of the ASCII string buffer when passed
and the length of the ASCII message when returned. The third
parameter points to the ASCII string buffer to take the actual
message associated with the error code. The retrieved ASCII string is
always null terminated and the length of the returned string
replaces the size of the error message buffer when the API returns.
Prototype
MT_RESULT MTGetLastErrorA (
const PMT_RESULT pExtError,
const PUSHORT nErrBufSize,
const PSTR pErrBuf,
);
Parameters
pExtError Pointer to error code buffer
nErrBufSize Pointer to size of error message
buffer
pErrBuf Pointer to error message buffer
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to function
MT_RET_DATA_TRUNCATED Data copied but truncated; the
buffer size set by the user applica-
tion is not large enough for this API
request
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Scenario
Normally, MTGetLastError() is mapped as MTGetLastErrorA() to
use an ASCII string for displaying messages. The user application
can define UNICODE before including NTIAPI.h to use a unicode
string instead of ASCII.
Function Reference Library
• 83
Introduction
MTGetLastErrorW()
Description
MTGetLastErrorW() is a function that is used to retrieve the last
error code and its associated message occurred in the system. It
works the same as MTGetLastErrorA() except that the error
message is put into UNICODE string format.
Prototype
MT_RESULT GetLastErrorW(
const PMT_RESULT pExtError,
const PUSHORT nErrBufSize,
const PWSTR pErrBuf,
);
Parameters
pExtError Pointer to error code buffer
nErrBufSize Pointer to size of error message buffer
pErrBuf Pointer to error message buffer
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to function
MT_RET_DATA_TRUNCATED Data copied but truncated; the buffer
size set by the user application is not
large enough for this API request
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Scenario
Normally, MTGetLastError() is mapped as MTGetLastErrorA() to
use an ASCII string for displaying messages. The user application
can define UNICODE before including NTIAPI.h to use
MTGetLastErrorW(), the unicode version, instead of ASCII.
Function Reference Library
• 84
Introduction
MTGetReturnCodeDescription()
Description
Retrieves the text description for any return code.
Prototype
voide MTGetReturnCodeDescription (
const MT_RESULT ReturnCode,
const PCHAR pDescription,
const int nLength,
);
Parameters
ReturnCode The value generated for any MT_RET
message. For example 0x0.
pDescription poiner to the NULL terminated
description
nLength length of the description buffer
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to function
Events
None
Function Reference Library
• 85
Introduction
MTGetEventCodeDescription()
Description
Retrieves the text description for any event code.
Prototype
void MTGetEventCodeDescription (
const ULONG EventCode,
const PCHAR pDescription,
const int nLength
);
Parameters
EventCode The hex value generated for any
event code. For example 0x01.
pDescription poiner to the NULL terminated
description
nLength length of the description buffer
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to function
Events
None
Function Reference Library
• 86
Introduction
General Rules:
• All Bus Types - to create a system with multiple Master boards that are not
connected with H.100 and MVIP cables, Bus Segmentation must be enabled.
• MVIP - to allow more than one Master board per system Bus Segmentation
must be enabled using the Control Panel or MTSetAdapterConfig(). If Bus
Segmentation is not enabled, then only one Master board is allowed.
• H.100 - allows up to two Master boards per system without enabling Bus Seg-
mentation. To create a system with more than two Master boards, Bus Seg-
mentation must be enabled using the Control Panel or
MTSetAdapterConfig().
• H.100 - if the system is created with two Master boards and Bus Segmentation
is disabled, then one board must be set as MASTER_A and the other
MASTER_B using MTSetCTMasterClock().
NOTE: When boards are connected with a Bus cable, Ai-Logix does not
recommend enabling Bus segmentation.
A flow diagram, on the following page, outlines the process for setting a board’s
clock source.
Function Reference Library
• 87
Introduction
NOTE: This flow diagram assumes one Master Board per system and system boards are connected with a H.100 or MVIP cable.
MTSetCTMasterClock() MTSetCTMasterClock()
YES Is this a NO
mMaster = MODE_MASTER (MVIP) mMaster = MODE_SLAVE
Master Board?
- or -
MODE_MASTER_A (H.100) Configuration is complete
MTSetCTMasterClock
Clock Source = CLOCK_SOURCE_OSC YES NO
Use the Local
Clock?
Configuration is complete
MTSetCTMasterClock
Clock Source = CLOCK_SOURCE_SEC8K (MVIP) YES Obtain clock NO
- or - from CT Bus?
CLOCK_SOURCE_CT_H100 (H.100)
Configuration is complete
Configuration is complete
Function Reference Library
• 88
Introduction
MTSetCTMasterClock()
Description
MTSetCTMasterClock() changes the master mode and clock
source settings for MVIP/H.100 bus to any of the following:
MASTER_A, MASTER_B, or SLAVE for H100 MASTER or SLAVE for
MVIP
Prototype
MT_RESULT MTSetCTMasterClock (
const BOARD nBoard,
const int BusType,
const int mMaster,
const USHORT ClockSource
);
Parameters
nBoard board index number
BusType MUX_MVIP or MUX_H100
mMaster H.100: MODE_MASTER_A,
MODE_MASTER_B, or MODE_SLAVE
MVIP: MODE_MASTER or MODE_SLAVE
ClockSource clock source for the specified master,
ignored if MODE_SLAVE specified
Possible ClockSource values are:
CLOCK_SOURCE_OSC 1
CLOCK_SOURCE_CT_NETREF 2
MUX_H100
CLOCK_SOURCE_SEC8K 2
MUX_MVIP
CLOCK_SOURCE_CT_H100 3
MUX_H100 only
CLOCK_SOURCE_NET1 4
CLOCK_SOURCE_NET2 5
CLOCK_SOURCE_NET3 6
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Error in function pointer
MT_RET_INVALID_BOARD Board number is out of range
MT_RET_BOARD_NOT_ Board device not opened for access
OPENED
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_BUSTYPE Failure to specify MUX_MVIP or
MUX_H100
Events
None
Function Reference Library
• 89
Introduction
CODE EXAMPLE
MTSetCTMasterClock() Code Example
result = MTSetCTMasterClock(board,bustype,master,clock);
if(result == MT_RET_OK)
{
printf("MTSetCTMasterClock()
successful...\n");
printf("Setting...\nBus type to:
MUX_MVIP\nMaster mode to: MODE_MASTER\nClock source to: NET1\n");
}
A complete code example is available on the Ai-Logix website:
http://www.ai-logix.com/support.html
Function Reference Library
• 90
Introduction
MTGetCTMasterClock()
Description
Retrieves the master mode (Master or Slave for MVIP, MasterA,
MasterB or Slave for H.100) and clock source settings of the MVIP/
H.100 bus
Prototype
MT_RESULT MTGetCTMasterClock(
const BOARD nBoard,
const int BusType ,
const int pMaster,
const USHORT pClockSource
);
Parameters
nBoard board index number
BusType MUX_MVIP or MUX_H100
pMaster buffer for the returned master setting,
MODE_SLAVE, MODE_MASTER_A, or
MODE_MASTER_B
pClockSource buffer for the returned clock source set-
ting
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to function
MT_RET_INVALID_BOARD Board number is out of range
MT_RET_BOARD_NOT_OPENED Board device not opened for access
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_BUSTYPE Failure to specify MUX_MVIP or
MUX_H100
MT_RET_DATA_TRUNCATED Data copied but truncated; the buffer
size set by the user application is not
large enough for this API request
Events
None
Function Reference Library
• 91
Introduction
CODE EXAMPLE
MTGetCTMasterClock() Code Example
result = MTGetCTMasterClock(board,bustype,&master,&clock);
if(result == MT_RET_OK)
{
printf("MTGetCTMasterClock()
successful...\n");
printf("Bus type: MUX_MVIP\n");
printf("Master mode: ");
switch(master) // for MVIP setup only
{
case MODE_SLAVE:
printf("Slave\n");
break;
case MODE_MASTER:
printf("Master\n");
break;
}
printf("Clock source: ");
switch(clock) // for MVIP setup only
{
case CLOCK_SOURCE_OSC:
printf("OSC\n");
break;
case CLOCK_SOURCE_SEC8K:
printf("SEC8K\n");
break;
case CLOCK_SOURCE_NET1:
printf("NET1\n");
break;
case CLOCK_SOURCE_NET2:
printf("NET2\n");
break;
case CLOCK_SOURCE_NET3:
printf("NET3\n");
break;
}
A complete code example is available on the Ai-Logix website:
http://www.ai-logix.com/support.html
Function Reference Library
• 92
Introduction
MTSetCTNetrefSource()
This API was formerly called MTSetSlaveSEC8KClockSource()
Description
Sets the Netref clock source on an H.100 bus or the SEC8K clock
source on an MVIP bus. A board must be in slave mode to use this
API with a CT bus.
Prototype
MT_RESULT MTSetCTNetrefSource (
const BOARD nBoard,
const int BusType,
const USHORT ClockSource
);
Parameters
MTGetCTNetrefSource()
This API was formerly called MTGetSlaveSEC8KClockSource()
Description
MTGetCTNetrefSource() retrieves the Netref clock source setting
(H.100) and SEC8K clock source setting (MVIP).
Prototype
MT_RESULT MTGetCTNetrefSource(
const BOARD nBoard,
const int BusType ,
USHORT * const pClockSource
);
Parameters
nBoard board index number
BusType MUX_MVIP or MUX_H100
pClockSource buffer for the returned NetRef setting
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to function
MT_RET_INVALID_BOARD Board number is out of range
MT_RET_BOARD_NOT_OPENED Board device not opened for access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 95
Introduction
MTSetCTSlaveClockMode()
Description
MTSetCTSlaveClockMode() sets the clock source (Master Clock A
or Master Clock B) of a specified board in H.100 bus mode. It also
enables/disables auto-switching to an alternate clock if the selected
clock is invalid.
Prototype
MT_RESULT MTSetCTSlaveClockMode(
const BOARD nBoard,
const int BusType,
const USHORT Clock,
const BOOLEAN fAutoSwitch
);
Parameters
MTGetCTSlaveClockMode()
Description
MTGetCTSlaveClockMode() retrieves the clock source (from
Master A or Master B) and auto-switching setting of a specified
board in H.100 slave mode.
Prototype
MT_RESULT MTGetCTSlaveClockMode(
const BOARD nBoard,
const int BusType,
PUSHORT const pClock,
BOOLEAN * const pAutoSwitch
);
Parameters
nBoard board index number
BusType MUX_H100, MUX_MVIP
pClock buffer for the returned clock currently
selected
pAutoSwitch buffer for the returned auto-switching
setting
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to function
MT_RET_INVALID_BOARD Board number is out of range
MT_RET_BOARD_NOT_OPENED Board device not opened for access
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_BUSTYPE Invalid bus type was specified
Events
None
Function Reference Library
• 97
Introduction
MTSetNET1(), MTSetNET2()
Obsoleted - Use MTSetNet().
Description
Sets the source of the recovered received clock for the specified
board. The board index is 0 for the first SmartWORKS board within
the platform.
With a SmartWORKS DP, the framer index goes from 0 to 3 for the
four possible framers for each line. On a SmartWORKS NGX, the
framer index goes from 0-7 for the eight possible framers on either
the NGX base card or the MX80 daughter card(s). See the User’s
Guide for more information on each SmartWORKS board.
Prototype
MT_RESULT MTSetNET1(
MT_RESULT MTSetNET2(
const BOARD nBoard,
const USHORT nFramer
);
Parameters
nBoard board index
nFramer framer index (Valid ranges for Smart-
WORKS DP is 0-3, valid ranges for Smart-
WORKS NGX is 0-7-see description
below)
For SmartWORKS DP
MTSetNET1() sets for the specified board the source of the
recovered received clock from
Framer 0 line 1 NE side - incoming (recommended)
Framer 1 line 1 CP side - outgoing
Framer 2 line 2 NE side - incoming
Framer 3 line 2 CP side - outgoing
For SmartWORKS NGX
MTSetNET1() (base card) and MTSetNet2() (daughter card) set the
source of the recovered received clock for the specified board from:
Framer 0 Line 1 of the NGX base or daughter card
Framer 1 Line 2 of the NGX base or daughter card
Framer 2 Line 3 of the NGX base or daughter card
Framer 3 Line 4 of the NGX base or daughter card
Framer 4 Line 5 of the NGX base or daughter card
Framer 5 Line 6 of the NGX base or daughter card
Framer 6 Line 7 of the NGX base or daughter card
Framer 7 Line 8 of the NGX base or daughter card
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to function
MT_RET_INVALID_BOARD Board number is out of range
Function Reference Library
• 98
Introduction
MTGetNET()
Description
Retrieves the source of recovered received clock.
The NET index starts from 1. For SmartWORKS cards, the maximum
NET index is 2; for NGX cards, the maximum NET index is 3.
The framer index starts from 0 to 3 for the four possible framers for
each line. The SmartWORKS DP has four (4) framers, SmartWORKS
DT has two (2) framers, and the SmartWORKS NGX has either
eight(8), sixteen (16) or twenty-four (24) depending on the number
of daughter cards.
For NET index 1, MTSetNET() sets the source of the recovered clock
for the specified board from:
Framer 0 line 1 NE side - incoming (recommended)
Framer 1 line 1 CP side - outgoing
Framer 2 line 2 NE side - incoming
Framer 3 line 2 CP side - outgoing
For NET index 2, MTSetNET() sets the source of the recovered clock
for the specified board from:
Framer 0 line 1 NE side - incoming
Framer 1 line 1 CP side - outgoing
Framer 2 line 2 NE side - incoming (recommended)
Framer 3 line 2 CP side - outgoing
Prototype
MT_RESULT MTGetNET(
const BOARD nBoard,
const USHORT nNET,
USHORT * const pFramer
);
Parameters
nBoard board index
nNET NET index
pFramer pointer to framer index
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Error in board type, or NULL pointer
MT_RET_INVALID_BOARD Board number is out of range
MT_RET_BOARD_NOT_OPENED Board device not opened for access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 100
Introduction
MTSetNET()
Description
Sets the source of recovered received clock.
For SmartWORKS cards, the maximum NET index is 2; for NGX cards,
the maximum NET index is 3.
The framer index starts from 0 to 3 for the four possible framers for
each line. The SmartWORKS DP has four (4) framers, SmartWORKS
DT has two (2) framers, and the SmartWORKS NGX has either
eight(8), sixteen (16) or twenty-four (24) depending on the number
of daughter cards.
The NGX base card is NET1, the daughter cards are NET2 and NET3
respectively. See the User’s Guide for more information on each
SmartWORKS board.
Prototype
MT_RESULT MTSetNET(
const BOARD nBoard,
const USHORT nNET,
const USHORT nFramer
);
Parameters
nBoard board index
nNET NET index
nFramer framer index (Valid ranges for Smart-
WORKS DP is 0-3, SmartWORKS DT is 0-1,
valid ranges for SmartWORKS NGX is 0-7
-see description below)
For SmartWORKS DP
MTSetNET() sets for the specified board the source of the
recovered received clock from:
Framer 0 line 1 NE side - incoming (recommended)
Framer 1 line 1 CP side - outgoing
Framer 2 line 2 NE side - incoming
Framer 3 line 2 CP side - outgoing
For SmartWORKS NGX
MTSetNET() sets the source of the recovered received clock for the
specified board from:
Framer 0 Line 1 of the NGX base or daughter card
Framer 1 Line 2 of the NGX base or daughter card
Framer 2 Line 3 of the NGX base or daughter card
Framer 3 Line 4 of the NGX base or daughter card
Framer 4 Line 5 of the NGX base or daughter card
Function Reference Library
• 101
Introduction
MTArmFramerAlarm()
Description
MTArmFramerAlarm() arms the alarm watch for framer error
reporting, otherwise framer error alarm goes unreported. When
alarmed, an error is only reported once. The application must rearm
the alarm so the next error can be reported.
The board index is 0 for the first SmartWORKS board within the
platform.
The framer index is 0 for the first framer. A framer alarm API
(MTGetFramerAlarmStatus()) specifies which framer is to retrieve
the arm status.
);
Parameters
nBoard board index
nFramer framer index - valid ranges
DP board: 0-3
DT board: 0-1
NGX board: 0-23 (24 channel card)
AlarmEnable framer alarm enable
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Error in board index, board type, or
NULL pointer
MT_RET_INVALID_BOARD Board number is out of range
MT_RET_BOARD_NOT_OPENED Board device not opened for access
MT_RET_CHANNEL_NOT_OPENED This return value only applies to the NGX
where there is one framer per channel.
This is returned to the user if this API is
invoked on a closed channel.
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
EVT_LOS_ALARM
EVT_LOF_ALARM
EVT_AIS_ALARM
EVT_YELLOW_ALARM
EVT_LOSMF_ALARM
EVT_LOCRCMF_ALARM
EVT_TS16RAI_ALARM
See Also MTGetFramerAlarmArmStatus()
Function Reference Library
• 104
Introduction
MTDisarmFramerAlarm()
Description
MTDisarmFramerAlarm() disarms the alarm watch for framer error
reporting. When alarmed, an error is only reported once. The
application must rearm the alarm so the next error can be reported.
The board index is 0 for the first SmartWORKS board within the
platform.
The framer index is 0 for the first framer.
A framer alarm API specifies which framer is to retrieve the arm
status.
MTGetFramerAlarmArmStatus()
Description
Retrieves whether the specified alarm watch is armed.
Prototype
MT_RESULT MTGetFramerAlarmArmStatus(
const BOARD nBoard,
const USHORT nFramer,
const ULONG AlarmEnable,
ULONG * const pAlarmEnable
);
Parameters
nBoard board index
nFramer framer index - valid ranges
DP board: 0-3
DT board: 0-1
NGX board: 0-23 (24 channel card)
AlarmEnable framer alarm enable
pAlarmEnable pointer to framer alarm arm status
buffer
Framer alarm arm status will be
retrieved into the provided buffer in the
bit order as the enable bit defined for
framer alarm enable. Bit with value 1 is
for alarm armed, bit with value 0 is for
alarm not armed.
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Error in board index, board type, or
NULL pointer
MT_RET_INVALID_BOARD Board number is out of range
MT_RET_BOARD_NOT_OPENED Board device not opened for access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
See Also:MTArmFramerAlarm()
Function Reference Library
• 107
Introduction
MTGetFramerAlarmStatus()
Description
Retrieves framer alarms. MTArmFramerAlarm() must be used in
cooperation with this API. Alarms will not be reported unless
MTArmFramerAlarm() has been used the arm the alarm.
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Error in board index, board type, or
NULL pointer
MT_RET_INVALID_BOARD Board number is out of range
MT_RET_BOARD_NOT_OPENED Board device not opened for access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
See Also:MTArmFramerAlarm()
Function Reference Library
• 110
Introduction
MTGetT1FramerStatistic()
Description
Gets error statistics for the specified framer.
In T1 mode, accumulation of bit errors, framing bit errors, OOF and
line code violations is provided for performance monitoring.
The board index is 0 for the first SmartWORKS board within the
platform. The framer index is 0 for the first framer.
Prototype
MT_RESULT MTGetT1FramerStatistic(
const BOARD nBoard,
const USHORT nFramer,
PMT_T1_FRAMER_STAT const pFramerStat,
PULONG const pLength
);
Parameters
nBoard board index
nFramer framer index
pFramerStat pointer to framer statistic buffer
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MT_T1_FRAMER_STAT structure.
Structure
The framer status MT_T1_FRAMER_STAT is defined as follows:
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Error in board index, board type, or
NULL pointer
MT_RET_INVALID_BOARD Board number is out of range
MT_RET_BOARD_NOT_OPENED Board device not opened for access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 112
Introduction
MTGetE1FramerStatistic()
Description
Gets error statistics for the specified framer. In E1 mode,
accumulation of line code errors, frame alignment signal (FAS) bit
errors, far end block error and line code violations is provided for
performance monitoring.
The board index is 0 for the first SmartWORKS board within the
platform.
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Error in board index, board type, or
NULL pointer
MT_RET_INVALID_BOARD Board number is out of range
MT_RET_BOARD_NOT_OPENED Board device not opened for access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 114
Introduction
MTGetNGXFramerStatistic()
Description
Retrieves various network interface statistics that have accumulated
on the specified framer either since the system was started or since
the last call of MTClearFramerStatistic(). The statistics include
cumulative errors on the PBX signal, cumulative errors on the Phone
signal, cumulative count of synchronization loss errors, the
amplitude of the PBX signal in volts, the amplitude of the Phone
signal in volts, the amplitude of the Noise level in volts and the
current clipping status for the selected framer.
Prototype
MT_RESULT MTGetNGXFramerStatistic(
const BOARD nBoard,
const USHORT nFramer,
PMT_NTTE_FRAMER_STAT const pFramerStat,
PULONG pLength
);
Parameters
nBoard Board number
nFramer Framer index (0-23)
pFramerStat Pointer to an MT_NTTE_FRAMER_STAT
structure that will be filled in by the
function
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MT_NTTE_FRAMER_STAT struc-
ture
Structure
MTGetFraming()
Description
Gets a framing format for a specified framer on the specified board.
Prototype
MT_RESULT MTGetFraming (
PMT_FRAMER_STATE const pFraming
);
Parameter
pFraming Parameter pFramer is a pointer to struc-
ture MT_FRAMER_STATE which contains
a field for board index
(MT_FRAMER_STATE.nBoard) and framer
index (MT_FRAMER_STATE.nFramer) on
the specified board.
Structure
The FRAMER_STATE structure is defined as follows:.
UCHAR nBoard Board index. The board index is 0 for the first
SmartWORKS board within the platform
UCHAR nFramer Framer index. The framer index is 0 for the first
framer on board
UCHAR State Framer state:
FRAMER_RESET
FRAMER_T1_PASSIVE FRAMER_T1_TERMINATE
FRAMER_E1_PASSIVE FRAMER_E1_TERMINATE
UCHAR reserved
UCHAR FramingFormat FF_E1_G704 - default
FF_E1_CRC4
FF_E1_UNFRAMED
FF_T1_SF
FF_T1_ESF
FF_T1_UNFRAMED
UCHAR LineCoding LC_AMI - default
LC_E1_HDB3
LC_T1_B8ZS
UCHAR LBO Possible values for MT_FRAMER_STATE.LBO are
defined in the NtiData.h file.
UCHAR ZCS Zero-code suppression:
ZCS_NONE - default
ZCS_GTE
ZCS_DDS
ZCS_BELL
Return Codes
Function Reference Library
• 117
Introduction
MT_RET_OK No error
MT_RET_INVALID_PARAM Error in framing parameter, board index,
board type, or NULL pointer
MT_RET_INVALID_BOARD Board number is out of range
MT_RET_BOARD_NOT_OPENED Board device not opened for access
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_TIMEOUT Wait for event timed out
Function Reference Library
• 118
Introduction
MTClearFramerStatistic()
Description
Clears error statistics for the specified framer.
In T1 mode, accumulation of CRC-6 errors, framing bit errors, OOF
and line code violations is provided for performance monitoring.
In E1 mode, accumulation of CRC-4 errors, frame alignment signal
(FAS) bit errors, far end block error and line code violations is
provided for performance monitoring.
The board index is 0 for the first SmartWORKS board within the
platform. The framer index is 0 for the first framer.
MTSetFramerLoopbackMode()
Description
The MTSetFramerLoopbackMode() function will place the
designated channel in one of several different data loopback
modes. This application is used to test framer operation on any
digital network (ISDN, E1, T1). This function is designed only for
synchronous operation on DT channels.
The desired mode may be selected by passing a valid mode ID in
the LoopbackMode parameter. Valid modes are defined as:
FRAMER_LOOPBACK_NONE - framer is not in loopback mode
FRAMER_NETWORK_LINE_LOOPBACK – Places the framer
associated with the channel in loopback mode between the framer
and the central office. This is useful for testing the digital trunk.
FRAMER_NETWORK_PAYLOAD_LOOPBACK - This is useful for testing
framer clock operation.
The data read out of RX-FIFO is timed to the transmitter clock, and the
transmit frame alignment indication is used to synchronize the output
frame alignment. The transmit frame alignment is arbitrary. Note that
because the transmit and receive streams are not superframe aligned, any
robbed-bit signaling in the receive stream will not fall in the correct frame
once looped back and that transmit robbed-bit signaling will overwrite
the looped back data if signaling insertion is enabled.
FRAMER_SYSTEM_DIGITAL_LOOPBACK – Places the framer
associated with the channel in loopback mode between the framer
and the on-board voice resource. This is useful for testing framer
operation with the board’s DSP resources.
Prototype
MT_RESULT MTSetFramerLoopbackMode(
const BOARD nBoard,
const USHORT nFramer,
const USHORT LoopbackMode
);
Parameters
Events
None
Function Reference Library
• 121
Introduction
MTGetFramerLoopbackMode()
Description
The MTGetFramerLoopbackMode() function retreives the current
framer loopback mode. This function is designed only for synchronous
operation on DT channels.
Valid modes are defined as:
FRAMER_LOOPBACK_NONE - framer is not in loopback mode
FRAMER_NETWORK_LINE_LOOPBACK – Places the framer
associated with the channel in loopback mode between the framer
and the central office. This is useful for testing the digital trunk.
FRAMER_NETWORK_PAYLOAD_LOOPBACK - This is useful for testing
framer clock operation. The data read out of RX-FIFO is timed to the
transmitter clock, and the transmit frame alignment indication is used to
synchronize the output frame alignment. The transmit frame alignment is
arbitrary. Note that because the transmit and receive streams are not
superframe aligned, any robbed-bit signaling in the receive stream will not
fall in the correct frame once looped back and that transmit robbed-bit
signaling will overwrite the looped back data if signaling insertion is
enabled.
FRAMER_SYSTEM_DIGITAL_LOOPBACK – Places the framer
associated with the channel in loopback mode between the framer
and the on-board voice resource. This is useful for testing framer
operation with the board’s DSP resources.
Prototype
MT_RESULT MTGetFramerLoopbackMode(
const BOARD nBoard,
const USHORT nFramer,
const pUSHORT pLoopbackMode
);
Parameters
MTResetFramerLoopbackMode()
Description
The MTResetFramerLoopbackMode() function disables loopback
mode on the designated framer (FRAMER_LOOPBACK_NONE). Data
already on the Encode and Decode queues will not be flushed by
this function. This function is designed only for synchronous
operation on DT channels.
Prototype
MT_RESULT MTResetFramerLoopbackMode(
const BOARD nBoard,
const USHORT nFramer
);
Parameters
MTEnableFramerABCDSignalingEvent()
Description
This function controls ABCD signaling change through events
EVT_INCOMING_SIGCHANGE and EVT_OUTGOING_SIGCHANGE.
The actual ABCD bits are kept in the MT_EVENT.SubReason field.
The actual timeslot where the signaling change occurred is kept in
the MT_EVENT.XtraInfo field.
Signaling bits A, B, C, & D are contained as bits 3, 2, 1, and 0
respectively. When T1 with SF framing mode is selected only two
bits are used, therefore bits A=C and bits B=D.
ABCD signaling change reporting is disabled by default.
Prototype
MT_RESULT MTEnableFramerABCDSignalingEvent(
const BOARD nboard,
const USHORT nframer
);
Parameters
nboard board index: 0 for first board
nframer framer index: 0-3 for the DP, and 0-1 for
the DT.
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Framer index error
MT_RET_INVALID_BOARD invalid board type
MT_RET_BOARD_NOT_OPENED Board device not opened for access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
EVT_INCOMING_SIGCHANGE
EVT_OUTGOING_SIGCHANGE
Scenario
ABCD signaling events are reported as CHANNEL events. Use
MTWaitForChannelEvent() or MTSetEventCallback() to retrieve
ABCD signaling events after an ABCD signaling change is reported.
See Also: MTWaitForChannelEvent(), MTSetEventCallback()
Function Reference Library
• 124
Introduction
CODE EXAMPLE
MTEnableFramerABCDSignalingEvent()
handleMT(MTSetEventCallback(channel,(MTCALLBACK)ChannelEventCallBack,0),"MTSet
EventCallback() channel %d",channel);
if(handleMT(MTEnableFramerABCDSignalingEvent(board,framer),"MTEnableFramerABCD
SignalingEvent() board %d, framer %d",board,framer))
{
wait = true;
while(wait)
Sleep(20);
}
handleMT(MTClearEventCallback(channel),"MTClearEventCallback() channel
%d",channel);
handleMT(MTSysShutdown(),"MTSysShutdown()");
MTDisableFramerABCDSignalingEvent()
Description
Disables the queuing and reporting of ABCD signaling changes.
ABCD signaling change reporting is disabled by default.
Prototype
MT_RESULT MTDisableFramerABCDSignalingEvent(
const BOARD nBoard,
const USHORT nframer
);
Parameters
nBoard board index: 0 for first board
nframer framer index: 0-3 for the DP, and 0-1 for
the DT
Return Codes
MT_RET_OK No Error
MT_RET_INVALID_PARAM Board index or framer index error
MT_RET_INVALID_BOARD Invalid board type
MT_RET_BOARD_NOT_OPENED Board device not opened for access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 126
Introduction
MTGetFramerABCDSignalingEventStatus()
Description
Retrieves the status of the queuing and reporting of ABCD signaling
changes.
Prototype
MT_RESULT MTGetFramerABCDSignalingEventStatus (
const BOARD nBoard,
const USHORT nFramer,
PUSHORT const fEnabled
);
Parameters
nBoard board index: 0 for first board, -1 for all
boards
nFramer framer index: 0-3 for the DP and 0-1 for
the DT
fEnabled status flag: 1=enabled, 0=disabled
Return Codes
MT_RET_OK No Error
MT_RET_INVALID_PARAM Board index or framer index error
MT_RET_INVALID_BOARD Invalid board type
MT_RET_BOARD_NOT_OPENED Board device not opened for access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None.
Function Reference Library
• 127
Introduction
MTGetTimeSlotRxSignaling()
Description
MTGetTimeSlotRxSignaling() retrieves the current ABCD
signaling information on the specified time slot on the specified
framer of the specified board.
The board index is 0 for the first SmartWORKS board within the
platform. The framer index is 0 for the first framer.
Prototype
MT_RESULT MTGetTimeSlotRxSignaling() (
const BOARD nBoard,
const USHORT nFramer,
const ULONG nTimeSlot,
PMT_TS_SIGNALING const pSignaling
);
Parameters
nBoard board index
nFramer framer index from 0 to 3 for the DP, and
0-1 for the DT
nTimeSlot time slot index from 1 to 24 (T1) or 1 to
30 (E1)
pSignaling pointer to MT_TS_SIGNALING structure
Structure
Structure MT_TS_SIGNALING is defined as follows:
MT_TS_SIGNALING
Type Name Purpose
UCHAR Framer Framer index
UCHAR TimeSlot Time slot index
UCHAR Signal Signaling bits:
ABCD bits:
0x01 - D bit
0x02 - C bit
0x04 - B bit
0x08 - A bit
NOTE: In T1/SF
framer mode, bits
A=C and bits B=D
//UCHAR PrevSignal* Previous signaling
//ULONG ElapsedTime* Duration (in 10ms unit)
between Signal and Pre-
vSignal
*The data in the fields PrevSignal and Elapsed Time are not passed into this structure.
Instead, the information is passed into the MT_EVENT structure when the events
Function Reference Library
• 128
Introduction
CODE EXAMPLE
Code Example MTGetTimeslotRxSignaling()
ZeroMemory(&signaling,size);
if(handleMT(MTGetTimeSlotRxSignaling(board,frame,slot,&signaling),"MTGetTimeSl
otRxSignaling() board %d, frame %d, slot %d",board,frame,slot))
{
UCHAR frameNo = signaling.Framer;
UCHAR slotNo = signaling.TimeSlot;
UCHAR signal = signaling.Signal;
cout << "Frame = " << (INT)frameNo << endl
<< "Time slot = " << (INT)slotNo << endl
<< "Signal = " << (INT)signal << endl <<
endl;
}
handleMT(MTSysShutdown(),"MTSysShutdown()");
MTSetTimeSlotTxSignaling()
This API is used with terminate boards only
Description
Sets the transmit signaling information on the specified time slot
MTSetTimeSlotRxSignaling() sets the transmit ABCD signaling
information on a specified time slot on a specified framer of a
board.
The board index is 0 for the first NTI board within the platform. The
framer index is 0 for the first framer. The time slot index is 1 for the
first T1 time slot, 0 for the first E1 time slot.
Signal bits for the T1 robbed bit signaling are defined as:
0x01 D bit
0x02 C bit
0x04 B bit
0x08 A bit
NOTE: In T1 mode with ESF selected, all four bits are transmitted.
Valid signal values range from 0x0 to 0xF. In T1 mode with SF (D4)
selected, A is the same as C and B is the same as D.
There are only four valid signal values: 0x0, 0x5, 0xA and 0xF.
Prototype
MT_RESULT MTSetTimeSlotTxSignaling (
const BOARD nBoard,
const USHORT nFramer,
const ULONG nTimeslot,
const USHORT Signaling
);
Parameters
nBoard board index
nFramer framer index: 0 to 1 for DT and 0-3 for
the DP
nTimeslot time slot index: 1 to 24 for T1, 0 to 30 for
E1(0 and 16 are reserved)
Signaling the signal to transmit
Return codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Bad index or pointer
MT_RET_API_THREAD_PROTECTED Another thread is currently accessing
this API
MT_RET_NOT_AVAILABLE Driver is not loaded
Function Reference Library
• 130
Introduction
Events
None
CODE EXAMPLE
Code Example MTSetTimeslotTxSignaling()
ZeroMemory(&signaling,size);
if(handleMT(MTGetTimeSlotTxSignaling(board,frame,slot,&signaling),"MTGetTimeSl
otTxSignaling() board %d, frame %d, slot %d",board,frame,slot))
{
UCHAR frameNo = signaling.Framer;
UCHAR slotNo = signaling.TimeSlot;
UCHAR signal = signaling.Signal;
cout << "Frame = " << (INT)frameNo << endl
<< "Time slot = " << (INT)slotNo << endl
<< "Signal = " << (INT)signal << endl <<
endl;
}
MTGetTimeSlotTxSignaling()
This API is used with terminate boards only
Description
MTGetTimeSlotTxSignaling() retrieves the current transmit ABCD
signaling information on the specified time slot on the specified
framer of the specified board. Board index is 0 for the first NTI board
within the platform. Framer index is 0 for the first framer. Time slot
index is 1 for the first T1 time slot, 0 for the first E1 time slot.
Prototype
MT_RESULT MTGetTimeSlotTxSignaling(
const BOARD nBoard,
const USHORT nFramer,
const ULONG nTimeslot,
PMT_TS_SIGNALING const pSignaling
);
Parameters
nBoard board index
nFramer framer index: 0 to 3 for DP, 0 to 1 for DT
nTimeslot time slot index: 1 to 24 for T1, 1 to 30 for
E1
pSignaling pointer to signaling structure
Structure
Structure MT_TS_SIGNALING is defined as follows :
MT_TS_SIGNALING
Type Name Purpose
UCHAR Framer Framer index
UCHAR TimeSlot Time slot index
UCHAR Signal Signaling bits:
ABCD bits:
0x01 - D bit
0x02 - C bit
0x04 - B bit
0x08 - A bit
NOTE: In T1/SF fram-
ing mode, bits A=C
and bits B=D
UCHAR PrevSignal Previous signaling
ULONG ElapsedTime Duration (in 10ms unit)
between Signal and Pre-
vSignal
Function Reference Library
• 132
Introduction
MTGetAJMap()
Description
MTGetAJMap() locates the specified audio jack and returns the
index of the board that the audio jack resides on.
Prototype
MT_RESULT MTGetAJMap(
const int iAudioJack,
PBOARD const pBoard
);
Parameters
iAudioJack audio jack index 0-15, : 0 for the first
audio jack
pBoard Address to take the returned board
index
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Bad audio jack index or PBOARD pointer
MT_RET_BUSY On channel busy
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 134
Introduction
MTAJTalk()
Description
MTAJTalk() sets the audio jack to transmit its output to the
specified CT stream and time slot. In MVIP mode, selecting a
forward direction uses the first eight (8) MVIP streams for the 256
MVIP time slots. Selecting a reverse direction uses the second eight
(8) MVIP streams for the 256 MVIP time slots. The MVIP time slot
index is from 0 to 255.
Scenario
The audio jack can talk or listen on either forward or reversed MVIP
streams. The VR and PT channels talk on reversed MVIP streams and
listen on forward MVIP streams.
For example, for a channel to receive input from an audio jack
through MVIP time slot 5, the following is advised:
1)Set a route for the channel to listen on MVIP time slot 5
2)Set the audio jack to talk on MVIP time slot 5 with a forward
direction
Prototype
MT_RESULT MTAJTalk (
const int iAudioJack,
const int iStream,
const int iSlot
);
Parameters
iAudioJack audio jack index 0-15, 0 for the first
audio jack
iStream Index of TDM stream, stream direction:
under MVIP: 0-7 for forward, 8-15 for
reverse. Under H.100: 0 - 31
iSlot index of TDM slot on a stream; MVIP
time slot: 0 to 31, H.100: see description
of MTAJListen
Return Codes
MT_RET_OK No error
MT_RET_MUX_OFF Multiplexer system was not
started
MT_RET_BOARD_NOT_OPENED Board device not opened
for access
MT_RET_INVALID_PARAM One bad index, direction, or
time slot parameters
MT_RET_BUSY CT stream and time slot
taken
MT_RET_INVALID_CHANNEL Audio jack index is out of
range
MT_RET_NOT_AVAILABLE Driver is not loaded
Function Reference Library
• 135
Introduction
Events
None
Function Reference Library
• 136
Introduction
MTAJListen()
Description
MTAJListen() sets the audio jack to receive its input from the
specified CT bus time slot. When the CT bus type is MVIP, the first
eight (8) MVIP streams (0 - 7) are on the forward direction which
uses 256 time slots. The next eight (8) streams (8 - 15) are on the
reverse direction which also use 256 time slots. The MVIP time slot
index is from 0 to 255.
If the CT bus type is H.100, the number of timeslots available per
streams 0 - 15 depends on which H.100 stream speed is selected in
the SmartControl panel.
At 2048 KHz, 32 timeslots per stream are available.
At 4096 KHz, 64 timeslots per stream are available.
At 8192 KHz, 128 timeslots per stream are available.
Scenario
The audio jack can talk or listen on either forward or reversed MVIP
streams. VR and PT channels talk on reversed MVIP streams and
listen on forward MVIP streams.
For example, in order for a channel to transmit its output to an
audio jack through MVIP time slot 5, the following is advised:
1)Set a route for the channel to talk on MVIP time slot 5
2)Set the audio jack to listen on MVIP time slot 5 with a reverse
direction
Prototype
MT_RESULT MTAJListen(
const int iAudioJack,
const int iStream,
const int iSlot
);
Parameters
iAudioJack audio jack index 0-15, 0 for the first
audio jackIndex
iStream from code: Index of TDM stream: 0 - 15
for MVIP, 0 - 31 for H.100
iSlot from code: Index of TDM slot per stream:
0 - 31 for MVIP, H.100: see description
above
Function Reference Library
• 137
Introduction
Function Reference Library
• 138
Introduction
Return Codes
MT_RET_OK No error
MT_RET_MUX_OFF Multiplexer system was not
started
MT_RET_BOARD_NOT_OPENED Board device not opened
for access
MT_RET_INVALID_PARAM One bad index, direction,
or time slot parameters
MT_RET_BUSY CT stream and time slot
taken
MT_RET_INVALID_CHANNEL Audio jack index is out of
range
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 139
Introduction
MTGetAJTalk()
Description
MTGetAJTalk() retrieves the time slot information which a
specified audio jack is transmitting onto.
The returned direction code may have the following values:
0 forward direction
1 reverse direction
-1 not connected
The returned time slot index may have the following values:
0 to 255 connected time slot index
-1 not connected
Prototype
MT_RESULT MTGetAJTalk(
const int iAudioJack,
int * const pStream,
int * const pSlot
);
Parameters
iAudioJack audio jack index: 0 for the first audio jack
pStream Address for TDM stream index: 0 - 15 for
MVIP, -1 for not connected
pSlot Address for TDM slot index: 0 - 31 for
MVIP, -1 for not connected
Return Codes
MT_RET_OK No error
MT_RET_MUX_OFF Multiplexer system was
not started
MT_RET_BOARD_NOT_OPENED Board device not opened
for access
MT_RET_INVALID_PARAM One bad index, direction,
or time slot parameters
MT_RET_BUSY On channel busy
MT_RET_INVALID_CHANNEL Channel number is out of
range
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 140
Introduction
MTGetAJListen()
Description
MTGetAJListen() retrieves the time slot information from which
the specified audio jack is receiving.
The returned time slot index may have the following values:
0 - 31 time slot index when MVIP is selected
0 - 127 time slot index when H.100 is selected
-1 not connected
Prototype
MT_RESULT MTGetAJListen(
const int iAudioJack,
int * const pStream,
int * const pSlot
);
Parameters
iAudioJack audio jack index: 0 for the first audio jack
pStream Address for TDM stream index: 0 - 15 for
MVIP, -1 for not connected
pSlot Address for TDM slot index: 0 - 31 for
MVIP, -1 for not connected
Return Codes
MT_RET_OK No error
MT_RET_MUX_OFF Multiplexer system was not
started
MT_RET_BOARD_NOT_OPENED Board device not opened
for access
MT_RET_INVALID_PARAM One bad index, direction,
or time slot parameters
MT_RET_BUSY On channel busy
MT_RET_INVALID_CHANNEL Channel number is out of
range
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 141
Introduction
MTResetAJTalk()
Description
MTResetAJTalk() clears the previously set talk, if any, on the
specified audio jack.
Prototype
MT_RESULT MTResetAJTalk(
const int iAudioJack
);
Parameters
iAudioJack audio jack index 0-15: 0 for the first
audio jack
Return Codes
MT_RET_OK No error
MT_RET_MUX_OFF Multiplexer system was not
started
MT_RET_BOARD_NOT_OPENED Board device not opened
for access
MT_RET_INVALID_PARAM On bad index
MT_RET_BUSY On channel busy
MT_RET_INVALID_CHANNEL Channel number is out of
range
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 142
Introduction
MTResetAJListen()
Description
MTResetAJListen() clears the previously set LISTEN, if any, on the
audio jack.
Prototype
MT_RESULT MTResetAJListen(
const int iAudioJack
);
Parameters
iAudioJack audio jack index: 0 for the first audio
jack
Return Codes
MT_RET_OK No error
MT_RET_MUX_OFF Multiplexer system was not
started
MT_RET_BOARD_NOT_OPENED Board device not opened
for access
MT_RET_INVALID_PARAM Bad index, direction pointer,
or time slot pointer
MT_RET_BUSY On channel busy
MT_RET_INVALID_CHANNEL Channel number is out of
range
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 143
Introduction
MTGetAdapterInfo()
This API was previously called MTGetBoardInfo()
Description
MTGetAdapterInfo() fills the MTADAPTER_INFO structure with
information about the specified board. NOTE: SmartWORKS boards
are indexed beginning with 0. The total number of boards in the
system can be retrieved through MTGetSystemInfo() function.
This function can be called for both local and external boards. The
board numbers for global boards can be calculated similarly to the
calculation of global channels:
For external boards, only the channels parameter will contain valid
information.
Prototype
MT_RESULT MTGetAdapterInfo (
const BOARD nboard,
PMTADAPTER_INFO const pBoardInfo,
PULONG const pLength
);
Parameters
nboard board number
pBoardInfo pointer to MTADAPTER_INFO structure
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MTADAPTER_INFO structure.
Structure
The MTADAPTER_INFO structure is defined as follows:
ULONG Status The status of the board. To retreive a ASCII description of the board
status use MTGetAdapterStatusDescription().
ULONG BoardNumber Board index number with 0 for the first board
MT_VERSION FWVersion This is the DSP on-board firmware version. See “MT_VERSION” on
page 94 for the definition of version information
ULONG BaseAddress I/O base address
ULONG Interrupt Interrupt number
ULONG StartChannel Logical number of the first on board channel
ULONG Channels Number of channels on the board
Function Reference Library
• 145
Introduction
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to function
MT_RET_INVALID_BOARD Board number is out of range
Function Reference Library
• 146
Introduction
CODE EXAMPLE
MTGetAdapterInfo() Code Example
ZeroMemory(&adapterinfo,size);
result =
MTGetAdapterInfo(board,&adapterinfo,&size);
if(result == MT_RET_OK)
{
printf("MTGetAdapterInfo()
successful...\n");
ULONG boardNo = adapterinfo.BoardNumber;
ULONG status = adapterinfo.Status;
MT_VERSION version = adapterinfo.FWVersion;
printf("Board: %u\nFirmware: %d.%d.%d Build
%d %c
%c\n",boardNo,version.Major,version.Minor,version.Internal,version.Build,versi
on.Release,version.Feature);
printf("Status: ");
switch(status)
{
A complete code example is available on the Ai-Logix website:
http://www.ai-logix.com/support.html
MTGetAdapterStatusDescription()
Description
MTGetAdapterStatusDesciption() retrieves the text description
that can be used to explain the value returned by the
MTADAPTER_INFO.Status field.
Prototype
MT_RESULT MTGetAdapterInfo (
const ULONG StatusCode,
const PCHAR pDescription,
const int nLength
);
Parameters
StatusCode status code passed into the
MTADAPTER_INFO.Status field. For
example: 0x05.
pDescription pointer for the NULL terminated descrip-
tion
nLength length of the description buffer
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to function
Events
None
Function Reference Library
• 148
Introduction
MTGetAdapterXInfo()
Description
MTADAPTER_INFO contains general information whereas
MTADAPTER_XINFO contains information for protocol/variant
settings for digital cards (DP/DT).
The user application must have the ownership of the specified
board.
Prototype
MT_RESULT MTGetAdapterXInfo(
const BOARD nBoard,
PMTBOARD_XINFO const pBoardXInfo,
PULONG const pLength
);
Parameters
nBoard board index, 0 for the 1st board
pBoardXInfo pointer to the PMT_BOARD_XINFO
structure
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MTADAPTER_XINFO structure.
Structure
Return Codes
MT_RET_OK No error
MT_RET_DATA_TRUNCATED Data copied but truncated; the buffer
size set by the user application is not
large enough for this API request
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 150
Introduction
MTGetBoardOEMInfo()
The API was formerly called MTGetOEMInfo()
Description
MTGetBoardOEMInfo() returns the MTOEM_INFO structure with
specific OEM information about each board. The contents of the
structure are dependent on the OEM.
Prototype
MT_RESULT MTGetBoardOEMInfo (
const BOARD nboard,
PMTOEM_INFO const pOem_info (PMTOEM_INFO),
PULONG const pLength
);
Parameters
nboard board number
pOem_info pointer to the MTOEM_INFO structure
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MTOEM_INFO structure.
Structure
The MTOEM_INFO is defined as the following:
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to function
MT_RET_INVALID_BOARD Board number is out of range
MT_RET_DATA_TRUNCATED Data copied but truncated; the buffer
size set by the user application is not
large enough for this API request
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 151
Introduction
CODE EXAMPLE
MTGetBoardOEMInfo() Code Example
ZeroMemory(&oeminfo,size);
result =
MTGetBoardOEMInfo(board,&oeminfo,&size);
if(result == MT_RET_OK)
{
printf("MTGetBoardOEMInfo()
successful...\n");
CHAR *oemInfo = oeminfo.OEMInfo;
CHAR *copyRight = oeminfo.Copyright;
printf("OEM Info: %s\nCopyright:
%s\n",oemInfo,copyRight);
}
A complete code example is available on the Ai-Logix website:
http://www.ai-logix.com/support.html
MTGetBoardAssemblyInfo()
This API was formerly called MTGetBoardSerialInfo()
Description
MTGetBoardAssemblyInfo() is used to retrieve the serial
information that resides on the board's EEPROM. The application
may read but not alter this information.
Prototype
MT_RESULT MTGetBoardAssemblyInfo(
const BOARD nBoard,
PSERIAL_INFO const pBoard_SerialInfo,
PULONG const pLength
);
Parameters
nBoard board number
pBoard_SerialInfo pointer to SERIAL_INFO structure
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the SERIAL_INFO structure.
Structure
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to function
MT_RET_INVALID_BOARD Board number is out of range
MT_RET_DATA_TRUNCATED Data copied but truncated; the buffer
size set by the user application is not
large enough for this API request
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 153
Introduction
CODE EXAMPLE
MTGetBoardAssemblyInfo() Code Example
ZeroMemory(&serialinfo,size);
result =
MTGetBoardAssemblyInfo(board,&serialinfo,&size);
if(result == MT_RET_OK)
{
printf("MTGetBoardAssemblyInfo()
successful...\n");
CHAR *assemblyNo =
serialinfo.AssemblyNumber;
CHAR *hwRev = serialinfo.HWRevision;
CHAR *serialNo = serialinfo.SerialNumber;
CHAR *assemblyCode =
serialinfo.AssemblyCode;
CHAR *dateCode = serialinfo.DateCode;
printf("Assembly No.: %s\nHardware revision:
%s\nSerial No.: %s\nAssembly code: %s\nDate Code:
%s\n",assemblyNo,hwRev,serialNo,assemblyCode,dateCode);
}
A complete code example is available on the Ai-Logix website:
http://www.ai-logix.com/support.html
MTBlinkBoard()
Description
MTBlinkBoard() causes CR17 LED on the specified board to blink
its board index plus one 10 times so that the user can match a
physical board with its board number. There is a 2 second delay
between each blinking of the index plus one.
For board 0, MTBlinkBoard() causes the CR-17 to blink once for 10
times, with a 2 second delay between each blink. For board 1,
MTBlinkBoard() causes the CR17 to blink twice for 10 times.
Prototype
MT_RESULT MTBlinkBoard (
const BOARD nboard
);
Parameters
nboard board number
Return Codes
MT_RET_OK No error
MT_RET_INVALID_BOARD Board number is out of
range
MT_RET_BOARD_NOT_OPENED Board device not opened
for access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
CODE EXAMPLE
MTBlinkBoard() Code Example
result = MTBlinkBoard(board);
if(result == MT_RET_OK)
{
printf("MTBlinkBoard() successful...\n");
printf("CR17 LED on board %d will blink %02d
time(s)\n",board,board + 1);
}
A complete code example is available on the Ai-Logix website:
http://www.ai-logix.com/support.html
Function Reference Library
• 155
Introduction
MTStopBlinkBoard()
Description
MTBlinkBoard() causes CR17 LED on the specified board to blink
its board index plus one 10 times so that the user can match a
physical board with its board number. There is a 2 second delay
between each blinking of the index plus one.
For board 0, MTBlinkBoard() causes the CR-17 to blink once for 10
times, with a 2 second delay between each blink. For board 1,
MTBlinkBoard() causes the CR17 to blink twice for 10 times.
Prototype
MT_RESULT MTStopBlinkBoard (
const BOARD nboard
);
Parameters
nboard board number
Return Code
MT_RET_OK No error
MT_RET_INVALID_BOARD Board number is out of
range
MT_RET_BOARD_NOT_OPENED Board device not opened
for access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 156
Introduction
MTOpenBoard()
Description
MTOpenBoard() opens the specified board for access. The
channels will remain closed. This supports up to 64 applications per
board.
ITo open all boards and channels use the function MTSysStartup().
Prototype
MT_RESULT MTOpenBoard(
const BOARD nboard
);
Parameters
nboard board number
Return Codes
MT_RET_OK No error
MT_RET_NOT_STARTED On failure (most likely due to the
resource having been already grabbed
by another application)
MT_RET_INVALID_BOARD Board number is out of range
MT_RET_MALFUNCTION Hardware failed during initialization
MT_RET_BOARD_INUSE On failure (most likely due to the
resource having been already grabbed
by another application)
MT_RET_DEVICE_NOTFOUND Voice interface device was not found
MT_RET_INTERNAL_ERROR Internal error in DLL
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
See Also:MTSysStartup()
Function Reference Library
• 157
Introduction
MTCloseBoard()
Description
MTCloseBoard() closes the specified board for further access.
Should the user application need to release all resources (boards,
channels, TDM timeslots, etc.), it is suggested to do so with
MTSysShutdown(). Calling of this function is not necessary unless
only a specified board is to be closed.
Prototype
MT_RESULT MTCloseBoard(
const BOARD nboard
);
Parameters
nboard board number
Return Codes
MT_RET_OK No error
MT_RET_NOT_STARTED On failure (most likely due
to the resource having been
already grabbed by another application)
MT_RET_INVALID_BOARD Board number is out of
range
MT_RET_BOARD_NOT_OPENED Board device not opened
for access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
See Also:MTSysShutdown()
Function Reference Library
• 158
Introduction
MTGetBoardOpenStatus()
Description
This API returns the ownership of the specified board. A board
needs to be opened before any access or control can be performed
on it by the application.
Scenario
A board can only be opened by one application at one time. When a
board is opened and held by one application, attempting to open
the same board will fail.However, APIs such as
MTGetAdapterInfo(), MTGetBoardOEMInfo(),
MTGetBoardAssemblyInfo() still return board information
regardless of the board open/close ownership.
Prototype
MT_RESULT MTGetBoardOpenStatus(
const BOARD nboard,
BOOLEAN * const pOpen
);
Parameters
nboard Board Index starting with 0
pOpen Pointer to the open status
Return Codes
MT_RET_OK No error
MT_RET_INVALID_BOARD Board number is out of range
MT_RET_INVALID_PARAM Invalid argument passed to function
Possible values returned inside *PBOOL-
EAN:
TRUE-Board is opened, i.e. owned by the
caller application
FALSE-Board is not opened by the caller
application
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
See Also: MTGetChannelOpenStatus()
Function Reference Library
• 159
Introduction
MTSetAdapterToDefault()
Description
MTSetAdapterToDefault() returns the board to default settings.
Prototype
MT_RESULT MTSetAdapterToDefault (
const BOARD nBoard
);
Parameters
nBoard board number
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to function
Events
None
Function Reference Library
• 160
Introduction
CALL PROCESSING
This section describes how the SmartWORKS Call Control API allows an application
developer to manage setup and tear down of incoming and outgoing calls. Dialog
between user applications and the SmartWORKS API is handled by
request/confirmation/indication/response exchanges as follows:
The user application issues a request and receives confirmation to its request as an
event. The SmartWORKS API issues indications as events and the application
responds. The diagram below shows this dialog:
Call Processing
User Application
SmartWORKS
INCOMING CALLS
The diagram below illustrates a typical incoming call accepted by the user's
application:
1 · Through the polling or callback mechanism, the application receives the event
EVT_CC_CONNECT_IND
2 · The application processes the information carried by this event (Sending
Complete, Called Party Number, Calling Party Number, etc.)
a When using ISDN: once this event is received, the application accepts
the call by calling the API MTCC_ConnectResp().
b When using RBS: when the SendingComplete field is set, this means
that all the called party information is provided. The application then
accepts the call by calling the API function MTCC_ConnectResp(). NOTE: If
the SendingComplete field is 0, this means that the called party number
information is not complete yet. The application must wait for the event
EVT_CC_INFO_IND to get this information and then accepts the call by
calling the API function MTCC_ConnectResp().
3 · When the call is connected point to point, the application receives the event
EVT_CC_CONNECT_CONF.
Incoming Calls
User Application SmartWORKS
EVT_CC_CONNECT_IND
(SendingComplete=0)
EVT_CC_INFO_IND
MTCC_ConnectResp()
OUTGOING CALL
The diagram below illustrates the Call Control exchange for a typical outgoing call
originated by the SmartWORKS application:
1 · The application formats a MT_CC_CONNECT_REQ structure and calls the API
function MTCC_ConnectReq().
2 · Through the polling or callback mechanism, the application receives the event
EVT_CC_PROGRESS_IND to indicate that the call is in progress (depending on
which signaling protocol is in use.)
3 · The application receives the event EVT_CC_ALERT_IND to indicate that the
remote side is being alerted (depending on which signaling protocol is in use.)
4 · When the remote side accepts the call, the application receives the event
EVT_CC_CONNECT_CONF to indicate that the call is connected end to end.
Outgoing Calls
User Application SmartWORKS
MTCC_ConnectRequest()
EVT_CC_PROGRESS_IND
EVT_CC_ALERT_IND
Screening Options
Presentation Options
0x10 MT_CC_PRES_RESTRICTED The local switch states that the calling number is
restricted
0x20 MT_CC_NB_NOT_AVAILABLE The local switch states that the calling number is
not available
Function Reference Library
• 165
Introduction
tEVT_CC_DISC_CONF
Call Abandoned
User Application
EVT_CALL_ABANDONED
SETUP
CALL PROCEEDING
ALERTING
DISCONNECT
CPE
CO
RELEASE
SmartWORKS
Call Connected
User Application
EVT_CALL_CONNECTED
SETUP
CALL PROCEEDING
ALERTING
CONNECT
CPE
CO
CONNECT ACK
SmartWORKS
Function Reference Library
• 167
Introduction
Call Held
User Application
EVT_CALL_HELD
HOLD
HOLD ACK
CPE
CO
SmartWORKS
Call Rejected
User Application
EVT_CALL_REJECTED
SETUP
CALL PROCEEDING
ALERTING
DISCONNECT
CPE
CO
RELEASE
SmartWORKS
Call Released
User Application
EVT_CALL_RELEASED
CALL PROCEEDING
RELEASE
CPE
RELEASE COMP
CO
SmartWORKS
Function Reference Library
• 168
Introduction
Call Resumed
User Application
EVT_CALL_RESUMED
RESUME
RESUME ACK
CPE
CO
SmartWORKS
Call Retrieved
User Application
EVT_CALL_RETRIEVED
RETRIEVE
RETRIEVE ACK
CPE
SmartWORKS
CO
Call Suspended
User Application
EVT_CALL_SUSPENDED
SUSPEND
SUSPEND ACK
CPE
CO
SmartWORKS
Function Reference Library
• 169
Introduction
ISDN STANDARDS
TERMINATE CALL CONTROL. - SmartWORKS DT
ISDN PRI variants:
• NI-2 (North America)
• AT&T 5ESS (North America)
• Nortel DMS100 (North America)
• Euro-ISDN (Europe & Rest of the World)
• NTT Japan
• Austel 1 (Australia)
• QSIG (North America)
T1 RBS variants:
• E&M immediate
• E&M Wink
• Loop Start FXS
• Loop Start FXO
PASSIVE CALL CONTROL - SmartWORKS DP
• All ISDN protocols are supported.
NOTE: The SmartWORKS NGX only supports the passive tapping of ISDN
BRI.
The supplementary services are provided through the following API structures:
• CC_FACILITY_REQ
• CC_FACILITY_CONF
• CC_FACILITY_IND
• CC_CONNECT_REQ
Function Reference Library
• 170
Introduction
NOTE:
The support of Supplementary services depends on ISDN variants
• Call Hold / Call Retrieve (valid for US variants only)
• Recall (valid for ETSI variant only)
Outgoing Calls
In the Loop Start FXS variant, the protocol doesn't provide any information
indicating that the called party has accepted the call. When the called party digits
have been dialed, the RBS stack starts a 10 second timer. After 10 seconds expires,
the RBS stack notifies the application that the call is connected via the
EVT_CC_CONNECT_CONF event.
Function Reference Library
• 173
Introduction
E&M Immediate
Call Control RBS Stack RBS Stack Call Control
EVT_CC_PROGRESS_IND
DTMF Digits EVT_CC_INFO_IND
User Application
User Application
EVT_CC_CONNECT_CONF Off hook MTCC_ConnectResp
EVT_CC_CONNECT_CONF
EVT_CC_DISC_CONF On hook
Outgoing Incoming
E&M Wink
Call Control RBS Stack RBS Stack Call Control
EVT_CC_PROGRESS_IND WINK
User Application
EVT_CC_CONNECT_CONF Off hook MTCC_ConnectResp
EVT_CC_CONNECT_CONF
EVT_CC_DISC_CONF On hook
Outgoing Incoming
EVT_CC_PROGRESS_IND
User Application
EVT_CC_CONNECT_CONF MTCC_ConnectResp
EVT_CC_CONNECT_CONF
EVT_CC_DISC_CONF
Outgoing Incoming
EVT_CC_PROGRESS_IND
EVT_CC_INFO_IND
User Application
User Application
EVT_CC_CONNECT_CONF Off hook MTCC_ConnectResp
EVT_CC_CONNECT_CONF
EVT_CC_DISC_CONF On hook
Outgoing Incoming
NOTE - It is important to understand that both ISDN and RBS rely on the
same Call Control APIs. An explanation is provided at the beginning of this
section: .
Function Reference Library
• 178
Introduction
MTCC_ConnectRequest()
Description
MTCC_ConnectRequest() allows the user application to initiate an
outgoing call. The application must allocate a unique Connection ID
for the call and format an MT_CC_CONNECT_REQ structure before
calling this function. MTCC_ConnectRequest() checks the
structure content and returns the error code
MT_RET_CC_INVALID_REQ if any field is invalid.
Scenarios
Outbound calling number presentation and screening can be
controlled using the SmartWORKS API. See “Call Screening and
Number Presentation” on page 163.
Users can set the user specific protocol used to pass text messages
along the ISDN network. All fields are controlled in the MT_CC_U2U
structure. NOTE: The SmartWORKS API limits the text message to
128 bytes.
MTCC_ConnectRequest
EVT_
EVT_
EVT_
Prototype
MT_RESULT MTCC_ConnectRequest(
const CHANNEL nChannel,
PMT_CC_CONNECT_REQ const pCallnfo
);
Parameters
nChannel channel number
pCallInfo pointer to MT_CC_CONNECT_REQ
structure. This structure, as well as
related structures, are defined in the Nti-
DataCC.h file.
Return Code
Function Reference Library
• 179
Introduction
MT_RET_OK No error
MT_CC_CHANNEL_INUSE Channel is not idle
MT_CC_NO_DIGITS No called party number provided
MT_RET_NOT_AVAILABLE Driver is not loaded
Function Reference Library
• 180
Introduction
Events
EVT_CC_PROGRESS_IND - Call progress indication
EVT_CC_CONNECT_CONF - Call connect confirmation
CODE EXAMPLE
MTCC_ConnectRequest() Code Example
/*
result =
MTCC_ConnectRequest(channel,&request);
if(result == MT_RET_OK)
printf("MTCC_ConnectRequest()
successful...\n");
else
printf("MTCC_ConnectRequest() failed...\n");
*/
A complete code example is available on the Ai-Logix website:
http://www.ai-logix.com/support.html
Function Reference Library
• 181
Introduction
MTCC_ConnectResp()
Description
MTCC_ConnectResp() allows the user application to accept an
incoming call notified by the Call Control event
EVT_CC_CONNECT_IND. Before accepting the call, the user
application must allocate a unique connection ID for this call and
associate it with the Call Reference indicated in the
MT_CC_CONNECT_IND carried by the event
EVT_CC_CONNECT_IND. MTCC_ConnectResp() checks the
provided structure and if any field is invalid, it returns the error code
MT_RET_CC_INVALID_REQ.
EVT_
MTCC_ConnectResp()
EVT_
Prototype
MT_RESULT MTCC_ConnectResp(
const CHANNEL nChannel,
PMT_CC_CONNECT_RESP const pCallInfo
);
Parameters
nChannel Channel Number
pCallInfo Pointer to PMT_CC_CONNECT_REQ
structure. This structure, as well as
related structures, are defined in the Nti-
DataCC.h file.
Return Codes
MT_RET_OK No error
MT_CC_INVALID_STATE Channel is not in incoming call state
MT_RET_NOT_AVAILABLE Driver is not loaded
Ai-Logix, Inc.
182 •
SmartWORKS Developer’s Guide
Events
EV_CC_CONNECT_CONF - Call connect confirmation
Function Reference Library
• 183
Introduction
MTCC_DiscRequest()
Description
MTCC_DiscRequest() allows the user's application to release an
already connected call, to refuse an incoming call or to abort an
outgoing call. The application must wait for Call Control event
EVT_CC_DISC_CONF to declare the call release complete.
MTCC_DiscRequest() checks the content of the MT_CC_DISC_REQ
structure provided and if any field value is invalid, it returns the
error code MT_RET_CC_INVALID_REQ
MTCC_ConnectResp()
EVT_
EVT_
Ai-Logix, Inc.
184 •
SmartWORKS Developer’s Guide
Prototype
MT_RESULT MTCC_DiscRequest(
const CHANNEL nChannel,
PMT_CC_DISC_REQ const pCallInfo
);
Parameters
nChannel channel number
pCallInfo pointer to MT_CC_DISC_REQ structure.
This structure, as well as related struc-
tures, are defined in the NtiDataCC.h file.
Return Code
MT_RET_OK No error
MT_CC_INVALID_STATE No call to release
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
EVT_CC_DISC_CONF - Call release confirmation
Function Reference Library
• 185
Introduction
MTCC_FacilityRequest()
Description
This function allows the user application to issue a facility
management request. The ISDN supplementary services are mainly
provided through this function call. The field Code is used to specify
which facility (MT_CC_FAC_HOLD, MT_CC_FAC_RETREIVE,
MT_FAC_CALL_FORWARDING,.. etc) . The field Action specifies the
action to take (MT_CC_ACTION_ACTIVATE , MT_CC_ACTION_CLEAR
or MT_CC_ACTION_ENQUIRY). The other fields are used based on
the facility. As result of this request a Facility ISDN messages is sent
to the network.
Prototype
MT_RESULT MTCC_FacilityRequest(
const CHANNEL nChannel,
PMT_CC_FACILITY_REQ const pFacilityInfo
);
Parameters
nChannel Channel Number
pFacilityInfo Pointer to MT_CC_FACILITY_REQ struc-
ture. This structure, as well as related
structures, are defined in the Nti-
DataCC.h file.
Return Codes
MT_RET_OK No Error
MT_NB_NO_FREE_CONID if no call resource is available
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
EVT_CC_FACILITY_CONF - confirms that the request has been
executed
Function Reference Library
• 187
Introduction
MTCC_SuspendRequest()
Description
The user application uses this function to suspend an active call.
The application should provide the connection ID and the call
reference of the call. A call identity can also be given for the
suspended call in order to resume it later.
Prototype
MT_RESULT MTCC_ SuspendRequest (
const CHANNEL nChannel,
PMT_CC_SUSPEND_REQ const pSuspendInfo
);
Parameters
nChannel Channel Number
pSuspendInfo Pointer to MT_CC_ SUSPEND_REQ struc-
ture. This structure, as well as related
structures, are defined in the Nti-
DataCC.h file.
Return Codes
MT_RET_OK No Error
MT_NB_INVALID_CONID if the provided Connection ID is not
valid
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
EVT_CC_SUSPEND_CONF - confirms that the call has been
suspended.
Ai-Logix, Inc.
188 •
SmartWORKS Developer’s Guide
MTCC_UserInfoRequest()
Description
This function allows the user application to exchange user to user
information. A User information ISDN message (if supported) is sent
to the other peer.
Prototype
MT_RESULT MTCC_ UserInfoRequest (
const CHANNEL nChannel,
PMT_CC_USERINFO_REQ const pUserInfo
);
Parameters
nChannel Channel Number
pUserInfo Pointer to MT_CC_ USERINFO _REQ
structure. This structure, as well as
related structures, are defined in the Nti-
DataCC.h file.
Return Codes
MT_RET_OK No Error
MT_NB_INVALID_CONID if the provided Connection ID is not
valid
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 189
Introduction
MTCC_ResumeRequest()
Description
The application uses this function to resume a suspended call. The
application allocates a new connection Id to the call and provides
the call identity associated to the suspended call.
Prototype
MT_RESULT MTCC_ ResumeRequest (
const CHANNEL nChannel,
PMT_CC_RESUME_REQ const pResumeInfo
);
Parameters
nChannel Channel Number
pResumeInfo Pointer to MT_CC_ RESUME_REQ struc-
ture. This structure, as well as related
structures, are defined in the Nti-
DataCC.h file.
Return Codes
MT_RET_OK No Error
MT_NB_NO_FREE_CONID if no call resource is available
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
EVT_CC_RESUME_CONF - confirms that the call has been resumed
to active state.
Ai-Logix, Inc.
190 •
SmartWORKS Developer’s Guide
The following API’s are supported on the passive SmartWORKS DP cards for ISDN
support.
The interface to the user application is a two-way interaction:
1 · Call Control indications from the board to the user application
2 · Application requests to the board for information about call Sessions
APPLICATION REQUESTS
The User application may issue requests to retrieve statistics or information about a
channel or a call session. This can be done through the following API functions:
• MTCC_GetStatusByChan()
• MTCC_GetStatusByRef()
• MTCC_GetStatistics()
Function Reference Library
• 191
Introduction
Note: When the polling method is used, events prefixed with EVT_CC_
typically require user applications to call MTReturnEventBuffer() passing in
MT_EVENT.ptrBuffer to free the allocated memory. See the Functional
Reference Library where MTReturnEventBuffer() is explained for more
information.
MT_CC_CALL_INFO STRUCTURE
The MT_CC_CALL_INFO structure is relied on by most APIs used for passive ISDN.
The MT_CC_CALL_INFO structure is defined in the NtiDataCC.h file and contains the
fields below:.
NOTE: The NumberingPlan and the NumberOfDigits fields are defined in the
NtiDataCC.h file.
SUB_ADDRESS STRUCTURE
This structure is used to indicate the calling party sub-address, the called party sub-
address and the connected sub-address.
Function Reference Library
• 193
Introduction
SUBADDRTYPE
This field indicates the coding format used for the sub-address. The valid values for
this field are:
MT_CC_SUBADDR_NSAPNSAP /x213 format
MT_CC_SUBADDR_USERUSER Specified format
ODDEVENIND
The Odd/Even indicator field declares whether the number of digits is odd or even.
It is used when a byte is carrying two digits. The valid values for this field are:
MT_CC_SUBADDR_EVENnumber of digits is odd
MT_CC_SUBADDR_ODDnumber of digits is even
CALL IDENTITY STRUCTURE
.
MTCC_GetStatusByCh()
Description
MTCC_GetStatusByCh() scans all existing ISDN calls to determine
which calls are associated with the specified channel number.
MTCC_GetStatusByCh() then returns a complete
MT_CC_CALL_INFO for this call. If the channel is free (meaning it’s
not associated to any ISDN call) this function will return the error
code MT_RET_ISDNPT_CHANNEL_NOT_FOUND.
Prototype
MT_RESULT MTCC_GetStatusByCh(
const CHANNEL nChannel,
PMT_CC_CALL_INFO const pCallInfo,
PULONG const pLength
);
Parameters
nChannel Channel Number
pCallInfo Pointer MT_CC_CALL_INFO structure.
This structure is explained at the begin-
ning of this section.
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MT_CC_CALL_INFO structure.
Return Codes
MT_RET_OK No error
MT_RET_ISDNPT_CHANNEL_NOT_FOUND ISDN channel not
found
MT_RET_INVALID_CHANNEL Channel number is
out of range
MT_RET_CHANNEL_NOT_OPEN Channel device not
opened for access
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_DATA_TRUNCATED Data copied but truncated; the buffer
size set by the user application is not
large enough for this API request
Events
None
Function Reference Library
• 195
Introduction
CODE EXAMPLE
MTCC_GetStatusbyChan() Code Example
ZeroMemory(&callinfo,size);
result =
MTCC_GetStatusByCh(channel,&callinfo,&size);
if(result == MT_RET_OK)
{
printf("MTCC_GetStatusByCh()
successful...\n");
ULONG callRef = callinfo.CallRef;
ULONG callSource = callinfo.CallSource;
ULONG callState = callinfo.CallState;
printf("Call Reference: %0x\nCall Source:
%d\nCall State: %d\n",callRef,callSource,callState);
}
A complete code example is available on the Ai-Logix website:
http://www.ai-logix.com/support.html
Ai-Logix, Inc.
196 •
SmartWORKS Developer’s Guide
MTCC_GetStatusByRef()
Description
MTCC_GetStatusByRef() returns a complete MT_CC_CALL_INFO
for the call specified by the CallRef parameter. If the specified Call
reference no longer exists, this function returns the error code
MT_RET_ISDNPT_CALL_NOT_FOUND.
Prototype
MT_RESULT MTCC_GetStatusByRef(
const ULONG nCallRef,
PMT_CC_CALL_INFO const pCallInfo,
PULONG const pLength
);
Parameters
nCallRef ISDN Call reference
pCallInfo Pointer to MT_CC_CALL_INFO structure.
This structure is explained at the begin-
ning of this section.
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MT_CC_CALL_INFO structure.
Return Codes
MT_RET_OK No error
MT_RET_ISDNPT_CHANNEL_NOT_FOUND ISDN channel not
found, bad call
reference
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_DATA_TRUNCATED Data copied but truncated; the buffer
size set by the user application is not
large enough for this API request
Events
None
CODE EXAMPLE
MTGetStatusbyRef() Code Example
ZeroMemory(&callinfo,size);
result =
MTCC_GetStatusByRef(callRef,&callinfo,&size);
if(result == MT_RET_OK)
{
printf("MTCC_GetStatusByRef()
successful...\n");
ULONG callSource = callinfo.CallSource;
ULONG callState = callinfo.CallState;
printf("Call Reference: %0x\nCall Source:
%d\nCall State: %d\n",callRef,callSource,callState);
}
Function Reference Library
• 197
Introduction
MTGetDataLinkStatus()
Description
MTGetDataLinkStatus() returns the data link state for the trunk
specified by the board number and trunk number parameters. Data
Link Status can be defined as the following:
• MT_DL_UNRESOLVED - not syched up
• MT_DL_ACTIVATED - physical layer has synched up
• MT_DL_ESTABLISHED - data link layer has synched up
• MT_DL_CO_CONNECTING - a Sabme frame was sent from CO. CO is waiting for
a reply
• MT_DL_CPE_CONNECTING - a Sabme frame was sent from CPE. CPE is waiting
for a reply
• MT_DL_CO_RELEASING - the CO sent a Disconnect(Disc) frame
• MT_DL_CPE_RELEASING - the CPE sent a Disconnect(Disc) frame
Prototype
MT_RESULT MTGetDataLinkStatus(
const BOARD nBoard,
const USHORT nTrunk,
PULONG const pDLStatus
);
Parameters
nBoard Board Number
nTrunk Trunk number within the specified
board
pDLStatus Pointer to the link state
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Error in function pointer
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 199
Introduction
MTGetDataLinkStatistics()
Description
MTGetDataLinkStatistics() returns the collected Data Link
statistics for the trunk specified by the Board Number and Trunk
number parameters.
The counts returned correspond to the total number since the
channel was last opened. The MT_DL_STATS structure separates
both incoming and outgoing data. The structure is returned with
incoming data presented first.
Prototype
MT_RESULT MTGetDataLinkStatistics(
const BOARD nBoard,
const USHORT nTrunk,
PMT_DL_STATS const pDLStats,
PULONG const pLength
);
Parameters
nBoard Board Number
nTrunk Trunk number within the specified
board
pDLStats Pointer to an PMT_DL_STATS structure
(defined in the NtiDataCC.h file)
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the PMT_DL_STATS structure.
Structure
The MT_DL_STATS structure is defined as the following:
NOTE: The counts returned correspond to the total number since
the channel was last opened.
Incoming
SabmeCnt the count of Sabme frames received
from the outside network
DiscCnt the count of the disconnect frames sent
by the outside network to the local net-
work
RnrCnt the count of the receive not ready
frames that have been sent by the out-
side network
FrmrCnt the count of incoming frames rejected.
The frame that was received was no
good.
Ns_ErrCnt indicates the number of sequence num-
ber errors received on incoming data
CrBitErrCnt Incoming data was expected from the
outside, but came in the format of the
local network. This indicates the tapped
board is not cabled properly.
Ai-Logix, Inc.
200 •
SmartWORKS Developer’s Guide
Outgoing
SabmeCnt the count of Sabme frames received
from the local network
DiscCnt the count of the disconnect frames sent
by the local network to the outside net-
work
RnrCnt the count of the receive not ready
frames that have been sent by the local
network
FrmrCnt the count of outgoing frames rejected.
The frame that was received was no
good.
Ns_ErrCnt indicates the number of sequence num-
ber errors received on outgoing data
CrBitErrCnt Outgoing data was expected from the
local network, but came in the format of
the outside network. This indicates the
tapped board is not cabled properly.
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Error in function pointer
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 201
Introduction
MTGetCCStatistics()
Description
MTGetCCStatistics() returns the collected ISDN statistics for the
trunk specified by the board number and trunk number
parameters.
The counts returned correspond to the total number since the
channel was last opened.
Prototype
MT_RESULT MTGetCCStatistics(
const BOARD nBoard,
const USHORT nTrunk,
PMT_CC_STATS const pCCStats,
PULONG const pLength
);
Parameters
nBoard Board Number
nTrunk Trunk number within the specified
board
pCCStats Pointer to the CC_STATS structure
(defined in the NtiDataCC.h file)
pLength Set by the user application, this is a
pointer to the size of the given buffer for
the PMT_CC_STATS structure.
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to function
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Ai-Logix, Inc.
202 •
SmartWORKS Developer’s Guide
MTGetPHYStatistics()
Description
MTGetPHYStatistics() returns the collected physical layer statistics
for the trunk specified by the parameters nBoard and nTrunk.
Though DTMF detection, event reporting, and queuing are on by default, it’s
possible to reconfigure this setting through function MTControlToneQ() or
MTChInputToneDetectControl() which provides an on/off for tone detection and
queuing.
Function Reference Library
• 207
Introduction
Prototype
MT_RESULT MTCallString (
const CHANNEL nChannel,
PCSTR (A), or PCWSTR(W) pCall_string,
const PMT_IO_CONTROL pIoCtl
);
MT_RESULT MTCallStringEx
const CHANNEL nChannel,
PCSTR(A), or PCWSTR(W) pCall_string,
const PMT_IO_CONTROL pIoCtl,
const LPOVERLAPPED pOverlapped
);
MT_RESULT MTCallStringAsync
const CHANNEL nChannel,
PCSTR(A), or PCWSTR(W) pCall_string,
const PMT_IO_CONTROL pIoCtl,
const MTCOMPLETE pCompletionRoutine,
const LPARAM lParam
);
Parameters
nChannel Channel number
pCall_string pointer to a zero terminated dial string,
pCall_string
pIoCtl pointer to a MT_IO_CONTROL struc-
ture (defined in the previous chapter of
this book).
pCompletionRoutine pointer to completion routine
lParam parameter to echo back to completion
Return Codes
MT_RET_OK No error
MT_RET_IO_PENDING Background I/O operation is
in progress or queued
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_CHANNEL Channel number is out of
range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened
for access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
EVT_CPM_STOP
Ai-Logix, Inc.
210 •
SmartWORKS Developer’s Guide
CODE EXAMPLE
MTCallString() Code Example
result = MTCallString(channel,buffer,&ioctrl);
if(result == MT_RET_OK || result ==
MT_RET_IO_PENDING)
{
printf("MTCallString() successful...\n");
BOOL waiting = true;
while(waiting)
{
// wait for event with 10 second timeout
result =
MTWaitForChannelEvent(channel,10000,&event,&evtsize);
if(result == MT_RET_OK)
{
A complete code example is available on the Ai-Logix website:
http://www.ai-logix.com/support.html
Function Reference Library
• 211
Introduction
Prototypes
MT_RESULT MTDialString (
const CHANNEL nChannel,
const PCSTR (A), or pDial_string,
const PCWSTR(W)
const PMT_IO_CONTROL pIoCtl
);
MT_RESULT MTDialStringEx (
const CHANNEL nChannel,
const PCSTR (A) or pDial_string,
const PCWSTR(W)
const PMT_IO_CONTROL pIoCtl,
const LPOVERLAPPED pOverlapped
);
MT_RESULT MTDialStringAsync (
const CHANNEL nChannel,
const PCSTR(A) or pDial_string,
const PCWSTR (W)
const PMT_IO_CONTROL pIoCtl,
const MTCOMPLETE pCompletionRoutine,
const LPARAM lParam
);
Parameters
nChannel Channel number to dial out to
pDial_string Null terminated string of ASCII digits
representing the digits to dial. The spe-
cial digits are defined below.
pIoCtl pointer to a MT_IO_CONTROL struc-
ture (defined in the previous chapter of
this book). The MT_IO_CONTROL.Max-
Time field provides timeout specifica-
tion for dialing.
pOverlappped Pointer to NT overlapped structure
pCompleteRoutine Completion function address
lParam Long word user parameter
Special Characters
, Pause (or the character specified
through the MT_PSTN.pause_char field)
& Hook flash (or the character specified
through MT_PSTN.flash_char field), sup-
ported only ANALOG_FXO_LS(Smart-
WORKS AT) or ANALOG_VFXO_LS_E
(SmartWORKS LD) channels.
Function Reference Library
• 213
Introduction
CODE EXAMPLE
MTDialString() Code Example
result = MTDialString(channel,buffer,&ioctrl);
if(result == MT_RET_OK || result ==
MT_RET_IO_PENDING)
{
printf("MTDialString() successful...\n");
result =
MTWaitForChannelEvent(channel,5000,&event,&evtsize);
if(result != MT_RET_OK)
printf("MTWaitForChannelEvent() timed
out...\n");
}
A complete code example is available on the Ai-Logix website:
http://www.ai-logix.com/support.html
Ai-Logix, Inc.
214 •
SmartWORKS Developer’s Guide
MTDisableCallerID()
Description
Channel caller ID detection is disabled. Queued caller ID packets are
not removed by this function.
Prototype
MT_RESULT MTDisableCallerID (
const CHANNEL nChannel
);
Parameters
nChannel channel number
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of
range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened
for access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 215
Introduction
MTEnableCallerID()
Description
CallerID detection is enabled by default with a sensitivity level set to
0x80. Each channel is able to store up to 15 CallerID packets. Once
the queue is full, new CallerID information will be lost.
MTGetCallerIDStatus()
Description
CallerID detection operation state and level is retrieved for the
specified channel.
MTGetCallerID()
Description
This function returns the detected caller ID packet data string up to
the length provided in the length field. The suggested buffer should
be 256 bytes to take the maximum possible ID information. If the
buffer is not large enough, the portion of caller ID unable to fit into
the buffer is lost.
MTFlushCallerID()
Description
This function removes all queued caller ID packet(s) for the
specified channel.
Prototype
MT_RESULT MTFlushCallerID (
const CHANNEL nChannel
);
Parameter
nChannel channel number
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 219
Introduction
MTGetCallStatus()
This API was formerly called MTGetCallResult()
Description
MTGetCallStatus() returns the result of the last CPM function
termination. When a function terminates with the EVT_CPM_STOP
event, the SubReason field of the MT_EVENT structure contains the
precise termination reason. This value can also be found in the
CpmTerm field of the CALL_RESULT structure.
The following table lists all the values of the SubReason field of the
MT_EVENT structure.
Event Description
CPM_BUSY Busy signal detected
CPM_NO_ANSWER No answer after number of rings
CPM_NO_RINGBACK No ringback after timeout
CPM_CONNECT Call is answered
CPM_INTERCEPT Special Intercept Tone (SIT) detected
CPM_BUSY_NORMAL Regular (slow) busy cadence
CPM_BUSY_TRUNK Trunk (fast) busy cadence
CPM_CONNECT_FAX Connect to a FAX machine
CPM_CONNECT_MODEM Connect to a modem
CPM_CONNECT_MACHINE Connect to an answering machine
CPM_CONNECT_LOOP Connect because of loop-drop
CPM_CONNECT_VOICE Connect to a voice answer
CPM_CONNECT_CADBRK Connect to a cadence break
The CALL_RESULT structure:
Type Name Purpose
ULONG Status status value
ULONG CpmTerm Last CPM termination
ULONG offFreq Percent of signal off-frequency
ULONG Frequency Detected frequency
ULONG HiTime Longest high period in cadence
ULONG LoTimeShort Shortest low period in cadence
ULONG LoTimeLong Longest low period in cadence
ULONG AnswerTime Duration of answer for CON-
NECT
ULONG SubTerm Termination sub type
Currently only the CpmTerm and SubTerm fields are supported.
Prototype
MT_RESULT MTGetCallStatus (
const CHANNEL nChannel,
const PCALL_RESULT pCall_result,
PULONG const pLength
);
Ai-Logix, Inc.
220 •
SmartWORKS Developer’s Guide
Parameters
nChannel channel number
pCall_result pointer to CALL_RESULT structure
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the CALL_RESULT structure.
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_CHANNEL Channel number is out of
range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened
for access
MT_RET_DATA_TRUNCATED Data copied but truncated; the buffer
size set by the user application is not
large enough for this API request
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
CODE EXAMPLE
MTGetCallStatus() Code Example
ZeroMemory(&callresult,size);
result =
MTGetCallStatus(channel,&callresult,&size);
if(result == MT_RET_OK)
{
printf("MTGetCallStatus() successful...\n");
ULONG status = callresult.Status;
ULONG termination = callresult.CpmTerm;
printf("Status: %u\nLast CPM termination:
%u\n",status,termination);
}
A complete code example is available on the Ai-Logix website:
http://www.ai-logix.com/support.html
Function Reference Library
• 221
Introduction
Scenario
Upon using the completion notification mechanism (i.e.
MTGetDigitsAsync() the termination event will not only be passed
to the application through the invoking of the completion routine,
but will also be reported to the event queue if enabled.
Prototype
MT_RESULT MTGetDigits (
const CHANNEL nChannel,
const PMT_IO_CONTROL pIoCtl
);
MT_RESULT MTGetDigitsEx (
const CHANNEL nChannel,
const PMT_IO_CONTROL pIoCtl,
const MTCOMPLETE pCompletionRoutine,
const LPOVERLAPPED pOverlapped
);
MT_RESULT MTGetDigitsAsync (
const CHANNEL nChannel,
const PMT_IO_CONTROL pIoCtl,
const MTCOMPLETE pCompletionRoutine,
const LPARAM lParam
);
Parameters
nChannel channel number
pIoCtl pointer to a MT_IO_CONTROL struc-
ture (defined in the previous chapter of
this book).
pOverlapped pointer to NT overlapped structure
pCompletionRoutine completion function address
lParam pointer to long word user parameter
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_IO_PENDING Background I/O operation is in
progress or queued
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 223
Introduction
CODE EXAMPLE
MTGetDigits() Code Example
result = MTGetDigits(channel,&ioctrl);
if(result == MT_RET_OK || result ==
MT_RET_IO_PENDING)
{
printf("MTGetDigits() successful...\n");
result =
MTWaitForChannelEvent(channel,5000,&event,&evtsize);
if(result != MT_RET_OK)
printf("MTWaitForChannelEvent() timed
out...\n");
}
A complete code example is available on the Ai-Logix website:
http://www.ai-logix.com/support.html
Ai-Logix, Inc.
224 •
SmartWORKS Developer’s Guide
MTReadDigit()
Description
MTReadDigit() retrieves the first digit in the DTMF queue to the
UCHAR buffer. If the queue is empty, UCHAR buffer is set to 0x00.
Otherwise, UCHAR contains one of 16 possible characters: 0
through 9, #, *, and A through D.
Scenario
The digit direction information is lost after the DTMF digit is
retrieved through this API call.
Prototype
MT_RESULT MTReadDigit (
const CHANNEL nChannel,
const PUCHAR pDigit
);
Parameters
nChannel channel number
pDigit pointer to a character that will receive
the digit
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
CODE EXAMPLE
MTReadDigit() Code Example
result = MTReadDigit(channel,&digit);
if(result == MT_RET_OK)
{
printf("MTReadDigit() successful...\n");
if(digit)
printf("DTMF digit: %c\n",digit);
else
printf("No digits currently
available...\n");
}
A complete code example is available on the Ai-Logix website:
http://www.ai-logix.com/support.html
Function Reference Library
• 225
Introduction
MTReadDTMFTone()
Description
MTReadDTMFTone() retrieves the first digit in the DTMF queue to
the UCHAR digit buffer. If the queue is empty, UCHAR buffer is set to
0x00. Otherwise, UCHAR contains one of 16 possible characters: 0
through 9, #, *, and A through D.
MTReadMFTone()
Description
MTReadMFTone() retrieves the first tone in the MF queue to the
UCHAR tone buffer. If the queue is empty, UCHAR buffer is set to
0x00. Otherwise, UCHAR contains values 0x01 to 0x0f for forward
tones 1 to 15 and 0x11 to 0x1f for backward tones 1 to15,
respectively.
MTClearDTMFDigits()
This API was previously called MTClearDigits()
Description
MTClearDTMFDigits() flushes the digit queue of all DTMF digits
received in the specified channel.
The queue allows a maximum of 256 digits.
Scenario
Before an application needs new digits from the caller, it can flush
the queue so it will not use old digits.
Prototype
MT_RESULT MTClearDTMFDigits (
const channel nChannel
);
Parameter
nChannel channel number
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
CODE EXAMPLE
MTClearDTMFDigits() Code Example
result = MTClearDTMFDigits(channel);
if(result == MT_RET_OK)
{
printf("MTClearDTMFDigits()
successful...\n");
printf("DTMF digits flushed on channel
%d\n",channel);
}
A complete code example is available on the Ai-Logix website:
http://www.ai-logix.com/support.html
Ai-Logix, Inc.
228 •
SmartWORKS Developer’s Guide
MTClearMFTones()
Description
MTClearMFTones() flushes the MF tone queue of all tones received
in the specified channel.
Prototype
MT_RESULT MTClearMFTones (
const channel nChannel
);
Parameters
nChannel Channel Number
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
Event Codes
None
Function Reference Library
• 229
Introduction
MTControlToneQ()
This API will be obsoleted as of Jan. 2005. Use MTChInputToneDetectControl()
instead. This API was previously called MTControlDigits().
Description
Parameter tone type specifies whether this is to control DTMF
queue or MF queue. This API controls the queue of the primary
channel. If mixing is enabled, both the primary and secondary
channels are set.
Possible values for queue control are as follows:
MTChInputToneDetectControl()
MTEnableMixingDetect() was previously used.
Description
Parameter tone type specifies whether this is to control DTMF
queue or MF queue per each input of a channel.
Possible values for queue control are as follows:
MTChInputToneDetectStatus()
Description
Retreives the queue control status of each input per channel.
MTSetSLIC()
Description
This function is used on LD101 station ports only.
The MTSetSLIC() function sets state of the Subscriber Line Interface
Circuit(SLIC).
The station port includes battery feed and provides +24V. It is
capable of detecting ON_HOOK, OFF_HOOK line conditions, and
provides 600 Ohm termination. This port has a 2W/4W hybrid.
The SmartWORKS API supports two modes of SLIC operation:
power-down, active-normal.
NOTE: InterLoc mechanism to protect the station channel has been
implemented. Before this port opens, the line is checked for
voltage. If the voltage is 17 Volts or greater then the SLIC does not
go into active-normal mode and the return code, MT_RET_BUSY is
returned to the user application.
Prototype
MT_RESULT MTSetSLIC (
const CHANNEL nChannel,
const USHORT Value
);
Parameter
nChannel channel number
Value SLIC control: 0=power down
1=active-normal
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_BUSY Inter-Loc support. The port is
not opened since there is volt-
age on the line
Events
None
Function Reference Library
• 233
Introduction
MTGetSLIC()
Description
This function is used on LD101 station ports only.
The MTGetSLIC() function gets the current state of the Subscriber
Line Interface Circuit(SLIC).
The SmartWORKS API supports two modes of operatioin: power-
down, active-normal.
Prototype
MT_RESULT MTGetSLIC (
const CHANNEL nChannel,
const USHORT pValue
);
Parameter
nChannel channel number
pValue pointer to the value SLIC control:
0=power down
1=active-normal
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Ai-Logix, Inc.
234 •
SmartWORKS Developer’s Guide
CONTROL FUNCTIONS
Function Reference Library
• 235
Introduction
MTStopChannel()
Description
MTStopChannel() stops a single channel without affecting any
other channel in the system. This function is useful in halting a
record or playback function if, for instance, the system operator is
finished recording a new message prompt.
CODE EXAMPLE
Code Example MTStopChannel()
if(handleMT(MTStopChannel(channel),"MTStopChannel() channel %d",channel))
{
wait = true;
while(wait)
Sleep(20);
}
MTStopCurrentFunction()
Description
MTStopCurrentFunction() terminates only the current function in
progress on the specified codec on a channel. Any subsequent
functions in the queue will be executed.
CODE EXAMPLE
Code Example MTStopCurrentFunction()
if(handleMT(MTStopCurrentFunction(channel,operation),"MTStopCurrentFunction()
channel %d, operation %d",channel,operation))
{
wait = true;
while(wait)
Sleep(20);
}
handleMT(MTClearEventCallback(channel),"MTClearEventCallback() channel
%d",channel);
EVENT FUNCTIONS
Ai-Logix, Inc.
240 •
SmartWORKS Developer’s Guide
MTOpenChannel()
Description
MTOpenChannel() opens the specified channel for access.
It is suggested to open all boards and channels by invoking
MTSysStartup() if the developer does NOT intend to implement
multiple applications using the SmartWORKS SDK.
Prototype
MT_RESULT MTOpenChannel(
const CHANNEL nChannel
);
Parameters
nChannel channel number
Return Codes
MT_RET_OK No error
MT_RET_CHANNEL_INUSE On failure (most likely due to
the resource having been
already grabbed by another
application)
MT_RET_MALFUNCTION Hardware failed during initial-
ization
MT_RET_DEVICE_NOTFOUND Voice interface device was not
found
MT_RET_INTERNAL_ERROR Internal error in DLL
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
See Also: MTSysStartup()
Function Reference Library
• 241
Introduction
MTPutChannelEvent()
This API was formerly called MTPutEvent()
Description
MTPutChannelEvent() places an application specified event into
the event queue of the specified channel.
Scenario
If an event callback function is registered for the specified channel,
the callback function will be invoked with the newly added event.
Otherwise, this event can be retrieved through polling using
MTWaitForChannelEvent() or MTGetChannelEvent().
MTSetOutputSource()
Description
MTSetOutputSource() selects the source of channel output from
either the decoder (default) or the mixed inputs to the channel.
Prototypes
MT_RESULT MTSetOutputSource(
const CHANNEL nChannel,
const USHORT Source
);
Parameters
nChannel Channel Number
Source Output Source Value:
0 = CHANNEL_DEVICE
1 = AUDIO_STREAM
2 = PRIMARY_INPUT
3 = SECONDARY_INPUT
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Ai-Logix, Inc.
244 •
SmartWORKS Developer’s Guide
MTGetOutputSource()
Description
MTGetOutputSource() selects the source of channel output from
either the decoder (default) or the mixed inputs to the channel. The
MTGetOutputSource() API obtains these settings.
Prototypes
MT_RESULT MTGetOutputSource(
const CHANNEL nChannel,
const USHORT pSource
);
Parameters
nChannel Channel Number
pSource Pointer to the output source value
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Error in output source
MT_RET_INVALID_CHANNEL Channel number is out of
range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened
for access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 245
Introduction
MTCloseChannel()
Description
MTCloseChannel() closes the specified channel for access.
MTGetChannelOpenStatus()
Description
This API returns the ownership of the specified channel. A channel
needs to be opened before any access or control can be performed
on it by the application.
Scenario
A channel can only be opened by one application at one time.
When a channel is opened and held by one application, attempting
to open the same channel will fail upon reset of the applications in
the platform.
Prototype
MT_RESULT MTGetChannelOpenStatus(
const CHANNEL nChannel,
BOOLEAN * const pOpen
);
Parameters
nChannel channel number
pOpen Pointer to the open status
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_CHANNEL Channel number is out of
range. possible values returned
inside open status:
TRUE - Channel is opened, i.e.
owned by the caller application
FALSE- Channel is not opened
by the caller application
Events
None
See Also: MTGetBoardOpenStatus()
Function Reference Library
• 247
Introduction
MTClearBoardEventCallback()
Description
This function disables the board event callback previously set up
through the MTSetBoardEventCallback() function. Board events
will have to be polled through MTWaitForAdapterEvent().
This API works as a synchronous function. Therefore, once callback
is initiated, it does not release it’s lock on the user application until a
response has been received. Invoking
MTClearBoardEventCallback() from a callback function would
enter this control path into a deadlock. To prevent this the return
MT_RET_API_THREAD_PROTECTED message is generated.
Prototype
MT_RESULT MTClearBoardEventCallback(
const BOARD nBoard
);
Parameters
nBoard board index: 0 for the first board, -1 for
all boards
Return Codes
MT_RET_OK No error
MT_RET_INVALID_BOARD Board number is out of range
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_BOARD_NOT_OPENED Board device not opened for
access
Events
None
Ai-Logix, Inc.
248 •
SmartWORKS Developer’s Guide
MTSetPriorityEventCallback()
Description
MTSetPriorityEventCallback() provides a function point that will
be called when the specified event occurs on the specified channel.
All pending events, including the specified trigger event, will be
passed to the user application through a callback function
parameter. The callback function can be declared or defined in the
user application as illustrated below. If set through
MTSetEventCallback() a general event callback function for a
channel and then set through MTSetPriorityEventCallback() a
priority event callback function for the same channel, then when
the specified channel receives the event specified through
MTSetPriorityEventCallback() function, the priority event callback
function will be invoked. Other events will invoke the general event
callback function.
CINTERFACE void MTCALLBACK(GCI, int, PMT_EVENT, LPARAM);
CINTERFACE void PriorityEventCallback(
GCI iCh, int EventCount, int, PMT_EVENT pEvent, LPARAM
lParam) {}
Parameter iCh refers to the channel on which the event(s) are
queued; parameter EventCount refers to the number of events
pointed to by the MT_EVENT parameter. Parameter PMT_EVENT
points to information of EventCount event(s) in the array of
structure type MT_EVENT. These events are no longer in the
channel queue for later retrieval. The event specified by EventCode
is the last event in the event array, since it was the last event to be
placed in the event queue.
When called, the priority callback function should process all events
pointed to by an event (i.e. PMT_EVENT).
To process more than one event as a priority, this API must be called
once for each event.
Prototype
MT_RESULT MTSetPriorityEventCallback (
const CHANNEL nChannel,
const LONG EventCode,
MTCALLBACK const Callback,
const LPARAM lParam
);
Parameters
nChannel channel number
EventCode event code that will invoke callback
Callback pointer to callback function
lParam User event to be returned on callback
Function Reference Library
• 249
Introduction
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function of NULL pointer, event
code on GCI number
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_BOARD_NOT_OPENED Board device not opened for
access
Events
Currently the SmartWORKS SDK only registers one priority callback
for each channel, hence, only one event code is monitored.
CODE EXAMPLE
MTSetPriorityEventCallback() Code Example
result =
MTSetPriorityEventCallback(channel,EVT_CALLID_STOP,(MTCALLBACK)PriorityEventCa
llback,myParam);
if(result == MT_RET_OK)
{
printf("MTSetPriorityEventCallback()
successfully registered on all %d channels...\n",totalChannels);
}
A complete code example is available on the Ai-Logix website:
http://www.ai-logix.com/support.html
Ai-Logix, Inc.
250 •
SmartWORKS Developer’s Guide
MTPutBoardEvent()
Description
Puts an event to the board. The MT_EVENTstructure is explained in
the previous chapter.
Prototype
MT_RESULT MTPutBoardEvent (
const BOARD nBoard,
PMT_EVENT const pMTEvent,
PULONG const pLength
);
Parameters
nBoard board number
pMTEvent pointer to a event buffer
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MT_EVENT structure.
Return Codes
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_BOARD_NOT_OPENED Board device not opened for
access
Function Reference Library
• 251
Introduction
MTSetEventFilter()
This API was formerly called MTSetEvents()
Description
MTSetEventFilter() enables the reporting of incoming events, as
well as setting the number of rings(nRing) that will trigger the
EVT_RINGS event. The following are events that can be enabled by
using the appropriate bit value. To enable more than one event use
the sum of bit values
The default event bit enable setting is 0 (all off ).
NOTE: MTSetEventFilter() does not control the filtering of D-
channel events.
Prototype
MT_RESULT MTSetEventFilter (
const CHANNEL nChannel,
const USHORT EventEnable,
const USHORT nRings
);
Parameter
nChannel channel number
EventEnable event bit enable
nRings updates MT_PSTN.ring_count field,
number of rings for EVT_RINGS
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_CHANNEL_NOT_OPENED Occurs when a channel is not
yet opened
Events
None
Function Reference Library
• 253
Introduction
MTGetEventFilters()
Description
MTGetEventFilters() gets the current channel line event bit enable
and the ring count to report an incoming event. The enable bits are
defined in MTSetEventFilters() API.
Prototype
MT_RESULT MTGetEventFilters (
const CHANNEL nChannel,
const PUSHORT pEventEnable,
const PUSHORT pRings
);
Parameters
nChannel channel number
pEventEnable pointer to event bit enable
pRings pointer to number of rings for
EVT_RINGS
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_CHANNEL_NOT_OPENED Occurs when a channel is not
yet opened
Events
None
CODE EXAMPLE
MTGetEventFilters() Code Example
result = MTGetEventFilters(channel,&events,&rings);
if(result == MT_RET_OK)
{
printf("MTGetEventFilters()
successful...\n");
printf("Sum of events enabled: %u\nNo. of
rings: %u\n",events,rings);
}
A complete code example is available on the Ai-Logix website:
http://www.ai-logix.com/support.html
Ai-Logix, Inc.
254 •
SmartWORKS Developer’s Guide
MTSetEventFilters()
Description
MTSetEventFilters() sets the filter enable bits used for phone line
event monitoring and reporting. These bits are set on a per channel
basis. The default setting is 0 - all off.
Prototype
MT_RESULT MTSetEventFilters (
const CHANNEL nChannel,
const PUSHORT EventEnable,
const PUSHORT pRings
);
Parameters
nChannel channel number
EventEnable event bits that have been enabled
Rings the number of rings used to trigger the
event EVT_RINGS
The following bits can be set.
Filter Setting Bit Event
SE_LCURRENT_CHANGE 0X0001 EVT_LOOP_DROP, EVT_LOOP_ON
(SmartWORKS LD, and
SmartWORKS AT)
SE_RINGS 0X0002 EVT_RINGS (incoming ring detected)
SE_ACT 0X0004 EVT_MON_ACTIVITY,
EVT_MAX_ACTIVITY
SE_SIL 0X0008 EVT_MON_SILENCE, EVT_MAX_SILENCE
SE_OFFH 0X0010 EVT_OFFHOOK
SE_ONH 0X0020 EVT_ONHOOK
0X0100 EVT_REVERSAL
SE_LVOLTAGE_CHANGE 0X0200 EVT_LVOLTAGE_OFFHOOK,
EVT_LVOLTAGE_NOTOFFHOOK (Smart-
WORKS PT)
EVT_LVOLTAGEABOVEORBELOW,
EVT_LVOLTAGEBELOW,
EVT_LVOLTAGEABOVE
(SmartWORKS LD)
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_CHANNEL_NOT_OPENED Occurs when a channel is not
yet opened
Events
None
Function Reference Library
• 255
Introduction
CODE EXAMPLE
MTSetEventFilters() Code Example
result = MTSetEventFilters(channel,events,rings);
if(result == MT_RET_OK)
{
printf("MTSetEventFilters()
successful...\n");
printf("Setting...\nSum of events enabled:
%u\nNo. of rings: %u\n",events,rings);
}
A complete code example is available on the Ai-Logix website:
http://www.ai-logix.com/support.html
Ai-Logix, Inc.
256 •
SmartWORKS Developer’s Guide
MTClearEventCallback()
Description
MTClearEventCallback() clears the callback function that was
previously registered for the specified channel(s).
Scenario
Event callback cannot be cleared by registering a NULL callback
function. Use this API function to clear the registered callback
function.
This API works as a synchronous function. Therefore, once callback
is initiated, it does not release it’s lock on the user application until a
response has been received. Invoking MTClearEventCallback()
from a callback function would enter this control path into a
deadlock. To prevent this the return
MT_RET_API_THREAD_PROTECTED message is generated.
Prototype
MT_RESULT MTClearEventCallback (
const channel nChannel
);
Parameter
nChannel channel number
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_CHANNEL_NOT_OPENED Occurs when a channel is not
yet opened
MT_RET_API_THREAD_PROTECTED this API has called a function
that is already locked by
another application
Events
None
Function Reference Library
• 257
Introduction
MTClearPriorityEventCallback()
Description
MTClearPriorityEventCallback() clears the callback function that
was previously registered for the specified channel(s) for the
specified event. Currently, event code is not checked.
To clear more than one event, this API must be called once for each
event.
Scenario
Priority callback cannot be cleared by registering a NULL callback
function. Use this API function to clear the registered callback
function.
Prototype
MT_RESULT MTClearPriorityEventCallback(
const CHANNEL nChannel,
const LONG EventCode
);
Parameters
nChannel channel number
EventCode event code that will invoke callback
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_CHANNEL_NOT_OPENED Occurs when a channel is not
yet opened
Events
None
Ai-Logix, Inc.
258 •
SmartWORKS Developer’s Guide
MTEventControl()
Description
MTEventControl() enables or disables the event queuing operation
for all the channels in the system. It is channel independent. The
following possible actions are available
Prototype
MT_RESULT MTEventControl (
const USHORT ACTION
);
Parameter
ACTION action to perform
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 259
Introduction
MTFlushEvents()
Description
MTFlushEvents() clears all events queued for a channel.
Prototype
MT_RESULT MTFlushEvents (
const CHANNEL nChannel
);
Parameters
nChannel Channel Number
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Occurs when a channel is not
yet opened
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Ai-Logix, Inc.
260 •
SmartWORKS Developer’s Guide
MTGetChannelInfo()
Description
MTGetChannelInfo() returns detailed information about channel
properties and startup status of the board the channel resides on.
Scenario
Unlike MTGetAdapterInfo(), MTGetChannelInfo() only retrieves
the load status of the board the specified channel resides on.
Should more information about a board be desired, use
MTGetAdapterInfo() which retrieves sp, board version, etc. Use
MTGetGCIMap() to find out the index number of specified
channel’s board. Use MTGetChannelStatus() to determine the
runtime status of a channel.
Prototype
MT_RESULT MTGetChannelInfo (
const CHANNEL nChannel,
PMTCHAN_INFO const pChannel_info,
PULONG const pLength
);
Parameters
nChannel channel number
pChannel_info pointer to MTCHAN_INFO structure to
store
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MTCHAN_INFO structure.
Structure
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_DATA_TRUNCATED Data copied but truncated; the
buffer size set by the user appli-
cation is not large enough for
this API request
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Ai-Logix, Inc.
262 •
SmartWORKS Developer’s Guide
MTGetChannelEvent
This API was formerly called MTGetEvent().
Description
MTGetChannelEvent() retrieves the first event out of the event
queues for all the channels. Each channel has its own event queue.
This API will return whenever it finds any event for any channel.
Should there be events on both channel 1 and channel 10 at the
same time, the event on channel 1 is returned. Should there be no
event in the system, this function awaits the arrival of the next new
event on any channel or the expiration of the specified waiting
period.
MTSetEventCallback()
Description
MTSetEventCallback() provides a function pointer that will be
called when an event is on the event queue. The function described
in MTCALLBACK field is registered for every channel available to the
application. The callback function can be declared in the user
application as illustrated in the example below:
CINTERFACE void MTCALLBACK(GCI, int, PMT_EVENT, LPARAM);
CINTERFACE void EventCallback(
GCI iCh, int EventCount, int, PMT_EVENT pEvent, LPARAM
lParam) {}
If a user wishes to set all channels with MTSetEventCallback(), the
GCI parameter must be configured as follows:
MTGetChannelStatus()
This API was formerly called MTGetStatus()
Description
MTGetChannelStatus() returns detailed, current information
about a channel. If no event queue is used, this is the only means to
keep track of a channel's operation status.
Prototype
MT_RESULT MTGetChannelStatus (
const CHANNEL nChannel,
PMTCHAN_STATUS const pChan_status,
PULONG const pLength
);
Parameters
nChannel channel number
pChan_status pointer to MTCHAN_STATUS structure to
store channel status info
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MTCHAN_STATUS structure
Structure
The MTCHAN_STATUS structure is defined as follows:
x0000 TASK_IDLE
x0001 TASK_RECORD
x0002 TASK_PLAY
x0003 TASK_RECPLAY
(TASK_RECORD &
TASK_PLAY)
x0004 TASK_GETDIGITS
x0008 TASK_OFFHOOK
x0010 TASK_DIALING
x0020 TASK_ONHOOK
x0040 TASK_CPM
x0080 TASK_PARAM
x0100 TASK_WINK
x0200 TASK_PLAYTONE
x0400 TASK_PREREC
x0800 TASK_STREAMING
xffffffff NOT_OPENED
Return Codes
MT_RET_OK No error
MT_RET_DATA_TRUNCATED Data copied but truncated; the
buffer size set by the user appli-
cation is not large enough for
this API request
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 269
Introduction
CODE EXAMPLE
MTGetChannelStatus() Code Example
ZeroMemory(&chanstatus,size);
result =
MTGetChannelStatus(channel,&chanstatus,&size);
if(result == MT_RET_OK)
{
printf("MTGetChannelStatus()
successful...\n");
ULONG status = chanstatus.Status;
printf("Channel status: ");
switch(status)
{
A complete code example is available on the Ai-Logix website:
http://www.ai-logix.com/support.html
Ai-Logix, Inc.
270 •
SmartWORKS Developer’s Guide
MTSetChannelToDefault()
Description
MTSetChannelToDefault() returns channel configuration to
default settings.
Prototype
MT_RESULT MTSetChannelToDefault (
const CHANNEL nChannel
);
Parameters
nChannel Channel Number
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Occurs when a channel is not
yet opened
MT_RET_INVALID_PARAM Invalid argument passed to
function
Events
None
Function Reference Library
• 271
Introduction
MTGetStatistics()
Description
Runtime errors such as encode overflow, decode underflow, and
etc. are recorded for each NTI channel. This API allows user
application to retrieve these counters.
The user application does not need to have the access rights of the
specified channel.
MTGetBoardStatistics()
Description
Runtime errors such as encode overflow, decode underflow, and
etc. are recorded for each NTI channel. This API allows user
application to retrieve these counters for an entire board.
The user application does not need to have the access rights of the
channels.
MTResetStatistics()
Indicates that the application fails to retrieve information from the queue::
Reserved field::
Return Codes
MT_RET_OK No error
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 275
Introduction
MTResetBoardStatistics()
NOTE
MTResetBoardStatistics() works only when there is no PanicCode recorded
Description
This API works on the specified board the same way as
MTResetStatistics() works on the specified channel.
MTWaitForAdapterEvent()
The API was formerly called MTWaitForBoardEvent()
Description
Checks board event queue and returns the next event on the
queue. This function is typically used in a "message pump" thread
to periodically check on the status of an active board.
MTWaitForChannelEvent()
This API was formerly called MTWaitForEvent()
Description
Checks channel event queue and returns the next event on the
channel queue before the specified timeout. This function is
typically used in a "message pump" thread to periodically check on
the status of an active channel. A timeout of -1 can be used when
it’s necessary to wait until an event occurs.
MTGetChannelOwner()
Description
If the specified channel is opened, the returned *pPid contains the
process ID of the access owner of the specified channel. If the
channel is currently not opened by any thread or application, the
returned *pPid will be 0.
MTPutBoardEvent()
Description
Puts an event to the board. The MT_EVENTstructure is explained in
the previous chapter.
Prototype
MT_RESULT MTPutBoardEvent (
const BOARD nBoard,
PMT_EVENT const pMTEvent,
PULONG const pLength
);
Parameters
nBoard Board Number
pMTEvent pointer to the PMT_EVENT structure
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MT_EVENT structure.
Return Codes
MT_RET_BOARD_NOT_OPENED Board not opened for access
Events
None
Ai-Logix, Inc.
282 •
SmartWORKS Developer’s Guide
MTSetBoardEventCallback()
Description
MTSetBoardEventCallback() provides a function pointer that will
be called when an event is on the board event queue. When the
BOARD parameter is equal to -1, the function described in
MTCALLBACK field is registered for every board available to the
application. The callback function can be declared in the user
application as illustrated in the example below:
CINTERFACE void MTCALLBACK(USHORT, int, PMT_EVENT, LPARAM);
CINTERFACE void EventCallback(
BOARD iBrd, int EventCount, int, PMT_EVENT pEvent,
LPARAM lParam) {}
Parameter iBrd refers to the board on which the event(s) are
queued; parameter EventCount refers to the number of events
returned with this callback. Parameter pEvent points to the event
array. Parameter lParam is passed as specified in function
MTSetBoardEventCallback().
Return Codes
MT_RET_OK No error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_BOARD Board number is out of range
MT_RET_BOARD_NOT_OPENED Board device not opened for
access
Events
None
Ai-Logix, Inc.
284 •
SmartWORKS Developer’s Guide
MTSysSetEventCallback()
Description
MTSysSetEventCallback() provides a function pointer that will be
called when an event is on the system event queue.
When a callback function is invoked, the function does not need to
use MTWaitForSysEvent() to retrieve the queued events. Events are
passed in the array pointed to by the MTCALLBACK parameter. User
applications should not release the memory for the event array.
MTCALLBACK and LPARAM provide the DLL the address of the API
completion routine and the user expected parameter for invoking
the completion routine
This API is only used to retrieve system events, such as events
generated when using MTResyncTime().
MTSysClearEventCallback() works as a synchronous function.
Therefore, once callback is initiated, it does not release it’s lock on
the user application until a response has been received. Invoking
MTSysClearEventCallback() from a callback function would enter
this control path into a deadlock. To prevent this the return
MT_RET_API_THREAD_PROTECTED message is generated.
Prototype
MT_RESULT MTSysSetEventCallback (
MTCALLBACK pCallback,
LPARAM lParam
);
Parameter
pCallback used as resource indexing, set to –1 to
indicate the resource as SYSTEM.
lParam user defined parameter
Return Codes
MT_RET_OK No error
Events
None
Function Reference Library
• 285
Introduction
MTSysClearEventCallback()
Description
MTSysClearEventCallback() clears the callback function that was
previously registered for the system.
This API is used when using the callback function for retrieving
system events such as those generated by the MTSyncTime() API.
This API works as a synchronous function. Therefore, once callback
is initiated, it does not release it’s lock on the user application until a
response has been received. Invoking MTSysClearEventCallback()
from a callback function would enter this control path into a
deadlock. To prevent this the return
MT_RET_API_THREAD_PROTECTED message is generated.
Prototype
MT_RESULT MTSysClearEventCallback (
VOID
);
Parameter
no parameter
Return Codes
MT_RET_OK No error
Events
None
Ai-Logix, Inc.
286 •
SmartWORKS Developer’s Guide
MTSysWaitForEvent()
Description
Checks system event queue and returns the next event on the
queue before the specified timeout. This function is typically used
in a "message pump" thread to periodically check on the status. A
timeout of -1 can be used when it’s necessary to wait until an event
occurs.
GAIN/VOLUME FUNCTIONS
Ai-Logix, Inc.
288 •
SmartWORKS Developer’s Guide
3.14
Target
Maximum Amplification
Input (dBm)
3.14
In steady state condition signal with power above the target will be attenuated to
reach target power. Signals with energy lower then target will be amplified to reach
the target level. The amount of amplification is limited by a parameter MA.
MA is programmable from the API in 6 dB steps.
The rate at which the gain changes is controlled by two parameters: attack slew rate
and decay slew rate.
Function Reference Library
• 289
Introduction
Attack controls the speed of the gain decrease, decay controls the speed of the gain
increase. The attack and decay are programmable from the API in units of 0.00212
dB/millisecond. Changing the Attack and Decay settings are not recommended.
The default settings for AGC are:
Target amplitude (TMA)
-6 dBm
Maximum Amplification (MA)
30 dB
Attack
400
Decay
4
The following figure shows the effect of AGC on a test signal.
Ai-Logix, Inc.
290 •
SmartWORKS Developer’s Guide
0.9
0.8
0.7
0.6
0.5
0.4
0.3
0.2
0.1
0.0
-0.1
-.02
-0.3
-0.4
-0.5
-0.6
-0.7
-0.8
-0.9 Time
0.00.5 0.01.0 0.01.5 0.02.0 0.02.5 0.03.0 0.03.5 0.04.0 0.04.5 0.05.0
Target: 0dBm · Max Gain: 30dB · Attack: 0.848 dB/ms · Decay: 0.01696 dB/ms · Gain: -6dB
1.0
0.9
0.8
0.7
0.6
0.5
0.4
0.3
0.2
0.1
0.0
-0.1
-.02
-0.3
-0.4
-0.5
-0.6
-0.7
-0.8
-0.9 Time
0.00.5 0.01.0 0.01.5 0.02.0 0.02.5 0.03.0 0.03.5 0.04.0 0.04.5 0.05.0
Maximum
Type of Network Target Amplitude Attack Decay
Amplitude
phone -6 400 4 30
radio -6 400 1* 30
Target
-12 dBm
Input
-20dBm
-40dBm
To effectivly apply gain to voice levels, but reduce background levels the following
settings are recommended:
Target amplitude (TMA)
-6
Maximum Amplification (MA)
18 dB
Ai-Logix, Inc.
292 •
SmartWORKS Developer’s Guide
API CONTROL
Originally Activity Detection was designed to work in the following way:
• activity detection, when enabled with MTEnableACTD(), only worked on the
primary input of the channel. MTEnableMixing() then MTEnableMixingDe-
tect() was used to enable activity detection on the secondary channel. The
API SetACTDParams() configured activity detection parameters, but the
same values were used for both inputs.
The APIs used to control activity detection were recently enhanced to allow for
configuration on a per input basis.
Users can still control activity parameters with the API MTSetACTDParams().
However, this method is only recommended when activity detection configuration
is the same on both inputs.
To control activity detection on the primary input, do the following:
- MTChInputACTDControl() - enable / disable activity detection
- MTChInputSetACTDParams() or MTSetACTDParams() - configures activity
detection parameters
To control activity detection on both inputs, do the following:
- MTEnableMixing() - combine the primary and secondary inputs
- MTChInputACTDControl() - enables / disables activity detection (per input).
MTEnableMixingDetect() will be obsoleted in Jan. 2005.
- MTChInputSetACTDParams() - configures activity detection parameters on
both the primary and secondary inputs (NOTE: MTSetACTD() can still be used,
but the configuration values will be the same for both the primary and
secondary inputs).
Function Reference Library
• 293
Introduction
MTSetAGC()
Description
MTSetAGC() sets the input Automatic Gain Control parameters for
both inputs on the channel.
Parameter TMA (target maximum amplitude) ranges from 1 to -45
dBm. The default is 0 dBm.
Parameter AGCR (attack gain change rate) is in unit of -0.00212 dB
per millisecond. The default is 400 units, i.e., (-0.00212 x 400) dB/ms.
Parameter DGCR (decay gain change rate) is in unit of 0.00212 dB
per millisecond. The default is 8 units, i.e., (0.00212 x8) dB/ms.
Parameter MA (maximum amplification) ranges from 6 dB to 48 dB
in 6 dB steps. This parameter must be in multiple of 6 dB. The
default is 42 dB.
NOTE: For a complete explanation of gain control refer to
“Introduction: Automatic Gain Control” on page 288 .
Prototype
MT_RESULT MTSetAGC() (
const CHANNEL nChannel,
const SHORT TMA,
const SHORT AGCR,
const SHORT DGCR,
const SHORT MA
);
Parameters
nChannel channel number
TMA Target Maximum Amplitude, 1 to -45
dBm, def= -6 dBm
AGCR Attack Gain Change Rate, in unit of -
0.00212 dB/ms, def=400.
Value must be: >=0
DGCR Decay Gain Change Rate, in unit of
0.00212 dB/ms, def=4
Value must be: >=0
MA Maximum Amplification, 6 dB to 48 dB in
6dB steps, def=30 dB
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
See Also: MTSetAVC()
Ai-Logix, Inc.
294 •
SmartWORKS Developer’s Guide
MTChInputSetAGC()
Formally known as MTSetAGC().
Description
MTChInputSetAGC() sets the input Automatic Gain Control
parameters on a per input basis for each channel.
MTGetAGC()
Description
MTGetAGC() retrieves the input AGC parameters used by both
inputs per channel.
Parameter TMA (target maximum amplitude) ranges from 1 to -45
dBm. The default is 0 dBm.
Parameter AGCR (attack gain change rate) is in unit of -0.00212 dB
per millisecond. The default is 400 units, i.e., (-0.00212 x 400) dB/ms.
Parameter DGCR (decay gain change rate) is in unit of 0.00212 dB
per millisecond. The default is 8 units, i.e., (0.00212 x8) dB/ms.
Parameter MA (maximum amplification) ranges from 6 dB to 48 dB
in 6 dB steps. This parameter must be in multiple of 6 dB. The
default is 42 dB.
NOTE: For a complete explanation of gain control refer to
“Introduction: Automatic Gain Control” on page 288 .
Prototype
MT_RESULT MTGetAGC (
const CHANNEL nChannel,
PSHORT const pTMA,
PSHORT const pAGCR,
PSHORT const pDGCR,
PSHORT const pMA
);
Parameters
nChannel channel number
pTMA Target Maximum Amplitude, 1 to -45
dBm, def= -6 dBm
pAGCR Attack Gain Change Rate, in unit of -
0.00212 dB/ms, def=400
Value must be: >=0
pDGCR Decay Gain Change Rate, in unit of
0.00212 dB/ms, def=4
Value must be: >=0
pMA Maximum Amplification, 6 dB to 48 dB in
6dB steps, def= 30 dB
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 297
Introduction
MTChInputGetAGC()
Formally known as MTGetAGC().
Description
MTChInputGetAGC() retrieves the input Automatic Gain Control
parameters on a per input basis for each channel.
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 299
Introduction
MTSetGain()
Description
MTSetGain() sets the gain for both inputs of the specified channel.
Valid gain values range from -50 dB to +24dB. By default, the gain is
set to 0 dB.
Opening and closing a channel will not affect the gain settings. If
one application opens and sets the gain of a channel to 6dB and
closes the channel, the channel’s gain setting is left at 6dB until an
application sets it to a different value.
CODE EXAMPLE
Code Example MTSetGain()
handleMT(MTSetGain(channel,gain),"MTSetGain() channel %d",channel);
MTChInputSetGain()
Formally known as MTSetGain().
Description
MTChInputSetGain() sets the input gain of the specified input per
channel. Valid gain values range from -50 dB to +24dB. By default,
the gain is set to 0 dB.
Opening and closing a channel will not affect the gain settings. If
one application opens and sets the gain of a channel input to 6dB
and closes the channel, the input’s gain setting is left at 6dB until an
application sets it to a different value.
MTGetGain()
Description
MTGetGain() gets the current gain of both inputs on the specified
channel. Valid gain values range from -50 dB to +24dB. By default,
the gain is set to 0 dB.
Opening and closing a channel will not affect the gain settings. If
one application opens and sets the gain of a channel to 6dB and
closes the channel, the channel’s gain setting is left at 6dB until an
application sets it to a different value.
CODE EXAMPLE
MTGetGain()
if(handleMT(MTGetGain(channel,&gain),"MTGetGain() channel %d",channel))
cout << "Gain = " << gain << endl << endl;
MTChInputGetGain()
Formally known as MTGetGain().
Description
MTChInputGetGain() gets the current gain of the specified input
per channel. Valid gain values range from -50 dB to +24dB. By
default, the gain is set to 0 dB.
Opening and closing a channel will not affect the gain settings. If
one application opens and sets the gain of the input to 6dB and
closes the channel, the input’s gain setting is left at 6dB until an
application sets it to a different value.
MTStepGain()
Description
Use this API to modify the gain value that has been set with the
MTSetGain() function. By default gain is set to a default of 0. This
API can be used to step the gain up or down by 1dB or reset gain to
default of 0.
Step values:
-1 Adjust gain down by 1 dB
1 Adjust gain up by 1 dB
0 Reset gain to 0 dB
MTSetGain() sets the input gain of the specified channel. Valid gain
values range from -50 dB to +24dB. By default, the gain is set to 0
dB.
Opening and closing a channel will not affect the gain settings. If
one application opens and sets the gain of a channel to 6dB and
closes the channel, the channel’s gain setting is left at 6dB until an
application sets it to a different value.
MTChInputStepGain()
Formally known as MTStepGain().
Description
Use this API to modify the gain value that has been set with the
MTSetGain() or MTChInputSetGain() function. By default gain is
set to a default of 0. This API can be used to step the gain up or
down by 1dB or reset gain to default of 0. This API steps the gain
level of the specified input per channel.
Step values:
-1 Adjust gain down by 1 dB
1 Adjust gain up by 1 dB
0 Reset gain to 0 dB
MTAGCControl()
Description
MTAGCControl() enables or disables the AGC for both inputs of the
specified channel. AGC parameters are set through MTSetAGC().
AGC control is disabled by default.
If a channel's AGC is enabled, opening/closing of a channel is not
going to change this state.
NOTE: To control the AGC of the two inputs independantly of one
another use MTChInputAGCControl() and then
MTChInputSetAGC().
NOTE: For a complete explanation of gain control refer to
“Introduction: Automatic Gain Control” on page 288 .
Prototype
MT_RESULT MTAGCControl (
const CHANNEL nChannel,
const BOOLEAN fOn
);
Parameters
nChannel channel number
fOn TRUE for enable AGC; FALSE for disable
AGC
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Ai-Logix, Inc.
306 •
SmartWORKS Developer’s Guide
MTChInputAGCControl()
Formally known as MTAGCControl().
Description
MTChInputAGCControl() enables or disables the input Automatic
Gain Control of the specified input per channel. When this control
option is used, AGC parameters must be set with
MTChInputSetAGC() instead of MTSetAGC().
AGC control is disabled by default.
If a channel's AGC is enabled, opening/closing of a channel is not
going to change this state.
NOTE: For a complete explanation of gain control refer to
“Introduction: Automatic Gain Control” on page 288 .
Prototype
MT_RESULT MTChInputAGCControl (
const CHANNEL nChannel,
const SHORT nInput,
const BOOLEAN fOn
);
Parameters
nChannel channel number
nIndex Input Index: 0=primary,1=secondary
fOn TRUE for enable AGC; FALSE for disable
AGC
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 307
Introduction
MTAGCStatus()
Description
MTAGCStatus() retrieves the AGC operating status (TRUE for
enabled; FALSE for disabled) for both inputs on a channel. This
status check is used when AGC is enabled using MTAGCControl(). If
the API MTChInputAGCControl() was used to enable AGC, then
use MTChInputAGCStatus().
If a channel's AGC is enabled, opening/closing of a channel is not
going to change this state.
Prototype
MT_RESULT MTAGCStatus (
const CHANNEL nChannel,
BOOLEAN * const pOn
);
Parameters
nChannel channel number
pOn TRUE for AGC on, FALSE for AGC off
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Ai-Logix, Inc.
308 •
SmartWORKS Developer’s Guide
MTChInputAGCStatus()
Formally known as MTAGCStatus().
Description
MTChInputAGCStatus() retrieves the AGC operating status (TRUE
for enabled; FALSE for disabled) of each input on the channel.
This status check is used when AGC is enabled using
MTChInputAGCControl(). If the API MTAGCControl() was used to
enable AGC, then use MTAGCStatus().
If a channel's AGC is enabled, opening/closing of a channel is not
going to change this state.
Prototype
MT_RESULT MTChInputAGCStatus (
const CHANNEL nChannel,
const SHORT nInput,
BOOLEAN * const pOn
);
Parameters
nChannel channel number
nInput Input Index: 0=primary, 1=secondary
pOn TRUE for AGC on, FALSE for AGC off
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 309
Introduction
MTGetAVC()
Description
MTGetAVC() retrieves the output AVC parameters.
Parameter TMA (target maximum amplitude) ranges from 1 to -45
dBm. The default is -6 dBm.
Parameter AVCR (attack volume change rate) is in unit of -0.00212
dB per millisecond. The default is 400 units, i.e., (-0.00212 x 400) dB/
ms.
Parameter DVCR (decay volume change rate) is in unit of 0.00212 dB
per millisecond. The default is 4 units, i.e., (0.00212 x8) dB/ms.
Parameter MA (maximum amplification) ranges from 6 dB to 48 dB
in 6 dB steps. The default is 30 dB.
Prototype
MT_RESULT MTGetAVC (
const CHANNEL nChannel,
PSHORT const pTMA,
PSHORT const pAVCR,
PSHORT const pDVCR,
PSHORT const pMA
);
Parameters
nChannel channel number
pTMA pointer to Target Max. Amplitude, 1 to -
45 dBm, def=-6 dBm
pAVCR pointer to Attack Volume Change Rate
pDVCR pointer to Decay Volume Change Rate
pMA pointer to Maximum Amplification
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Ai-Logix, Inc.
310 •
SmartWORKS Developer’s Guide
MTSetVolume()
Description
MTSetVolume() sets the output volume of the specified channel.
Valid ranges for this parameter are from +24 dB to –50 dB. By
default, the volume is set to 0 dB. Setting the volume to -50 dB is
equal to muting the channel input.
Opening and closing a channel will not affect the volume setting.
Therefore, if one application opens and sets the volume of a
channel to 6dB and closes the channel, the channel's volume
setting will be left at 6dB until (the same or other) application sets it
to a different value.
Prototype
MT_RESULT MTSetVolume (
const CHANNEL nChannel,
const SHORT Volume
);
Parameters
nChannel channel number
Volume valid range: +24 dB to -50dB
-50 equals muting
def=0dB
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
See Also: MTSetGain()
CODE EXAMPLE
Code Example MTSetVolume()
handleMT(MTSetVolume(channel,volume),"MTSetVolume() channel %d, volume
%d",channel,volume);
MTGetVolume()
Description
MTGetVolume() gets the current output volume of the specified
channel. Valid ranges for this parameter are from +24 dB to –50 dB.
By default, the volume is set to 0 dB. Setting the volume to -50 dB is
equal to muting the channel input.
Opening and closing a channel will not affect the volume setting.
Therefore, if one application opens and sets the volume of a
channel to 6dB and closes the channel, the channel's volume
setting will be left at 6dB until (the same or other) application sets it
to a different value.
Prototype
MT_RESULT MTGetVolume (
const CHANNEL nChannel,
const PSHORT pVolume
);
Parameters
nChannel channel number
pVolume pointer to volume
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
CODE EXAMPLE
Code Example MTGetVolume()
if(handleMT(MTGetVolume(channel,&volume),"MTGetVolume() channel %d",channel))
cout << "Volume = " << volume << endl <<
endl;
MTStepVolume()
Description
Step the volume up or down by 1dB or reset volume to default of 0.
Step values:
-1 Adjust volume down by 1 dB
1 Adjust volume up by 1 dB
0 Reset volume to 0 dB
Opening and closing a channel will not affect the volume setting.
Therefore, if one application opens and sets the volume of a
channel to 6dB and closes the channel, the channel's gain setting
will be left at 6dB until (the same or other) application sets it to a
different value.
Prototypes
MT_RESULT MTStepVolume(
const CHANNEL nChannel,
const SHORT step
);
Parameters
nChannel channel number
step mode for step, STEP_DOWN,
STEP_RESET, or STEP_UP
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 313
Introduction
CODE EXAMPLE
Code Example MTStepVolume()
if(handleMT(MTGetVolume(channel,&volume),"MTGetVolume() channel %d",channel))
cout << "Volume = " << volume << endl <<
endl;
MTAVCControl()
Description
MTAVCControl() enables or disables the output AVC of the
specified channel. AVC parameters are set through MTSetAVC().
MTSetAVC()
Description
MTSetAVC() sets the output AVC parameters.
Parameter TMA (target maximum amplitude) ranges from 1 to -45
dBm. The default is -6 dBm.
Parameter AVCR (attack volume change rate) is in unit of -0.00212
dB per millisecond. The default is 400 units, i.e., (-0.00212 x 400) dB/
ms.
Parameter DVCR (decay volume change rate) is in unit of 0.00212 dB
per millisecond. The default is 4 units, i.e., (0.00212 x8) dB/ms.
Parameter MA (maximum amplification) ranges from 6 dB to 48 dB
in 6 dB steps. This parameter must be in multiple of 6 dB. The
default is 30 dB.
Prototype
MT_RESULT MTSetAVC (
const CHANNEL nChannel,
const SHORT TMA,
const SHORT AVCR,
const SHORT DVCR,
const SHORT MA
);
Parameters
nChannel channel number
TMA Target Maximum Amplitude, 1 to -45
dBm, def=-6 dBm
AVCR Attack Volume Change Rate, in unit of -
0.00212 dB/ms, def=400
Value must be: <=0
DVCR Decay Volume Change Rate, in unit of
0.00212 dB/ms, def=4
Value must be: <=0
MA Maximum Amplification, 6 dB to 48 dB in
6dB steps, def=30 dB
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Ai-Logix, Inc.
316 •
SmartWORKS Developer’s Guide
MTAVCStatus()
Description
MTAVCStatus() retrieves the output AVC operating status: TRUE for
enabled; FALSE for disabled.
If a channel's AVC is enabled, opening/closing of a channel is not
going to change this state.
Prototype
MT_RESULT MTAVCStatus (
const CHANNEL nChannel,
BOOLEAN * const pOn
);
Parameters
nChannel channel number
pOn TRUE for AVC on, FALSE for AVC off
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 317
Introduction
MTGetGCI()
Description
All APIs use the GCI as a channel reference. This function retrieves
the GCI based on the provided board and on board channel
indexes.
Prototype
MT_RESULT MTGetGCI (
const BOARD nBoard,
const CHANNEL nChannelOnBoard,
PCHANNEL const pGCI
);
Parameters
nBoard board number
nChannelOnBoard channel number on board
pGCI pointer to logical channel number
(channel GCI)
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_INVALID_BOARD Board number is out of range
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
CODE EXAMPLE
MTGetGCI()
result = MTGetGCI(board,channel,&pChannel);
if(result == MT_RET_OK)
{
printf("MTGetGCI() successful...\n");
printf("GCI: %d\n",pChannel);
}
A complete code example is available on the Ai-Logix website:
http://www.ai-logix.com/support.html
Function Reference Library
• 319
Introduction
MTGetGCIMap()
Description
All APIs use GCI as a channel reference. This function maps a GCI
indexed channel to a board on the system, as well as the channel
index on that board. Board type information is also provided for
reference. Information about each board can be retrieved through
MTGetAdapterInfo() function.
Prototype
MT_RESULT MTGetGCIMap (
const CHANNEL nGCI,
PBOARD const0 pBoard,
PUSHORT const pTDMBoardType,
PCHANNEL const pChannelOnBoard
);
Parameters
nGCI logical channel number, (GCI for a chan-
nel
pBoard pointer for board index, 0 for the first
board
pTDMBoardType pointer for board type
pChannelOnBoard pointer for on board channel index, 0 for
the first channel on board (not affected
by user’s GCI index setting)
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
See Also: MTGetAdapterInfo()
Ai-Logix, Inc.
320 •
SmartWORKS Developer’s Guide
MTHighpassFilterControl()
Description
Setting the input highpass filter on enables seconday and primary
PCM streams to pass through a highpass filter before further
processing.
By default, the highpass filter is enabled. This API need not be used
unless the input highpass filter was disabled previously to the
channel.
It is highly recommended that highpass filtering remain enabled,
especially when using SmartWORKS DT and SmartWORKS DP
boards.
Prototype
MT_RESULT MTHighpassFilterControl (
const CHANNEL nChannel,
const BOOLEAN fOn
);
Parameters
nChannel channel number
fOn TRUE to enable the filter, FALSE to dis-
able the filter
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
Events
None
Ai-Logix, Inc.
322 •
SmartWORKS Developer’s Guide
MTHighpassFilterStatus()
Description
Retrieves the status of the input high pass filter for the specified
channel. See MTHighpassFilterControl().
Prototype
MT_RESULT MTHighpassFilterStatus (
const CHANNEL nChannel,
BOOLEAN * const pOn
);
Parameters
nChannel channel number
pOn TRUE to enable the filter, FALSE to dis-
able the filter
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
Events
None
Function Reference Library
• 323
Introduction
MTSetDeviceIO()
Description
Register’s the specified channel’s user device I/O routines for record
and playback media access through MTRecDevice() and
MTPlayDevice().
The parameters should contain at least one non-NULL address for
either read() or write(). Specification for seek is optional. However,
should seek not be defined, MT_IO_CONTROL.FileIndex filed should
be set to 0 when calling MTPlayDevice(), and MTRecDevice().
MTDEVICEIO is defined as a boolean function which takes the file
handle, buffer pointer, data length, and pointer for returned data
length as parameters. A return value of TRUE indicates that the
device function has completed the task successfully. A return value
of FALSE indicates error in user IO and terminates the API functions
such as MTRecDevice() and MTPlayDevice().
MTStartCurrentFunction()
Description
In NTI, all record and playback tasks are controlled through the
MT_IO_CONTROL.StartControl field. This API suppresses the start
control of START_ACTD, START_LOOPON, and START_LVOLTAGE for
the current pending task and forces the task to start immediately.
Note: Currently, the start control is applicable only on record.
Should there be start control added for playback in the future, this
API will suppress those start controls also.
MTStartMUX()
Description
MTStartMUX() is called to prepare MUX operation before MUX
connections can be made. All configurations will be set to default
based on the configuration of the TDMCardType and TDMBusType.
On successful execution, USHORT pointer contains the total
configured channels grabbed by the application.
When calling this function after MUX is already started, return code
MT_RET_MUX_ON will be returned and channel numbers will be
retrieved if buffer is provided. Error code MT_RET_NO_MUX will be
returned if MUX system is not available.
Events
None
Ai-Logix, Inc.
334 •
SmartWORKS Developer’s Guide
MTStopMUXOnChannel()
Description
MTStopMUXOnChannel() clears the MUX connection on the
specified channel without shutting the MUX down, hence leaving
MUX on other channels undisturbed.
When calling this function after MUX is stopped the return code
MT_RET_MUX_OFF will be returned.
Prototype
MT_RESULT MTStopMUXOnChannel (
const CHANNEL nChannel
);
Parameters
nChannel channel number
Return Codes
MT_RET_OK No error
MT_RET_MUX_OFF MUX not started
MT_TIMEOUT Wait for event timed out
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_IDLE Channel is idle
Events
None
See Also: MTSysShutdown()
Function Reference Library
• 335
Introduction
MTStopMUX()
Description
MTStopMUX() clears all existing MUX connections on all channels
grabbed by the user application and shuts the MUX down.
When calling this function after MUX is stopped, return code
MT_RET_MUX_OFF will be returned.
MTGetCTSlotConnection()
Description
This function returns a status table of a group of CT timeslots. The
group is specified by the following parameters: StartStream,
StartTimeSlot, and pSlotCount. If the requested pSlotCount exceeds
the actual available time slots, the number of actual timeslots will
be returned.
Prototype
MT_RESULT MTGetCTSlotConnection(
const int BusType,
const int StartStream,
const int StartTimeSlot,
int * const pSlotCount ,
PMT_CT_SLOT const pSlotTable
);
Parameter
BusType MUX_MVIP or MUX_H100
StartStream Indexed 0 to 15 for MVIP, 31 for H100
StartTimeSlot Indexed 0 to MAX_MVIP_SLOT-1 or
MAX_H100_SLOT-1
pSlotCount Pointer to count of the MT_CT_SLOT
buffer
pSlotTable Pointer to MT_CT_SLOT buffer
Return Codes
MT_RET_OK No error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_BOARD Board number is out of range
MT_RET_BOARD_NOT_OPENED Board device not opened for
access
MT_RET_INVALID_BUSTYPE Failure to specify MUX_MVIP or
MUX_H100
Events
None
Events
None
Events
None
Function Reference Library
• 337
Introduction
PLAY FUNCTIONS
Record and playback are background functions that are queued for execution in the
order of their arrival. Functions are separated to an encode or decode queue.
For record functionality, the SmartWORKS API starts encoding when a record
request is queued and stops the encoding when all queued requests are filled.
Should the recording media format differ from one request to the next, the
encoding will be reset and restarted on the execution of the request with the new
media format. The APIs for record are MTRecBuffer() and MTRecFile().
The same applies to playback functionality. APIs for playback are MTPlayBuffer()
and MTPlayFile().
All queued record and playback requests can be deleted through function
MTStopCurrentFunction() or MTStopChannel(). When an application terminates a
playback function manually with the MTStopChannel() function, then the data
remaining in the SmartWORKS board hardware buffer is flushed.
MEDIA CONTROL
The SmartWORKS Media Control interface makes it possible to encode and decode
audio voice data to and from the host system. The Media Control interface has two
basic modes of operation: file mode or data-streaming mode. When using file
mode, the Media Control interface manages all file I/O overhead and will record or
play voice data directly to disk. In the data-streaming mode, voice data is passed to
buffers, which the application must manage.
INDEXED FILE PLAYBACK
A special playback mode is the indexed playback. With the MTPlayIndex() function,
the application passes a file handle to the API, as well as a table of file offsets and
byte counts. This table describes blocks of data from the file that should be played
back in the order described. This is used for playing messages, prompts, and spoken
numbers.
A simple indexed number file can consist of recordings of the numbers zero
through nine, preceded by a table of indexes and block sizes where those
recordings can be found. When the application wants to pronounce a phone
number, it builds an index table of the desired numbers to playback. The built table
is passed to the driver, which will play the blocks from the file in the specified order.
The MTPlayIndex() function is provided to eliminate the overhead of opening and
closing separate files for each digit to pronounce, as well as to facilitate smooth
transitions between the blocks.
Ai-Logix, Inc.
338 •
SmartWORKS Developer’s Guide
Prototype
MT_RESULT MTPlayBuffer (
const CHANNEL nChannel,
const PMT_IO_CONTROL pIoCtl
);
MT_RESULT MTPlayBufferEx(
const CHANNEL nChannel,
const PMT_IO_CONTROL pIoCtl,
const LPOVERLAPPED pOverlapped
);
MT_RESULT MTPlayBufferAsync(
const CHANNEL nChannel,
const PMT_IO_CONTROL pIoCtl,
const MTCOMPLETE pCompletionRoutine,
const LPARAM lParam
);
Parameters
nChannel channel number of the channel to play
to
pIoCtl pointer to a MT_IO_CONTROL struc-
ture (defined in the previous chapter of
this book).
Function Reference Library
• 339
Introduction
NOTE
If UNICODE is defined SmartWORKS will call the API with the ‘W’ suffix, if UNICODE is
not defined, SmartWORKS will call the API with the ‘A’ suffix. i.e. MTPlayFileA or
MTPlayFileW.
Description
MTPlayFile() is a background function that plays data from a file.
MTPlayFile(), MTPlayFileAsync(), and MTPlayFileEx() will actually
map to modified versions of themselves depending on whether or
not UNICODE is defined for the user application. See “UNICODE
Support” on page 23 for more information about APIs affected by
defining UNICODE in a user application.
Prototype
MT_RESULT MTPlayFile (
const CHANNEL nChannel,
PCSTR -(A) pFileName,
PCWSTR - (W)
const PMT_IO_CONTROL pIoCtl
);
MT_RESULT MTPlayFileEx (
const CHANNEL nChannel,
PCSTR - (A) pFileName,
PCWSTR - (W)
const PMT_IO_CONTROL pIoCtl,
const LPOVERLAPPED pOverlapped
);
MT_RESULT MTPlayFileAsync (
const CHANNEL nChannel,
PCSTR - (A) pFileName,
PCWSTR - (W)
const PMT_IO_CONTROL pIoCtl,
const MTCOMPLETE pCompletionRoutine,
const LPARAM lParam
);
Parameters
nChannel channel number
pFileName ASCII file name
pIoCtl pointer to a MT_IO_CONTROL struc-
ture (defined in the previous chapter of
this book).
pOverlapped pointer to overlapped structure
lParam user defined parameter
pCompleteRoutine completion routine address
Function Reference Library
• 341
Introduction
Return Codes
MT_RET_OK No error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_IO_PENDING Background I/O operation is in
progress or queued
MT_RET_BUSY On channel busy
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_NO_MEM An operation could not be com-
pleted due to insufficient mem-
ory or an error occurred while
attempting to allocate memory
MT_RET_FORMAT_NOT_SUPPORTED Media format is not supported
for this channel
MT_RET_INVALID_FILENAME Invalid file name
Events
EVT_EOF
EVT_MAXBYTE
EVT_MAXTIME
EVT_MAXDIGIT
EVT_INTERDIGIT
EVT_TERMDIGIT
See Also: MTRecFile(), MTPlayBuffer(), MTStreamBufOut(),
MTPlayDevice()
Ai-Logix, Inc.
342 •
SmartWORKS Developer’s Guide
CODE EXAMPLE
Code Example MTPlayFile()
handleMT(MTSetEventFilters(channel,filters,rings),"MTSetEventFilters() channel
%d, filters %d, rings %d",channel,filters,rings);
handleMT(MTSetEventCallback(channel,(MTCALLBACK)ChannelEventCallBack,0),"MTSet
EventCallback() channel %d",channel);
ZeroMemory(&ioctrl,size);
ioctrl.FileType = MT_PCM_Raw_16bit;
if(handleMT(MTPlayFile(channel,buffer.c_str(),&ioctrl),"MTPlayFile() channel
%d",channel))
{
wait = true;
while(wait)
Sleep(20);
}
handleMT(MTClearEventCallback(channel),"MTClearEventCallback() channel
%d",channel);
handleMT(MTSysShutdown(),"MTSysShutdown()");
CODE EXAMPLE
Code Example MTPlayFileAsync()
if(!handleMT(MTSysStartup(),"MTSysStartup()"))
exit(-1);
ZeroMemory(&ioctrl,size);
ioctrl.FileType = MT_PCM_Raw_16bit;
if(handleMT(MTPlayFileAsync(channel,buffer.c_str(),&ioctrl,(MTCOMPLETE)AsyncCa
llBack,0x1234),"MTPlayFileAsync() channel %d",channel))
{
wait = true;
while(wait)
Sleep(20);
}
handleMT(MTSysShutdown(),"MTSysShutdown()");
NOTE
If UNICODE is defined SmartWORKS will call the API with the ‘W’ suffix, if UNICODE is
not defined, SmartWORKS will call the API with the ‘A’ suffix. i.e. MTPlayIndexA or
MTPlayIndexW.
MTPlayIndex(), MTPlayIndexEx(), and MTPlayIndexAsync() will actually map to
modified versions of themselves depending on whether or not UNICODE is defined
for the user application. See “UNICODE Support” on page 23 for more information
about APIs affected by defining UNCODE in a user application
Description
The parameter PMT_INDEX_TABLE is a pointer to an array of the
MT_INDEX_TABLE.
Setting the MT_INDEX_TABLE.Phraseoffset to -1 indicates the end of
an array.
Setting the MT_INDEX_TABLE.PhraseLength to 0 indicates a
skipping of that index entry.
TABLE 7: MT_INDEX_TABLE
Type Name Purpose
ULONG Phraseoffset offset, from the beginning of the file, to start the play from
Set to -1 to indicate the end of the table
ULONG PhraseLength Length of data to play. Set to 0 to indicate a skipping of
index entry.
Return Codes
MT_RET_OK No error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_IO_PENDING Background I/O operation is in
progress or queued
MT_RET_BUSY On channel busy
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_NO_MEM An operation could not be com-
pleted due to insufficient mem-
ory or an error occurred while
attempting to allocate memory
MT_RET_FORMAT_NOT_SUPPORTED Media format is not supported
for this channel
MT_RET_INVALID_FILENAME Invalid file name
Events
EVT_INDEX_PLAYED
Other termination events
Ai-Logix, Inc.
346 •
SmartWORKS Developer’s Guide
RECORD FUNCTIONS
Record and playback are background functions that are queued for execution on
the order of their arrival to either encode queue or decode queue separately.
For record functionality, the SmartWORKS API starts the encoding when a record
request is queued and stops the encoding when all queued requests are filled.
Should the recording media format differs from one request to the next, the
encoding will be reset and restarted on the execution of the request with the new
media format. The APIs for record are MTRecBuffer() and MTRecFile().
The same applies to playback functionality. APIs for playback are MTPlayBuffer()
and MTPlayFile().
All queued record and playback requests can be deleted through function
MTStopCurrentFunction() or MTStopChannel(). When an application terminates a
playback function manually with the MTStopChannel() function, then the data
remaining in the SmartWORKS board hardware buffer is flushed.
MEDIA CONTROL
The SmartWORKS Media Control interface makes it possible to encode and decode
audio voice data to and from the host system. The Media Control interface has two
basic modes of operation: file mode or data-streaming mode. When using file
mode, the Media Control interface manages all file I/O overhead and will record or
play voice data directly to disk. In the data-streaming mode, voice data is passed to
buffers, which the application must manage.
Function Reference Library
• 347
Introduction
Prototype
MT_RESULT MTRecBuffer (
const CHANNEL nChannel,
const PMT_IO_CONTROL pIoCtl
);
MT_RESULT MTRecBufferEx (
const CHANNEL nChannel,
const PMT_IO_CONTROL pIoCtl,
const LPOVERLAPPED pOverlapped
);
MT_RESULT MTRecBufferAsync (
const CHANNEL nChannel,
const PMT_IO_CONTROL pIoCtl,
const MTCOMPLETE pCompletionRoutine,
const LPARAM lParam
);
Parameters
nChannel channel to record from
pIoCtl pointer to a MT_IO_CONTROL struc-
ture (defined in the previous chapter of
this book).
Ai-Logix, Inc.
348 •
SmartWORKS Developer’s Guide
CODE EXAMPLE
Code Example MTRecBufferAsync()
ZeroMemory(&event,evtsize);
ZeroMemory(&ioctrl,iosize);
ioctrl.Buffer = buffer;
ioctrl.Length = 1024;
ioctrl.FileType = MT_PCM_Raw_16bit;
if(handleMT(MTRecBufferAsync(channel,&ioctrl,(MTCOMPLETE)AsyncCallBack,0x1234)
,"MTRecBufferAsync() channel %d",channel))
{
wait = true;
while(wait)
Sleep(20);
}
NOTE
If UNICODE is defined SmartWORKS will call the API with the ‘W’ suffix, if UNICODE
is not defined, SmartWORKS will call the API with the ‘A’ suffix. i.e. MTRecFileA or
MTRecFileW.
Description
MTRecFile() is a background function that starts recording to a file.
If this function terminates because of MaxSilence (as specified by
the MT_IO_CONTROL structure), the silence data is discarded. The
SILENCE_TRUNCATION bit must be set in MT_IO_CONTROL in the
StartControl field. Note that Ai-Logix’s legacy products had start
offsets set by incrementing the offset by the file size plus 1 byte.
SmartWORKS does not follow this convention. Instead, offsets
under the SmartWORKS API are set by using the exact file size or
less than the exact files size if you wish to trim back the recording
over the tail of the previous recording.
CODE EXAMPLE
Code Example MTRecFile()
handleMT(MTSetEventFilters(channel,filters,rings),"MTSetEventFilters() channel
%d, filters %d, rings %d",channel,filters,rings);
handleMT(MTSetEventCallback(channel,(MTCALLBACK)ChannelEventCallBack,0),"MTSet
EventCallback() channel %d",channel);
string buffer =
"C:\\recordings\\testrec.pcm"; // file to be recorded
ZeroMemory(&ioctrl,size);
ioctrl.FileType = MT_PCM_Raw_16bit;
if(handleMT(MTRecFile(channel,buffer.c_str(),&ioctrl),"MTRecFile() channel
%d",channel))
{
wait = true;
while(wait)
Sleep(20);
}
handleMT(MTClearEventCallback(channel),"MTClearEventCallback() channel
%d",channel);
CODE EXAMPLE
Code Example MTRecFileAsync()
string buffer = "C:\\recordings\\testrec.pcm"; // file to be recorded
ZeroMemory(&ioctrl,size);
ioctrl.FileType = MT_PCM_Raw_16bit;
if(handleMT(MTRecFileAsync(channel,buffer.c_str(),&ioctrl,(MTCOMPLETE)AsyncCal
lBack,0x1234),"MTRecFileAsync() channel %d",channel))
{
wait = true;
while(wait)
Sleep(20);
}
STREAM FUNCTIONS
Function Reference Library
• 353
Introduction
NOTE: The SmartWORKS DLL limits buffer size: maximum streaming buffer
size is set to 1MBytes, minimum cap to 1KBytes.
Ai-Logix, Inc.
354 •
SmartWORKS Developer’s Guide
MTSetStreamingConfig()
Description
Configures channel streaming parameters. The default streaming
buffer block size is 64K.
Scenario
The streaming buffer size will be applied on the next
MTSartStreaming() call. If streaming is active, it’s buffer size will
not be changed.
NOTE: The SmartWORKS DLL limits buffer size: maximum streaming buffer
size is set to 1MBytes, minimum cap to 1KBytes.
Prototype
MT_RESULT MTSetStreamingConfig(
const CHANNEL nChannel,
const ULONG BufSize
);
Parameters
nChannel channel number
BufSize DLL buffer size, the size of the buffer set
by the application for the DLL to buffer
into. Default 64K bytes. Valid range:
1Kbytes - 1MBytes
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 355
Introduction
MTGetStreamingConfig()
Description
Gets channel streaming parameters. The default streaming buffer
block size is 64K.
Prototype
MT_RESULT MTGetStreamingConfig(
const CHANNEL nChannel,
const PULONG pBufSize
);
Parameters
nChannel channel number
pBufSize DLL buffer size, the size of the buffer set
by the application for the DLL to buffer
into. Default 64K bytes
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Ai-Logix, Inc.
356 •
SmartWORKS Developer’s Guide
MTStartStreaming()
Description
Currently, encode streaming and decode streaming should be
started separately through two calls to MTStartStreaming().
TIP: If you are doing real-time monitoring and sending data directly
from the event routine to a monitoring routine you can reduce the
latency between recording and playing by making the watermark
size much smaller. The optimal size depends on the encoding
format in use. For example, with MS GSM 6.10 33 bytes of data are
recorded each 20 ms. Therefore, a buffer size of 165 bytes would
result in data being captured 100 ms after the first byte had been
recorded. This would imply a barely perceptible delay between
recording and playing. The downside of a smaller watermark is
more frequent channel service.
NOTE: MaxBytes and MaxTime cannot be used for termination
limits when streaming.
NOTE: The SmartWORKS DLL limits buffer size: maximum streaming buffer
size is set to 1MBytes, minimum cap to 1KBytes.
Prototype
MT_RESULT MTStartStreaming(
const CHANNEL nChannel,
const USHORT Action,
const PMT_IO_CONTROL pIoCtl
);
Parameters
nChannel channel number
Action action of the following:
MT_STREAM_INPUT
MT_STREAM_OUTPUT
pIoCtl pointer to a MT_IO_CONTROL struc-
ture (defined in the previous chapter of
this book). NOTE: MaxBytes and Max-
Time cannot be used for termination
limits when streaming.
Function Reference Library
• 357
Introduction
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_BUSY When streaming already
started, or when channel is
busy
MT_RET_IO_PENDING Streaming is in startup process
(this is the normal return code
when the API is successfully
called)
MT_RET_NO_MEM On internal memory shortage
MT_RET_FORMAT_NOT_SUPPORTED Media format is not supported
for this channel
Events
EVT_STREAMIN_START
EVT_STREAMOUT_START
EVT_STREAMIN_DROPPED
EVT_STREAMOUT_EMPTY
EVT_STREAMIN_WATERMARK
EVT_STREAMOUT_WATERMARK
Ai-Logix, Inc.
358 •
SmartWORKS Developer’s Guide
MTStreamBufOut()
Description
Instead of using MTPlayBuffer() to play a specified size of voice
data, the application can use a stream output function. This enables
buffering into the internal queue for playback until the user stops
the stream function.
The timeout specifies the waiting time for queue availability. Should
timeout be set to 0, this function returns immediately. If there is
enough space in the queue to satisfy the requested data length,
data will be moved from the user buffer to the queue. Otherwise,
the data length will be set to 0 on return. Should the timeout be set
to none zero, this function returns when either the specified
timeout expires or a data block of the specified size is moved to the
queue buffer, whichever happens first. In both cases, the data
length field will contain the actual byte count of data been moved
from the user buffer to the internal queue. The timeout period is at
least 20 milliseconds.
The stream data length should contain the user specified data
length and will be set to the actual data moved into the internal
buffer on return.
NOTE: The SmartWORKS DLL limits buffer size: maximum streaming buffer
size is set to 1MBytes, minimum cap to 1KBytes.
Prototype
MT_RESULT MTStreamBufOut(
const CHANNEL nChannel,
const DWORD dwTimeoutMs,
PUCHAR const pBuf,
PULONG const pBufSize
);
Parameters
nChannel channel number
dwTimeoutMs timeout (in ms) when queue is full this
value must be at least 20 ms.
(-1= wait until buffer space is available)
pBuf pointer to data buffer to feed into play-
back streaming
pBufSize application buffer size
Return Codes
MT_RET_OK No error
MT_RET_IO_PENDING Streaming still in startup pro-
cess
MT_RET_NOT_ENOUGH_BUFSPACE The amount of free space does
not satisfy request with timeout
set to 0
MT_RET_SERVICE_NOT_STARTED Streaming is not started
Function Reference Library
• 359
Introduction
MTStreamBufIn()
Description
Instead of using MTRecBuffer() to record a specified size of voice
data, application can use streaming functions. This enables
buffering into the internal queue and a stream input function to get
voice block one by one until either the application stops the stream
function or the specified termination situation occurs. Note that the
termination condition is set through MTStartStreaming() call.
The timeout specifies the waiting time for data availability. Should
timeout be set to 0, this function returns immediately. If there is
enough data in the queue to satisfy the requested data length, data
will be moved to the user buffer. Otherwise, the data length will be
set to 0 on return. Should the timeout be set to a positive number,
this function returns when either the specified timeout expires or a
data block of the requested size is moved to the user buffer,
whichever happens first. In both cases, the data length field will
contain the actual byte count of data been moved to the user
provided buffer. The timeout period is at least 20 milliseconds.
Should the timeout period be set to -1, this function returns when
the specified data length is satisfied. Setting timeout period to -1 is
equivalent to setting no timeout period.
The stream data length should contain the user requested data
length and will be set to the actual data moved into the user buffer
on return.
NOTE: The SmartWORKS DLL limits buffer size: maximum streaming buffer
size is set to 1MBytes, minimum cap to 1KBytes.
Prototype
MT_RESULT MTStreamBufIn(
const CHANNEL nChannel,
const DWORD dwTimeoutMs ranges,
PUCHAR const pBuf,
PULONG const pBufSize
);
Parameters
nChannel channel number
dwTimeoutMs timeout (in ms) when queue is empty,
this value must be at least 20 ms, (-1=
wait until queue data is available)
pBuf pointer to buffer to take the streaming
data
pBufSize application buffer size
Return Codes
MT_RET_OK No error
Function Reference Library
• 361
Introduction
MTStreamBufPause()
Description
Pause the output streaming. The playback will be paused
immediately. Decode data can still be queued so long as there is
enough free space in the internal decode streaming buffer. The user
application can either stop the decode streaming or resume
playback through MTStreamBufResume(). This API function does
not apply to encode streaming.
Prototype
MT_RESULT MTStreamBufPause(
const CHANNEL nChannel
);
Parameters
nChannel channel number
Return Codes
MT_RET_OK No error
MT_RET_SERVICE_NOT_STARTED Streaming is not started
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_IDLE Decode (playback) streaming is
already paused
Events
EVT_STREAMOUT_PAUSED
Function Reference Library
• 363
Introduction
MTStreamBufResume()
Description
MTStreamBufResume() resumes any paused output streaming on
a specified channel.
Prototype
MT_RESULT MTStreamBufResume(
const CHANNEL nChannel
);
Parameters
nChannel channel number
Return Codes
MT_RET_OK No error
MT_RET_SERVICE_NOT_STARTED Streaming is not started
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_BUSY Decode (playback) streaming is
not paused
Events
None
Ai-Logix, Inc.
364 •
SmartWORKS Developer’s Guide
MTStopStreaming()
Description
Stops the streaming of data.
The parameter Action specifies how it should be stopped.
STRUCTURE FUNCTIONS
Function Reference Library
• 367
Introduction
MTGetPSTNParams()
This API was formerly called MTGetPSTN().
Description
MTGetPSTNParams() returns the current PSTN parameter settings.
Structure MT_PSTN is detailed in section MTSetPSTNParams().
Prototype
MT_RESULT MTGetPSTNParams (
const CHANNEL nChannel,
PMT_PSTN const pRegs,
PULONG const pLength
);
Parameters
nChannel channel number
pRegs pointer to MT_PSTN structure. This
structure is defined on the next pages
were MTSetPSTNParams is defined.
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MT_PSTN structure.
CODE EXAMPLE
MTGetPSTNParams() Code Example
ZeroMemory(&pstn,size);
result =
MTGetPSTNParams(channel,&pstn,&size);
if(result == MT_RET_OK)
{
printf("MTGetPSTNParams() successful...\n");
ULONG ringCount = pstn.ring_count;
ULONG loopDeglitch = pstn.loop_deglitch;
ULONG loopDelay = pstn.loop_delay;
printf("Ring count: %u\nLoop deglitch:
%u\nLoop delay: %u\n",ringCount,loopDeglitch,loopDelay);
}
A complete code example is available on the Ai-Logix website:
http://www.ai-logix.com/support.html
Function Reference Library
• 369
Introduction
MTSetPSTNParams()
This API was formerly called MTSetPSTN()
Description
MTSetPSTNParams() sets the PSTN parameters.
The telephone signal detection requires some timing parameters.
These can be set with the MTSetPSTNParams() function using the
MT_PSTN structure. Use this structure at any time the system is
active*
Prototype
MT_RESULT MTSetPSTNParams (
const CHANNEL nChannel,
PMT_PSTN const pRegs,
PULONG const pLength
);
Parameter
nChannel channel number
pRegs pointer to an MT_PSTN structure
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MT_PSTN structure.
TABLE 8: MT_PSTN
Type Name Purpose Default Units
TABLE 8: MT_PSTN
Type Name Purpose Default Units
CODE EXAMPLE
Code Example MTSetPSTNParams()
handleMT(MTSetPSTNParams(channel,&pstn,&size),"MTSetPSTNParams() channel
%d",channel);
if(handleMT(MTGetPSTNParams(channel,&pstn,&size),"MTGetPSTNParams() channel
%d",channel))
{
ULONG ringCount = pstn.ring_count;
ULONG loopDeglitch = pstn.loop_deglitch;
ULONG loopDelay = pstn.loop_delay;
cout << "Ring count = " << ringCount << endl
<< "Loop deglitch = " << loopDeglitch << endl
<< "Loop delay = " << loopDelay << endl <<
endl;
}
MTSetToneGenParams()
This API was formerly called MTSetGenRegs()
Description
MTSetToneGenParams() sets the DTMF/MF tone generation
parameters defined in MT_GENREGS structure as follows.
NOTE: If any values are set to 0, the application will replace them with the
default setting.
MTGetToneGenParams ()
This API was formerly called MTGetGenRegs()
Description
MTGetToneGenParams() returns the DTMF/MF tone generation
settings. The tone type indicates which generation structure is to be
retrieved, DTMF or MF. Refer to MTSetToneGenParams() for details
of MT_GENREGS structure which controls the generation of DTMF/
MF tones.
Prototype
MT_RESULT MTGetToneGenParams (
const CHANNEL nChannel,
const UCHAR Type,
PMT_GENREGS const pRegs,
PULONG const pLength
);
Parameters
nChannel channel number
Type tone type; TYPE_DTMF or TYPE_MF
pRegs pointer to MT_GENREGS structure
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MT_GENREGS structure.
MTSetToneDetectParams()
This API was formerly called MTSetDetectRegs()
Description
MTSetToneDetectParams() sets the DTMF/MF detection structure.
This structure controls the detection of DTMF/MF tones per
specification of parameter TYPE_DTMF or TYPE_MF.
Events
None
Function Reference Library
• 379
Introduction
MTChInputSetToneDetectParams()
This API was formerly called MTSetToneDetectParams().
Description
MTChInputSetToneDetectParams() sets the DTMF/MF detection
structure. This structure controls the detection of DTMF/MF tones
per specification of parameter TYPE_DTMF or TYPE_MF.
Events
None
Ai-Logix, Inc.
382 •
SmartWORKS Developer’s Guide
MTGetToneDetectParams()
This API will be obsoleted as of Jan. 2005. Use MTChInputGetToneDetectParams()
instead. This API used to be called MTGetDetectRegs().
Description
MTGetToneDetectParams() returns the DTMF/MF detection
structure. The regstype indicates whether the DTMF or MF
detection register is retrieved. This structure controls the detection
of DTMF/MF digits. Refer to MTSetToneDetectParams() for details.
If the API MTChInputSetToneDetectParams() was used to set
different parameters for each channel input, then use
MTChInputGetToneDetectParams() to obtain values.
Prototype
MT_RESULT MTGetToneDetectParams (
const CHANNEL nChannel,
UCHAR const Type,
PMT_DETECTREGS const pRegs,
PULONG const pLength
);
Parameters
nChannel channel number
Type tone type, TYPE_DTMF or TYPE_MF
pRegs pointer to MT_DETECTREGS structure
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MT_DETECTREGSS structure
MTChInputGetToneDetectParams()
This API used to be called MTGetToneDetectParams().
Description
MTChInputGetToneDetectParams() returns the DTMF/MF
detection structure. The regstype indicates whether the DTMF or
MF detection register is retrieved. This structure controls the
detection of DTMF/MF digits. Refer to
MTChInputSetToneDetectParams() or
MTSetToneDetectParams() for details.
Prototype
MT_RESULT MTChInputGetToneDetectParams (
const CHANNEL nChannel,
const SHORT nInput,
UCHAR const Type,
PMT_DETECTREGS const pRegs,
PULONG const pLength
);
Parameters
nChannel channel number
nInput Input index: 0=primary, 1=secondary
Type tone type, TYPE_DTMF or TYPE_MF
pRegs pointer to MT_DETECTREGS structure
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MT_DETECTREGSS structure
MTSetDTMFDetectParams()
Description
This API is only used when the tone detection trigger is set to
LEADING_EDGE detection. This is set by using the
MTSetToneDetectParams() API and set the Trigger field in the
MT_DetectRegs structure.
This API sets the parameters which control tone detection and
reporting.
Prototype
MT_RESULT MTSetDTMFDetectParams(
const CHANNEL nChannel,
PMT_DTMF_DETECTPARAMS const pParams,
PULONG const pLength
);
Parameters
nChannel channel number
pParams pointer to MT_DTMF_DETECTPARAMS
structure
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MT_DTMF_DETECTPARAMS
structure.
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
Function Reference Library
• 385
Introduction
MTChInputSetDTMFDetectParams()
Formally called MTSetDTMFDetectParams().
Description
This API is only used when the tone detection trigger is set to
LEADING_EDGE detection. This is set by using the
MTSetToneDetectParams() API and set the Trigger field in the
MT_DetectRegs structure.
This API sets the parameters which controls tone detection and
reporting for the specified input per channel.
Prototype
MT_RESULT MTChInputSetDTMFDetectParams(
const CHANNEL nChannel,
const SHORT nInput,
PMT_DTMF_DETECTPARAMS const pParams,
PULONG const pLength
);
Parameters
nChannel channel number
nInput Input index: 0=primary, 1=secondary
pParams pointer to MT_DTMF_DETECTPARAMS
structure
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MT_DTMF_DETECTPARAMS
structure.
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
Function Reference Library
• 387
Introduction
MTGetDTMFDetectParams()
This API will be obsoleted as of Jan. 2005. Use
MTChInputGetDTMFDetectParams() instead.
Description
This API is only used when the tone detection trigger is set to
LEADING_EDGE detection. This is set by using the
MTSetToneDetectParams() API and set the Trigger field in the
MT_DetectRegs structure.
This API gets the parameters which control tone detection and
reporting. This API reads the value of the channel’s primary input
only.
Prototype
MT_RESULT MTGetDTMFDetectParams (
const CHANNEL nChannel,
PMT_DTMF_DETECTPARAMS const pParams,
PULONG const pLength
);
Parameters
nChannel channel number
pParams pointer to MT_DTMF_DETECTPARAMS
structure
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MT_DTMF_DETECTPARAMS
structure.
MTChInputGetDTMFDetectParams()
Formally called MTGetDTMFDetectParams().
Description
This API is only used when the tone detection trigger is set to
LEADING_EDGE detection. This is set by using the
MTSetToneDetectParams() API and set the Trigger field in the
MT_DetectRegs structure.
This API gets the parameters which control tone detection and
reporting on the specified input of each channel.
Prototype
MT_RESULT MTChInputGetDTMFDetectParams (
const CHANNEL nChannel,
const SHORT nInput,
PMT_DTMF_DETECTPARAMS const pParams,
PULONG const pLength
);
Parameters
nChannel channel number
nInput Input Index: 0=primary, 1=secondary
pParams pointer to MT_DTMF_DETECTPARAMS
structure
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MT_DTMF_DETECTPARAMS
structure.
Activity Detection
Legend:
AT · Activity Threshold (dBm)
ST · Silence Threshold (dBm)
Hysterisis · Difference between AT and ST (dB)
ty
e
al nc
al vi
rv cti
rv ile
te A
te S
In um
In um
im
im
Power (dBm)
in
in
M
M
e
Activity
is bl
es a
Detected
er m
st ram
Hy rog
AT
P
ST Silence
Detected
Audio Signal
Time
State Silence Activity Silence
Legend
Minimum Activity Interval . . . . . MTACTPARAMS.min_activity
Minimum Silence Interval . . . . . MTACTPARAMS.min_silence
Programmable Hysteresis . . . . . MTACTPARAMS.threshold_high &
MTACTPARAMS.threshold_low
API CONTROL
Originally Activity Detection was designed to work in the following way:
• activity detection, when enabled with MTEnableACTD(), only worked on the
primary input of the channel. MTEnableMixing() then MTEnableMixingDe-
tect() was used to enable activity detection on the secondary channel. The
API SetACTDParams() configured activity detection parameters, but the
same values were used for both inputs.
The APIs used to control activity detection were recently enhanced to allow for
configuration on a per input basis.
Users can still control activity parameters with the API MTSetACTDParams().
However, this method is only recommended when activity detection configuration
is the same on both inputs.
To control activity detection on the primary input, do the following:
Ai-Logix, Inc.
392 •
SmartWORKS Developer’s Guide
MTSetACTDParams()
This API was formerly called MTSetACTDRegs()
Description
MTSetACTDParams() sets the silence/activity detection
configuration of both inputs on a channel. By default, the primary
input is the only input used. If MT
Prototypes
MT_RESULT MTSetACTDParams (
const CHANNEL nChannel,
PMT_ACTPARAMS const pActParams,
PULONG const pLength
);
Parameters
nChannel Channel number
pActParams Pointer to MT_ACTPARAMS
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MT_ACTPARAMS structure
CODE EXAMPLE
MTSetACTDParams() Code Example
ZeroMemory(&actparams,size);
actparams.max_activity = 0;
actparams.max_silence = 0;
actparams.min_activity = 40;
actparams.min_silence = 1500;
actparams.threshold_high = -48;
actparams.threshold_low = -51;
result =
MTSetACTDParams(channel,&actparams,&size);
if(result == MT_RET_OK)
{
printf("MTSetACTDParams() successful...\n");
ULONG maxActivity = actparams.max_activity;
ULONG maxSilence = actparams.max_silence;
ULONG minActivity = actparams.min_activity;
ULONG minSilence = actparams.min_silence;
FLOAT threshHigh = actparams.threshold_high;
printf("Max activity: %u\nMax silence:
%u\nMin activity: %u\nMin silence: %u\nHigh threshold:
%u\n",maxActivity,maxSilence,minActivity,minSilence,threshHigh);
}
A complete code example is available on the Ai-Logix website:
http://www.ai-logix.com/support.html
Ai-Logix, Inc.
396 •
SmartWORKS Developer’s Guide
MTChInputSetACTDParams()
This API was formerly called MTSetACTDRegs() or MTSetACTDParams().
Description
MTChInputSetACTDParams() sets the silence/activity detection
configuration on the specified input per channel.
Prototypes
MT_RESULT MTChInputSetACTDParams (
const CHANNEL nChannel,
const SHORT nInput,
PMT_ACTPARAMS const pActParams,
PULONG const pLength
);
Parameters
nChannel Channel number
nInput Input Index: 0=primary, 1=secondary
pActParams Pointer to MT_ACTPARAMS
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MT_ACTPARAMS structure
MTGetACTDParams()
This API will be obsolete as of Jan. 2005. Use MTChInputGetACTDParams() instead.
This API was also formerly called MTGetACTDRegs().
Description
Gets the silence/activity detection configuration. The structure
MT_ACTPARAMS is defined in the previous section where the API
MTSetACTDParams() is defined.
This function reads the configuration for the primary input only. For
primary and secondary configurations use
MTChInputGetACTDParams().
Prototype
MT_RESULT MTGetACTDParams (
const CHANNEL nChannel,
PMT_ACTPARAMS const pActParams,
PULONG const pLength
);
Parameters
nChannel channel number
pActParams pointer to an MT_ACTPARAMS structure
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MT_ACTPARAMS structure
CODE EXAMPLE
MTGetACTDParams() Code Example
result = MTGetACTDParams(channel,&actparams,&size);
if(result == MT_RET_OK)
{
printf("MTGetACTDParams() successful...\n");
ULONG maxActivity = actparams.max_activity;
ULONG maxSilence = actparams.max_silence;
ULONG minActivity = actparams.min_activity;
ULONG minSilence = actparams.min_silence;
FLOAT threshHigh = actparams.threshold_high;
printf("Max activity: %u\nMax silence:
%u\nMin activity: %u\nMin silence: %u\nHigh threshold:
%u\n",maxActivity,maxSilence,minActivity,minSilence,threshHigh);
}
A complete code example is available on the Ai-Logix website:
http://www.ai-logix.com/support.html
Ai-Logix, Inc.
400 •
SmartWORKS Developer’s Guide
MTChInputGetACTDParams()
This API was formerly called MTGetACTDRegs() or MTGetACTDParams().
Description
Gets the silence/activity detection configuration per input on each
channel. The structure MT_ACTPARAMS is defined in the previous
section where the API MTSetACTDParams() or
MTChInputACTDParams() is defined.
Prototype
MT_RESULT MTChInputGetACTDParams (
const CHANNEL nChannel,
const Input nInput,
PMT_ACTPARAMS const pActParams,
PULONG const pLength
);
Parameters
nChannel channel number
nInput Input Index: 0=primary, 1=secondary
pActParams pointer to an MT_ACTPARAMS structure
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MT_ACTPARAMS structure
MTEnableACTD()
This API will be obsoleted as of Jan. 2005. Use
MTChInputACTDControl() instead.
Description
The function enables or resumes activity detection on the primary
input of the specified channel. (If mixing detect is enabled using
MTEnableMixingDetect(), both the primary and secondary inputs
are enabled). Activity detection is enabled by default.
Scenario
When activity detection is enabled, only events such as
EVT_MON_SILENCE and EVT_MAX_SILENCE will be reported as long
as monitoring silence is turned on through MTSetEventFilters();
events such as EVT_MON_ACTIVITY and EVT_MAX_ACTIVITY will
only be reported if monitoring activity is turned on with
MTSetEventFilters(). If the line is silent, event EVT_MAX_SILENCE
will only be reported on the first occurrence to prevent flooding the
event queue. The same applies to EVT_MAX_ACTIVITY event
reporting.
Prototype
MT_RESULT MTEnableACTD (
const CHANNEL nChannel
);
Parameter
nChannel channel number
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
EVT_MON_ACTIVITY
EVT_MON_SILENCE
EVT_MAX_SILENCE
EVT_MAX_ACTIVITY
See Also: MTSetMoni(), MTSetACTDParams()
Ai-Logix, Inc.
402 •
SmartWORKS Developer’s Guide
MTDisableACTD()
This API will be obsoleted as of Jan. 2005. Use
MTChInputACTDControl() instead.
Description
The function disables or suspends activity detection on the primary
input of the specified channel. (If mixing detect is enabled using
MTEnableMixingDetect(), both the primary and secondary inputs
are disabled).
Prototype
MT_RESULT MTDisableACTD (
const CHANNEL nChannel
);
Parameter
nChannel channel number
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
EVT_MON_ACTIVITY
EVT_MON_SILENCE
Function Reference Library
• 403
Introduction
MTChInputACTDControl()
MTEnableACTD, MTDisableACTD and MTEnableMixingDetect()
were formally used.
Description
This function enables or disables activity detection on the specified
input per channel. Activity detection is enabled by default.
Scenario
When activity detection is enabled, only events such as
EVT_MON_SILENCE and EVT_MAX_SILENCE are reported as long as
monitoring silence is turned on through MTSetEventFilters; events
such as EVT_MON_ACTIVITY and EVT_MAX_ACTIVITY are only
reported if monitoring activity is turned on with
MTSetEventFilters(). If the line is silent, event EVT_MAX_SILENCE
will only be reported on the first occurrence to prevent flooding the
event queue. The same applies to EVT_MAX_ACTIVITY event
reporting.
Prototype
MT_RESULT MTEnableACTD (
const CHANNEL nChannel,
const SHORT nInput,
const BOOLEAN fOn
);
Parameter
nChannel channel number
nInput Input Index: 0=primary, 1=secondary
fOn TRUE for enabled, FALSE for disabled
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
EVT_MON_ACTIVITY
EVT_MON_SILENCE
EVT_MAX_SILENCE
EVT_MAX_ACTIVITY
See Also: MTSetMoni(), MTSetACTDParams()
Ai-Logix, Inc.
404 •
SmartWORKS Developer’s Guide
MTChInputACTDStatus
Description
This API retrieves the ACTD status for the specified channel input.
Prototype
MT_RESULT MTChInputACTDStatus (
const CHANNEL nChannel,
const SHORT nInput,
BOOLEAN * const Status
);
Parameter
nChannel channel number
nInput Input Index: 0=primary, 1=secondary
fOn TRUE for enabled, FALSE for disabled
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
Function Reference Library
• 405
Introduction
MTGetACTDDetectPower()
This API will be obsoleted as of Jan. 2005. Use
MTChInputGetACTDDetectPower() instead.
Description
Get current activity power value on the incoming line. This value is
measured before any gain is applied to the incoming signal. This
API is supported for all channels.
This API only checks the power of the primary input per channel. To
check both the primary and secondary inputs use
MTChInputGetACTDDetectPower().
Prototype
MT_RESULT MTGetACTDDetectPower (
const CHANNEL nChannel,
float * const pPower
);
Parameters
nChannel Channel Number
Power activity in dBm
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
EVT_MON_ACTIVITY
EVT_MON_SILENCE
See Also: MTSetMoni()
Ai-Logix, Inc.
406 •
SmartWORKS Developer’s Guide
MTChInputGetACTDDetectPower()
Formally known as MTGetACTDDetectPower().
Description
Get current activity power value of the specified input on the
incoming line. This value is measured before any gain is applied to
the incoming signal. This API is supported for all channels.
Prototype
MT_RESULT MTChInputGetACTDDetectPower (
const CHANNEL nChannel,
const SHORT nInput,
float * const pPower
);
Parameters
nChannel Channel Number
nInput Input Index: 0=primary, 1=secondary
Power activity in dBm
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
EVT_MON_ACTIVITY
EVT_MON_SILENCE
See Also: MTSetMoni()
Function Reference Library
• 407
Introduction
MTEnableMixing()
Description
Enables mixing of the second audio data with the primary audio
data before the audio data is sent to the encoder.
Scenario
On SmartWORKS DP and SmartWORKS NGX cards, the mixing of the
primary and secondary data streams is enabled by default. For the
cards to work properly this setting must remain unchanged from its
default state.
Prototypes
MT_RESULT MTEnableMixing (
const CHANNEL nChannel
);
Parameters
nChannel channel number
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Ai-Logix, Inc.
408 •
SmartWORKS Developer’s Guide
MTDisableMixing()
Description
Disables the mixing of the second audio data with the primary
audio data before the audio data is sent to the encoder.
Scenario
SmartWORKS DP and SmartWORKS NGX cards require that the
secondary stream mixing always be enabled.
Mixing must be disabled when using the SmartWORKS PCM card.
Prototypes
MT_RESULT MTDisableMixing (
const CHANNEL nChannel
);
Parameters
nChannel channel number
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 409
Introduction
MTGetMixingStatus()
Description
MTGetMixingStatus() retrieves the status of mixing (whether
enabled or disabled).
Prototypes
MT_RESULT MTGetMixingStatus(
const CHANNEL nChannel,
BOOLEAN * const pOn
);
Parameters
nChannel channel number
pOn pointer to take the status: 0 for disabled,
others for enabled
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid argument passed to
function
Events
None
Ai-Logix, Inc.
410 •
SmartWORKS Developer’s Guide
MTEnableMixingDetect()
This API will be obsoleted as of Jan. 2005. Use
MTChInputACTDControl() to enable activity detection on the
channel inputs. Use MTChInputToneDetectControl() to enable
tone detection on channel inputs.
Description
This API enables the signal on the second audio data stream to be
detected and reported. Detectors involved are for DTMF, and
activity.
Scenario
This API enables on the second stream all detections that are
already enabled for the primary stream. For SmartWORKS DP and
SmartWORKS NGX cards, all channels are defaulted to have
detection on the secondary channel enabled.
Prototypes
MT_RESULT MTEnableMixingDetect (
const CHANNEL nChannel
);
Parameters
nChannel channel number
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 411
Introduction
MTDisableMixingDetect()
This API will be obsoleted as of Jan. 2005. Use
MTChInputToneDetectControl() and MTChInputACTDControl()
instead.
Description
This API disables detectors on the secondary input stream.
Detectors involved are for DTMF, activity, call-progress tones, and
caller-ID packets. Each of these detectors still needs to be enabled
through proper APIs.
Scenario
SmartWORKS DP and SmartWORKS NGX cards require detection on
the secondary stream be enabled.
Prototypes
MT_RESULT MTDisableMixingDetect (
const CHANNEL nChannel
);
Parameters
nChannel channel number
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Ai-Logix, Inc.
412 •
SmartWORKS Developer’s Guide
MTGetMixingDetectStatus()
This API will be obsoleted as of Jan. 2005. Use
MTChInputToneDetectStatus() and MTChInputACTDStatus()
instead.
Description
MTGetMixingDetectStatus() retrieves the status of mixing
detection (whether mixing detection is enabled or disabled).
Prototypes
MT_RESULT MTGetMixingDetectStatus(
const CHANNEL nChannel,
BOOLEAN * const pOn
);
Parameters
nChannel channel number
pOn pointer to take the status: 0 for disabled,
others for enabled
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid argument passed to
function
Events
None
Function Reference Library
• 413
Introduction
MTSetPxdParams()
This API was formerly called MTSetPxdRegs(). This API will be obsolete as of June
2004. Use MTSetECControl() instead.
Description
MTSetPxdParams() allows the user to set the playback volume,
input gain values, and enable or disable echo cancellation for a
specified channel.
Prototype
MT_RESULT MTSetPxdParams(
const CHANNEL nChannel,
PMT_PSTNPXD const pRegs,
PULONG const pLength
);
Parameters
nChannel channel number
pRegs pointer to MT_PSTNPXD structure
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MT_PSTNPXD structure
MTGetPxdParams()
This API was formerly called MTGetPxdRegs(). This API will be obsolete as of June
2004.
Description
MTGetPxdParams() allows the user to get the MVIP compression
format, the playback volume, input gain values and enable or
disable echo cancellation for a specified channel. The MT_PSTNPXD
structure is defined where the API MTSetPxdParams() is explained.
Prototype
MT_RESULT MTGetPxdParams (
const CHANNEL nChannel,
PMT_PSTNPXD const pRegs,
PULONG const pLength
);
Parameters
nChannel channel number
pRegs pointer to MT_PSTNPXD structure
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MT_PSTNPXD structure
MTSetECControl()
This API was formerly called MTSetPxdParams().
Description
MTSetECControl() allows the enabling or disabling of echo
cancellation for the specified channel. Echo cancellation can also be
controlled through MTSetPxdParams(), however this API will
become obsolete in June 2004. Use MTGetECControl() to check
the status of echo cancellation on the specified channel.
This API is only supported on terminate boards with 09 DSPs
(AT409, AT809, AT1609, DT3209, DT6409, LD409, LD809).
Prototype
MT_RESULT MTSetECControl (
const CHANNEL nChannel,
const USHORT Value
);
Parameters
nChannel channel number
Value enable = 1; disable = 0 (default)
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE This feature is not available on
this board
MT_RET_INVALID_PARAM Invalid argument passed to
function
Events
None
MTGetECControl()
Description
Use MTGetECControl() to check the status of echo cancellation on
the specified channel. MTGetPxdParams() can also be used to
check the status of echo cancellation. However, this API will become
obsolete in June 2004. It is recommended that you use
MTGetECContol().
This API is only supported on terminate boards with 09 DSPs
(AT409, AT809, AT1609, DT3209, DT6409, LD409, LD809).
Prototype
MT_RESULT MTGetECControl (
const CHANNEL nChannel,
PULONG const pValue
);
Parameters
nChannel channel number
pValue the status of echo cancellation on the
identified channel. 1= enabled,
0=disabled
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE This feature is not available on
this board
MT_RET_INVALID_PARAM Invalid argument passed to
function
Events
None
Ai-Logix, Inc.
418 •
SmartWORKS Developer’s Guide
MTSetECFreezeAdaptation()
Description
MTSetECFreezeAdaptation() allows the user to freeze the values
currently used by the echo cancellation feature. Once enabled, the
channel will only rely on these values and will no longer adapt to
changes on the network. Echo cancellation must first be enabled to
use this API. If echo canellation is reset (using MTECControl(), then
the adaptive capabilities of echo cancellation is automatically
restarted. Use MTGetECAdaptation() to check the status of
adaptive echo cancellation on a specified channel.
MTSetPXDParams() can also be used, however, this API will
become obsolete in June 2004.
This API is only supported on terminate boards with 09 DSPs
(AT409, AT809, AT1609, DT3209, DT6409, LD409, LD809).
Prototype
MT_RESULT MTSetECFreezeAdaptation (
const CHANNEL nChannel,
const USHORT Value
);
Parameters
nChannel channel number
Value enable = 1(frozen);
disable(adaptive) = 0 (default)
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE This feature is not available on
this board
MT_RET_NOT_APPLICABLE echo cancellation is supported
by this board, but is currently
disabled
MT_RET_INVALID_PARAM Invalid argument passed to
function
Events
None
Function Reference Library
• 419
Introduction
MTGetECFreezeAdaptation()
Description
Use MTGetECAdaptation() to check the status of echo cancellation
on the specified channel. MTGetPXDParams() can also be used,
however, this API will become obsolete in June 2004. It is
recommended that you use MTGetECAdaptation().
This API is only supported on terminate boards with 09 DSPs
(AT409, AT809, AT1609, DT3209, DT6409, LD409, LD809).
Prototype
MT_RESULT MTSetECFreezeAdaptation (
const CHANNEL nChannel,
PUSHORT const pValue
);
Parameters
nChannel channel number
pValue enable = 1(frozen);
disable(adaptive) = 0 (default)
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid argument passed to
function
Events
None
Ai-Logix, Inc.
420 •
SmartWORKS Developer’s Guide
MTSetECParams()
Description
MTSetECParams() allows the user to define parameters used when
echo cancellation is enabled. Echo cancellation must be enabled
with MTSetECControl() before this API can be used.
This API is only supported on terminate boards with 09 DSPs
(AT409, AT809, AT1609, DT3209, DT6409, LD409, LD809).
Prototype
MT_RESULT MTSetECParams (
const CHANNEL nChannel,
PMT_ECPARAMS const pParams,
PULONG const pLength
);
Parameters
nChannel channel number
pParams pointer to the data structure
PMT_ECPARAMS
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the PMT_ECPARAMS structure
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE This feature is not available on
this board
Function Reference Library
• 421
Introduction
MTGetECParams()
Description
This API uses to PMT_ ECPARAMS structure to obtain set values
used by the echo cancellation feature. The PMT_ECPARAMS
structure is defined where the API MTSetECParams() is defined.
This API is only supported on terminate boards with 09 DSPs
(AT409, AT809, AT1609, DT3209, DT6409, LD409, LD809).
Prototype
MT_RESULT MTGetECParams (
const CHANNEL nChannel,
PMT_ECPARAMS const pParams,
PULONG const pLength
);
Parameters
nChannel channel number
pParams pointer to the data structure
PMT_ECPARAMS
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the PMT_ECPARAMS structure
CPM FUNCTIONS
Ai-Logix, Inc.
424 •
SmartWORKS Developer’s Guide
MTGetCpmToneParams()
This API was formerly called MTGetCpmTone(). This API will be obsoleted and has
been replaced with MTChGetCPMSignalParams(). This API should not be used
when MTChSetCPMSignalParms() was used to create a signal profile.
Description
MTGetCpmToneParams() retrieves the CPM tone parameters used
to create a CPM signal profile.
CODE EXAMPLE
MTGetCpmToneParams()
if(handleMT(MTGetCpmToneParams(channel,0,&cpmtone,&size),"MTGetCpmToneParams()
channel %d",channel))
{
USHORT index = cpmtone.index;
USHORT signame = cpmtone.signalname;
USHORT sigtype = cpmtone.signaltype;
cout << "Signal index = " << index << endl
<< "Signal name = " << signame << endl
<< "Signal type = " << sigtype << endl <<
endl;
}
handleMT(MTSysShutdown(),"MTSysShutdown()");
MTSetCpmToneParams()
This API was formerly called MTSetCpmTone(). This API will be obsoleted and has
been replaced with MTChSetCPMSignalParams(). New development should use
this new API.
Description
MTSetCpmToneParams() sets the CPM tone parameters used to
create a CPM signal profile.
There are maximum of 15 CPM signal entries and the index ranges
from 0 to 14.
Each CPM signal will only be detected if it’s parameters are set
correctly and it is enabled. To enable a signal profile set the fEnable
flag in the CPM_SIGNAL structure to true, or use
MTSetChCPMSignalControl().
Prototype
MT_RESULT MTSetCpmToneParams (
const CHANNEL nChannel,
const PMT_CPMTONE pCpm,
PULONG const pLength
);
Parameters
nChannel channel number
pCpm pointer to a MT_CPMTONE structure
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MT_CPMTONE structure.
*Values for minimum and maximum pulse and gap durations are in
msec.
The firmware samples each signal at 20 ms intervals. When defining
the cadence pattern it is recommeneded that all times be specified
in increments of 20 ms, and that they provide at least 20 ms of
margin from the actual limits of the signal to be detected.
For compatibility with earlier Ai-Logix products, values for
frequencies are in Hz, even though what is actually stored internally
is the filter number. The frequencies specified must conform to the
following rules:
Each frequency must fall within the bandwidth of a filter. If the
frequency falls within the passbands of two filters, it is assigned to
the filter whose band edge is more distant.
If more than one frequency is specified, the frequencies must be
given in order, from low to high.
If more than one frequency is specified, each frequency must be
assigned to a different filter.
When the contents of an existing profile are read back by the user,
the CPM firmware substitutes the nominal frequency of each filter
in the profile. These will not necessarily be the frequencies used to
specify the profile.
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid argument passed to
function
Events
None
Ai-Logix, Inc.
428 •
SmartWORKS Developer’s Guide
CODE EXAMPLE
Code Example MTSetCpmToneParams()
if(handleMT(MTGetCpmToneParams(channel,0,&cpmtone,&size),"MTGetCpmToneParams()
channel %d",channel))
{
USHORT index = cpmtone.index;
USHORT signame = cpmtone.signalname;
USHORT sigtype = cpmtone.signaltype;
cout << "Signal index = " << index << endl
<< "Signal name = " << signame << endl
<< "Signal type = " << sigtype << endl <<
endl;
}
cpmtone.index = 0;
cpmtone.signalname = CPM_BUSY1;
cpmtone.signaltype = CPM_TONE;
cpmtone.signal.fEnable = 1;
cpmtone.signal.fDetectSIT = 0;
cpmtone.signal.fDetectLate = 0;
cpmtone.signal.fDetectCycle = 0;
cpmtone.signal.fDetectLost = 1;
cpmtone.signal.nCycleDetect = 1;
cpmtone.signal.Freq[0] = 350;
cpmtone.signal.Freq[1] = 440;
cpmtone.signal.Freq[2] = 0;
cpmtone.signal.Pulse[0]. > cpmtone.signal.Pulse[0]. > cpmtone.signal.Pulse[0].offmin = 140;
cpmtone.signal.Pulse[0].offmax = 200;
cpmtone.signal.Pulse[1]. > cpmtone.signal.Pulse[1]. > cpmtone.signal.Pulse[1].offmin = 0;
cpmtone.signal.Pulse[1].offmax = 0;
cpmtone.signal.Pulse[2]. > cpmtone.signal.Pulse[2]. > cpmtone.signal.Pulse[2].offmin = 0;
cpmtone.signal.Pulse[2].offmax = 0;
MTResetCpmToneParams()
This API was formerly called MTResetCpmTone(). This API will be obsoleted and has
been replaced with MTChResetCPMSignalParams(). New development should use
the new API.
Description
MTResetCpmToneParams() either disables all CPM signal profiles
or sets all CPM signal profiles to default settings.
NOTE: When this API is used, the Call State Machine is not reset.
Prototype
MT_RESULT MTResetCpmToneParams (
const CHANNEL nChannel,
const UCHAR Mode
);
Parameters
nChannel Channel Number
Mode CPM tones mode
0 = disable all signal profiles
1 = reset all signal profiles to values
stored in the registry
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Ai-Logix, Inc.
430 •
SmartWORKS Developer’s Guide
MTChResetCPMSignalParams()
This API was formerly called MTResetCpmToneParams().
Description
MTChResetCpmSignalParams() either disables all CPM signal
profiles or sets all CPM signal profiles to default settings.
MTSetCpmMode()
This API was formerly called MTSetCpmToneMode(). This API will be obsoleted and
has been replaced with MTChCPMControl() and MTChCPMStatus(). It is
recommeneded that new development use these APIs.
Description
MTSetCpmMode() enables or disables CPM on a specific channel.
Once enabled, CPM runs in monitoring mode by default and
EVT_MON_signalname events are retuned to the user application.
MTGetCpmMode()
This API will be obsoleted and has been replaced with MTChCPMStatus(). It is
recommeneded that new development use this API.
Description
MTGetCpmMode() retrieves the status of CPM on a specific
channel.
A monitor enable, controlled through MTSetMoni(), controls the
CPM monitor condition. A termination enable, controlled through
MTSetTerm(), controls the CPM termination conditions.
MTChCPMControl()
This API used to be called MTSetCpmMode().
Description
This API enables/disables CPM on a specific channel.
Once enabled, CPM runs in monitoring mode by default and
EVT_MON_signalname events are retuned to the user application.
MTChCPMStatus()
This API used to be called MTGetCpmMode().
Description
MTChCPMStatus() retrieves the status of CPM on a specific
channel.
A monitor enable, controlled through MTSetMoni(), controls the
CPM monitor condition. A termination enable, controlled through
MTSetTerm(), controls the CPM termination conditions.
MTGetUsrToneParams()
This API was formerly called MTGetUsrTone(). This API will be obsoleted and has
been replaced with MTChGetUsrSignalParams(). Any Usr Tone created with the
MTChSetUsrSignalParams() API must use this new API to retrieve information.
Description
MTGetUsrToneParams() allows retrieval of a user defined CPM
tone. The MT_USRTONE structure is defined where the API
MTSetUsrToneParams() is explained.
Prototype
MT_RESULT MTGetUsrToneParams (
const CHANNEL nChannel,
const USHORT Index,
const PMT_USRTONE pUsrTone,
PULONG const pLength
);
Parameters
nChannel channel number
Index signal index 15-19
pUsrTone pointer to MT_USRTONE structure
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MT_USRTONE structure
MTChGetUsrSignalParams()
This API was formerly called MTGetUsrToneParams().
Description
MTChGetUsrSignalParams() allows retrieval of a user defined
tone. The MT_USRTONE structure is defined where the API
MTChSetUsrSignalParams() is explained.
Prototype
MT_RESULT MTChGetUsrSignalParams (
const CHANNEL nChannel,
const USHORT Index,
const PMT_USRTONE pUsrTone,
PULONG const pLength
);
Parameters
nChannel channel number
Index signal index 15-19
pUsrTone pointer to MT_USRTONE structure
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MT_USRTONE structure
MTClearUsrToneParams()
This API was formerly called MTClearUsrTone(). This API will be obsoleted and has
been replaced with MTChClearUsrSignalParams(). If MTChSetUsrSignalParams()
was used to create a new usr tone, then this new API should be used to clear it.
Description
MTClearUsrToneParams() clears the user tone table for a specified
channel.
Prototype
MT_RESULT MTClearUsrToneParams (
const CHANNEL nChannel
);
Parameters
nChannel channel number
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Ai-Logix, Inc.
438 •
SmartWORKS Developer’s Guide
MTChClearUsrSignalParams()
This API was formerly called MTClearUsrToneParams().
Description
MTChClearUsrSignalParams() clears the user tone table for a
specified channel.
Prototype
MT_RESULT MTChClearUsrSignalParams (
const CHANNEL nChannel
);
Parameters
nChannel channel number
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 439
Introduction
MTSetUsrToneParams()
This API was formerly called MTSetUsrTone(). This API will be obsoleted and has
been replaced with MTChSetUsrSignalParams(). New development should use this
new API.
Description
MTSetUsrToneParams() adds the tone parameters used to define a
user defined CPM signal.
Prototype
MT_RESULT MTSetUsrToneParams (
const CHANNEL nChannel,
const PMT_USRTONE pUsrTone,
PULONG const pLength
);
Parameters
nChannel channel number
pUsrTone pointer to a MT_USRTONE structure
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MT_USRTONE structure
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Error in channel, pointer, or
tone index
Events
None
Function Reference Library
• 441
Introduction
MTChSetUsrSignalParams()
This API was formerly called MTSetUsrToneParams().
Description
MTChSetUsrSignalParams() adds the tone parameters used to
define a user defined CPM signal.
Refer to the application note: Understanding Signal Profiles for more
information.
Prototype
MT_RESULT MTChSetUsrSignalParams (
const CHANNEL nChannel,
const PMT_USRTONE pUsrTone,
PULONG const pLength
);
Parameters
nChannel channel number
pUsrTone pointer to a MT_USRTONE structure
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MT_USRTONE structure
MTSetCPMSigSwitch()
This API was formerly called MTSetUsrToneMode(). This API is not used. Use
MTChCPMSignalControl() and MTChCPMSignalStatus(). Use
MTChUsrSignalControl() and MTChUsrSignalStatus() for Usr tones.
Description
MTSetCPMSigSwitch() allows the user to enable or disable the
detection of a given CPM signal. MtSetUseToneMode() has been
left for backward compatibility with legacy products.
Prototype
MT_RESULT MTSetCPMSigSwitch (
const CHANNEL nChannel,
const USHORT Index,
const UCHAR fState
);
Parameters
nChannel channel number
Index CPM signal index 0 -14, user signal CPM
index 15-19
fState user tone Mode::
0=off
1=on (on by default)
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Error in channel, pointer, or
tone index
Events
None
Ai-Logix, Inc.
444 •
SmartWORKS Developer’s Guide
MTGetCPMSigSwitch()
This API was formerly called MTGetUsrToneMode(). This API is not used. Use
MTChCPMSignalStatus(). Use MTChUsrSignalStatus() for Usr tones.
Description
MTGetCPMSigSwitch() allows the user to retrieve whether
detection has been enabled or disabled for a given user tone.
Prototype
MT_RESULT MTGetCPMSigSwitch (
const CHANNEL nChannel,
const USHORT Index,
const PUCHAR pState
);
Parameters
nChannel channel number
Index From 0-14 for CPM, 15-19 for user
defined CPM signal
pState 0 for disabled, others for enabled (1 by
default)
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Error in channel, pointer, or
tone index
Events
None
Function Reference Library
• 445
Introduction
MTChCPMSignalControl()
Used to be called MTSetCPMSigSwitch().
Description
MTChCPMSignalControl() allows the user to enable or disable the
detection of a given CPM signal.
Prototype
MT_RESULT MTChCPMSignalControl (
const CHANNEL nChannel,
const USHORT Index,
const UCHAR fState
);
Parameters
nChannel channel number
Index Signal Index ID 0 -14
fState tone Mode::
0=off
1=on (on by default)
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Error in channel, pointer, or
tone index
Events
None
Ai-Logix, Inc.
446 •
SmartWORKS Developer’s Guide
MTChCPMSignalStatus()
This API was formerly called MTGetCPMSigSwitch().
Description
MTChCPMSignalStatus() allows the user to retrieve whether
detection has been enabled or disabled for a given CPM signal
profile.
Prototype
MT_RESULT MTChCPMSignalStatus (
const CHANNEL nChannel,
const USHORT Index,
const PUCHAR pState
);
Parameters
nChannel channel number
Index Signal Index ID 0-14 for CPM
pState 0 for disabled, others for enabled (1 by
default)
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Error in channel, pointer, or
tone index
Events
None
Function Reference Library
• 447
Introduction
MTChUsrSignalControl()
Used to be called MTSetCPMSigSwitch().
Description
MTChUsrSignalControl() allows the user to enable or disable the
detection of a given Usr defined signal.
Prototype
MT_RESULT MTChUsrSignalControl (
const CHANNEL nChannel,
const USHORT Index,
const UCHAR fState
);
Parameters
nChannel channel number
Index Signal Index ID 15-19
fState user signal state:
0=off
1=on (on by default)
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Error in channel, pointer, or
tone index
Events
None
Ai-Logix, Inc.
448 •
SmartWORKS Developer’s Guide
MTChUsrSignalStatus()
This API was formerly called MTGetCPMSigSwitch().
Description
MTChUsrSignalStatus() allows the user to retrieve whether
detection has been enabled or disabled for a given Usr defined
signal profile.
Prototype
MT_RESULT MTChUsrSignalStatus (
const CHANNEL nChannel,
const USHORT Index,
const PUCHAR pState
);
Parameters
nChannel channel number
Index Signal Index ID 15-19
pState 0 for disabled, others for enabled (1 by
default)
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Error in channel, pointer, or
tone index
Events
None
Function Reference Library
• 449
Introduction
MTChSetCPMSignalParams()
This API was formerly called MTSetCpmToneParams()
Description
MTChSetCpmSignalParams() sets the CPM tone parameters used
to create a CPM signal profile.
There are maximum of 15 CPM tone entries and the index ranges
from 0 to 14.
Each CPM signal will only be detected if it’s parameters are set
correctly and it is enabled. To enable a signal profile, set the fEnable
field to true in the CPT_SIGNAL structure or use the
MTChCPMSignalControl() API.
It is highly recommended that the user read the Application note:
Understanding Signal Profiels before creating and modifying signal
profiles.
Prototype
MT_RESULT MTChSetCpmSignalParams (
const CHANNEL nChannel,
const PMT_CPT_TONE pCpt,
PULONG const pLength
);
Parameters
nChannel channel number
pCpt pointer to a MT_CPT_TONE structure
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MT_CPT_TONE structure.
*Values for minimum and maximum pulse and gap durations are in
msec. The firmware samples each signal at 20 ms intervals. When
defining the cadence pattern it is recommeneded that all times be
specified in increments of 20 ms, and that they provide at least 20
ms of margin from the actual limits of the signal to be detected.
Values for frequencies are based on a 256 FFT output. A signal’s
nominal frequency must first be converted to bin numbers using
MTCalculateFilterRange(). The vaules must conform to the
following rules:
If more than one frequency range is specified (in bins), the
frequencies must be given in order, from low to high.
Refer to the application note: Understanding Signal Profiles for more
information.
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid argument passed to
function
Events
None
Function Reference Library
• 451
Introduction
MTChGetCPMSignalParams()
This API was formerly called MTGetCpmToneParams()
Description
MTGetCpmSignalParams() gets the current values for a CPM
signal.
There are maximum of 15 CPM signal profiles and the index ranges
from 0 to 14.
The MT_CPM_TONE structure is defined where the API
MTChSetCPMSignalParams() is explained.
Prototype
MT_RESULT MTChGetCpmSignalParams (
const CHANNEL nChannel,
const USHORT Index,
const PMT_CPT_TONE pCpt,
PULONG const pLength
);
Parameters
nChannel channel number
Index the index ID (0-14) for this CPM signal
pCpt pointer to a MT_CPT_TONE structure
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MT_CPT_TONE structure.
MTChResetCpmSignalParams()
This API was formerly called MTResetCpmToneParams().
Description
MTChResetCpmSignalParams() either disables all CPM signal
profiles or sets all CPM signal profiles to default settings.
MTCalculateFilterRange()
Description
The SmartWORKS API allows user to set the upper and lower
frequencies for three unique sinewaves of a signal. When these
values are passed to the firmware (MTChSetCPMSignalParams() or
MTChSetUsrSignalParams()) bin numbers based on a 256 FFT
output must be used.
The API MTCalculateFilterRange() is used to convert a signal’s
nominal frequency into bins. The bins associated with each nominal
frequency values are returned in the CPT_SIGNAL structure.
This calculator is also available on the SmartView interface under
the Settings menu.
- this function accepts upto three nominal frequencies
- any values not used must be set to ‘0’ (if Freq1 and Freq3 are
defined, Freq2 must not be set to ‘0’)
- nominal frequencies must be entered from lower to highest value
A complete discussion is available in the application note:
Understanding Signal Profiles.
Prototype
MT_RESULT MTCalculateFilterRange (
double dFreq1,
double dFreq2,
double dFreq3,
CPT_SIGNAL pCPTSignal
);
Parameters
dFreq1 nominal frequency (HZ)
dFreq2 nominal frequency (HZ)
dFreq3 nominal frequency (HZ)
pCPTSignal pointer to the CPT_SIGNAL structure
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAMETER Invalid parameter passed. Verify that
both values are within the 350 Hz to
2208 Hz. The lower value must be less
than the upper value
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Ai-Logix, Inc.
454 •
SmartWORKS Developer’s Guide
MTLoadSignalProfile()
Description
The function MTLoadSignalProfile() loads one CPT_TONE from the
specified file holding signal profiles into the data structure
provided.
The profile name is a null terminated string that identifies one of the
files holding individual CPM signal profiles. The profile name must
not contain a file extension. The signal name is one ofthe CPM
signal names defined in the NtiData.h header file (i.e. CPM_BUSY1).
Once the data structure is loaded, invoke
MTChSetCPMSignalParams() or MTChSetUsrSignalParams() to
configure the channel with this signal profile. At the time variables,
such as Index ID, should be modified per the needs of the user
application.
Refer to the application note: Understanding Signal Profiles, for more
information about creating/modifying profiles.
Prototype
MT_RESULT MTLoadSignalProfile( (
PCHAR pProfileName,
PCHAR pSignalName,
PMT_CPT_TONE pCPTSignal
);
Parameters
pProfileName profile name
pSignalName the signal name (i.e. CPM_BUST1)
pCPTSignal a pointer to the MT_CPT_TONE structure
Return Codes
MT_RET_OK No error
MT_RET_INVALID_FILENAME If either the profile or signal name can-
not be located
Events
None
Function Reference Library
• 455
Introduction
MTChSetVoiceDetectParams()
Description
The MTChSetVoiceDetectParams() sets the Voice detection
structure (MT_VOICEDETECTPARAMS). This structure controls the
detection of human voice or answering machine when the
application is running the Call Progress Monitoring (CPM) feature
with Voice Detection enabled (MTChVoiceDetectControl()).
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAMS Invalid argument passed to
function
MT_RET_DATA_TRUNCATED Data copied but truncated; the
buffer size set by the user appli-
cation is not large enough for
this API request
Events
None
Function Reference Library
• 457
Introduction
MTChGetVoiceDetectParams()
Description
The MTChGetVoiceDetectParams() gets the current settings of the
Voice detection structure (MT_VOICEDETECTPARAMS). This
structure controls the detection of human voice or answering
machine when the application is running the Call Progress
Monitoring (CPM) feature with Voice Detection enabled
(MTChVoiceDetectControl()).
MTChVoiceDetectControl()
Description
This API enables/disables voice detection on a specified channel. By
default, when a channel is first opened, Call Progress
Monitoring(CPM) and voice detection is enabled.
Prototype
MT_RESULT MTChVoiceDetectControl (
const CHANNEL nChannel,
Boolean fOn
);
Parameters
nChannel Channel Number
fOn value that sets the state of voice detec-
tion:
TRUE=enable
FALSE=disable
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAMS Invalid argument passed to
function
Events
None
Function Reference Library
• 459
Introduction
MTChVoiceDetectStatus()
Description
This API retrieves the current status of voice detection on a
specified channel. By default, when a channel is first opened, Call
Progress Monitoring(CPM) and voice detection is enabled.
Prototype
MT_RESULT MTChVoiceDetectControl (
const CHANNEL nChannel,
Boolean pOn
);
Parameters
nChannel Channel Number
pOn pointer to the value holding the status
of voice detection:
TRUE=enable
FALSE=disable
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAMS Invalid argument passed to
function
Events
None
Ai-Logix, Inc.
460 •
SmartWORKS Developer’s Guide
MTGetAlertToneParams()
This API was formerly called MTGetAlertTone()
Description
Alert tone is played to the decoder and encoder so that alert tone
occurs during the recording process, and is part of the recorded
data stream.
The alert tone can be enabled through the ALERT_TONE flag inside
the MT_IO_CONTROL.StartControl field.
Prototype
MT_RESULT MTGetAlertToneParams(
const CHANNEL nChannel,
const PMT_ALERTTONE pAlert,
PULONG const pLength
);
Parameters
nChannel channel number
pAlert pointer to an MT_ALERTTONE structure
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MT_ALERTTONE structure
Structure
Structure MT_ALERTTONE is defined as the following:
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Error in channel, pointer, or
tone index
Ai-Logix, Inc.
462 •
SmartWORKS Developer’s Guide
MTSetAlertToneParams()
This API was formerly called MTSetAlertTone()
Description
Alert tone is played to the decoder and encoder so that alert tone
occurs during the recording process, and is part of the recorded
data stream.
The alert tone can be enabled through the ALERT_TONE flag inside
the MT_IO_CONTROL.StartControl field.
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Error in channel, pointer, or
tone index
Events
None
Function Reference Library
• 465
Introduction
MTStartAlertTone()
Description
Alert tone is played to the decoder and encoder so that alert tone
occurs during the recording process, and is part of the recorded
data stream.
The alert tone can be enabled through the ALERT_TONE flag inside
the MT_IO_CONTROL.StartControl field.
Scenario
The streaming buffer is allocated and maintained inside the DLL.
The user application does not need to provide a buffer through
MT_IO_CONTROL.
Prototype
MT_RESULT MTStartAlertTone(
const CHANNEL nChannel
);
Parameters
nChannel channel number
Structure
Structure MT_ALERTTONE is defined as the following:
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_SERVICE_ALREADY_STARTED Requested service already
started
Events
None
See Also: MTStopStreaming(), MTStreamBufIn(),
MTStreamBufOut()
Ai-Logix, Inc.
466 •
SmartWORKS Developer’s Guide
MTStopAlertTone()
Description
Alert tone is played to the decoder and encoder so that alert tone
occurs during the recording process, and is part of the recorded
data stream.
The alert tone can be enabled through the ALERT_TONE flag inside
the MT_IO_CONTROL.StartControl field.
Prototype
MT_RESULT MTStopAlertTone(
const CHANNEL nChannel
);
Parameters
nChannel channel number
Structure
Structure MT_ALERTTONE is defined as the following:
MTCALLBACK and LPARAM provide the DLL the address of the API
completion routine and the user expected parameter for invoking
the completion routine.
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_IO_PENDING Background I/O operation is in
progress or queued
Ai-Logix, Inc.
470 •
SmartWORKS Developer’s Guide
TERMINATION/MONITOR FUNCTIONS
Ai-Logix, Inc.
472 •
SmartWORKS Developer’s Guide
MTGetLastTerm()
Description
Gets the previous termination event code.
Prototypes
MT_RESULT MTGetLastTerm (
const CHANNEL nChannel,
PULONG const pEventCode
);
Parameters
nChannel channel number
pEventCode pointer to a buffer for event code
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid argument passed to
function
Events
None
Function Reference Library
• 473
Introduction
MTSetTerm()
Description
Termination enable bits control the termination conditions on a per
channel basis. When a termination condition is met, all background
functions running on the channel are stopped and events are
generated.
One EVT_CPM_STOP event is generated for each task that was
stopped. The Subreason and XtraInfo fields indicate the line
condition and the FuncCode field indicates the type of media task
that was stopped.
If MTSetChannelToDefault() is invoked, these settings are put back
to default. The enabled default TERM_ bits are represented in the
table below and mapped to settings that have been maintained for
backwards compatibility.
TERM_ Bits v3.2 or earlier
TERM_CONNECT (answer machine, TERM_CONNECT (answer machine,
human) human, fax)
TERM_MON_BUSY1 TERM_BUSY (normal)
TERM_MON_BUSY2 TERM_BUSY (trunk busy)
TERM_MON_SIT1, TERM_MON_SIT2, TERM_INTERCEPT
TERM_MON_SIT3, TERM_MON_SIT4
TERM_MON_SIT5
TERM_NO_ANSWER TERM_NO_ANSWER
TERM_LOOP_DROP (loop voltage/ TERM_LOOP_DROP (loop voltage/
current on hook current on hook)
TERM_LVOLTAGE_NOTOFFHOOK TERM_LVOLTAGE_NOTOFFHOOK
(SmartWORKS LD only) (SmartWORKS LD only)
TERM_MON_FAX1, TERM_CONNECT (answer machine,
TERM_MON_FAX2 human, fax)
TERM_MAX_SILENCE TERM_MAX_SILENCE
TERM_MAX_ACTIVITY TERM_MAX_ACTIVITY
Prototype
MT_RESULT MTSetTerm (
const CHANNEL nChannel,
const ULONG TermEnable
);
Parameters
nChannel channel number
TermEnable monitor event monitoring enable bit
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid argument passed to
function
Events
None
Ai-Logix, Inc.
476 •
SmartWORKS Developer’s Guide
MTGetTerm()
Description
MTGetTerm() retrieves the current termination enable bits. A
termination enable bit controls termination conditions linked to the
termination of background functions. NOTE: Termination enable
bits can also be set through the TermEnable field in the
IO_CONTROL structure for a specific task..
The following bits can be put together with “OR” to enable monitor
events:
Prototype
MT_RESULT MTGetTerm (
const CHANNEL nChannel,
const PULONG pTermEnable
);
Parameters
nChannel channel number
pTermEnable pointer to termination event enable bits
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid argument passed to
function
Events
None
Function Reference Library
• 477
Introduction
MTSetMoni()
Description
Monitor event enable bits control which monitoring events are
reported to the user applicatioin. MTSetMoni() is similar to
MTSetEventFilters() but defines CPM specific monitor events.
MTGetMoni() retrieves the current CPM monitoring conditions.
If MTSetChannelToDefault() is invoked, these settings are returned
to the default. By default, MONI_BUSY1, MONI_RINGBACK1,
MONI_DIAL1, MONI_DIAL2, and MONI_DIAL3 (MONI_BUSY,
MONI_RINGBACK, and MONI_DIAL for v 3.2 or earlier) are enabled.
This bits control the CPM monitoring on a per channel basis. Call
Progress Monitoring must be enabled when these bits are enabled.
NOTE: Monitoring options can be set for a specific task using the
MoniEnable field of the MT_IO_CONTROL structure.
The following bits can be put together with “OR” to enable monitor
events:
Signal Name MTSetMoni() Control Corresponding Event
BUSY1 MONI_BUSY1 EVT_MON_BUSY1
BUSY1 MONI_BUSY* EVT_MON_BUSY1
(EVT_MON_BUSY)
BUSY2 MONI_BUSY2 EVT_MON_BUSY2
BUSY2 MONI_TBUSY* EVT_MON_BUSY2
EVT_MON_TBUSY)
DIAL1-3 MONI_DIAL* EVT_MON_DIAL1-3
CALLWAITING MONI_CALLWAITING EVT_MON_CALLWAITING
RECEIVEOFF MONI_RECEIVEOFF EVT_MON_RECEIVEOFF
RINGBACK1 MONI_RINGBACK1 EVT_MON_RINGBACK1
RINGBACK1 MONI_RINGBACK* EVT_MON_RINGBACK1
(EVT_MON_RINGBACK)
RINGBACK2 MONI_RINGBACK2 EVT_MON_RINGBACK2
RINGBACK2 MONI_DRINGBACK* EVT_MON_RINGBACK2
EVT_MON_DRINGBACK)
SIT 1-5 MONI_SIT* EVT_MON_SIT1-5
FAX1 & FAX2 MONI_FAX* EVT_MON_FAX
FAX1 MONI_FAX1 EVT_MON_FAX1
FAX2 MONI_FAX2 EVT_MON_FAX2
MONI_UTONE EVT_UTONE_ON+
MONI_SIGNAL_CYCLE EVT_MON_SIGNAL_CYCLE
SIT1 MONI_SIT1 EVT_MON_SIT1
SIT2 MONI_SIT2 EVT_MON_SIT2
Ai-Logix, Inc.
478 •
SmartWORKS Developer’s Guide
MTGetMoni()
Description
Monitor event enable bits control CPM monitoring conditions. By
default, this is set to all zeros. With MTSetMoni() the application
can enable several additional CPM monitor events. MTSetMoni() is
similar to MTSetEventFilters() but defines CPM monitor events.
MTGetMoni() retrieves the current CPM monitoring conditions.
CONFIGURATION FUNCTIONS
These APIs provide the developer with a method of setting or checking registry
parameters without using the control panel applet (SmartControl). These APIs can
also be used as configuration check/prevention.
NOTE - The NTI driver and DLL rely on system and adapter level parameters
at load time to configure their behavior. When the configuration is changed,
both the driver and the DLL must be reloaded for the new configuration to
take effect.
Function Reference Library
• 481
Introduction
MTGetSystemConfig()
Description
Use this API to get system configuration from the registry.
Prototype
int MTGetSystemConfig (
PMTSYS_CONFIG const pConfig,
PULONG const pLength
);
Parameters
pConfig pointer to the system config structure
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MTSYS_CONFIG structure
Return Codes
This API returns 0 on success. For registry values that are not
configured, the default values will be returned.
Ai-Logix, Inc.
482 •
SmartWORKS Developer’s Guide
MTSetSystemConfig()
Description
Sets system configuration into the Windows registry. The NTI driver
and DLL rely on system and adapter level parameters at load time to
configure their behavior. When the configuration is changed, both
the driver and the DLL must be reloaded for the new configuration
to take effect.
Prototype
int MTSetSystemConfig (
MTSYS_CONFIG const Config,
PULONG const pLength
);
Parameters
Config pointer to the system config structure
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MTADAPTER_CONFIG structure
Return Codes
All parameters will be range checked before updating the registry.
This API returns 0 on success. Otherwise, the API returns the index
of the error field of structure MTSYSTEM_CONFIG.
Ai-Logix, Inc.
484 •
SmartWORKS Developer’s Guide
MTGetAdapterConfig()
Description
Use this API to get current adapter configuration from the registry.
The adapter index should be in field
MTADAPTER_CONFIG.SystemIndex before calling this API.
CODE EXAMPLE
MTGetAdapterConfig() Code Example
ZeroMemory(&adapterinfo,infosize);
result =
MTGetAdapterInfo(board,&adapterinfo,&infosize);
if(result != MT_RET_OK)
printf("MTGetAdapterInfo() failed...\n");
ZeroMemory(&adapterconfig,configsize);
res =
MTGetAdapterConfig(&adapterconfig,&configsize);
if(res == 0)
{
printf("MTGetAdapterConfig()
successful...\n");
ULONG sysindex = adapterconfig.SystemIndex;
UCHAR preference =
adapterconfig.PresentationPreference;
ULONG smsize = adapterconfig.SMSize;
printf("System Index: %u\nPresentation
Preference: %c\nShared Memory Size (SMSize):
%u\n",sysindex,preference,smsize);
}
A complete code example is available on the Ai-Logix website:
http://www.ai-logix.com/support.html
Ai-Logix, Inc.
486 •
SmartWORKS Developer’s Guide
MTSetAdapterConfig()
Description
The NTI driver and DLL rely on system and adapter level parameters
at load time to configure their behavior. When the configuration is
changed, both the driver and the DLL must be reloaded for the new
configuration to take effect. There are two ways to reload the driver
and DLL:
Stop/Start the board drivers using the device manager.
Reset the board via an API (Windows OS only). Invoke
MTBoardReset(), then use this API to modify the registry settings,
invoke MTBoardConfig() which loads the parameters to the DLL,
then invoke MTBoardEnable().
Return Codes
All parameters will be range checked before updating the registry.
This API returns 0 on success. Otherwise, the API returns the index
of the error field of structure MTADAPTER_CONFIG. No system level
check is performed in this API. The checking of configuration
conflict, if any, between boards is not within the scope of this API.
Ai-Logix, Inc.
490 •
SmartWORKS Developer’s Guide
MTSetAdapterEEPROMConfig()
Description
This API allows users to populate a data field for board
identification.
Prototype
int MTSetAdapterEEPROMConfig (
const BOARD nBoard,
PCHAR const pEEPROMConfig,
PULONG const pLength
):
Parameters
nBoard number of the specified board
pEEPROMConfig pointer to the user data. This field is lim-
ited to 128 bytes.
pLength Set by the user application, this is a
pointer to the size of the given buffer for
the EEPROMConfig parameter
MTGetAdapterEEPROMConfig()
Description
MTGetAdapterConfig() gets the user populated data field for
board identification. This API obtains the user specified value.
Prototype
int MTGetAdapterEEPROMConfig (
const BOARD nBoard,
PCHAR const pEEPROMConfig,
PULONG const pLength
):
Parameters
nBoard number of the specified board
pEEPROMConfig pointer to the EEPROMConfig parameter
used to get the board ID.
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the EEPROMConfig parameter.
CT BUS FUNCTIONS
MTArmMasterAlarm()
Description
MTArmMasterAlarm() arms the report of master clock
synchronization related errors through EVT_MASTER_PLL_ALARM.
Prototype
MT_RESULT MTArmMasterAlarm (
const BOARD nBoard
);
Parameters
nBoard board number
Return Codes
MT_RET_OK No error
MT_RET_INVALID_BOARD Board number is out of range
MT_RET_BOARD_NOT_OPENED Board is not opened for access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
EVT_MASTER_PLL_ALARM
Ai-Logix, Inc.
494 •
SmartWORKS Developer’s Guide
MTDisarmMasterAlarm()
Description
MTDisarmMasterAlarm() clears the arming for reporting of master
clock synchronization related errors.
Prototype
MT_RESULT MTDisarmMasterAlarm (
const BOARD nBoard
);
Parameters
nBoard board number
Return Codes
MT_RET_OK No error
MT_RET_INVALID_BOARD Board number is out of range
MT_RET_BOARD_NOT_OPENED Board is not opened for access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 495
Introduction
MTGetMasterAlarmStatus()
Description
MTGetMasterAlarmStatus() retrieves the arming status for
reporting of the master clock synchronization error. The BOOLEAN
parameter will contain TRUE if alarm armed; FALSE if disarmed.
Prototype
MT_RESULT MTGetMasterAlarmStatus (
const BOARD nBoard,
BOOLEAN * const pEnabled
);
Parameters
nBoard board number
pEnabled pointer to information accessed
Return Codes
MT_RET_OK No error
MT_RET_BOARD_NOT_OPENED Board is not opened for access
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_BOARD Board number is out of range
Events
None
Ai-Logix, Inc.
496 •
SmartWORKS Developer’s Guide
MTArmCTAlarm()
Description
MTArmCTAlarm() arms the alarm for monitoring MVIP/H.100 bus
related errors. When armed, detected errors will be reported once
and the alarm will be disarmed. MVIP bus related errors are
reported as event EVT_MVIP_ALARM only when its alarm is armed.
H.100 bus related errors are reported as events
EVT_H100_MASTER_A_ALARM and EVT_H100_MASTER_B_ALARM
only when their respective alarms are armed.
Prototype
MT_RESULT MTArmCTAlarm(
const BOARD nBoard,
const int BusType,
const int nMaster
);
Parameters
nBoard board index number
BusType MUX_MVIP or MUX_H100
nMaster MODE_MASTER_A or MODE_MASTER_B
for MUX_H100; MODE_MASTER for
MUX_MVIP
Return Code
MT_RET_OK No error
MT_RET_BOARD_NOT_OPENED Board is not opened for access
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_BOARD Board number is out of range
MT_RET_INVALID_BUSTYPE Failure to specify MUX_MVIP or
MUX_H100
Events
None
Function Reference Library
• 497
Introduction
MTDisarmCTAlarm()
Description
MTDisarmCTAlarm() disables reporting of MVIP/H.100 bus related
errors.
Prototype
MT_RESULT MTDisarmCTAlarm(
const BOARD nBoard,
const int BusType,
const int nMaster
);
Parameters
nBoard board index number
BusType MUX_MVIP or MUX_H100
nMaster MODE_MASTER_A or MODE_MASTER_B
for MUX_H100; MODE_MASTER for
MUX_MVIP
Return Codes
MT_RET_OK No error
MT_RET_BOARD_NOT_OPENED Board is not opened for access
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_BOARD Board number is out of range
MT_RET_INVALID_BUSTYPE Failure to specify MUX_MVIP or
MUX_H100
Events
None
MTGetCTAlarmStatus()
This API was formerly called MTGetMVIPAlarmStatus()
Description
MTGetCTAlarmStatus() retrieves the arming status of the MVIP/
H.100 alarm. The BOOLEAN parameter will return TRUE if the alarm
is armed, FALSE if disarmed.
Prototype
MT_RESULT MTGetCTAlarmStatus (
const BOARD nBoard,
const int BusType,
const int nMaster,
BOOLEAN * const pArmed
);
Parameters
nBoard board index number
BusType MUX_MVIP or MUX_H100
nMaster MODE_MASTER, MODE_MASTER_A or
MODE_MASTER_B
pArmed pointer to retrieve the alarm’s arming
status
Return Codes
MT_RET_OK No error
MT_RET_BOARD_NOT_OPENED Board is not opened for access
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_INVALID_BOARD Board number is out of range
MT_RET_INVALID_BUSTYPE Failure to specify MUX_MVIP or
MUX_H100
Events
None
MTSetCTRoute()
This API was formerly called MTSetRoute()
Description
MTSetCTRoute() sets a link between a channel and the CT bus on a
specified CT stream and CT bus timeslot. Link directions can be
DIR_TALK, DIR_LISTEN or DIR_SUPER. DIR_TALK and DIR_LISTEN are
used with the primary input and output. DIR_SUPER is used for
listening on the secondary input.
Scenario
This API is most commonly used when data passes from the CT bus
to a channel (NI).
Ai-Logix, Inc.
500 •
SmartWORKS Developer’s Guide
Prototype
MT_RESUTL MTSetCTRoute ( Parameters
const CHANNEL nChannel,
const UCHAR Direction,
const int Stream,
const int Slot
);
nChannel channel number
Direction DIR_TALK, DIR_LISTEN or
DIR_SUPER(listen secondary input only)
Stream CT bus stream index: 0-15 for MVIP, 0-31
for H100
Slot CT bus slot index within the specified
stream
0-31 for MVIP, 0-31 for H100 with a
stream speed of 2048 KHz
0-63 for H100 with stream speed of 4096
KHz
0-127 for H100 with stream speed of
8192 KHz
Return Codes
MT_RET_OK No error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
Events
None
Function Reference Library
• 501
Introduction
MTGetCTRoute()
Description
Retrieves a specified channel's MVIP/H.100 link and it’s specified link
direction (TALK, LISTEN, SUPER). If the channel is not connected to
the MVIP/H.100 bus, pStream will be returned as -1.
Prototype
MT_RESULT MTGetCTRoute (
const CHANNEL nChannel,
const UCHAR Direction,
int * const pStream,
int * const pSlot
);
Parameters
nChannel channel number
Direction DIR_TALK, DIR_LISTEN or DIR_SUPER
pStream buffer for the returned stream index
-1 = channel is not connected to the bus
pSlot buffer for the returned slot index
Return Codes
MT_RET_OK No error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_INVALID_PARAM Invalid argument passed to
function
Events
None
Ai-Logix, Inc.
502 •
SmartWORKS Developer’s Guide
MTResetCTRoute()
This API was formerly called MTResetRoute()
Description
MTResetCTRoute() resets the MVIP/H.100 link. A link’s direction
can be DIR_TALK, DIR_LISTEN, or DIR_SUPER. MTResetCTRoute()
requires users to pass exact parameters (stream and timeslot) both
of which are set by MTSetCTRoute(). If users don’t want to store the
stream and timeslot information, that information can be retrieved
by MTGetCTRoute() first, after which MTResetCTRoute() can be
called.
Prototype
MT_RESULT MTResetCTRoute (
const CHANNEL nChannel,
const UCHAR Direction,
const int Stream,
const int Slot
);
Parameters
nChannel channel number
Direction DIR_TALK, DIR_LISTEN or DIR_SUPER
Stream CT bus stream index: 0-15 for MVIP, 0-31
for H100
Slot CT bus slot index within the specified
stream
0-31 for MVIP, 0-31 for H100 with a
stream speed of 2048 KHz
0-63 for H100 with stream speed of 4096
KHz
0-127 for H100 with stream speed of
8192 KHz
Return Codes
MT_RET_OK No error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_INVALID_PARAM Invalid argument passed to
function
Events
None
Function Reference Library
• 503
Introduction
MTSetInputs()
Description
MTSetInputs() sets the CT bus connection of the primary and
secondary input of the specified channel.
When the CT bus type is MVIP, the first eight (8) MVIP streams (0 - 7)
are on the forward direction which uses 256 time slots. The next
eight (8) streams (8 - 15) are on the reverse direction which also use
256 time slots. The MVIP time slot index is from 0 to 255.
Return Codes
MT_RET_OK No error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_BUSY Channel is busy
Events
None
Function Reference Library
• 505
Introduction
MTGetInputs()
Description
MTGetInputs() retrieves the CT bus connection of the primary and
secondary input of the specified channel.
When the CT bus type is MVIP, the first eight (8) MVIP streams (0 - 7)
are on the forward direction which uses 256 time slots. The next
eight (8) streams (8 - 15) are on the reverse direction which also use
256 time slots. The MVIP time slot index is from 0 to 255.
Return Codes
MT_RET_OK No error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_INVALID_PARAM Invalid argument passed to
function
Events
None
Function Reference Library
• 507
Introduction
MTResetInputs()
Description
Calling this API will disconnect the primary and secondary input
connections from the CT bus (MVIP or H.100). If a channel is not
connected to the CT bus, the return value for all directions and
timeslots will be -1. If a channel is connected, proper values
according to the settings (made with MTSetInputs()) will be
returned.
Scenario
Use Supervise APIs to monitor remote conversations on the same
CT bus.
Prototype
MT_RESULT MTResetInputs(
const CHANNEL nChannel
);
Parameters
nChannel channel number
Return Codes
MT_RET_OK No error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_MUX_OFF Multiplexer system was not
started
Events
None
Ai-Logix, Inc.
508 •
SmartWORKS Developer’s Guide
MTSetOutput()
Description
MTSetOutput() connects the channel’s DSP output to the specified
MVIP/H.100 time slot for monitoring. MTResetOutput() clears the
connection.
Note: Only one channel can transmit (talk) on a time slot, however,
multiple channels can receive (listen) on a time slot (See
MTSetInputs()).
When used, the channel source must be defined by using
MTSetOutputSource(). As the incoming data passes through the
DSPs, the following can still be applied to channel data: DTMF/MF,
Caller ID, Activity detection, Automatic Gain Control and Gain. The
data is passed into the CT Bus and also processed on the board for
recording. Refer to the section that explains MTSetOutputSource()
for a drawing of the logical diagram.
Prototypes
MT_RESULT MTSetOutput(
const CHANNEL nChannel,
const int iStream,
const int iSlot
):
Parameters
nChannel channel number
iStream stream number (0-15 for MVIP, 0 - 31 for
H.100)
iSlot time slot number (0-31 for MVIP,
0 - 127 for H.100 - assuming 8192 KHz)
Return Codes
MT_RET_OK No error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_INVALID_PARAM Invalid argument passed to
function
MT_RET_BUSY When the specified timeslot is
already taken
Events
None
See Also: MTSetOutputSource()
Function Reference Library
• 509
Introduction
MTGetOutput()
Description
Retrieves the MVIP/H.100 bus connectivity of a specified channel's
DSP output. If a DSP output is not connected to the MVIP/H.100
bus, pStream will be returned with the value of -1.
Prototype
MT_RESULT MTGetOutput(
const CHANNEL nChannel,
int * const pStream,
int * const pSlot
);
Parameters
nChannel channel number
pStream buffer for the returned stream index
-1 = not connected
pSlot buffer for the returned slot index
Return Codes
MT_RET_OK No error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_INVALID_PARAM Invalid argument passed to
function
Events
None
Ai-Logix, Inc.
510 •
SmartWORKS Developer’s Guide
MTResetOutput()
Description
MTResetOutput() clears a channel’s connection to the MVIP/H.100
timeslot set by MTSetOutput().
Prototypes
MT_RESULT MTResetOutput(
const CHANNEL nChannel
);
Parameters
nChannel channel number
Return Codes
MT_RET_OK No error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_INVALID_PARAM Invalid argument passed to
function
Events
None
Function Reference Library
• 511
Introduction
MTGetFramerOutput()
Description
Used to get framer data from MVIP or H.100 Bus. More information
is provided on the next page that explains MTSetFramerOutput().
Prototype
MT_RESULT MTGetFramerOutput (
const BOARD nBoard,
const USHORT nFramer,
const USHORT nSlot,
int * const pStream,
int * const pSlot
);
Parameters
nBoard Board index
nFramer Index of framer on the specified board:
0-3 for the DP, and 0-1 for the DT board,
0-23 NGX (24 channel card)
nSlot Index of framer slot: 1-24 for T1, 1-30 for
E1
pStream Index of TDM stream: 0-15 for MVIP, 0-31
for H100
pSlot Index of TDM slot on a stream: 0-31 for
MVIP
Return Codes
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Ai-Logix, Inc.
512 •
SmartWORKS Developer’s Guide
MTSetFramerOutput()
Description
The API gives the user the ability to route the data from the output
of the framer to the CT Bus while still passing the same input data to
the DSPs by default. The data routed to the CT Bus directly from the
framers is not processed by the DSPs, therefore no gain control is
applied.
When using the SmartWORKS DP card the following rules apply:
There are two framers per trunk. Each framer contains a total of 24
(T1) or 31(E1) Timeslots.
0 1 NT B2 1 -- --
0 2 TE B1 1 TE B1 1
0 3 TE B2 1 -- --
1 0 NT B1 2 NT B2 1
1 1 NT B2 2 -- --
1 2 TE B1 2 TE B2 1
1 3 TE B2 2 -- --
.
.
.
23 1 NT B2 24 -- --
23 2 TE B1 24 TE B2 12
23 3 TE B2 24 -- --
Prototype
MT_RESULT MTSetFramerOutput (
const BOARD nBoard,
const USHORT nFramer,
const USHORT nSlot,
const int iStream,
const int iSlot
);
Parameters
nBoard Board index
nFramer Index of framer on the specified board:
0-3 for the DP, 0-1 DT, and 0-23 for the
NGX (24 channel card)
Ai-Logix, Inc.
514 •
SmartWORKS Developer’s Guide
MTResetFramerOuput()
Description
Resets framer output. More information is provided in the section
that explains MTSetFramerOutput().
Prototype
MT_RESULT MTResetFramerOutput (
const BOARD nBoard,
const USHORT nFramer,
const USHORT nSlot
);
Parameters
nBoard Board index
nFramer Index of framer on the specified board
nSlot Index of framer slot: 1-24 for T1, 0-31 for
E1
Return Codes
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Ai-Logix, Inc.
516 •
SmartWORKS Developer’s Guide
De-Bouncing:
The specification of de-bouncing time for ring and loop is implemented through
data structure MT_PSTN and APIs of MTSetPSTNParams() and
MTGetPSTNParams(). Data field ring_deglitch specifies the ring de-bouncing time,
and field loop_deglitch specifies the loop voltage de-bouncing time for PT channel.
Line Status:
Line status, through API MTGetChannelStatus(), for PT is represented through
status bits LINE_ONHOOK and LINE_NO_LVOLTAGE_MIDDLE (i.e.
LINE_NO_LVOLTAGE_OFFHOOK).
Event Filtering:
Event filtering, through API MTSetEventFilter(), of SE_LVOLTAGE_CHANGE results in
events EVT_LVOLTAGE_MIDDLE (i.e. EVT_LVOLTAGE_OFFHOOK) or
EVT_LVOLTAGE_ABOVEORBELOW (i.e. EVT_LVOLTAGE_NOTOFFHOOK) for PT
channels.
Event filtering of SE_LREV is obsolete and not supported for the loop current or
loop voltage polarity change states are already included in SE_LVOLTAGE_CHANGE
and SE_LCURRENT_CHANGE filtering.
Line Polarity:
Line polarity monitoring is performed through API MTSetMoni() of
MONI_REVERSAL bit.
Loop Termination:
The loop termination supported for media tasks are
TERM_LVOLTAGE_ABOVEORBELOW (i.e. TERM_LVOLTAGE_NOTOFFHOOK). In PT
channel, the starting of a media task based on START_LVOLTAGE_MIDDLE (i.e.
START_LVOLTAGE_OFFHOOK) implies the termination on
LVOLTAGE_ABOVEORBELOW (i.e. LVOLTAGE_NOTOFFHOOK).
SMARTWORKS LDA CARDS
LDA can detect both loop voltage change and loop current change.
Loop Voltage:
LDA provides user the configuration capability to set the thresholds of voltage high
and voltage low. This allows custom definition of the three loop voltage states of
ABOVE, BELOW, and MIDDLE (e.g. ONHOOK, REVERSE, and OFFHOOK states are the
common terms for ABOVE, BELOW, and MIDDLE states). With LDA’s capability of
detecting the three states of loop voltage change, LDA can detect the presence of a
wink, a state PT channel cannot detect. LDA can also provide current voltage
reading, a capability PT channel does not have.
De-Bouncing:
The specification of de-bouncing time for ring and loop is implemented through
data structure MT_PSTN and APIs of MTSetPSTNParams() and
MTGetPSTNParams(). Data field ring_deglitch specifies the ring de-bouncing time,
and field loop_deglitch specifies the loop current de-bouncing time for AT channel
and the loop voltage de-bouncing time for PT channel.
Ai-Logix, Inc.
518 •
SmartWORKS Developer’s Guide
Since LDA detects both loop current and loop voltage, the SDK needs supports the
case where the de-bouncing time for loop current and loop voltage differs. A set of
APIs for get and set loop voltage parameters are used: MTSetLVParams(),
MTGetLVParams().
Line Status:
Line status for LDA card will be represented through status bit LINE_ONHOOK,
LINE_POLARITY(0 for normal; 1 for reversed), LINE_NO_LOOP, and
LINE_NO_LVOLTAGE_MIDDLE.
Event Filtering:
For LDA channels, the possible yielding events are EVT_LVOLTAGE_ABOVE,
EVT_LVOLTAGE_BELOW, or EVT_LVOLTAGE_MIDDLE (i.e. EVT_LVOLTAGE_OFFHOOK).
Event filtering of SE_LCURRENT_CHANGE yields events of EVT_LOOP_ON,
EVT_LOOP_DROP, and EVT_LOOP_REVERSE. Event filtering of SE_LREV is obsolete
and not supported for the loop current or loop voltage polarity change states are
already included in SE_LVOLTAGE_CHANGE and SE_LCURRENT_CHANGE filtering.
Line Polarity:
Line polarity monitoring, through API MTSetMoni() of MONI_REVERSAL bit is
implemented on the LDA by adding a new event EVT_MON_REVERSAL during
detecting of state EVT_LOOP_REVERSE or EVT_LVOLTAGE_BELOW.
For events that indicates a loop current or voltage state change, the information of
the current state, the previous state and the duration of the previous state are
presented through field MT_EVENT.SubReason and MT_EVENT.DataLength:
CurrentState:
the least significant byte of field MT_EVENT.SubReason;
PreviousState:
the second least significant byte of field MT_EVENT.SubReason;
DurationOfPreviousState:
the value in MT_EVENT.DataLength times 125 micro-seconds
Event filtering of SE_WKRECV will not be implemented in SDK. User application can
determine the presence of a WINK based on the above timing information from
events.
API MTWink() does not apply to LDA channel for it can generate a hook flash, not a
wink.
Loop Termination:
The loop termination supported for media tasks are TERM_LOOP_DROP and
TERM_LVOLTAGE_ABOVEORBELOW (i.e. TERM_LVOLTAGE_NOTOFFHOOK). The
starting of a media task based on START_LVOLTAGE_MIDDLE (i.e.
START_LVOLTAGE_OFFHOOK) implies the termination on
LVOLTAGE_ABOVEORBELOW (i.e. LVOLTAGE_NOTOFFHOOK). The starting of a media
task based on START_LOOPON implies the termination of LOOP_DROP. Termination
TERM_LOOP_DROP and TERM_LVOLTAGE_ABOVEORBELOW is allowed one at one
time on a LDA channel. Media starting control of START_LVOLTAGE_MIDDLE and
START_LOOPON is allowed one at one time on a LDA channel.
Function Reference Library
• 519
Introduction
Also, in loop start settings where the tip is grounded and the ring is –48V, the
normal loop polarity detection on LDA is ABOVE, BELOW and MIDDLE. However, in
ground start settings where the ring is grounded and the tip is at 48V, the detection
will be reported reversed as stated above. An API (MTSetReverseLoopPolarity()) is
needed to report the same in ground start environment.
Ai-Logix, Inc.
520 •
SmartWORKS Developer’s Guide
MTGetLVDetectState()
Description
This API is only supported on the PT board.
MTGetLVDetectState() retrieves the detection state of loop
voltage. If a value of 0 is returned, this indicates that there is no
voltage - the channel is currently OFF_HOOK or has been
disconnected.
Prototype
MT_RESULT MTGetLVDetectState (
const CHANNEL nChannel,
const PUCHAR pState
);
Parameters
nChannel channel number
pState pointer to buffer for the detect state, 0
indicates no voltage
Return codes
MT_RET_OK no error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM invalid board index or framer
index
MT_RET_INVALID_CHANNEL Channel index error
MT_RET_CHANNEL_NOT_OPENED Channel not owned by the
caller
Events
None
Function Reference Library
• 521
Introduction
MTGetLCDetectState()
Description
This API is only supported on AT and LD boards.
This API gets loop current detect state per channel. If the value of 0
is returned this indicates that there is no loop current - the line is
either disconnected or ON_HOOK.
Prototype
MT_RESULT MTGetLCDetectState (
const CHANNEL nChannel,
const PUCHAR pState
):
Parameters
nChannel channel number
pState pointer to buffer for the detect state, 0
for not detecting none
Return codes
MT_RET_OK no error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid board index or framer
index
MT_RET_CHANNEL_NOT_OPENED Channel not owned by the
caller
Events
None
Ai-Logix, Inc.
522 •
SmartWORKS Developer’s Guide
MTGetRingDetectState()
Description
MTGetRingDetectState() retrieves the current detection state of
ring. A returned value of 0 indicates that the channel is currently not
detecting incoming ring. A value other than 0 indicates a ring is
currently being detected.
Prototypes
MT_RESULT MTGetRingDetectState (
const CHANNEL nChannel,
const PUCHAR pState
);
Parameters
nChannel channel index
pState pointer to buffer for the detect state, 0
for none detected
Return codes
MT_RET_OK no error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid board index or framer
index
MT_RET_CHANNEL_NOT_OPENED Channel not owned by the
caller
MT_RET_INVALID_CHANNEL Channel index error
Events
None
Function Reference Library
• 523
Introduction
MTSetLVParams()
Description
The API is only supported on the SmartWORKS LD boards.
LDA provides the user capability to set the thresholds of voltage
high and voltage low. This allows custom definition of the three
loop voltage states of ABOVE, BELOW, and MIDDLE (e.g. ONHOOK,
REVERSE, and OFFHOOK states are the common terms for ABOVE,
BELOW, and MIDDLE states).
Prototype
MT_RESULT MTSetLVParams(
const CHANNEL nChannel,
const SHORT ThresholdLow,
const SHORT ThresholdHigh,
const USHORT msDeglitchTime
);
Parameters
nChannel channel number
ThresholdLow LV threshold low: -60V to 60V, default = -
16V
ThresholdHigh LV threshold high: 60V to –60V, default =
+16V
msDeglitchTime De-bouncing time in unit of 10ms, valid
range is 10 ms to 2550 ms, default 50ms
Return codes
MT_RET_OK no error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid board index or framer
index
MT_RET_CHANNEL_NOT_OPENED Channel not owned by the
caller
Events
None
Function Reference Library
• 525
Introduction
MTGetLVParams()
Description
The API is only supported on the SmartWORKS LD boards.
MTGetLVDetectValue()
Description
The API is only supported on the SmartWORKS LD boards. It is used
for the purpose of measuring the voltage on any particular channel.
MTSetReverseLoopPolarity()
Description
The API is only supported on the SmartWORKS LD boards.
Line status for LDA card will be represented through status bit
LINE_ONHOOK, LINE_POLARITY(0 for normal; 1 for reversed),
LINE_NO_LOOP, and LINE_NO_LVOLTAGE_MIDDLE.
MTGetReverseLoopPolarity()
Description
The API is only supported on the SmartWORKS LD boards.
Line status for LDA card will be represented through status bit
LINE_ONHOOK, LINE_POLARITY(0 for normal; 1 for reversed),
LINE_NO_LOOP, and LINE_NO_LVOLTAGE_MIDDLE
SUMMATION FUNCTIONS
The following structure is used to hold summation information.
MTSUMMATION_INFO
MTGetSummationInfo ()
This API was previously called MTGetSummationResource(), and
MTGetSummationInputCount().
Description
This API is used to return the total number of inputs the specified
summation resource supports.
It is suggested that the user application use this API to query for the
maximum number of inputs supported by a summation resource
before launching the summation resource to work.
Prototype
MT_RESULT MTGetSummationInfo (
const int iSummation,
PMTSUMMATION_INFO const pInfo,
PULONG const pLength
);
Parameters
iSummation Index of summation resource: 0 for the
first one
pInfo Pointer to resource information struc-
ture, MT_SUMMATION_INFO.
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MT_SUMMATION_INFO struc-
ture.
Structure
The following table explains each field of the
MT_SUMMATION_INFO structure:
Return codes
MT_RET_OK no error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid board index or framer
index
Events
None
Ai-Logix, Inc.
532 •
SmartWORKS Developer’s Guide
MTResetSummation()
Description
Clears the all time slot connections of inputs and outputs on the
specified summation function. MTResetSummation() disconnects
the previously connected summation inputs and outputs.
For summation resources, when the input is added, the gain will be
set to the specified value. When the input is removed, the gain is
reset to the default, -50dB (mute).
Prototype
MT_RESULT MTResetSummation(
const int iSummation
);
Parameters
iSummation Index of summation function, 0 for the
first
Return Code
MT_RET_OK no error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid board index or framer
index
MT_RET_NOT_STARTED The specified input is not con-
nected
Events
None
See Also: MTRemoveSummationInput()
Function Reference Library
• 533
Introduction
MTStartSummation()
Description
MTStartSummation() connects the specified summation output to
the specified stream and time slot. When the CT bus is set to MVIP,
the stream index is from 0 to 15 for the 16 available streams, and the
time slot index is from 0 to 31 for the available time slots on each
stream.
If the CT bus type is H.100, the stream index is from 0-31 for the 32
available streams. The number of timeslots available per stream
depends on which H.100 stream speed is selected in the
SmartControl panel.
At 2048 KHz, 32 timeslots per stream are available.
At 4096 KHz, 64 timeslots per stream are available.
At 8192 KHz, 128 timeslots per stream are available.
Prototypes
MT_RESULT MTStartSummation (
const int iSummation,
const int iStream,
const int iSlot
);
Parameters
iSummation summation function index: 0 for the first
one
iStream summation output stream index, 0 - 15
for MVIP, 0-31 for H.100
iSlot summation output time slot index,
0 - 31 for MVIP, for H.100 the value is
determined by user configured stream
speed (see description above).
Return Code
MT_RET_OK no error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid board index or framer
index
MT_RET_BUSY On output time slot taken
Events
None
Ai-Logix, Inc.
534 •
SmartWORKS Developer’s Guide
MTStopSummation()
Description
MTStopSummmation() disconnects the previously connected
summation output. No other settings are changed.
Prototype
MT_RESULT MTStopSummation (
const int iSummation
);
Parameters
iSummation summation function index: 0 for the first
one
Return codes
MT_RET_OK no error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid board index or framer
index
MT_RET_NOT_STARTED On summation not started
Events
None
Function Reference Library
• 535
Introduction
MTAddSummationInput()
Description
MTAddSummationInput() connects an input timeslot to an input
unit on the specified summation function. Should there be a
timeslot previously connected to that input unit, the previous
connection will be replaced with the new time slot. The rest of the
summation inputs will not be altered.
When the CT bus is set to MVIP, the stream index is from 0 to 15 for
the 16 available streams, and the time slot index is from 0 to 31 for
the available time slots on each stream.
If the CT bus type is H.100, the stream index is from 0-31 for the 32
available streams. The number of timeslots available per stream
depends on which H.100 stream speed is selected in the
SmartControl panel.
At 2048 KHz, 32 timeslots per stream are available.
At 4096 KHz, 64 timeslots per stream are available.
At 8192 KHz, 128 timeslots per stream are available.
Prototype
MT_RESULT MTAddSummationInput (
const int iSummation,
const int iInput,
const int iStream,
const int iSlot,
const SHORT Gain
);
Parameters
iSummation Index of summation function, 0 for the
first
iInput Index of summation input: 0 - 15 for 16
summation inputs.
iStream Index of TDM output stream: 0 - 15 for
MVIP, 0-31 for H.100
iSlot Index of TDM output slot on a stream: 0 -
31 for MVIP,
0 - 31 for MVIP, for H.100 the value is
determined by user configured stream
speed (see description above).
Gain Initial gain for the specified input: valid
values: =24dB to
-50dB.
Ai-Logix, Inc.
536 •
SmartWORKS Developer’s Guide
Return codes
MT_RET_OK no error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid board index or framer
index
MT_RET_BUSY On time slot connection error
Events
None
Function Reference Library
• 537
Introduction
MTRemoveSummationInput()
Description
MTRemoveSummationInput() disconnects the previously
connected summation input.
Prototypes
MT_RESULT MTRemoveSummationInput (
const int iSummation,
const int iInput
);
Parameters
iSummation Summation function index: 0 for the first
one
iInput Summation input index: 0 to 15 for 16
summation inputs
Return Codes
MT_RET_OK no error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid board index or framer
index
MT_RET_NOT_STARTED The specified input is not con-
nected
Events
None
Ai-Logix, Inc.
538 •
SmartWORKS Developer’s Guide
MTGetSummationInputs()
Description
MTGetSummationInputs() retrieves the time slot connections for
a specified number of inputs on the specified summation function.
The operating state of the specified summation has no bearing on
this function. Inputs for a summation can always be connected
without the summation function being turned on.
Parameters pStream, pSlot, and pGain all work as an array. This array
must be large enough to accept the total number of input settings
specified with the pInput parameter. When returned, this integer
contains the number of inputs retrieved into the provided buffer.
Fox example, if a summation unit has a maximum of 16 inputs and
the caller specifies the retrieval of 32 inputs, the API will send the
updated information into the provided buffer and update the input
count integer from 32 to the actual number of 16.
Prototype
MT_RESULT MTGetSummationInputs (
const int iSummation,
int * const pInputs,
int * const pStream,
int * const pSlot,
SHORT * const pGain
);
Parameters
iSummation Summation function index: 0 for the first
one
pInputs Pointer to the total number of input set-
tings to retrieve.
pStream Pointer as an array to the streams for the
16 inputs
pSlot Pointer as an array to time slots for the
16 summation inputs
pGain Pointer as an array to gains for the 16
summation inputs
Return Codes
MT_RET_OK no error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid board index or framer
index
Function Reference Library
• 539
Introduction
MTGetSummationOutput()
Description
MTGetSummationOutput() retrieves the time slot connection for
the output on the specified summation function.
MTSetSummationGain()
Description
MTSetSummationGain() sets the gain for summation input on the
specified summation function. The operating state of the specified
summation has no bearing on this function. Gain for a summation
input can be changed whether or not the summation function is
turned on.
MTGetSummationGain()
Description
MTGetSummationGain() gets the gain for the summation input on
the specified summation function. The operating state of the
specified summation has no bearing on this function. Gain for a
summation input can be read whether or not the summation
function is turned on.
MTSetSummationVolume()
Description
MTSetSummationVolume() sets the volume for summation
output on the specified summation function. The operating state of
the specified summation has no bearing on this function. Volume
for a summation output can be changed whether or not the
summation function is turned on.
Prototype
MT_RESULT MTSetSummationVolume (
const int iSummation,
const SHORT Volume
);
Parameters
iSummation Summation function index: 0 for the first
one
Volume Output volume for the specified summa-
tion output. Valid values: 24 db to
-50dB.
Return codes
MT_RET_OK no error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid board index or framer
index
MT_RET_CHANNEL_NOT_OPENED On failure to gain ownership of
the specified summation func-
tion
Events
None
Ai-Logix, Inc.
544 •
SmartWORKS Developer’s Guide
MTGetSummationVolume()
Description
MTGetSummationVolume() gets the volume for summation
output on the specified summation function. The operating state of
the specified summation has no bearing on this function. Volume
for a summation output can be read whether or not the summation
function is turned on.
Prototype
MT_RESULT MTGetSummationVolume (
const int iSummation,
PSHORT const pVolume
);
Parameters
iSummation Summation function index: 0 for the first
one
pVolume The volume setting, Valid values: 24 dB
to -50dB
Return Codes
MT_RET_OK no error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid board index or framer
index
MT_RET_CHANNEL_NOT_OPENED On failure to gain ownership of
the specified summation func-
tion
Events
None
Function Reference Library
• 545
Introduction
MTSetSummationAVC()
Description
MTSetSummationAVC() sets the Automatic Volume Control (AVC)
for summation output on the specified summation function. The
operating state of the specified summation has no bearing on this
function. The AVC setting for a summation output can be changed
whether or not the summation function is turned on. Configuring
the AVC settings does not enable AVC functionality. Use
MTSummationAVCControl() to enable or disable AVC on
summation output.
Prototype
MT_RESULT MTSetSummationAVC (
const int iSummation,
const SHORT TMA,
const SHORT AVCR,
const SHORT DVCR,
const SHORT MA
);
Parameters
iSummation Summation function index: 0 for the first
one
TMA Target maximum amplitude (TMA), 1 to -
45 dBm, def=-6 dBm
AVCR Attack Volume Change Rate, in unit of -
0.00212 dB/ms, def=400
value must be <=0
DVCR Decay Volume Change Rate, in unit of
0.00212 dB/ms, def=4
value must be <=0
MA Max. Amplification, 6 dB to 48 dB in 6dB
steps, def=30 dB
Return codes
MT_RET_OK no error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid board index or framer
index
MT_RET_CHANNEL_NOT_OPENED On failure to gain ownership of
the specified summation func-
tion
Events
None
Ai-Logix, Inc.
546 •
SmartWORKS Developer’s Guide
MTGetSummationAVC()
Description
MTGetSummationAVC() retrieves the AVC settings for the output
on the specified summation function. The operating state of the
specified summation has no bearing on this function. AVC settings
for a summation output can be read whether or not the summation
function is turned on.
Prototypes
MT_RESULT MTGetSummationAVC (
const int iSummation,
PSHORT const pTMA,
PSHORT const pAVCR,
PSHORT const pDVCR,
PSHORT const pMA
);
Parameters
iSummation Summation function index: 0 for the first
one
pTMA Pointer for target max. amplitude (TMA)
pAVCR Pointer for attack volume change rate
(AVCR)
pDVCR Pointer for decay volume change rate
(DVCR)
pMA Pointer for max amplification (MA)
Return Codes
MT_RET_OK no error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid board index or framer
index
MT_RET_CHANNEL_NOT_OPENED On failure to gain ownership of
the specified summation func-
tion
Events
None
Function Reference Library
• 547
Introduction
MTSummationAVCControl()
Description
MTSummationAVCControl() controls the AVC for the output on
the specified summation function. The operating state of the
specified summation has no bearing on this function. AVC for a
summation output can be configured whether or not the
summation function is turned on.
Prototype
MT_RESULT MTSummationAVCControl (
const int iSummation,
const BOOLEAN fOn
);
Parameter
iSummation Summation function index: 0 for the first
one
fOn TRUE for enable; FALSE for disable the
AVC
Return Codes
MT_RET_OK no error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid board index or framer
index
MT_RET_CHANNEL_NOT_OPENED On failure to gain ownership of
the specified summation func-
tion
Events
None
Ai-Logix, Inc.
548 •
SmartWORKS Developer’s Guide
MTSummationAVCStatus()
Description
MTSummationAVCStatus() reads the AVC status for the output on
the specified summation function. The operating state of the
specified summation has no bearing on this function. AVC enabled/
disabled status for a summation output can be read whether or not
the summation function is turned on.
Prototype
MT_RESULT MTSummationAVCStatus (
const int iSummation,
BOOLEAN * const pOn
);
Parameters
iSummation Summation function index: 0 for the first
one
pOn Pointer for the status
Return Codes
MT_RET_OK no error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid board index or framer
index
MT_RET_CHANNEL_NOT_OPENED On failure to gain ownership of
the specified summation func-
tion
Events
None
Function Reference Library
• 549
Introduction
SYSTEM FUNCTIONS
Ai-Logix, Inc.
550 •
SmartWORKS Developer’s Guide
MTSysStartup()
This API was formerly called MTStartLink()
Description
When this API is called, SmartWORKS boards will be opened, all
SmartWORKS channels will be opened, board communications
between DLL and driver will be opened, and MVIP MUX will be
enabled.
MTGetSystemInfo()
This API was formerly called MTGetSysInfo()
Description
MTGetSystemInfo() fills the provided MTSYS_INFO structure with
information about the system status, number of boards, number of
channels, and the MUX operation information of the system
Prototype
MT_RESULT MTGetSystemInfo (
PMTSYS_INFO const pInfo,
PULONG const pLength
);
Parameters
pInfo pointer to MTSYS_INFO structure to
store information
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MTSYS_INFO structure
Structure.
Table Key:
Status Current system status of the following:
SYSTEM_INITIALIZED
SYSTEM_STARTED
SYSTEM_SHUTDOWN
DigiRate The current digitizing rate in bits per
second.
NumAudios Number of audio jacks.
NumBoards The number of boards in the local sys-
tem.
NumChans The number of channels in the local sys-
tem.
Mode The mode, always 1 for enhanced mode.
StartChan The starting channel of the local MUX
system in a multiple-PC global system.
StartBoard The starting board number of the local
MUX system in a multiple-PC global sys-
tem.
MuxBoards The number of boards in the global sys-
tem.
MuxSystem The type of MUX system. It can contain
the values of MUX_NONE or MUX_MVIP.
MuxMVIPSlot Starting MVIP slot assigned.
MuxMVIPTotalSlot Total MVIP slots assigned
MuxGroups The number of groups that are available
to the group conference functions can
be found in this parameter. (this field is
not used).
MuxChans The number of channels in the global
system.
GCIStartingIndex GCI Starting index: 0 or 1
Function Reference Library
• 553
Introduction
CODE EXAMPLE
MTGetSystemInfo() Code Example
ZeroMemory(&sysinfo,size);
result = MTGetSystemInfo(&sysinfo,&size);
if(result == MT_RET_OK)
{
printf("MTGetSystemInfo() successful...\n");
USHORT totalBoards = sysinfo.NumBoards;
USHORT totalChannels = sysinfo.NumChans;
UCHAR gciStart = sysinfo.GCIStartingIndex;
printf("Total number of boards: %u\nTotal
number of channels: %u\nGCI: %d\n",totalBoards,totalChannels,gciStart);
}
A complete code example is available on the Ai-Logix website:
http://www.ai-logix.com/support.html
MTSysShutdown()
This API was formerly called MTStopLink().
Description
Closes all channels by flushing all current and pending functions on
all channels. This closes all communication with driver, and all
channels. This system status will change from SYSTEM_STARTED to
SYSTEM_SHUTDOWN.
Once this API is used, the channels will no longer respond to any API
calls.
Prototypes
MT_RESULT MTSysShutdown (VOID)
Return Codes
MT_RET_OK no error
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 555
Introduction
MTGetVersion()
This API will be obsolete as of Sept. 2005. Use MTSysGetVersion() instead.
Description
MTGetVersion() returns the version of the SmartWORKS driver and
on board firmware. The versions are for the first board. Use
MTGetAdapterInfo() to get the versions for each board. The
version information is defined as MT_VERSION.
The SmartWORKS software version number is composed of two 32-
bit version long integers.
Prototype
MT_RESULT MTGetVersion (
PMT_VERSION const pDriverVersion,
PMT_VERSION const pFWVersion
);
Parameters
pDriverVersion stores version of the host driver
pFWVersion stores firmware version of the first board
in target platform
Structure.
Return Codes
MT_RET_OK no error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid argument passed to
function. Use MTGetLastError()
to check this error.
Events
None
Ai-Logix, Inc.
556 •
SmartWORKS Developer’s Guide
MTSysGetVersion()
This API has replaced MTGetVersion() and MTGetDLLVersion().
Description
This API retrieves the version of SDK components at run time. If a
component is missing from the target PC, the version info for it
should be all zeros
Prototype
MT_RESULT MTSysGetVersion (
PMTSDK_VERSION pSDKVersion,
PULONG pLength
);
Parameters
pSDKVersion pointer to the structure
pLength pointer to the length of the structure
Structure.
Return Codes
MT_RET_OK no error
MT_RET_INVALID_PARAM Invalid argument passed to
function. Use MTGetLastError()
to check this error.
Events
None
Function Reference Library
• 557
Introduction
MTGetDLLVersion()
This API will be obsolete as of Sept. 2005. Use MTSysGetVersion() instead.
Description
MTGetDLLVersion() is a function that is used to retrieve the version
information associated with the NtiDrv.dll file.
Prototype
MT_RESULT MTGetDLLVersion (
PMT_VERSION const pDLLVersion
);
Parameters
pDLLVersion Pointer to version information buffer
Return Codes
MT_RET_OK no error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_PARAM Invalid argument passed to
function. Use MTGetLastError()
to check this error.
Events
None
CODE EXAMPLE
MTGetDLLVersion() Code Example
ZeroMemory(&version,size);
result = MTGetDLLVersion(&version);
if(result == MT_RET_OK)
{
printf("MTGetDLLVersion() successful...\n");
UCHAR major = version.Major;
UCHAR minor = version.Minor;
USHORT internal = version.Internal;
USHORT build = version.Build;
UCHAR release = version.Release;
UCHAR feature = version.Feature;
printf("%02d.%02d.%02d\nBuild %d\nRelease
%d\nFeature %d\n",major,minor,internal,build,release,feature);
}
A complete code example is available on the Ai-Logix website:
http://www.ai-logix.com/support.html
Ai-Logix, Inc.
558 •
SmartWORKS Developer’s Guide
MTResyncTime()
Description
By default, the timestamp is synced when a board/channel is
opened the very first time. Use this API to re-synchronize the time
between the host PC and SmartWORKs board without shutting
down the NTI application. If the host PC’s time is modified this API is
called to resync the time so that event timestamps are adjusted.
MTOffHook()
Description
MTOffHook() takes a specified channel off hook provided that the
channel is in the on hook state. MT_RET_BUSY will be returned if the
channel is already in the off hook state. When a channel successfully
goes off hook, EVT_OFFHOOK will be issued [if enabled through
MTSetEventFilter()].
MTOnHook()
Description
MTOnHook() changes a specified channel that is off hook to the on
hook state. MT_RET_BUSY will be returned if the specified channel
is already on hook. When a channel successfully goes on hook,
EVT_ONHOOK will be issued (if enabled through
MTSetEventFilter()).
MTGetHookState()
Description
Returns the on/off hook state for an identified channel.
Prototype
MT_RESULT MTGetHookState (
CHANNEL nChannel,
const PUCHAR pState
);
Parameters
nChannel channel number
pState 0 for onhook
Return Codes
MT_RET_OK no error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_INVALID_CHANNEL Channel number is out of
range.
MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
Events
None
Function Reference Library
• 563
Introduction
MTWink()
TBD, at this time this API is not supported.
Description
MTWink() perform a wink, the sequence of going off-hook, waiting
for a moment, and going on-hook again. The function terminates
with an EVT_WINKDONE event. During this function, the status
fields of the MTCHAN_STATUS structure are set to MODE_WINK.
MakeWaveGSMHeader()
Description
MakeWaveGSMHeader() takes the specified data size and
generates a RIFF header for the GSM format. Refer to NtiData.h for
the definition of GSM_WAVE_HEADER, a standard Microsoft header
format.
Note:
Only Microsoft GSM is supported.
Scenario
In the situation where wave header is not to be generated by APIs
(such as streaming and device IO functions), the user application
can use MakeWaveGSMHeader() to write the header when
desired.
Prototype
void MakeWaveGSMHeader (
PGSM_WAVE_HEADER pWaveHeader,
int BytesWritten
);
Parameters
pWaveHeader pointer to buffer to take the header
BytesWritten size of the data
Return Codes
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
CODE EXAMPLE
MakeWaveGSMHeader()
MakeWaveGSMHeader(&header,60);
if(handleMT(MTRecFile(channel,buffer,&ioctrl),"MTRecFile()"))
handleMT(MTWaitForChannelEvent(channel,10000,&event,&evtsize),"MTWaitForChanne
lEvent()");
handleMT(MTClearEventCallback(channel),"MTClearEventCallback()");
handleMT(MTSysShutdown(),"MTSysShutdown()");
MakeWavePCMHeader()
Description
MakeWavePCMHeader() takes the specified data size and
generates a RIFF header for the PCM format. Refer to NtiData.h for
the definition of PPCM_WAVE_HEADER, a standard Microsoft
header format.
Scenario
In the situation where wave header is not to be generated by APIs
(such as streaming and device IO functions), the user application
can use MakeWavePCMHeader() to write the header when
desired.
Prototype
void MakeWavePCMHeader (
PPCM_WAVE_HEADER pWaveHeader,
int BytesWritten,
USHORT Format
);
Parameters
pWaveHeader pointer to buffer to take the header
BytesWritten size of the data
Format format of 8 or 16 bit PCM
Return Codes
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 567
Introduction
MTReturnEventBuffer()
Description
MTReturnEventBuffer() returns the event buffer to the API after
the user application is finished processing the event. NOTE: This API
is only required when the polling method is used, and when call
control events (EVT_CC_) are reported.
Return Codes
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 569
Introduction
MTGetAdapterDescription()
Description
When called, MTGetaAdapterDescription() will return an ASCII
description of the board in a system. A call to MTGetAdapterInfo()
is required to use this API to obtain the first parameter, BoardType.
Prototype
void MTGetAdapterDescription (
const ULONG BoardType,
const PCHAR pDescription,
const int nLength
);
Parameters
BoardType BoardType: VR6409, VR3200, etc.
pDescription Pointer for the NULL terminated descrip-
tion
nLength Length of the description buffer
CODE EXAMPLE
MTGetAdapterDescription() Code Example
// need to call MTGetAdapterInfo() before calling MTGetAdapterDescription()
ZeroMemory(&adapterinfo,adaptersize);
result =
MTGetAdapterInfo(board,&adapterinfo,&adaptersize);
if(result != MT_RET_OK)
{
printf("MTGetAdapterInfo() failed...\n");
printf("- Cannot get board
description...\n");
return 1;
}
else
{
ZeroMemory(&description,descsize);
MTGetAdapterDescription(adapterinfo.BoardType,description,descsize);
printf("MTGetAdapterDescription()
successful...\n");
printf("Board type: %u\nBoard description:
%s\n",adapterinfo.BoardType,description);
}
A complete code example is available on the Ai-Logix website:
http://www.ai-logix.com/support.html
MTStartMUXOnChannel()
Description
MTStartMUXOnChannel() is called to prepare MUX operation on a
specified channel before MUX connections can be made. All
configurations will be set to default based on the configuration of
the TDMCardType and TDMBusType. MTStartMUX() needs to be
called before MTStartMUXOnChannel().
FIRMWARE FUNCTIONS
Ai-Logix, Inc.
572 •
SmartWORKS Developer’s Guide
• In the event of error during the Update Flash operation, the user must restart
the driver
• The application performing the firmware upload process must have exclusive
access to the board. Multiple applications cannot be running when this func-
tion is initiated
The diagram on the following page illustrates the steps required when updating a
board’s firmware:
Function Reference Library
• 573
Introduction
MTWFInit()
Initialize the process
MT_RET_LIB_LOAD_FAILED NO MT_RET_OK?
YES
MTWFUpdateFirmware()
Begin the update
Only this
NO application
is running?
YES
MT_RET_INVALID_BOARD
MT_RET_INVALID_FILENAME NO MT_RET_IO_PENDING?
MT_RET_INVALID_BINFILE
MT_RET_INCOMPATIBLE_BIN_FILE
MT_RET_LIB_LOAD_FAILED
MT_RET_BOARD_INUSE
MT_RET_NO_MEM
YES
MTWFGetUpdatingStatus()
Check Progress
NO Percentage =
100?
YES
MTWFUninit()
Uninitialize the process
MTWFInit()
Description
Initializes the firmware load process.
Prototype
MT_RESULT MTWFInit (
VOID
);
Parameters
no parameter required
Return Codes
MT_RET_OK no error
MT_RET_LIB_LOAD_FAILED the driver (NtiDRV.DLL) load
failed
Events
None
Function Reference Library
• 575
Introduction
MTWFUpdateFirmware()
Description
This function loads the firmware. The file name is specified as a
function parameter.
If the parameter “CompletionRoutine” is NULL, this function
behaves as synchronous function. It returns MT_RET_OK when the
update is completed. If “CompletionRoutine” is not NULL, this
becomes a background function that returns
“MT_RET_IO_PENDING” with no error. The completion routine is
invoked when the firmware load is completed or any error occurs.
NOTE: This function must have exclusive rights to the board. For
best results, each application that access the board should invoke
MTCloseBoard().
Prototype
MT_RESULT MTWFUpdateFirmware(
const BOARD nBoard,
PCSTR pFileName,
MTWFCOMPLETE CompletionRoutine,
LPARAM lParam
);
Parameters
nBoard board number
pFileName the complete path and name of the
firmware file that must be loaded (NULL
terminated)
CompletionRoutine the address of the callback function
lParam a user defined parameter to echo back
to the completion routine
Return Codes
MT_RET_OK no error
MT_RET_IO_PENDING Background I/O operation is
in progress or queued
MT_RET_INVALID_BOARD Board number is out of range
MT_RET_INVALID_FILENAME the function is unable to locate
the firmware file
MT_RET_INVALID_BINFILE image file version cannot be
retrieved
MT_RET_BOARD_INCOMPATIBLE_BINFILE the firmware file does not
match the board type (sub sys-
tem id in file name does not
match with the sub system id
from MTGetAdepterDescrip-
tion() for corresponding Smart-
WORKS hardware
MT_RET_LIB_LOAD_FAILED the driver (NtiDRV.DLL) load
failed
Ai-Logix, Inc.
576 •
SmartWORKS Developer’s Guide
MTWFGetUpdatingStatus()
Description
This function retrieves the percentage of written flash, specified by
a percentage. This API is only used when MTWFUpdateFirmware()
is operating as background function.
Prototype
MT_RESULT MTWFGetUpdatingStatus (
const BOARD nBoard,
PULONG const percentage
);
Parameters
nBoard board number
percentage a pointer for retrieving the percentage
of the written flash
Return Codes
MT_RET_OK no error
MT_RET_LIB_LOAD_FAILED the driver (NtiDRV.DLL) load
failed
MT_RET_INVALID_BOARD Board number is out of range
Events
None
Ai-Logix, Inc.
578 •
SmartWORKS Developer’s Guide
MTWFUninit()
Description
This is cleanup function. It is strongly recommended to call this
function when users complete their operation with “NTIWF.DLL”.
This function will unload the “NTIDRV.DLL” loaded by this
“NTIWF.DLL”
Prototype
MT_RESULT MTWFUnit(
VOID
);
Parameters
no parameter required
Return Codes
MT_RET_OK no error
Events
None
Function Reference Library
• 579
Introduction
MTBoardSetIdleCoding()
Description
Sets the coding format for the idle packet. When the trunk is
reporting loss of sychronization (EVT_LOSYNC_ALARM), the framer
replaces the data stream normally passed to the TDM with an idle
packet signal. By default, µ-Law idle packet is used. This API is only
used with SmartWORKS PCM cards.
Prototype
MTBoardSetIdleCoding (
const BOARD iBrd,
const int iTrunk,
const int iCodingFormat
);
Parameters
iBrd Board number
iTrunk 0 for the 1st trunk, 1 for the 2nd
trunk
iCodingFormat ULAWPXD or ALAWPXD
Return Codes
MT_RET_OK No error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_TIMEOUT Wait for event timed out
MT_RET_INVALID_PARAM Invalid argument passed to function
Events
None
Function Reference Library
• 581
Introduction
MTBoardGetIdleCoding()
Description
Gets the coding format that is currently used for the idle packet sent
out when the trunk is reporting loss of synchronization
(EVT_LOSYNC_ALARM). By default, µ-Law idle packet is used.
Prototype
MTBoardGetIdleCoding (
const BOARD iBrd,
const int iTrunk,
int * const iCodingFormat
);
Parameters
iBrd Board number
iTrunk 0 for the 1st trunk, 1 for the 2nd
trunk
pCodingFormat pointer to the coding format: ULAW-
PXD or ALAWPXD
Return Codes
MT_RET_OK No error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_TIMEOUT Wait for event timed out
MT_RET_INVALID_PARAM Invalid argument passed to function
Events
None
Ai-Logix, Inc.
582 •
SmartWORKS Developer’s Guide
MTBoardSetTerminationImpedance()
Description
Sets the termination impedance for the identified trunk. By default,
all trunks are set to Hi-Impedance. This API is used with
SmartWORKS PCM cards only.
Prototype
MTBoardSetTerminationImpedance (
const BOARD iBrd,
const int iTrunk,
const int iImpedance
);
Parameters
iBrd Board number
iTrunk 0 for the 1st trunk, 1 for the 2nd
trunk
iImpedance 0 for Hi-Impedance(default), 1 for
Low-Impdedance
Return Codes
MT_RET_OK No error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_TIMEOUT Wait for event timed out
MT_RET_INVALID_PARAM Invalid argument passed to function
Events
None
Function Reference Library
• 583
Introduction
MTBoardGetTerminationImpedance()
Description
Gets the termination impedance for the identified trunk.
Prototype
MTBoardGetTerminationImpedance (
const BOARD iBrd,
const int iTrunk,
int * const pImpedance
);
Parameters
iBrd Board number
iTrunk 0 for the 1st trunk, 1 for the 2nd
trunk
pImpedance pointer to the current termination
impedance: 0 for Hi-Impedance, 1 for
Low-Impdedance
Return Codes
MT_RET_OK No error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_TIMEOUT Wait for event timed out
MT_RET_INVALID_PARAM Invalid argument passed to function
Events
None
Ai-Logix, Inc.
584 •
SmartWORKS Developer’s Guide
MTBoardPCMSetSignalConfig()
Description
Sets the PCM Signal Configuration for the specified trunk. When this
function is invoked the signal is reversed. This allows the application
to adjust the pin interpretation if the paired wiring was reversed
during installation. The default setting is normal for all signals.
Prototype
MTBoardPCMSetSignalConfig (
const BOARD iBrd,
const int iTrunk,
const MT_BOARD_PCM_SIGNAL Signal,
PULONG const pLength
);
Parameters
iBrd Board number
iTrunk 0 for the 1st trunk, 1 for the 2nd
trunk
Signal parameter used to identify the
MT_BOARD_PCM_SIGNAL
pLength number of bytes for structure Signal
Structure
Return Codes
MT_RET_OK No error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_TIMEOUT Wait for event timed out
MT_RET_INVALID_PARAM Invalid argument passed to function
Events
None
Function Reference Library
• 585
Introduction
MTBoardPCMGetSignalConfig()
Description
Gets the PCM Signal Configuration for the specified trunk.
Prototype
MTBoardPCMGetSignalConfig (
const BOARD iBrd,
const int iTrunk,
MT_BOARD_PCM_SIGNAL const pSignal,
PULONG const pLength
);
Parameters
iBrd Board number
iTrunk 0 for the 1st trunk, 1 for the 2nd
trunk
Signal pointer to the Signal structure
pLength number of bytes for the structure
pointed to by pSignal
Return Codes
MT_RET_OK No error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_TIMEOUT Wait for event timed out
MT_RET_INVALID_PARAM Invalid argument passed to function
Events
None
Ai-Logix, Inc.
586 •
SmartWORKS Developer’s Guide
MTBoardPCMTrunkFrameSyncControl()
Description
By default, TDM frame reference is received on trunk 0 (framer 0).
The SmartWORKS PCM cards can also transmit frame sync. This API
can be used to switch the trunk reference or enable/disable frame
sync transmission. By default, frame sync transmission is disabled
on both trunks.
Prototype
MTBoardPCMTrunkFrameSyncControl (
const BOARD iBrd,
const int iTrunk,
const BOOL fTxFrameSyncEnable
);
Parameters
iBrd Board number
iTrunk 0 for the 1st trunk, 1 for the 2nd
trunk
fTxFrameSyncEnable false for Disable (default), true for
Enable
Return Codes
MT_RET_OK No error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_TIMEOUT Wait for event timed out
MT_RET_INVALID_PARAM Invalid argument passed to function
Events
None
Function Reference Library
• 587
Introduction
MTBoardPCMTrunkFrameSyncStatus()
Description
Gets the current frame sync status on the specified trunk.
Prototype
MTBoardPCMTrunkFrameSyncStatus (
const BOARD iBrd,
const int iTrunk,
BOOL * const pTxFrameSyncEnable
);
Parameters
iBrd Board number
iTrunk 0 for the 1st trunk, 1 for the 2nd
trunk
pTxFrameSyncEnable pointer to the frame sync status:
false for Disable (default), true for
Enable
Return Codes
MT_RET_OK No error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_TIMEOUT Wait for event timed out
MT_RET_INVALID_PARAM Invalid argument passed to function
Events
None
Ai-Logix, Inc.
588 •
SmartWORKS Developer’s Guide
MTBoardPCMTrunkSlotTxControl()
Description
Enables/disables transmission on any specified timeslot. By default,
transmission is disabled on all SmartWORKS PCM timeslots. The
first channel on the board is connected to the first timeslot on the
first trunk. On the PCM6409 the 33rd channel is connected to the
first timeslot on the second trunk.
Prototype
MTBoardPCMTrunkSlotTxControl(
const BOARD iBrd,
const int iTrunk,
const DWORD32 fEnableBitMap
);
Parameters
iBrd Board number
iTrunk 0 for the 1st trunk, 1 for the 2nd
trunk
fEnableBitMap bit value 0 for disable, 1 for enable
bit 0 for first slot on the specified
trunk and etc.
Return Codes
MT_RET_OK No error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_TIMEOUT Wait for event timed out
MT_RET_INVALID_PARAM Invalid argument passed to function
Events
None
Function Reference Library
• 589
Introduction
MTBoardPCMTrunkSlotTxStatus()
Description
Gets the current transmission status on the specified timslot. The
first channel is connected to the first timeslot on the first trunk. On
the PCM6409 the 33rd channel is connected to the first timeslot on
the second trunk.
Prototype
MTBoardPCMTrunkSlotTxStatus(
const BOARD iBrd,
cosnt int iTrunk,
PDWORD32 pEnableBitMap
);
Parameters
iBrd Board number
iTrunk 0 for the 1st trunk, 1 for the 2nd
trunk
pEnableBitMap pointer to a 4-byte (32 bits) slot table
Return Codes
MT_RET_OK No error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_TIMEOUT Wait for event timed out
MT_RET_INVALID_PARAM Invalid argument passed to function
Events
None
Ai-Logix, Inc.
590 •
SmartWORKS Developer’s Guide
Chapter 6
Event Code Library
Ai-Logix, Inc.
592 •
SmartWORKS Developer’s Guide
The following section presents all SmartWORKS Event Codes in alphabetical order.
593 •
Event Codes Presented Alphabetically
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_ABANDONED An octet 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format containing Channel
the number ID (GCI)
of the
framer
reporting
the event
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_AIS_ALARM
Description: Alarm Indication Signal (AIS) alarm (T1 and E1 framers) has been detected. This indicates that the remote site is not receiving data. To
recieve this event, the framer alarm must be enabled using the MTArmFramerAlarm() API.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_AIS_ALARM An octet 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format containing Channel
the number ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
• 594
595 •
EVT_ANSWER_BUTTON_PRESSED
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_ANSWER_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_ANSWER_LIGHT_FASTFLASHING
EVT_ANSWER_LIGHT_VERY_FASTFLASHING
EVT_ANSWER_LIGHT_FLASHING
EVT_ANSWER_LIGHT_OFF
EVT_ANSWER_LIGHT_ON
EVT_ANSWER_LIGHT_QUICKFLASH
Purpose:
Indicates that the answer light on the phone is on, off, or flashing.
Description:
Observation of various phone models enabled the Ai-Logix lab to categorize phone lights as flashing, fast flashing, very fast flashing or quick flashing.
The cadence varies depending on PBX models, and this may also be configured. Our definition of flashing lights stems from the signal passed from
the PBX to the phone, and is based on factory default configurations for each model. Please refer to your PBX documentation for more information.
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_ANSWER_LIGHT_ *See Below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
• 596
597 •
EVT_ALERTING_AUTO_ANSWER
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_ALERTING_AUTO_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format ANSWER Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_AUDIO_CHANGE
Description: Indicates a change in the audio setting on the phone
NOTE: The Nortel Meridian does send the EVT_AUDIO_CHANGE, however results may vary per network environment. On the 2216 and 3905 phones
the PBX turns the audio on and doesn’t shut it off between calls. This event cannot be used alone to determine recording.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_AUDIO_CHANGE see below* 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
0 0 0 1 0x0001
0 0 1 0 0x0002
0 1 0 0 0x0004
0 1 0 1 0x0005
0 1 1 0 0x0006
0 1 1 1 0x0007
1 0 0 0 0x0008
1 0 0 1 0x0009
1 0 1 1 0x000B
1 1 0 0 0x000C
1 1 0 1 0x000D
1 1 1 0 0x000E
• 598
599 •
EVT_AUDIO_OFF
EVT_AUDIO_ON
Description: Although this event exists in the header file, it is not currently supported by the SmarkWORKS API. Refer to EVT_AUDIO_CHANGE.
EVT_AUTO_ANSWER
Description: Indicates that auto answer has activated
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_AUTO_ANSWER 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_AUTO_ANSWER_CANCELED
Description: Indicates that auto answer has been cancelled
Structure
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_AUTO_ANSWER_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format CANCELED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_BOARD_PANIC_ERROR
Description: Indicates a board panic error
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_BOARD_PANIC_ERROR 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_CALLBACK_BUTTON_PRESSED
Indicates that the callback button was pressed.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_CALLBACK_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format BUTTON_PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_CALLID_DROPPED See Below* See 0-n/a BoardID Global- 0-n/a 0-n/a
format Below* Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_CALLID_STOP
Description: Indicates that CallerID (in a well formed 1200bps FSK data packet) has been detected and received
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_CALLID_DROPPED See Below* See 0-n/a BoardID Global- 0-n/a 0-n/a
format Below* Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_CALLWAITING_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format BUTTON_PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_ANSWER_LIGHT_ *See Below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
Note: When the polling method is used, events prefixed with EVT_CC_ typically require user applications to call MTReturnEventBuffer()
passing in MT_EVENT.ptrBuffer to free the allocated memory. See the Functional Reference Library where MTReturnEventBuffer() is
explained for more information.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_CC_CALL_ALERTING 0-n/a See 0-n/a BoardID Global- See See Below*
format Below* Channel Below*
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
* XtraInfo:
This field contains four (4) bytes of data:
channel = Event.XtraInfo & 0x0000FFFF
The two (2) most significant bytes represent trunk #.
The two (2) least significant represent timeslot #
ptrBuffer:
ptrBuffer is a pointer to a null terminated string that contains the screen data.
DataLength:
DataLength is the length in bytes of the string pointed to by ptrBuffer.
• 604
605 •
SmartWORKS Developer’s Guide
Ai-Logix, Inc.
Type Name Purpose
Note: When the polling method is used, events prefixed with EVT_CC_ typically require user applications to call MTReturnEventBuffer()
passing in MT_EVENT.ptrBuffer to free the allocated memory. See the Functional Reference Library where MTReturnEventBuffer() is
explained for more information.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_CC_ALERT_IND 0-n/a See 0-n/a BoardID Global- See See Below*
format Below* Channel Below*
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*XtraInfo:
This field contains four (4) bytes of data:
channel = Event.XtraInfo & 0x0000FFFF
The two (2) most significant bytes represent trunk #.
The two (2) least significant represent channel #
ptrBuffer:
ptrBuffer is a pointer to a null terminated string that contains the screen data.
DataLength:
DataLength is the length in bytes of the string pointed to by ptrBuffer.
The MT_CC_ALERT_IND structure is populated with more data.
typedef struct
{
int ConnectionId ;
int CallRef ;
} MT_CC_ALERT_IND, * PMT_CC_ALERT_IND;
EVT_CC_CALL_ABANDONED
EVT_CALL_ABANDONED
Description: Indicates that an ISDN call was abandoned. Generated by the SmartWORKS DP and SmartWORKS NGX card (BRI ISDN only) This event is
reported as a channel event.
Note: When the polling method is used, events prefixed with EVT_CC_ typically require user applications to call MTReturnEventBuffer()
passing in MT_EVENT.ptrBuffer to free the allocated memory. See the Functional Reference Library where MTReturnEventBuffer() is
explained for more information.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_CC_CALL_ 0-n/a 0-n/a 0-n/a BoardID Global- See See Beolw*
format ABANDONED Channel Below*
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*ptrBuffer:
ptrBuffer is a pointer to a null terminated string that contains the screen data.
DataLength:
DataLength is the length in bytes of the string pointed to by ptrBuffer.
The MT_CALL_INFO structure is populated with more information. This structure is defined where the event EVT_CALL_ALERTING is explained.
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_CC_CALL_CONNECTED 0-n/a 0-n/a 0-n/a BoardID Global- See See Below*
format Channel Below*
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*ptrBuffer:
ptrBuffer is a pointer to a null terminated string that contains the screen data.
DataLength:
DataLength is the length in bytes of the string pointed to by ptrBuffer.
The MT_CALL_INFO structure is populated with more information. This structure is defined where the event EVT_CALL_ALERTING is explained.
EVT_CC_CALL_HELD
EVT_CALL_HELD
Indicates that an ISDN call has been held. Generated by the SmartWORKS DP and SmartWORKS NGX card (BRI ISDN only) This event is reported as a
channel event.
Note: When the polling method is used, events prefixed with EVT_CC_ typically require user applications to call MTReturnEventBuffer()
passing in MT_EVENT.ptrBuffer to free the allocated memory. See the Functional Reference Library where MTReturnEventBuffer() is
explained for more information.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_CC_CALL_HELD 0-n/a 0-n/a 0-n/a BoardID Global- See See Below*
format Channel Below*
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*prtBuffer:
ptrBuffer is a pointer to a null terminated string that contains the screen data.
DataLength:
DataLength is the length in bytes of the string pointed to by ptrBuffer.
The MT_CALL_INFO structure is populated with more information. This structure is defined where the event EVT_CALL_ALERTING is explained.
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_CC_CALL_REJECTED 0-n/a 0-n/a 0-n/a BoardID Global- See 0-n/a
format Channel Below*
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*ptrBuffer is a pointer to a null terminated string that contains the screen data.
The MT_CALL_INFO structure is populated with more information. This structure is defined where the event EVT_CALL_ALERTING is explained.
EVT_CC_CALL_RELEASED
EVT_CALL_RELEASED
Indicates that an ISDN call has been released. Generated by the SmartWORKS DP and SmartWORKS NGX card (BRI ISDN only) This event is reported as
a channel event.
Note: When the polling method is used, events prefixed with EVT_CC_ typically require user applications to call MTReturnEventBuffer()
passing in MT_EVENT.ptrBuffer to free the allocated memory. See the Functional Reference Library where MTReturnEventBuffer() is
explained for more information.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_CC_CALL_RELEASED 0-n/a 0-n/a 0-n/a BoardID Global- See See Below*
format Channel Below*
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*ptrBuffer:
ptrBuffer is a pointer to a null terminated string that contains the screen data.
DataLength:
DataLength is the length in bytes of the string pointed to by ptrBuffer.
The MT_CALL_INFO structure is populated with more information. This structure is defined where the event EVT_CALL_ALERTING is explained.
Note: When the polling method is used, events prefixed with EVT_CC_ typically require user applications to call MTReturnEventBuffer()
passing in MT_EVENT.ptrBuffer to free the allocated memory. See the Functional Reference Library where MTReturnEventBuffer() is
explained for more information.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_CC_CALL_RESUMED 0-n/a 0-n/a 0-n/a BoardID Global- See 0-n/a
format Channel Below*
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*ptrBuffer is a pointer to a null terminated string that contains the screen data.
The MT_CALL_INFO structure is populated with more information. This structure is defined where the event EVT_CALL_ALERTING is explained.
EVT_CC_CALL_RETRIEVED
EVT_CALL_RETRIEVED
Indicates that an ISDN call has been retrieved. Generated by the SmartWORKS DP and SmartWORKS NGX card (BRI ISDN only) This event is reported
as a channel event.
Note: When the polling method is used, events prefixed with EVT_CC_ typically require user applications to call MTReturnEventBuffer()
passing in MT_EVENT.ptrBuffer to free the allocated memory. See the Functional Reference Library where MTReturnEventBuffer() is
explained for more information.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_CC_CALL_RETRIEVED 0-n/a 0-n/a 0-n/a BoardID Global- See See Below*
format Channel Below*
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*ptrBuffer:
ptrBuffer is a pointer to a null terminated string that contains the screen data.
DataLength:
DataLength is the length in bytes of the string pointed to by ptrBuffer.
The MT_CALL_INFO structure is populated with more information. This structure is defined where the event EVT_CALL_ALERTING is explained.
Note: When the polling method is used, events prefixed with EVT_CC_ typically require user applications to call MTReturnEventBuffer()
passing in MT_EVENT.ptrBuffer to free the allocated memory. See the Functional Reference Library where MTReturnEventBuffer() is
explained for more information.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_CC_CALL_SUSPENDED 0-n/a 0-n/a 0-n/a BoardID Global- See See Below*
format Channel Below*
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*
ptrBuffer:
ptrBuffer is a pointer to a null terminated string that contains the screen data.
DataLength:
DataLength is the length in bytes of the string pointed to by ptrBuffer.
The MT_CALL_INFO structure is populated with more information. This structure is defined where the event EVT_CALL_ALERTING is explained.
EVT_CC_CONNECT_CONF
Indicates connect confirmation. Generated by the SmartWORKS DT card. All events are boards events except when using the RBS protocol in which
case it is reported as a channel event.
Note: When the polling method is used, events prefixed with EVT_CC_ typically require user applications to call MTReturnEventBuffer()
passing in MT_EVENT.ptrBuffer to free the allocated memory. See the Functional Reference Library where MTReturnEventBuffer() is
explained for more information.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_CC_CONNECT_CONF 0-n/a See 0-n/a BoardID Global- See See Below*
format Below* Channel Below*
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*XtraInfo:
This field contains four (4) bytes of data:
channel = Event.XtraInfo & 0x0000FFFF
The two (2) most significant bytes represent trunk #.
The two (2) least significant represent channel #
ptrBuffer:
ptrBuffer is a pointer to a null terminated string that contains the screen data.
DataLength:
DataLength is the length in bytes of the string pointed to by ptrBuffer.
• 616
int CallRef ;
617 •
int Flags ;
Note: When the polling method is used, events prefixed with EVT_CC_ typically require user applications to call MTReturnEventBuffer()
passing in MT_EVENT.ptrBuffer to free the allocated memory. See the Functional Reference Library where MTReturnEventBuffer() is
explained for more information.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_CC_CONNECT_IND 0-n/a See 0-n/a BoardID Global- See See Below*
format Below* Channel Below*
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
* XtraInfo:
This field contains four (4) bytes of data:
channel = Event.XtraInfo & 0x0000FFFF
The two (2) most significant bytes represent trunk #.
The two (2) least significant represent channel #
ptrBuffer:
ptrBuffer is a pointer to a null terminated string that contains the screen data.
DataLength:
DataLength is the length in bytes of the string pointed to by ptrBuffer.
• 618
int CallRef ;
619 •
int SendingComplete ; NOTE: Used with RBS only.
Note: When the polling method is used, events prefixed with EVT_CC_ typically require user applications to call MTReturnEventBuffer()
passing in MT_EVENT.ptrBuffer to free the allocated memory. See the Functional Reference Library where MTReturnEventBuffer() is
explained for more information.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_CC_DISC_CONF 0-n/a See 0-n/a BoardID Global- See See Below*
format Below* Channel Below*
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
* XtraInfo:
This field contains four (4) bytes of data:
channel = Event.XtraInfo & 0x0000FFFF
The two (2) most significant bytes represent trunk #.
The two (2) least significant represent channel #
ptrBuffer:
ptrBuffer is a pointer to a null terminated string that contains the screen data.
DataLength:
DataLength is the length in bytes of the string pointed to by ptrBuffer.
• 620
int ConnectionId ;
621 •
int CallRef ;
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_CC_DISC_IND 0-n/a See 0-n/a BoardID Global- See See Below*
format Below* Channel Below*
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
* XtraInfo:
This field contains four (4) bytes of data:
channel = Event.XtraInfo & 0x0000FFFF
The two (2) most significant bytes represent trunk #.
The two (2) least significant represent channel #
ptrBuffer:
ptrBuffer is a pointer to a null terminated string that contains the screen data.
DataLength:
DataLength is the length in bytes of the string pointed to by ptrBuffer.
• 622
int CallRef ;
623 •
int Cause ;
Note: When the polling method is used, events prefixed with EVT_CC_ typically require user applications to call MTReturnEventBuffer()
passing in MT_EVENT.ptrBuffer to free the allocated memory. See the Functional Reference Library where MTReturnEventBuffer() is
explained for more information.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_CC_FACILITY_CONF 0-n/a See 0-n/a BoardID Global- See See Below*
format Below* Channel Below*
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
* XtraInfo:
This field contains four (4) bytes of data:
channel = Event.XtraInfo & 0x0000FFFF
The two (2) most significant bytes represent trunk #.
The two (2) least significant represent channel #
ptrBuffer:
ptrBuffer is a pointer to a null terminated string that contains the screen data.
DataLength:
DataLength is the length in bytes of the string pointed to by ptrBuffer.
• 624
int ConnectionId ;
625 •
int CallRef ;
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_CC_FACILITY_IND 0-n/a See 0-n/a BoardID Global- See See Below*
format Below* Channel Below*
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
* XtraInfo:
This field contains four (4) bytes of data:
channel = Event.XtraInfo & 0x0000FFFF
The two (2) most significant bytes represent trunk #.
The two (2) least significant represent channel #
ptrBuffer:
ptrBuffer is a pointer to a null terminated string that contains the screen data.
DataLength:
DataLength is the length in bytes of the string pointed to by ptrBuffer.
• 626
int CallRef ;
627 •
int AccessId ;
} MT_CC_FACILITY_IND, * PMT_CC_FACILITY_IND;
EVT_CC_INFO_IND
Indicates ISDN called party digits. Generated by the SmartWORKS DT card. All events are boards events except when using the RBS protocol in which
case it is reported as a channel event.
Note: When the polling method is used, events prefixed with EVT_CC_ typically require user applications to call MTReturnEventBuffer()
passing in MT_EVENT.ptrBuffer to free the allocated memory. See the Functional Reference Library where MTReturnEventBuffer() is
explained for more information.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_CC_INFO_IND 0-n/a See 0-n/a BoardID Global- See See Below*
format Below* Channel Below*
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
* XtraInfo:
This field contains four (4) bytes of data:
channel = Event.XtraInfo & 0x0000FFFF
The two (2) most significant bytes represent trunk #.
The two (2) least significant represent channel #
ptrBuffer:
ptrBuffer is a pointer to a null terminated string that contains the screen data.
DataLength:
DataLength is the length in bytes of the string pointed to by ptrBuffer.
• 628
int CallRef ;
629 •
int Flags ;
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_CC_PROGRESS_IND 0-n/a See 0-n/a BoardID Global- See See Below*
format Below* Channel Below*
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
* XtraInfo:
This field contains four (4) bytes of data:
channel = Event.XtraInfo & 0x0000FFFF
The two (2) most significant bytes represent trunk #.
The two (2) least significant represent channel #
ptrBuffer:
ptrBuffer is a pointer to a null terminated string that contains the screen data.
DataLength:
DataLength is the length in bytes of the string pointed to by ptrBuffer.
The MT_CC_PROGRESS_IND structure is populated with this information:
• 630
int Flags ;
631 •
MT_CC_CHANNEL_ID ChannelId;
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_CC_RESUME_CONF 0-n/a See 0-n/a BoardID Global- See See Below*
format Below* Channel Below*
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
* XtraInfo:
This field contains four (4) bytes of data:
channel = Event.XtraInfo & 0x0000FFFF
The two (2) most significant bytes represent trunk #.
The two (2) least significant represent channel #
ptrBuffer:
ptrBuffer is a pointer to a null terminated string that contains the screen data.
DataLength:
DataLength is the length in bytes of the string pointed to by ptrBuffer.
• 632
int ConnectionId ;
633 •
int CallRef ;
} MT_CC_RESUME_CONF, * PMT_CC_RESUME_CONF;
EVT_CC_SUSPEND_CONF
A ISDN call was suspended. Generated by the SmartWORKS DT card. All events are boards events except when using the RBS protocol in which case it
is reported as a channel event.
Note: When the polling method is used, events prefixed with EVT_CC_ typically require user applications to call MTReturnEventBuffer()
passing in MT_EVENT.ptrBuffer to free the allocated memory. See the Functional Reference Library where MTReturnEventBuffer() is
explained for more information.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_CC_SUSPEND_CONF 0-n/a 0-n/a 0-n/a BoardID Global- See See Below*
format Channel Below*
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
* ptrBuffer:
ptrBuffer is a pointer to a null terminated string that contains the screen data.
DataLength:
DataLength is the length in bytes of the string pointed to by ptrBuffer.
• 634
} MT_CC_SUSPEND_CONF, * PMT_CC_SUSPEND_CONF;
635 •
EVT_CC_USERINFO_IND
EVT_CC_USER_INFO
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_CC_USER_INFO 0-n/a See 0-n/a BoardID Global- See See Below*
format Below* Channel Below*
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
* XtraInfo:
This field contains four (4) bytes of data:
channel = Event.XtraInfo & 0x0000FFFF
The two (2) most significant bytes represent trunk #.
The two (2) least significant represent channel #
ptrBuffer:
ptrBuffer is a pointer to a null terminated string that contains the screen data.
DataLength:
DataLength is the length in bytes of the string pointed to by ptrBuffer.
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_CC_USERINFO_REQ 0-n/a See 0-n/a BoardID Global- See See Below*
format Below* Channel Below*
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
* XtraInfo:
This field contains four (4) bytes of data:
channel = Event.XtraInfo & 0x0000FFFF
The two (2) most significant bytes represent trunk #.
The two (2) least significant represent channel #
ptrBuffer:
ptrBuffer is a pointer to a null terminated string that contains the screen data.
DataLength:
DataLength is the length in bytes of the string pointed to by ptrBuffer.
} MT_CC_USERINFO_REQ, * PMT_CC_USERINFO_REQ;
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_CFWD 0-n/a 0-n/a 0-n/a BoardID Global- See See Below*
format Channel Below*
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
ptrBuffer - pointer to the buffer containing a call string of the phone number the call was forwarded to.
DataLength - the length of the data contained in the buffer
EVT_CFWD_CANCELED
Indicates call forward cancellation
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_CFWD_CANCELED 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_CLEAR_BUTTON_PRESSED
Indicates that the clear button was pressed.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_CLEAR_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format BUTTON_PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_CONF_BUTTON_PRESSED
Indicates that the Conference button was pressed
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_CONF_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_CONF_BUTTON_RELEASED
Indicates that the Conference button was released
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_CONF_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format RELEASED Channel
ID (GCI)
• 640
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
641 •
EVT_CONFERENCE_LIGHT_FASTFLASHING
EVT_CONFERENCE_LIGHT_FLASHING
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_CONFERENCE_LIGHT_ *See Below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_CONNECTED 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_CPM_STOP See Below* See FuncCode BoardID Global- 0-n/a 0-n/a
format Below* Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*
Subreason and Xtra Info
This information is also populated in the CpmTerm field of the CALL_RESULT structure. The current background function is terminated and the channel either enters
into an idle state or executes the next background function if one is queued. The following table lists all valid termination reasons plus the information presented in
the XtraInfo field.:
Xtra
Subreason (EVT_CPM_STOP)
Info
CPM_MON_LOOP_DROP
CPM_MON_SILENCE
CPM_MON_ACTIVITY
CPM_MON_DIAL The Index of the signal
CPM_MON_BUSY* The Index of the signal
(normal or trunk busy)
(using MTCallString())
CPM_CONNECT CPM_CONNECT_MACHINE
CPM_CONNECT_HUMAN
----------------------------------- -----------------------------------
(using other background tasks)
CPM_MON_HUMAN
CPM_MON_MACHINE
CPM_NO_ANSWER
CPM_MON_INTERCEPT* the Index of the SIT signal
CPM_MON_MAX_SILENCE
CPM_MAX_SILENCE
CPM_MON_MAX_ACTIVITY
CPM_MAX_ACTIVITY
CPM_MON_LVOLTAGE_DROP
(same as TERM_LVOLTAGE_
ABOVE_OR_BELOW
CPM_MON_UTONE Signal Index ID
CPM_MON_CALLWAITING
CPM_MON_RECEIVOFF
CPM_MON_DIAL1
CPM_MON_DIAL2
CPM_MON_DIAL3
CPM_MON_BUSY1
CPM_MON_BUSY2
CPM_MON_FAX1
CPM_MON_FAX2
CPM_MON_SIT1
CPM_MON_SIT2
CPM_MON_SIT3
CPM_MON_SIT4
CPM_MON_SIT5
*This option has been maintained for backwards compatibility.
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_DESTINATION_BUSY 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_DESTINATION_BUTTON_PRESSED
Indicates that the destination button was pressed.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_DESTINATION_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format BUTTON_PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_DEVICE_READ_ERROR
Indicates a user device read error
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_DEVICE_READ_ERROR 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_DEVICE_SEEK_ERROR
Indicates a user device seek error
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_DEVICE_SEEK_ERROR 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_DEVICE_WRITE_ERROR
Indicates a user device writer error
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_DEVICE_WRITE_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format ERROR Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_DIALED
Indicates that dialing is complete
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
• 646
647 •
EVT_DIGIT
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_DIGIT See Below* 0= 0-n/a BoardID Global- 0-n/a 0-n/a
format outgoing Channel
1= ID (GCI)
incoming
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_DIGIT_DROPPED
Indicates that a received DTMF digit was dropped due to a full queue. A maximum of 256 digits is allowed in the queue.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_DIGIT_DROPPED *See Below 0= 0-n/a BoardID Global- 0-n/a 0-n/a
format outgoing Channel
1= ID (GCI)
incoming
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_DIGIT_PRESSED See Below* 0-n/a Reserved BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_DIGIT_RELEASED
Indicates that a digit button was released
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_DIGIT_RELEASED See Below* 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_DIGITENABLE Termination 0-n/a FuncCode BoardID Global- See See Below*
format Digit Channel Below*
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
ptrBuffer - pointer to either a file or buffer (depending on which API was called, playing a file or from a buffer)
DataLength - length (bytes) of exercised data at termination
EVT_DIRECTORY_BUTTON_PRESSED
Description: Indicates that the directory button has been pressed
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_DIRECTORY_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_DIRECTORY_LIGHT_FASTFLASHING
EVT_DIRECTORY_LIGHT_VERY_FASTFLASHING
EVT_DIRECTORY_LIGHT_FLASHING
EVT_DIRECTORY_LIGHT_OFF
EVT_DIRECTORY_LIGHT_ON
EVT_DIRECTORY_LIGHT_QUICKFLASH
Purpose:
Indicates that the directory light on the phone is on, off, or flashing.
Description:
Observation of various phone models enabled the Ai-Logix lab to categorize phone lights as flashing, fast flashing, very fast flashing or quick flashing.
The cadence varies depending on PBX models, and this may also be configured. Our definition of flashing lights stems from the signal passed from
the PBX to the phone, and is based on factory default configurations for each model. Please refer to your PBX documentation for more information.
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_DIRECTORY_LIGHT_ *See Below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
• 650
651 •
EVT_DISCONNECTED
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_DISCONNECTED 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_DISK_FULL
Indicates that the disk is full
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_DISK_FULL 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_DISK_WRITE_ERROR
Indicates that a file write error occurred
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_DISK_WRITE_ERROR 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_DISPLAY_CLEAR
Indicates that the phone display has been cleared
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_DISPLAY_CLEAR 0-n/a 0-n/a* 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*Several of the Bosch Integral phones support a multi-windowed display. The X-tra info field specifies which window the display event has occurred in.
EVT_DISPLAY_CLOCK
Indicates that the PBX has told the phone to display the clock (usually date and time)
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_DISPLAY_CLOCK 0-n/a 0-n/a 0-n/a BoardID Global- *See 0-n/a
format Channel below
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*Pointer to a tm structure indicating the pbx time and date. User applications must call MTReturnEventBuffer() if ptrBuffer is valid. This clears the buffer. ptrBuffer
may not be available on all pbxs.
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_DISPLAY_MESSAGE MSG_ID 0-n/a* 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*Several of the Bosch Integral phones support a multi-windowed display. The X-tra info field specifies which window the display event has occurred in.
EVT_DISPLAY_TIMER
Indicates that the PBX has told the phone to display the timer (displaying the call duration).
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_DISPLAY_TIMER 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_DIVERT_BUTTON_PRESSED
Indicates that the divert button was pressed.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_DIVERT_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format BUTTON_PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_DIVERT_LIGHT_ *See Below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_DND_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format BUTTON_PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_DND_LIGHT_ *See Below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_DSPRESET
Indicates that the DSPs just reset
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_DSPRESET 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_ENTER_BUTTON_PRESSED
Indicates that the enter button has been pressed
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_ENTER_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_EOF 0-n/a 0-n/a FuncCode BoardID Global- file length of
format Channel handle exercised
ID (GCI) data
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_ERROR
Indicates a hardware failure
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_ERROR 0-n/a Internal 0-n/a BoardID Global- 0-n/a 0-n/a
format Error Channel
Code ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_EXIT_BUTTON_PRESSED
Indicates that the Exit button has been pressed
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_EXIT_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_EXIT_BUTTON_RELEASED
Indicates that the Exit button has been released
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_EXIT_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format RELEASED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_FAXRECVEOP
EVT_FAXSEND_DONE
EVT_FAXRECV_DONE
EVT_FAX_ERROR
EVT_FAX_PHASEB_COMP
EVT_FAX_PHASED_COMP
Although these are documented in the header file, these events are not supported by the API.
EVT_FEATURE_BUTTON_PRESSSED
Indicates that a feature button has been pressed
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_FEATURE_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
• 660
661 •
EVT_FEATURE_LIGHT_FASTFLASHING
EVT_FEATURE_LIGHT_FLASHING
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_FEATURE_LIGHT_ *See Below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_FINISHED_PLAY
Not supported. Although this event exists in the header file, it is not currently supported by the SmartWORKS API.
EVT_FEATURE_HEADER_ERROR
Indicates a frame header error, terminating the function
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_FEATURE_HEADER_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format ERROR Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_FEATURE_BUTTON_PRESSSED
Indicates thats a feature button has been pressed
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_FEATURE_BUTTON_ *see below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
• 662
663 •
EVT_FEATURE_BUTTON_RELEASED
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_FEATURE_BUTTON_ *see below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_FLASH_BUTTON_PRESSED
Description: Indicates that the flash button has been pressed
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_FLASH_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_FLASH_BUTTON_RELEASED
Description: Indicates that the flash button has been released
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_FLASH_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format RELEASED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_FLASH_LIGHT_ *See Below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_FEATURE_BUTTON_ 0-n/a 0-n/a FuncCode BoardID Global- file length of
format PRESSED Channel handle exercised
ID (GCI) data
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_FUNCTION_BUTTON_RELEASED
Indicates thats a function button has been released
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_FUNCTION_BUTTON_ *see below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_FUNCTION_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_FUNCTION_LIGHT_FASTFLASHING
EVT_FUNCTION_LIGHT_FLASHING
EVT_FUNCTION_LIGHT_OFF
EVT_FUNCTION_LIGHT_ON
EVT_FUNCTION_LIGHT_QUICKFLASH
EVT_FUNCTION_LIGHT_VERY_FASTFLASHING
EVT_FUNCTION_LIGHT_WINK
EVT_FUNCTION_LIGHT_SLOW_WINK
EVT_FUNCTION_LIGHT_MEDIUM_WINK
Purpose:
Indicates that the function light on the phone is on, off or flashing.
Description:
Observation of various phone models enabled the Ai-Logix lab to categorize phone lights as flashing, fast flashing, very fast flashing or quick flashing.
The cadence varies depending on PBX models, and this may also be configured. Our definition of flashing lights stems from the signal passed from
the PBX to the phone, and is based on factory default configurations for each model. Please refer to your PBX documentation for more information.
The “WINK” events were added with SmartWORKS release 2.10.0, and are supported on the Siemens / Rolm IBM 9751. There is a difference in on/off
patterns when comparing winks to flashes. The subreason fields will be the same as all other light events.
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_FUNCTION_LIGHT_ *See Below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
• 668
---------------------------------------------
Alcatel phones do not have lights, instead pictures are presented on the phone display. The following bits are set:
669 •
Bits 0-7 = “Light” Number
Bits 8 = square, located on the right side of the display area
EVT_GROUP_BUTTON_PRESSED
Indicates that the group button was pressed.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_GROUP_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format BUTTON_PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_GROUP_LIGHT_FASTFLASHING
EVT_GROUP_LIGHT_VERY_FASTFLASHING
EVT_GROUP_LIGHT_FLASHING
EVT_GROUP_LIGHT_OFF
EVT_GROUP_LIGHT_ON
EVT_GROUP_LIGHT_QUICKFLASH
Purpose:
Indicates that the group light on the phone is on, off, or flashing.
Description:
Observation of various phone models enabled the Ai-Logix lab to categorize phone lights as flashing, fast flashing, very fast flashing or quick flashing.
The cadence varies depending on PBX models, and this may also be configured. Our definition of flashing lights stems from the signal passed from
the PBX to the phone, and is based on factory default configurations for each model. Please refer to your PBX documentation for more information.
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_GROUP_LIGHT_ *See Below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
• 670
671 •
EVT_H100_MASTER_A_ALARM
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_H100_MASTER_A_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format ALARM Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_H100_MASTER_B_ALARM
Indicates H100 Master B clock error detection. This event will be generated when it has been armed by an Arm H.100 Clock B Error Event command, and CT812
reports an error condition on line CT_C8_B on the H.100 bus.
This event is only applicable when the switching handler is in H.100 mode.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_H100_MASTER_B_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format ALARM Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_HANDSFREE_BUTTON_PRESSED
Description: Indicates that the handsfree button has been pressed
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_HANDSFREE_BUTTON 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format _PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_HANDSFREE_LIGHT_ *See Below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_HELP_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_HELP_LIGHT_ *See Below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_HOLD_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_HOLD_BUTTON_RELEASED
Indicates that the hold button has been released
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_HOLD_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format RELEASED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_HOLD_LIGHT_ *See Below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_IDLE 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_INCOMING_SIGCHANGE
Indicates a Change of Signaling Bits (ABCD) on incoming line
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_INCOMING_ See Below* See 0-n/a BoardID Global- 0-n/a See Below*
format SIGCHANGE Below* Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*·SubReason:
an octect the new values of the signaling bits A, B, C, and D, in bits 3, 2, 1, and 0, respectively. Bits 8, 7, 6, 5 contain the previous values of the signaling bits.
XtraInfo:
the number of the framer reporting the event (most significant bit)
the timeslot on which the change was detected(least significant bit)
• 678
679 •
EVT_INDEX_PLAYED
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_INDEX_PLAYED 0-n/a 0-n/a FuncCode BoardID Global- file length of
format Channel handle exercised
ID (GCI) data
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_INTERCOM_BUTTON_PRESSED
Indicates that the intercom button has been pressed
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_INTERCOM_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_INTERCOM_LIGHT_ *See below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_INTERDIGIT
Indicates termination of a background media function because the maximum Interdigit delay has been exceeded
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_INTERDIGIT 0-n/a 0-n/a FuncCode BoardID Global- See See Below*
format Channel Below*
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
ptrBuffer - pointer to either a file or buffer (depending on which API was called, playing a file or from a buffer)
DataLength - length (bytes) of exercised data at termination
682 •
EVT_LIGHT_FASTFLASHING
EVT_LIGHT_FLASHING
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_LIGHT_ *See below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_LINE_BUTTON_PRESSED
Indicates that the line button has been pressed
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_LINE_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_LINE_LIGHT_FASTFLASHING
EVT_LINE_LIGHT_FLASHING
EVT_LINE_LIGHT_ON
EVT_LINE_LIGHT_OFF
EVT_LINE_LIGHT_QUICKFLASH
EVT_LINE_LIGHT_VERY_FASTFLASHING
Purpose:
Indicates that the line light on the phone is on, off or flashing.
Description:
Observation of various phone models enabled the Ai-Logix lab to categorize phone lights as flashing, fast flashing, very fast flashing or quick flashing.
The cadence varies depending on PBX models, and this may also be configured. Our definition of flashing lights stems from the signal passed from
the PBX to the phone, and is based on factory default configurations for each model. Please refer to your PBX documentation for more information.
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_LINE_LIGHT_ *see below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
These may vary depending on phone model and PBX. The subreason field is only populated when the light is flashing.
*Bits 8 = Green
Bit 9 = Red
Bit 10 = Amber
Bits 11-31 = Reserved
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_LOCRCMF_ALARM 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_LOF_ALARM
Indicates a Loss of Framer alarm on T1 or E1 networks. For these events to generate, framer alarms must be enabled using the MTArmFramerAlarm() API.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_LOF_ALARM An octet 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format containing Channel
the number ID (GCI)
of the
framer
reporting
the event
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_LOOP_DROP
Indicates a Loop current dropped, meaning a phone went back on hook
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_LOOP_DROP See Below* 0-n/a 0-n/a BoardID Global- 0-n/a See Below*
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
SubReason:
Current & Previous state
DataLen:
Duration of previous state in ms.
EVT_LOOP_ON
Indicates a Loop current on event, meaning a phone is off hook
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_LOOP_ON See Below* 0-n/a 0-n/a BoardID Global- 0-n/a See Below*
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
• 685
686 •
EVT_LOOP_REVERSE
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_LOOP_REVERSE See Below* 0-n/a 0-n/a BoardID Global- 0-n/a See Below*
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
SubReason:
Current & Previous state
DataLen:
Duration of previous state in ms
EVT_LOOP_STOP
Indicates termination of background media function due to a drop in loop current (phone went back on hook)
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_LOOP_STOP 0-n/a 0-n/a FuncCode BoardID Global- Reserved Reserved
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_LOOPON_RECORD
Indicates recording started on detection of loop current
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_LOOPON_RECORD 0-n/a 0-n/a FuncCode BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_LOSYNC_ALARM
Indicates a Loss of synchronization alarm on the SmartWORKS PCM framer. This event is only generated if framer alarms are enabled using the
MTArmFramerAlarm() API.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_LOSYNC_ALARM An octet 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format containing Channel
the number ID (GCI)
of the
framer
reporting
the event
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_LOS_ALARM An octet 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format containing Channel
the number ID (GCI)
of the
framer
reporting
the event
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_LOSMF_ALARM
Indicates loss of signaling multiframe alignment alarm (E1 only). This event is only generated if framer alarms are enabled using the MTArmFramerAlarm() API.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_LOSMF_ALARM An octet 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format containing Channel
the number ID (GCI)
of the
framer
reporting
the event
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_LVOLTAGE_ABOVE
Indicates a loop voltage has been detected that falls above the set threshold (ThresholdHigh parameters in the MTSetLVParams() API). This event is only generated
by the SmartWORKS LD board.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_LVOLTAGE_ See Below* 0-n/a 0-n/a BoardID Global- 0-n/a See Below*
format ABOVE Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
DataLen:
Duration of previous state in 10 ms increments
• 689
690 •
EVT_LVOLTAGE_BELOW
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_LVOLTAGE_ See Below* 0-n/a 0-n/a BoardID Global- 0-n/a See Below*
format BELOW Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*SubReason:
Current & Previous voltage state
DataLen:
Duration of previous state in 10 ms increments
EVT_LVOLTAGE_MIDDLE
Indicates a loop voltage detected that falls between the set thresholds (LowThreshold and HighThreshold parameters used by the MTSetLVParams() API).This event
is only generated by the SmartWORKS LD board. This indicates that the phone is on hook.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_LVOLTAGE_ See Below* 0-n/a 0-n/a BoardID Global- 0-n/a See Below*
format MIDDLE Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*SubReason:
Current & Previous voltage state
DataLen:
Duration of previous state in 10 ms increments
EVT_LVOLTAGE_NOTOFFHOOK
EVT_LVOLTAGE_ABOVEORBELOW
Indicates a loop voltage state that is not off hook (it is either above or below the threshold high or threshold low range).
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_LVOLTAGE_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format NOTOFFHOOK Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*SubReason:
Current & Previous voltage state
DataLen:
Duration of previous state in 10 ms increments
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_LVOLTAGE_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format OFFHOOK Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_LVOLTAGE_RECORD
Indicates recording started on detection of offhook loop voltage. On the SmartWORKS PT and SmartWORKS AT boards this occurs when the EVT_OFFHOOK is
generated. On the SmartWORKS LD board this occurs when the event EVT_LVOLTAGE_ABOVE is generated.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_LVOLTAGE_ 0-n/a 0-n/a FuncCode BoardID Global- 0-n/a 0-n/a
format RECORD Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_MASTER_PLL_ALARM
Indicates master PLL error detected. This event will be generated when it has been armed by an Arm Master PLL Error Event command, and CT812 reports a Master
PLL error condition.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MASTER_PLL_ALARM 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_MAX_ACTIVITY
Issued by a channel device when activity detection is enabled and the activity timer has reached its specified maximum value. Upon issuing this event, the activity
timer is reset to zero (0).
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MAX_ACTIVITY See Below* 0= FuncCode BoardID Global- 0-n/a 0-n/a
format outgoing Channel
1= ID (GCI)
incoming
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*Timing Information - displays the amount of time (in ms) the line remained in the of the previous state. Information is presented in 1ms units, with a maximum of
65535ms.
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MAX_SILENCE See Below* 0= FuncCode BoardID Global- 0-n/a 0-n/a
format outgoing Channel
1= ID (GCI)
incoming
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*Timing Information - displays the amount of time (in ms) the line remained in the of the previous state. Information is presented in 1ms units, with a maximum of
65535ms.
EVT_MAXBYTES
Indicates maximum bytes reached on play or record
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MAXBYTES 0-n/a 0-n/a FuncCode BoardID Global- pointer to length of
format Channel file han- exercised
ID (GCI) del data
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_MAXDIGITS
Indicates termination of background function when a maximum DTMF digits has been received
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MAXDIGITS # of digits 0-n/a FuncCode BoardID Global- See # of digits or
format Channel Below* length of
ID (GCI) exercised
data
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
ptrBuffer - pointer to either a file or buffer (depending on which API was called, playing a file or from a buffer)
EVT_MAXTIME
Indicates termination of background function when the maximum time (ms) has been reached.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MAXTIME See Below* 0-n/a FuncCode BoardID Global- pointer to length of
format Channel file han- exercised
ID (GCI) dle data
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_MENU_BUTTON_PRESSED
Indicates that a menu button has been pressed
Structure:
In FileTIME 0-n/a EVT_MENU_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
• 695
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
696 •
EVT_MENU_BUTTON_RELEASED
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MENU_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format RELEASED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_MESSAGE_BUTTON_PRESSED
Indicates that a message button has been pressed
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MESSAGE_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_MESSAGE_BUTTON_RELEASED
Indicates that a message button has been released.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MESSAGE_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format RELEASED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_MESSAGE_CHANGE
Indicates a message change on the LCD of the phone. This relates to data such as agent ID and phone number. This string is null terminated.
Other phrases displayed on the phone LCD generate EVT_DISPLAY_MESSAGE.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MESSAGE_CHANGE 0-n/a 0-n/a 0-n/a BoardID Global- *see *see below
format Channel below
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
* ptrBuffer is a pointer to a null terminated string that contains the screen data.
DataLength is the length in bytes of the string (including the null termination) pointed to by ptrBuffer.
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MESSAGE_LIGHT_ *See Below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MFTONE See Below* 0= 0-n/a BoardID Global- 0-n/a 0-n/a
format outgoing Channel
1= ID (GCI)
incoming
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*an octet containing an unsigned number indicating the MF tone received. This value will be 0x01 through 0x0F for forward tones 1 through 15, and
0x11 through 0x1F for backward tones 1 through 15, respectively. Thus, bits 0 through 3 contain the tone number, and bit 4 is reset for forward
tones, and set for backward tones.
EVT_MFTONE_DROPPED
Indicates that received MF(R2) tone has been dropped due to a full queue
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MFTONE_DROPPED See Below* 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
• 699
700 •
EVT_MIC_BUTTON_PRESSED
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MIC_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_MIC_BUTTON_RELEASED
Indicates that a microphone button has been released
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MIC_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format RELEASED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_MIC_LIGHT_FASTFLASHING
EVT_MIC_LIGHT_FLASHING
EVT_MIC_LIGHT_ON
EVT_MIC_LIGHT_OFF
EVT_MIC_LIGHT_QUICKFLASH
EVT_MIC_LIGHT_VERY_FASTFLASHING
Purpose:
Indicates that a microphone light on the phone is on, off, or flashing.
Description:
Observation of various phone models enabled the Ai-Logix lab to categorize phone lights as flashing, fast flashing, very fast flashing or quick flashing.
The cadence varies depending on PBX models, and this may also be configured. Our definition of flashing lights stems from the signal passed from
the PBX to the phone, and is based on factory default configurations for each model. Please refer to your PBX documentation for more information.
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MIC_LIGHT_ *See Below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
• 701
702 •
EVT_MODE_BUTTON_PRESSED
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MODE_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_MON_ACTIVITY
Indicates silence off and activity on
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MON_ACTIVITY See Below* 0= 0-n/a BoardID Global- 0-n/a 0-n/a
format outgoing Channel
1= ID (GCI)
incoming
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*Timing Information - displays the amount of time (in ms) the line remained in the of the previous state. Information is presented in 1ms units, with a maximum of
65535ms.
EVT_MON_BUSY
Indicates CPM detection of busy cadence cycle. The signal Index ID is passed in the XtraInfo field.
NOTE: This event was obsoleted with v3.3. It has been mapped to EVT_MON_BUSY1 for backwards compatibility.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MON_BUSY1 See Below* See 0-n/a BoardID Global- 0-n/a 0-n/a
format Below* Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*
Subreason -
The value of 0x0000 indicates a signal has been detected.
The value of 0xFFFFFFFF indicates loss of signal (MT_CPM_SIGNAL.fDetectLost must be enabled in the Signal Profile).
XtraInfo - the index number of the signal in the CPM signal table
More information is available in the application notes, “Ai-Logix’s Call Progress Monitoring” and “Managing CPM Events” located on the Ai-Logix website:
http://www.ai-logix.com/support.html
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MON_BUSY1 See Below* See 0-n/a BoardID Global- 0-n/a 0-n/a
format Below* Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*
Subreason -
The value of 0x0000 indicates a signal has been detected.
The value of 0xFFFFFFFF indicates loss of signal (MT_CPM_SIGNAL.fDetectLost must be enabled in the Signal Profile).
XtraInfo - the index number of the signal in the CPM signal table
More information is available in the application notes, “Ai-Logix’s Call Progress Monitoring” and “Managing CPM Events” located on the Ai-Logix website:
http://www.ai-logix.com/support.html
EVT_MON_BUSY2
Indicates CPM detection of BUSY2 signal. The signal Index ID is passed in the XtraInfo field. By default, this signal profile contains values for the North American tunk
(fast) busy.
NOTE: EVT_MON_TBUSY was obsoleted with v3.3. It has been mapped to EVT_MON_BUSY2 for backwards compatibility.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MON_BUSY2 See Below* See 0-n/a BoardID Global- 0-n/a 0-n/a
format Below* Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*
Subreason -
The value of 0x0000 indicates a signal has been detected.
The value of 0xFFFFFFFF indicates loss of signal (MT_CPM_SIGNAL.fDetectLost must be enabled in the Signal Profile).
XtraInfo - the index number of the signal in the CPM signal table
More information is available in the application notes, “Ai-Logix’s Call Progress Monitoring” and “Managing CPM Events” located on the Ai-Logix website:
http://www.ai-logix.com/support.html
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MON_ See Below* See 0-n/a BoardID Global- 0-n/a 0-n/a
format CALLWAITING Below* Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*Subreason -
The value of 0x0000 indicates a signal has been detected.
The value of 0xFFFFFFFF indicates loss of signal (MT_CPM_SIGNAL.fDetectLost must be enabled in the Signal Profile).
XtraInfo - the index number of the signal in the CPM signal table
More information is available in the application notes, “Ai-Logix’s Call Progress Monitoring” and “Managing CPM Events” located on the Ai-Logix website:
http://www.ai-logix.com/support.html
EVT_MON_CPM_CYCLE
Used to display the total cycle count of a detected CPM signal. One EVT_MON_CPM_CYCLE is generated for each complete cycle of a signal. The fDetectCycle field
must be enabled in the signal profile. This option should only be enabled for signals with a repeating cadence pattern.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MON_BUSY See Below* n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MON_DIAL See Below* See FuncCode BoardID Global- pointer to length of
format Below* Channel file han- exercised
ID (GCI) dle data
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*Subreason -
The value of 0x0000 indicates a signal has been detected.
The value of 0xFFFFFFFF indicates loss of signal (MT_CPM_SIGNAL.fDetectLost must be enabled).
XtraInfo - the index number of the signal in the CPM signal table
More information is available in the application notes, “Ai-Logix’s Call Progress Monitoring” and “Managing CPM Events” located on the Ai-Logix website:
http://www.ai-logix.com/support.html
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MON_DIAL1 See Below* See FuncCode BoardID Global- pointer to length of
format Below* Channel file han- exercised
ID (GCI) dle data
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*Subreason -
The value of 0x0000 indicates a signal has been detected.
The value of 0xFFFFFFFF indicates loss of signal (MT_CPM_SIGNAL.fDetectLost must be enabled).
XtraInfo - the index number of the signal in the CPM signal table
More information is available in the application notes, “Ai-Logix’s Call Progress Monitoring” and “Managing CPM Events” located on the Ai-Logix website:
http://www.ai-logix.com/support.html
EVT_MON_DIAL2
Indicates CPM detection of a DIAL2 signal on the line. The signal Index ID is passed in the XtraInfo field.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MON_DIAL2 See Below* See FuncCode BoardID Global- pointer to length of
format Below* Channel file han- exercised
ID (GCI) dle data
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*Subreason -
The value of 0x0000 indicates a signal has been detected.
The value of 0xFFFFFFFF indicates loss of signal (MT_CPM_SIGNAL.fDetectLost must be enabled).
XtraInfo - the index number of the signal in the CPM signal table
More information is available in the application notes, “Ai-Logix’s Call Progress Monitoring” and “Managing CPM Events” located on the Ai-Logix website:
http://www.ai-logix.com/support.html
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MON_DIAL3 See Below* See FuncCode BoardID Global- pointer to length of
format Below* Channel file han- exercised
ID (GCI) dle data
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*Subreason -
The value of 0x0000 indicates a signal has been detected.
The value of 0xFFFFFFFF indicates loss of signal (MT_CPM_SIGNAL.fDetectLost must be enabled).
XtraInfo - the index number of the signal in the CPM signal table
More information is available in the application notes, “Ai-Logix’s Call Progress Monitoring” and “Managing CPM Events” located on the Ai-Logix website:
http://www.ai-logix.com/support.html
EVT_MON_DRINGBACK
Indicates CPM detection of a RINGBACK2 signal. The signal Index ID is passed in the XtraInfo field.
NOTE: This event has been obsoleted as of v3.3 release. It has been mapped to EVT_MON_RINGBACK2 for backwards compatibility.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MON_RINGBACK2 See Below* See FuncCode BoardID Global- pointer to length of
format Below* Channel file han- exercised
ID (GCI) dle data
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*
Subreason -
The value of 0x0000 indicates a signal has been detected.
The value of 0xFFFFFFFF indicates loss of signal (MT_CPM_SIGNAL.fDetectLost must be enabled).
XtraInfo - the index number of the signal in the CPM signal table
More information is available in the application notes, “Ai-Logix’s Call Progress Monitoring” and “Managing CPM Events” located on the Ai-Logix website:
http://www.ai-logix.com/support.html
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MON_FAX1 0-n/a See FuncCode BoardID Global- pointer to length of
format Below* Channel file han- exercised
ID (GCI) dle data
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*
Subreason -
The value of 0x0000 indicates a signal has been detected.
The value of 0xFFFFFFFF indicates loss of signal (MT_CPM_SIGNAL.fDetectLost must be enabled).
XtraInfo - the index number of the signal in the CPM signal table
More information is available in the application notes, “Ai-Logix’s Call Progress Monitoring” and “Managing CPM Events” located on the Ai-Logix website:
http://www.ai-logix.com/support.html
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MON_FAX1 0-n/a See FuncCode BoardID Global- pointer to length of
format Below* Channel file han- exercised
ID (GCI) dle data
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*
Subreason -
The value of 0x0000 indicates a signal has been detected.
The value of 0xFFFFFFFF indicates loss of signal (MT_CPM_SIGNAL.fDetectLost must be enabled).
XtraInfo - the index number of the signal in the CPM signal table
More information is available in the application notes, “Ai-Logix’s Call Progress Monitoring” and “Managing CPM Events” located on the Ai-Logix website:
http://www.ai-logix.com/support.html
EVT_MON_FAX2
Indicates CPM detection of a FAX2 signal. The signal Index ID is passed in the XtraInfo field.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MON_FAX2 0-n/a See FuncCode BoardID Global- pointer to length of
format Below* Channel file han- exercised
ID (GCI) dle data
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*
Subreason -
The value of 0x0000 indicates a signal has been detected.
The value of 0xFFFFFFFF indicates loss of signal (MT_CPM_SIGNAL.fDetectLost must be enabled).
XtraInfo - the index number of the signal in the CPM signal table
More information is available in the application notes, “Ai-Logix’s Call Progress Monitoring” and “Managing CPM Events” located on the Ai-Logix website:
http://www.ai-logix.com/support.html
EVT_MON_HUMAN
Indicates that the CPM detection of voice activity, after complete analysis is a live person (human).
More information about voice detection is available in the application notes, “Ai-Logix’s Call Progress Monitoring” and “Managing CPM Events” located on the Ai-Logix
website:
http://www.ai-logix.com/support.html
Structure:
In FileTIME 0-n/a EVT_MON_HUMAN 0-n/a 0-n/a N/A BoardID Global- pointer to length of
format Channel file han- exercised
ID (GCI) dle data
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
• 714
715 •
SmartWORKS Developer’s Guide
Ai-Logix, Inc.
EVT_MON_MACHINE
Indicates that the CPM detection of voice activity, after complete analysis is an answering machine.
More information about voice detection is available in the application notes, “Ai-Logix’s Call Progress Monitoring” and “Managing CPM Events” located on the Ai-Logix
website:
http://www.ai-logix.com/support.html
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DaaLength
In FileTIME 0-n/a EVT_MON_MACHINE 0-n/a 0-n/a N/A BoardID Global- pointer to length of
format Channel file han- exercised
ID (GCI) dle data
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_MON_NOVOICE
This event is only generated after the CPM feature detects voice on the line. If silence is detected (no voice activity) then this event is generated.
More information about voice detection is available in the application notes, “Ai-Logix’s Call Progress Monitoring” and “Managing CPM Events” located on the Ai-Logix
website:
http://www.ai-logix.com/support.html
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DaaLength
In FileTIME 0-n/a EVT_MON_NOVOICE 0-n/a 0-n/a N/A BoardID Global- pointer to length of
format Channel file han- exercised
ID (GCI) dle data
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_MON_RECEIVEOFF
Indicates CPM detection of a RECEIVEOFF signal. The signal Index ID is passed in the XtraInfo field.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MON_RECEIVEOFF 0-n/a See FuncCode BoardID Global- pointer to length of
format Below* Channel file han- exercised
ID (GCI) dle data
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*
Subreason -
The value of 0x0000 indicates a signal has been detected.
The value of 0xFFFFFFFF indicates loss of signal (MT_CPM_SIGNAL.fDetectLost must be enabled).
XtraInfo - the index number of the signal in the CPM signal table
More information is available in the application notes, “Ai-Logix’s Call Progress Monitoring” and “Managing CPM Events” located on the Ai-Logix website:
http://www.ai-logix.com/support.html
EVT_MON_REVERSAL
Indicates the detection of a loop current polarity reversal.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
• 716
717 •
EVT_MON_RINGBACK
EVT_MON_RINGBACK1
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MON_RINGBACK1 See Below* See FuncCode BoardID Global- pointer to length of
format Below* Channel file han- exercised
ID (GCI) dle data
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*
Subreason -
The value of 0x0000 indicates a signal has been detected.
The value of 0xFFFFFFFF indicates loss of signal (MT_CPM_SIGNAL.fDetectLost must be enabled).
XtraInfo - the index number of the signal in the CPM signal table
More information is available in the application notes, “Ai-Logix’s Call Progress Monitoring” and “Managing CPM Events” located on the Ai-Logix website:
http://www.ai-logix.com/support.html
718 •
EVT_MON_RINGBACK1
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MON_RINGBACK1 See Below* See FuncCode BoardID Global- pointer to length of
format Below* Channel file han- exercised
ID (GCI) dle data
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*
Subreason -
The value of 0x0000 indicates a signal has been detected.
The value of 0xFFFFFFFF indicates loss of signal (MT_CPM_SIGNAL.fDetectLost must be enabled).
XtraInfo - the index number of the signal in the CPM signal table
More information is available in the application notes, “Ai-Logix’s Call Progress Monitoring” and “Managing CPM Events” located on the Ai-Logix website:
http://www.ai-logix.com/support.html
EVT_MON_RINGBACK2
Indicates CPM detection of a RINGBACK2 signal. The signal Index ID is passed in the XtraInfo field. By default, this signal profile contains values that define the North
American double ringback.
NOTE: The event EVT_MON_DRINGBACK was obsoleted as of v3.3 release. It has been mapped to event EVT_MON_RINGBACK2 for backwards compatibility.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MON_RINGBACK2 See Below* See FuncCode BoardID Global- pointer to length of
format Below* Channel file han- exercised
ID (GCI) dle data
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*
Subreason -
The value of 0x0000 indicates a signal has been detected.
The value of 0xFFFFFFFF indicates loss of signal (MT_CPM_SIGNAL.fDetectLost must be enabled).
XtraInfo - the index number of the signal in the CPM signal table
More information is available in the application notes, “Ai-Logix’s Call Progress Monitoring” and “Managing CPM Events” located on the Ai-Logix website:
http://www.ai-logix.com/support.html
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MON_SIGNAL_CYCLE See Below* See N/A BoardID Global- pointer to length of
format Below* Channel file han- exercised
ID (GCI) dle data
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*Subreason -
The total cycle count.
XtraInfo - the index number of the signal in the CPM signal table
More information is available in the application notes, “Ai-Logix’s Call Progress Monitoring” and “Managing CPM Events” located on the Ai-Logix website:
http://www.ai-logix.com/support.html
EVT_MON_SILENCE
Indicates the detection of silence on the line.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MON_SILENCE See Below* 0-n/a FuncCode BoardID Global- pointer to length of
format Channel file han- exercised
ID (GCI) dle data
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*Timing Information - displays the amount of time (in ms) the line remained in the of the previous state. Information is presented in 1ms units, with a maximum of
65535ms.
EVT_MON_SIT
EVT_MON_SIT1, EVT_MON_SIT2, EVT_MON_SIT3, EVT_MON_SIT4, EVT_MON_SIT5
Indicates the CPM detection of a (SIT) signal. The signal Index ID is passed in the XtraInfo field. When MONI_SIT is enabled, then EVT_MON_SIT(1-5) is generated per
respective signal.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MON_SIT(1-5) See Below* See FuncCode BoardID Global- pointer to length of
format Below* Channel file han- exercised
ID (GCI) dle data
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*
Subreason -
The value of 0x0000 indicates a signal has been detected.
The value of 0xFFFFFFFF indicates loss of signal (MT_CPM_SIGNAL.fDetectLost must be enabled).
XtraInfo - the index number of the signal in the CPM signal table
More information is available in the application notes, “Ai-Logix’s Call Progress Monitoring” and “Managing CPM Events” located on the Ai-Logix website:
http://www.ai-logix.com/support.html
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MON_SIT1 See Below* See FuncCode BoardID Global- pointer to length of
format Below* Channel file han- exercised
ID (GCI) dle data
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*
Subreason -
The value of 0x0000 indicates a signal has been detected.
The value of 0xFFFFFFFF indicates loss of signal (MT_CPM_SIGNAL.fDetectLost must be enabled).
XtraInfo - the index number of the signal in the CPM signal table
More information is available in the application notes, “Ai-Logix’s Call Progress Monitoring” and “Managing CPM Events” located on the Ai-Logix website:
http://www.ai-logix.com/support.html
EVT_MON_SIT2
Indicates the CPM detection of a SIT2 signal. The signal Index ID is passed in the XtraInfo field.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MON_SIT2 See Below* See FuncCode BoardID Global- pointer to length of
format Below* Channel file han- exercised
ID (GCI) dle data
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*
Subreason -
The value of 0x0000 indicates a signal has been detected.
The value of 0xFFFFFFFF indicates loss of signal (MT_CPM_SIGNAL.fDetectLost must be enabled).
XtraInfo - the index number of the signal in the CPM signal table
More information is available in the application notes, “Ai-Logix’s Call Progress Monitoring” and “Managing CPM Events” located on the Ai-Logix website:
http://www.ai-logix.com/support.html
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MON_SIT3 See Below* See FuncCode BoardID Global- pointer to length of
format Below* Channel file han- exercised
ID (GCI) dle data
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*
Subreason -
The value of 0x0000 indicates a signal has been detected.
The value of 0xFFFFFFFF indicates loss of signal (MT_CPM_SIGNAL.fDetectLost must be enabled).
XtraInfo - the index number of the signal in the CPM signal table
More information is available in the application notes, “Ai-Logix’s Call Progress Monitoring” and “Managing CPM Events” located on the Ai-Logix website:
http://www.ai-logix.com/support.html
EVT_MON_SIT4
Indicates the CPM detection of a SIT4 signal. The signal Index ID is passed in the XtraInfo field.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MON_SIT4 See Below* See FuncCode BoardID Global- pointer to length of
format Below* Channel file han- exercised
ID (GCI) dle data
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*
Subreason -
The value of 0x0000 indicates a signal has been detected.
The value of 0xFFFFFFFF indicates loss of signal (MT_CPM_SIGNAL.fDetectLost must be enabled).
XtraInfo - the index number of the signal in the CPM signal table
More information is available in the application notes, “Ai-Logix’s Call Progress Monitoring” and “Managing CPM Events” located on the Ai-Logix website:
http://www.ai-logix.com/support.html
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MON_SIT5 See Below* See FuncCode BoardID Global- pointer to length of
format Below* Channel file han- exercised
ID (GCI) dle data
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*
Subreason -
The value of 0x0000 indicates a signal has been detected.
The value of 0xFFFFFFFF indicates loss of signal (MT_CPM_SIGNAL.fDetectLost must be enabled).
XtraInfo - the index number of the signal in the CPM signal table
More information is available in the application notes, “Ai-Logix’s Call Progress Monitoring” and “Managing CPM Events” located on the Ai-Logix website:
http://www.ai-logix.com/support.html
EVT_MON_TBUSY
Indicates CPM detection of BUSY2 signal. The signal Index ID is passed in the XtraInfo field. By default, the signal profiles contain values defining a North American
trunk (fast) busy signal.
NOTE: This event has been obsoleted with the v3.3 release. It has been mapped to EVT_MON_BUSY2 for backwards compatibility.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MON_BUSY2 See Below* See 0-n/a BoardID Global- 0-n/a 0-n/a
format Below* Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*
Subreason -
The value of 0x0000 indicates a signal has been detected.
The value of 0xFFFFFFFF indicates loss of signal (MT_CPM_SIGNAL.fDetectLost must be enabled).
XtraInfo - the index number of the signal in the CPM signal table
More information is available in the application notes, “Ai-Logix’s Call Progress Monitoring” and “Managing CPM Events” located on the Ai-Logix website:
http://www.ai-logix.com/support.html
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MON_UTONE See Below* See 0-n/a BoardID Global- 0-n/a 0-n/a
format Below* Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*Subreason -
The value of 0x0000 indicates a signal has been detected.
The value of 0xFFFFFFFF indicates loss of signal (MT_CPM_SIGNAL.fDetectLost must be enabled).
XtraInfo - the index number of the signal in the CPM signal table
More information is available in the application notes, “Ai-Logix’s Call Progress Monitoring” and “Managing CPM Events” located on the Ai-Logix website:
http://www.ai-logix.com/support.html
EVT_MON_VOICE
Indicates the CPM detection of voice activity on the line. The line will be analyzed further to determine whether the voice activity is either a live person (human) or
answer machine (machine).
More information about voice detection is available in the application notes, “Ai-Logix’s Call Progress Monitoring” and “Managing CPM Events” located on the Ai-Logix
website:
http://www.ai-logix.com/support.html
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DaaLength
In FileTIME 0-n/a EVT_MON_VOICE 0-n/a 0-n/a FuncCode BoardID Global- pointer to length of
format Channel file han- exercised
ID (GCI) dle data
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_MUTE_BUTTON_PRESSED
Indicates that the mute button has been pressed on the client phone.
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MUTE_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MUTE_LIGHT_ *See Below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_MVIP_ALARM 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_NEWCALL_BUTTON_PRESSED
Indicates that the new call button was pressed. Normally, this button is used if an agent attempted to call someone and the line is busy or they dialed
the wrong extension. Rather than hang up the hookswitch, they can press the "new call" button. It has very similar behavior as the hookswitch.
Also, if a dialed is busy number, and another call is coming into the line at the same time, the agent can press the new call button to retrieve the
incoming call.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_NEWCALL_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format BUTTON_PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_NEXT_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_NEXT_BUTTON_RELEASED
Indicates that the Next button has been released.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_NEXT_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format RELEASED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_NOT_AVAILABLE
Indicates functionality not available or busy
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_NOT_AVAILABLE 0-n/a Internal 0-n/a BoardID Global- 0-n/a 0-n/a
format Error Channel
Code ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_NOT_SUPPORTED
Indicates functionality not supported
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_NOT_SUPPORTED 0-n/a Internal 0-n/a BoardID Global- 0-n/a 0-n/a
format Error Channel
Code ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_OFFHOOK
Indicates Offhook complete
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_OFFHOOK 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_ONHOOK
Indicates Onhook complete
Structure:
In FileTIME 0-n/a EVT_ONHOOK 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
• 733
734 •
EVT_OUTGOING_SIGCHANGE
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_OUTGOING_ See Below* See 0-n/a BoardID Global- 0-n/a See Below*
format SIGCHANGE Below* Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*·SubReason:
an octect the new values of the signaling bits A, B, C, and D, in bits 3, 2, 1, and 0, respectively. Bits 8, 7, 6, 5 contain the previous values of the signaling bits.
XtraInfo:
the number of the framer reporting the event (most significant bit)
the timeslot on which the change was detected(least significant bit)
DataLength:
the duration of the previous state in 10 ms units
EVT_PAGE_BUTTON_PRESSED
Indicates that the page button was pressed.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_PAGE_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_PAGE_BUTTON_RELEASED
Indicates that the page button was released.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_PAGE_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format RELEASED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_PAGE_LIGHT_ *See Below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_PARK_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_PARK_LIGHT_ *See Below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_PAUSED_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_PBX_DCH
Not Supported. Although this event exists in the header file, it is not currently supported by the SmartWORKS API.
EVT_PHN_DCH
Not Supported. Although this event exists in the header file, it is not currently supported by the SmartWORKS API.
EVT_PREVIOUS_BUTTON_PRESSED
Indicates that the previous button has been pressed
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_PREVIOUS_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_PROGRAM_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_PROGRAM_LIGHT_FASTFLASHING
EVT_PROGRAM_LIGHT_FLASHING
EVT_PROGRAM_LIGHT_OFF
EVT_PROGRAM_LIGHT_ON
EVT_PROGRAM_LIGHT_QUICKFLASH
EVT_PROGRAM_LIGHT_VERY_FASTFLASHING
EVT_PROGRAM_LIGHT_WINK
Purpose:
Indicates that the program light on the phone is on, off or flashing.
Description:
Observation of various phone models enabled the Ai-Logix lab to categorize phone lights as flashing, fast flashing, very fast flashing, quick flashing or
winking. The cadence varies depending on PBX models, and this may also be configured. Our definition of flashing lights stems from the signal
passed from the PBX to the phone, and is based on factory default configurations for each model. Please refer to your PBX documentation for more
information.
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_PROGRAM_LIGHT_ *See Below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
• 741
742 •
EVT_READY_BUTTON_PRESSED
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_READY_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_READY_BUTTON_RELEASED
Indicates that the ready button was released
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_READY_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format RELEASED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_READY_LIGHT_FASTFLASHING
EVT_READY_LIGHT_FLASHING
EVT_READY_LIGHT_OFF
EVT_READY_LIGHT_ON
EVT_READY_LIGHT_QUICKFLASH
EVT_READY_LIGHT_VERY_FASTFLASHING
Purpose:
Indicates that the ready light on the phone is on, off or flashing.
Description:
Observation of various phone models enabled the Ai-Logix lab to categorize phone lights as flashing, fast flashing, very fast flashing or quick flashing.
The cadence varies depending on PBX models, and this may also be configured. Our definition of flashing lights stems from the signal passed from
the PBX to the phone, and is based on factory default configurations for each model. Please refer to your PBX documentation for more information.
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_READY_LIGHT_ *See Below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
• 743
744 •
EVT_RECALL_BUTTON_PRESSED
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_RECALL_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_REDIAL_BUTTON_PRESSED
Indicates that the Redial Button has been pressed
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_REDIAL_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_REDIAL_BUTTON_RELEASED
Indicates that the Recall button has been released
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_REDIAL_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format RELEASED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_REJECTED
Not supported. Although this event exists in the header file, it is not currently supported by the SmartWORKS API.
EVT_RELEASE_BUTTON_PRESSED
Indicates that the Release button has been pressed
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_RELEASE_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_RELEASE_BUTTON_RELEASED
Indicates that the Release button has been released
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_RELEASE_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format RELEASED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_RELEASE_LIGHT_ *See Below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_REORDER 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
Description:
Observation of various phone models enabled the Ai-Logix lab to categorize phone lights as flashing, fast flashing, very fast flashing or quick flashing.
The cadence varies depending on PBX models, and this may also be configured. Our definition of flashing lights stems from the signal passed from
the PBX to the phone, and is based on factory default configurations for each model. Please refer to your PBX documentation for more information.
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_RING_LIGHT_ *See Below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_RING_OFF 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_RING_ON
Indicates when the phone starts ringing. The phone ring cadence can be determined by calculating the time interval between EVT_RING_ON and EVT_RING_OFF
using the TimeStamp in the event structure
Strutcure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_RING_ON 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_RINGS
Indicates an incoming call. The ring detector on the board has detected that the line is ringing.
Structure:
In FileTIME 0-n/a EVT_RINGS total count 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format of rings Channel
ID (GCI)
• 749
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
750 •
EVT_RINGTONES_BUTTON_PRESSED
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_RINGTONES_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_RINGTONES_LIGHT_FASTFLASHING
EVT_RINGTONES_LIGHT_FLASHING
EVT_RINGTONES_LIGHT_OFF
EVT_RINGTONES_LIGHT_ON
EVT_RINGTONES_LIGHT_QUICKFLASH
EVT_RINGTONES_LIGHT_VERY_FASTFLASHING
Purpose:
Indicates that the ringtones light on the phone is on, off or flashing.
Description:
Observation of various phone models enabled the Ai-Logix lab to categorize phone lights as flashing, fast flashing, very fast flashing or quick flashing.
The cadence varies depending on PBX models, and this may also be configured. Our definition of flashing lights stems from the signal passed from
the PBX to the phone, and is based on factory default configurations for each model. Please refer to your PBX documentation for more information.
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_RINGTONES_LIGHT_ *See Below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
• 751
752 •
EVT_SAVE_BUTTON_PRESSED
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_SAVE_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_SAVE_LIGHT_FASTFLASHING
EVT_SAVE_LIGHT_FLASHING
EVT_SAVE_LIGHT_OFF
EVT_SAVE_LIGHT_ON
EVT_SAVE_LIGHT_QUICKFLASH
EVT_SAVE_LIGHT_VERY_FASTFLASHING
Purpose:
Indicates that the save light on the phone is on, off or flashing.
Description:
Observation of various phone models enabled the Ai-Logix lab to categorize phone lights as flashing, fast flashing, very fast flashing or quick flashing.
The cadence varies depending on PBX models, and this may also be configured. Our definition of flashing lights stems from the signal passed from
the PBX to the phone, and is based on factory default configurations for each model. Please refer to your PBX documentation for more information.
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_SAVE_LIGHT_ *See Below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
• 753
EVT_SCROLL_BUTTON_PRESSED
Indicates that the scroll button was pressed.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_SCROLL_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format BUTTON_PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_SCROLL_BUTTON_RELEASED
Indicates that the scroll button was released.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_SCROLL_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format BUTTON_RELEASED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_SCROLL_LIGHT_ *See Below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_SELECT_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_SET_BUSY
Indicates “set to busy” is active
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_SET_BUSY 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_SET_BUSY_CANCELED
Indicates “set to busy” is not active
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
• 756
757 •
EVT_SHIFT_BUTTON_PRESSED
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_SHIFT_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_SOFT_BUTTON_PRESSED
Indicates that a soft button has been pressed
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_SOFT_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
758 •
EVT_SOFT_LIGHT_FASTFLASHING
EVT_SOFT_LIGHT_VERY_FASTFLASHING
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_SOFT_LIGHT_ *See Below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_SPEAKER_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_SPEAKER_BUTTON_RELEASED
Indicates that a speaker (or hands free) button has been released
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_SPEAKER_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format RELEASED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
Purpose:
Indicates that a speaker light on the phone is on, off or flashing.
Description:
Observation of various phone models enabled the Ai-Logix lab to categorize phone lights as flashing, fast flashing, very fast flashing, quick flashing or
winking. The cadence varies depending on PBX models, and this may also be configured. Our definition of flashing lights stems from the signal
passed from the PBX to the phone, and is based on factory default configurations for each model. Please refer to your PBX documentation for more
information.
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_SPEAKER_LIGHT_ *See Below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_SPEEDDIAL_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
Purpose:
Indicates that a speeddial light on the phone is on, off or flashing.
Description:
Observation of various phone models enabled the Ai-Logix lab to categorize phone lights as flashing, fast flashing, very fast flashing, quick flashing or
winking. The cadence varies depending on PBX models, and this may also be configured. Our definition of flashing lights stems from the signal
passed from the PBX to the phone, and is based on factory default configurations for each model. Please refer to your PBX documentation for more
information.
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_SPEEDDIAL_LIGHT_ *See Below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_STOP 0-n/a 0-n/a FuncCode BoardID Global- pointer to length of
format Channel file han- exercised
ID (GCI) dle data
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_STREAMIN_DROPPED See Below* 0-n/a FuncCode BoardID Global- 0-n/a See Below*
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*Subreason: This field is populated with EVT_MAXBYTES indicating that the maximum bytes set has been reached
DataLen:
length of data dropped
EVT_STREAMIN_START
Indicates data encode streaming started
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_STREAMIN_START 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_STREAMIN_STOP
Indicates data encode streaming stopped
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_STREAMIN_STOP See Below* 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*SubReason:
This field populated with EVT_STREAMIN_COMP indicating that streaming has completed.
EVT_STREAMIN_WATERMARK
Indicates data encode streaming watermark reached. It is fired when the number of bytes in the buffer at least equals the number set in the watermark then writes
from the buffer to the file.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_STREAMIN_ See Below* 0-n/a 0-n/a BoardID Global- 0-n/a SEe
format WATERMARK Channel Beloew*
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
Subreason: This field is populated with EVT_MAXBYTES indicating that the set maximum bytes has been reached
DataLen:
• 765
766 •
EVT_STREAMOUT_EMPTY
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_STREAMOUT_EMPTY 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_STREAMOUT_PAUSED
Indicates output streaming paused
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_STREAMOUT_PAUSED 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_STREAMOUT_RESUMED
Indicates output streaming resumed
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_STREAMOUT_ 0-n/a See 0-n/a BoardID Global- See See Below*
format RESUMED Below* Channel Below*
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
XtraInfo - ERROR_SERVICE_PREQUEST_TIMEOUT
ptrBuffer - pointer to either a file or buffer (depending on which API was called, playing a file or from a buffer)
DataLength - length (bytes) of exercised data at termination
EVT_STREAMOUT_START
Indicates data DEcode streaming started
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_STREAMOUT_START 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_STREAMOUT_STOP See Below* 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
SubReason:
This field populated with EVT_STREAMOUT_COMP indicating that the data Decode streaming process has completed
EVT_STREAMOUT_WATERMARK
Indicates data DEcode streaming watermark reached. It is fired when the number of bytes in the buffer at least equals the number set in the watermark then writes
from the buffer to the file.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_STREAMOUT_ See Below* 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format WATERMARK Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
Subreason: This field is populated with EVT_MAXBYTES indicating the number set for the watermark
EVT_SUPERVISOR_BUTTON_PRESSED
Indicates that the supervisor button was pressed
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_SUPERVISOR_BUTTON 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format _PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_SUPERVISOR_BUTTON_RELEASED
Indicates that the supervisor button was released
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_SUPERVISOR_BUTTON 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format _RELEASED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_SUPERVISOR_LIGHT_ *See Below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_SYS_BOARD_ADDED 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_SYS_BOARD_REMOVED
Not implemented yet.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_SYS_BOARD_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format REMOVED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_SYS_ERROR
Indicates a system response timeout error
Structure:
In FileTIME 0-n/a EVT_SYS_ERROR 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
• 771
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
772 •
EVT_SYS_SYNCTIME_NEW
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_SYS_SYNCTIME_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format NEW Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_SYS_SYNCTIME_OLD
Resynchronization completed. The timestamp of this event displays the old time. This event is only generated when system events are controlled with
MTSysWaitForEvent() or MTSysSetEventCallback().
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_SYS_SYNCTIME_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format OLD Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_TERMDIGIT
Indicates termination of background function due to a terminating DTMF digit that has been received
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_DIGITENABLE Termination 0-n/a FuncCode BoardID Global- See See Below*
format Digit Channel Below*
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
ptrBuffer - pointer to either a file or buffer (depending on which API was called, playing a file or from a buffer)
DataLength - length (bytes) of exercised data at termination
EVT_TERMVOLTAGE_NOTOFFHOOK
EVT_TERMVOLTAGE_ABOVEORBELOW
Indicates termination of background function on loop voltage changed to notoffhook
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_TERMVOLTAGE_ 0-n/a 0-n/a FuncCode BoardID Global- 0-n/a 0-n/a
format NOTOFFHOOK Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_TERMSILENCE See Below* 0-n/a FuncCode BoardID Global- 0-n/a length of
format Channel exercised
ID (GCI) data
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
*
SubReason:
This field populated with CPM_MAX_SILENCE indicating that the maximum silence is met to terminate play or record
EVT_TERMLVOLTAGE_ABOVEORBELOW
EVT_TERMLVOLTAGE_NOTOFFHOOK
Indicates termination of background function due to the loop voltage state that is NOT MIDDLE (LD) or is NOTOFFHOOK (PT). The SmartWORKS LD board generates
EVT_LVOLTAGE_ABOVE and EVT_LVOLTAGE_BELOW events when the voltage state is NOT middle (offhook).
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_TERMLVOLTAGE_ 0-n/a 0-n/a FuncCode BoardID Global- 0-n/a length of
format Channel exercised
ID (GCI) data
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_TONEP_DONE
Indicates tone generation complete
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_TONEP_DONE 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_TONEPERR
Indicates tone generation template error
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_TONEPERR 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_TRANSFER_BUTTON_PRESSED
Indicates that the Transfer button has been pressed
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
• 775
776 •
EVT_TRANSFER_BUTTON_RELEASED
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_TRANSFER_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format RELEASED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_TRANSFER_LIGHT_FASTFLASHING
EVT_TRANSFER_LIGHT_FLASHING
EVT_TRANSFER_LIGHT_OFF
EVT_TRANSFER_LIGHT_ON
EVT_TRANSFER_LIGHT_QUICKFLASH
EVT_TRANSFER_LIGHT_VERY_FASTFLASHING
EVT_TRANSFER_LIGHT_WINK
Purpose:
Indicates that the transfer light on the phone is on, off or flashing.
Description:
Observation of various phone models enabled the Ai-Logix lab to categorize phone lights as flashing, fast flashing, very fast flashing, quick flashing or
winking. The cadence varies depending on PBX models, and this may also be configured. Our definition of flashing lights stems from the signal
passed from the PBX to the phone, and is based on factory default configurations for each model. Please refer to your PBX documentation for more
information.
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_TRANSFER_LIGHT_ *See Below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
• 777
778 •
EVT_TS16RAI_ALARM
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_TS16RAI_ALARM An octet 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format containing Channel
the number ID (GCI)
of the
framer
reporting
the event
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_UP_DOWN
Indicates that the volume up/downor view contrast buttons have been pressed
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_UP_DOWN 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_UTONE_OFF
Indicates detection of a user defined tone has ended. The Signal Index ID is passed into the XtraInfo field.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_UTONE_OFF n/a Index ID 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_UTONE_ON
Indicates detection of a user defined tone. The Signal Index ID is passed into the XtraInfo field.
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_UTONE_ON n/a Index ID 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_VOICE_RECORD
Indicates recording started on detection of activity
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
• 779
*The field is populated with CPM_MON_VOICE which indicates that voice activity was detected on the line.
780 •
EVT_WINKDONE
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_WINKDONE 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_WRAPUP_BUTTON_PRESSED
Indicates that the wrapup button was pressed
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_WRAPUP_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format PRESSED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_WRAPUP_BUTTON_RELEASED
Indicates that the wrapup button was released
Structure:
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_WRAPUP_BUTTON_ 0-n/a 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format RELEASED Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
EVT_WRAPUP_LIGHT_FASTFLASHING
EVT_WRAPUP_LIGHT_FLASHING
EVT_WRAPUP_LIGHT_OFF
EVT_WRAPUP_LIGHT_ON
EVT_WRAPUP_LIGHT_QUICKFLASH
EVT_WRAPUP_LIGHT_VERY_FASTFLASHING
Purpose:
Indicates that the wrapup light on the phone is on, off or flashing.
Description:
Observation of various phone models enabled the Ai-Logix lab to categorize phone lights as flashing, fast flashing, very fast flashing or quick flashing.
The cadence varies depending on PBX models, and this may also be configured. Our definition of flashing lights stems from the signal passed from
the PBX to the phone, and is based on factory default configurations for each model. Please refer to your PBX documentation for more information.
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_WRAPUP_LIGHT_ *See Below 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format Channel
ID (GCI)
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
• 781
782 •
EVT_YELLOW_ALARM
TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength
In FileTIME 0-n/a EVT_YELLOW_ALARM An octet 0-n/a 0-n/a BoardID Global- 0-n/a 0-n/a
format containing Channel
the number ID (GCI)
of the
framer
reporting
the event
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
Appendix A
Event Sequences
Ai-Logix, Inc.
686 •
SmartWORKS Developer’s Guide
Introduction
The following section outlines event sequences generated between phones that
are tapped by a SmartWORKS board on a supported PBX. Where possible, phone
illustrations have been included that display how phone buttons corollate to
various events in the SmartWORKS API.
EXAMPLE SEQUENCE
A Call from an extension connected to Channel 3 to an extension connected to
Channel 2.
CHANNEL EVENT CAUSE
Channel 3 EVT_AUDIO_ON(Handset 1) // phone (X102) picked up
Channel 3 EVT_OFFHOOK
Channel 3 EVT_CONNECTED(0x0000)
Channel 3 EVT_LIGHT_ON(GREEN 0)
Channel 3 EVT_LIGHT_ON(RED 0)
Channel 3 EVT_MESSAGE_CHANGE (17)
Channel 3
Channel 3 EVT_DIGIT_PRESSED(1) // phone (X102) dialed "1"
Channel 3 EVT_DIGIT_RELEASED(1)
Channel 3 EVT_MESSAGE_CHANGE (17)
Channel 3 1
Channel 3 EVT_DIGIT_PRESSED(0) // phone (X102) dialed "0"
Channel 3 EVT_DIGIT_RELEASED(0)
Channel 3 EVT_MESSAGE_CHANGE (17)
Channel 3 10
Channel 3 EVT_DIGIT_PRESSED(1) // phone (X102) dialed "1"
Channel 3 EVT_DIGIT_RELEASED(1)
Channel 3 EVT_CONNECTED(0x0000)
Channel 2 EVT_RING_ON(1)
Channel 2 EVT_LIGHT_OFF(GREEN 0)
Channel 2 EVT_LIGHT_OFF(RED 0)
Channel 2 EVT_LIGHT_FLASHING(GREEN 1)
Channel 2 EVT_LIGHT_OFF(RED 1)
Channel 2 EVT_LIGHT_ON(RED 1)
Channel 2 EVT_MESSAGE_CHANGE (25)
Channel 2 JOE Ext102
Channel 3 EVT_MESSAGE_CHANGE (17)
Channel 3 PETER Ext101
Channel 2 EVT_AUDIO_ON(Handset 1) // phone (X101) picked up
Channel 2 EVT_OFFHOOK
Channel 2 EVT_RING_OFF(1)
Channel 2 EVT_CONNECTED(0x0000)
Channel 2 EVT_LIGHT_ON(GREEN 1)
Channel 2 EVT_MESSAGE_CHANGE (25)
Channel 2 JOE Ext102
Channel 3 EVT_AUDIO_OFF(Handset 1) // phone (X102) hung up
Channel 3 EVT_ONHOOK
Channel 3 EVT_DISCONNECTED(0x0000)
Channel 2 EVT_DISCONNECTED(0x0000)
Channel 3 EVT_LIGHT_OFF(GREEN 0)
Channel 3 EVT_LIGHT_OFF(RED 0)
Channel 2 EVT_LIGHT_OFF(GREEN 1)
Channel 2 EVT_LIGHT_OFF(RED 1)
Channel 2 EVT_DISCONNECTED(0x0000)
Channel 3 EVT_LIGHT_ON(RED 0)
Channel 2 EVT_MESSAGE_CHANGE (25)
Channel 2
{Continues on next page}
Ai-Logix, Inc.
688 •
SmartWORKS Developer’s Guide
PHONE MAP
Menu
_______________________
Exit 1A–X
EVT_FUNCTION_BUTTON_PRESSED
Subreasons:
0x00000000– 0x00000017
1A 1G 1M 1S ________________________
0 6 12 18
2A
1 7 13 19 EVT_SPEAKER_BUTTON_PRESSED
8 EVT_SPEAKER_BUTTON_RELEASED
2 14 20
2B
3 9 15 21 EVT_HOLD_BUTTON_PRESSED
EVT_HOLD_BUTTON_RELEASED
4 10 16 22
________________________
5 11 17 23 3A–3L
1F 1L 1R 1X EVT_DIGIT_PRESSED
EVT_DIGIT_RELEASED
Subreasons: Correspond to digit pressed
2A 3A 3C or released
ABC DEF
Spkr Redial
1 2 3
3D 3F
GHI JKL MNO
Mute Conf
4 5 6
3G 3I
PQRS TUV WXYZ
Trnsfr 7 8 9
3J 3L
Hold
2B * 0 #
Event Sequences
• 689
Ericsson Event Sequences
EXAMPLE SEQUENCE
A Call from an extension connected to Channel 3 to an extension connected to
Channel 7.
CHANNEL EVENT CAUSE
Channel 3 EVT_OFFHOOK //Phone (X2002) picked up
Channel 3 EVT_LIGHT_ON(RED 11)
Channel 3 EVT_AUDIO_ON(Handset 1)
Channel 3 EVT_MESSAGE_CHANGE (84)
Channel 3
Channel 3
Channel 3
Channel 3 LOCK ACC
Channel 3 EVT_MESSAGE_CHANGE (84)
Channel 3
Channel 3
Channel 3
Channel 3 LOCK ACC AUTH TIMER
Channel 3 EVT_DIGIT_PRESSED(2) //Phone (X2002) dialed "2"
Channel 3 EVT_MESSAGE_CHANGE (84)
Channel 3
Channel 3
Channel 3 2
Channel 3 EVT_DIGIT_PRESSED(0) //Phone (X2002) dialed "0"
Channel 3 EVT_MESSAGE_CHANGE (84)
Channel 3
Channel 3
Channel 3 20
Channel 3 EVT_DIGIT_PRESSED(0) //Phone (X2002) dialed "0"
Channel 3 EVT_MESSAGE_CHANGE (84)
Channel 3
Channel 3
Channel 3 200
Channel 3 EVT_DIGIT_PRESSED(6) //Phone (X2002) dialed "6"
Channel 3 EVT_MESSAGE_CHANGE (84)
Channel 3
Channel 3
Channel 3 2006
Channel 7 EVT_LIGHT_FASTFLASHING(RED 11)
Channel 3 EVT_MESSAGE_CHANGE (84)
Channel 3
Channel 3 CALLBACK =
Channel 3 EVT_MESSAGE_CHANGE (84)
Channel 3
Channel 3 CALLBACK = 6
Channel 7 EVT_RING_ON(1)
Channel 3 EVT_MESSAGE_CHANGE (84)
Channel 3
Channel 3 CALLBACK = 6
Channel 3 2006
Channel 3 CAB PAG
Channel 3 EVT_MESSAGE_CHANGE (84)
{Continues on next page}
Ai-Logix, Inc.
690 •
SmartWORKS Developer’s Guide
PHONE MAP
Ericsson DBC662
MD110 ERICSSON
_______________________
1A–1P
EVT_FUNCTION_BUTTON_PRESSED
1A
Subreason: 0x00000000
1B
F1 F2 F3 F4
Subreason: 0x00000010
1C
Subreason: 0x00000011
1D
1A Prog F1 F2 F3 F4 Menu Subreason: 0x00000009
1E
2A ABC DEF2C Subreasons: 0x00000014–0x00000025
1 2 3 1E 1K ________________________
2DGHI
2A–2L
JKL MNO2F
1B Access 2 EVT_DIGIT_PRESSED
4 5 6
Subreasons: Correspond to digit pressed
2GPRS TUV WXY2I
1C Access 1
7 8 9
Mute
2J OPER 2L
* 0 #
1D Access 3
_______________________
1A–1I
EVT_FUNCTION_BUTTON_PRESSED
Ericsson DBC 202 Subreasons:
1A - 0x00000000
ERICSSON
1B - 0x00000001
1C - 0x00000002
6 1D - 0x00000003
1E - 0x0000000E
1F - 0x0000000D
1G - 0x00000009
1H- 0x0000000A
1I - 0x0000000B
______________________
2 EVT_TRANSFER_BUTTON_PRESSED
3A–3L
EVT_DIGIT_PRESSED
Subreasons: Correspond to digit pressed
* - 0x0000002A
1A # - 0x00000023
________________________
1 2 3 1B 4
EVT_SPEAKER_BUTTON_PRESSED
3A 3B 3C 1C Subreason: 0x00000000
5
4 5 6 1D EVT_RELEASE_BUTTON_PRESSED
3D 3E 3F Subreason: 0x00000000
1E 6
7 8 9 EVT_MESSAGE_CHANGE
Subreason: 0x00000000
3G 3H 3I 1F
L1-L3
* 0 # L3
2
EVT_LIGHT_ON
EVT_LIGHT_OFF
3J 3K 3L 1G EVT_LIGHT_QUICKFLASH
+ L2 _______________________
1H
L1
C L1 L2
1I
L3
4 5
Event Sequences
• 693
Ericsson Event Sequences
_______________________
Ericsson DBC203 1A–1I
EVT_FUNCTION_BUTTON_PRESSED
Subreasons: 1J - 0x00000008
1A - 0x00000000 1K - 0x0000000F
ERICSSON 1B - 0x00000001 1L - 0x00000010
1C - 0x00000002 1M - 0x00000011
1D - 0x00000003 1N - 0x00000012
6 1E - 0x0000000E 1O - 0x00000013
1F - 0x0000000D 1P - 0x00000014
1G - 0x00000009 1Q- 0x00000015
1H- 0x0000000A 1R - 0x00000016
1I - 0x0000000B 1S - 0x00000017
1T- 0x00000004
1U - 0x00000005
1T 1U 1V 1W 1V - 0x00000006
1W - 0x00000007
______________________
2 EVT_TRANSFER_BUTTON_PRESSED
_______________________
1A 3A–3L
1J
EVT_DIGIT_PRESSED
Subreasons: Correspond to digit pressed
1B 1K
1 2 3 * - 0x0000002A
# - 0x00000023
3A 3B 3C 1C 1L ________________________
4
4 5 6 1D 1M EVT_SPEAKER_BUTTON_PRESSED
3D 3E 3F Subreason: 0x00000000
1E 1N 5
7 8 9 EVT_RELEASE_BUTTON_PRESSED
Subreason: 0x00000000
1F 1O
3G 3H 3I 6
EVT_MESSAGE_CHANGE
* 0 # 2 1P
Subreason: 0x00000000
3J 3K 3L 1Q
1G
+ Light events have not been documented yet.
1H 1R
C
1I 1S
4 5
Ai-Logix, Inc.
694 •
SmartWORKS Developer’s Guide
2
EVT_TRANSFER_BUTTON_PRESSED
3
EVT_DIGIT_BUTTON_PRESSED
Subreasons:
3A - 0X00000031
1D 1C 3B - 0X00000032
1F 1E 3C - 0X00000033
3D - 0X00000034
3E - 0X00000035
3F - 0X00000036
1B 1 2 3 3G - 0X00000037
3A 3B 3H - 0X00000038
3C 3I - 0X00000039
Acc 2/ Prog 3J - 0X0000002A
1A 4 5 6 3K - 0X00000030
3L - 0X00000023
L1 3D 3E 3F
Access 1 L1
7 8 9 EVT_LIGHT_ON
EVT_LIGHT_OFF
L2 3G 3H 3I EVT_LIGHT_QUICKFLASH
EVT_LIGHT_FLASH
* 0 # Subreasons:
3J 3K 3L L2
EVT_LIGHT_ON
EVT_LIGHT_OFF
EVT_LIGHT_QUICKFLASH
EVT_LIGHT_FLASH
Transfer Subreasons:
2
Event Sequences
• 695
Nortel Meridian Event Sequences
EXAMPLE SEQUENCE
A Call from an extension connected to Ch1 to an extension connected to Ch2.
CHANNEL EVENT CAUSE
Channel 2 EVT_OFFHOOK //phone (X101) picked up
Channel 2 EVT_MESSAGE_CHANGE (17)
Channel 2 101->[ ]
Channel 1 EVT_MESSAGE_CHANGE (17)
Channel 1
Channel 2 EVT_DIGIT_PRESSED(1) //phone (X101) dialed "1"
Channel 2 EVT_MESSAGE_CHANGE (17)
Channel 2 101->[1 ]
Channel 2 EVT_DIGIT_PRESSED(0) //phone (X101) dialed "0"
Channel 2 EVT_MESSAGE_CHANGE (17)
Channel 2 101->[10 ]
Channel 2 EVT_DIGIT_PRESSED(0) //phone (X101) dialed "0"
Channel 2 EVT_MESSAGE_CHANGE (17)
Channel 2 101->[100]
Channel 1 EVT_MESSAGE_CHANGE (17)
Channel 1 100<-[101]
Channel 1 EVT_OFFHOOK //phone (X101) picked up
Channel 1 EVT_MESSAGE_CHANGE (17)
Channel 1 100==[101]
Channel 2 EVT_MESSAGE_CHANGE (17)
Channel 2 101==[100]
Channel 2 EVT_MESSAGE_CHANGE (17) //phone (X101) hung up
Channel 2
Channel 1 EVT_MESSAGE_CHANGE (17)
Channel 1 BUSY
Channel 2 EVT_ONHOOK
Channel 1 EVT_MESSAGE_CHANGE (17) //phone (X100) hung up
Channel 1
Channel 1 EVT_ONHOOK
Ai-Logix, Inc.
696 •
SmartWORKS Developer’s Guide
PHONE MAP
Nortel DTU-32D-2
_______________________
1A
NEC EVT_MESSAGE_CHANGE
________________________
2A EVT_HELP_BUTTON_PRESSED
1A 2B EVT_HOLD_BUTTON_PRESSED
NEC
________________________
3A–3P
EVT_LINE_BUTTON_PRESSED
Subreasons: 0x00000000–0x00000010
________________________
2A 4A–4P
3A 3D
EVT_FUNCTION_BUTTON_PRESSED
4A 4I
(0) (1) (2) (3) (0) (8) Subreasons: 0x00000000–0x00000010
3E 3H ________________________
(4) (5) (6) (7) (1) (9) 5A–5L
3I 3L EVT_DIGIT_PRESSED
(8) (9) (a) (b) (2) (a) Subreasons: Correspond to digit pressed
3M 3P ________________________
(c) (d) (e) (f ) (3) (b) 6A
5A 5C 6A EVT_FEATURE_BUTTON_PRESSED
(4) (c) 6B
1 2 3 EVT_RECALL_BUTTON_PRESSED
5D 5F 6B (5) (d) 6C
4 5 6 EVT_CONF_BUTTON_PRESSED
5G 5I 6C (6) (e) 6D
EVT_REDIAL_BUTTON_PRESSED
7 8 9 (7) (f ) 6E
5J 5L 6D
4H 4P EVT_HOLD_BUTTON_PRESSED
0 # 6F
* 6I EVT_TRANSFER_BUTTON_PRESSED
6G
6E 6F 6G 6H
EVT_ANSWER_BUTTON_PRESSED
6H
EVT_SPEAKER_BUTTON_PRESSED
6I
EVT_UP_DOWN
________________________
Event Sequences
• 697
NEC NEAX Event Sequences
EXAMPLE SEQUENCE
A Call from an extension connected to Channel 12 to an extension connected to
Channel 13.
CHANNEL EVENT CAUSE
Channel 12 EVT_OFFHOOK //phone (X133) picked up
Channel 12 EVT_AUDIO_ON(Handset 1)
Channel 12 EVT_LIGHT_ON(GREEN 15)
Channel 12 EVT_DIGIT_PRESSED(1) //phone (X133) dialed "1"
Channel 12 EVT_DIGIT_RELEASED(1)
Channel 12 EVT_DIGIT_PRESSED(3) //phone (X133) dialed "3"
Channel 12 EVT_DIGIT_RELEASED(3)
Channel 12 EVT_DIGIT_PRESSED(4) //phone (X133) dialed "4"
Channel 12 EVT_DIGIT_RELEASED(4)
Channel 12 EVT_MESSAGE_CHANGE (51)
Channel 12 1
Channel 12
Channel 12 EVT_MESSAGE_CHANGE (51)
Channel 12 134
Channel 12
Channel 13 EVT_RING_ON(1)
Channel 12 EVT_MESSAGE_CHANGE (51)
Channel 12 134
Channel 12 2:25 PM THU
Channel 13 EVT_LIGHT_FASTFLASHING(RED 15)
Channel 13 EVT_LIGHT_ON(RED 15) //phone (X134) picked up
Channel 13 EVT_RING_OFF(1)
Channel 13 EVT_OFFHOOK
Channel 13 EVT_AUDIO_ON(Handset 1)
Channel 13 EVT_LIGHT_ON(GREEN 15)
Channel 13 EVT_MESSAGE_CHANGE (51)
Channel 13 1
Channel 13
Channel 13 EVT_MESSAGE_CHANGE (51)
Channel 13 133
Channel 13
Channel 13 EVT_MESSAGE_CHANGE (51)
Channel 13 133
Channel 13 2:25 PM THU
Channel 12 EVT_ONHOOK //phone (X133) hung up
Channel 12 EVT_AUDIO_OFF(Handset 1)
Channel 12 EVT_LIGHT_OFF(GREEN 15)
Channel 13 EVT_ONHOOK //phone (X133) hung up
Channel 13 EVT_AUDIO_OFF(Handset 1)
Channel 13 EVT_LIGHT_OFF(GREEN 15)
Channel 13 EVT_LIGHT_OFF(RED 15)
Channel 12 EVT_MESSAGE_CHANGE (51)
Channel 12
Channel 12 2:26 PM THU 5
Channel 13 EVT_MESSAGE_CHANGE (51)
Channel 13
Channel 13 2:26 PM THU 5
Ai-Logix, Inc.
698 •
SmartWORKS Developer’s Guide
PHONE MAP
_______________________
1A
NEC EVT_MESSAGE_CHANGE
________________________
2A EVT_HELP_BUTTON_PRESSED
1A 2B EVT_HOLD_BUTTON_PRESSED
NEC
________________________
3A–3P
EVT_LINE_BUTTON_PRESSED
Subreasons: 0x00000000–0x00000010
________________________
2A 4A–4P
3A 3D
EVT_FUNCTION_BUTTON_PRESSED
4A 4I
(0) (1) (2) (3) (0) (8) Subreasons: 0x00000000–0x00000010
3E 3H ________________________
(4) (5) (6) (7) (1) (9) 5A–5L
3I 3L EVT_DIGIT_PRESSED
(8) (9) (a) (b) (2) (a) Subreasons: Correspond to digit pressed
3M 3P ________________________
(c) (d) (e) (f ) (3) (b) 6A
5A 5C 6A EVT_FEATURE_BUTTON_PRESSED
(4) (c) 6B
1 2 3 EVT_RECALL_BUTTON_PRESSED
5D 5F 6B (5) (d) 6C
4 5 6 EVT_CONF_BUTTON_PRESSED
5G 5I 6C (6) (e) 6D
EVT_REDIAL_BUTTON_PRESSED
7 8 9 (7) (f ) 6E
5J 5L 6D
4H 4P EVT_HOLD_BUTTON_PRESSED
0 # 6F
* 6I EVT_TRANSFER_BUTTON_PRESSED
6G
6E 6F 6G 6H
EVT_ANSWER_BUTTON_PRESSED
6H
EVT_SPEAKER_BUTTON_PRESSED
6I
EVT_UP_DOWN
________________________
Event Sequences
• 699
Siemens Event Sequences
EXAMPLE SEQUENCE
A Call from an extension connected to Channel 2 to an extension connected to Channel 1.
Channel 2 (11efa40) EVT_OFFHOOK //phone (x201) picked up
Channel 2 (104a) EVT_AUDIO_CHANGE (0x0000000000000005)(Handset TRAN
Speaker TRAN )
Channel 2 (102a) EVT_DISPLAY_CLEAR(0x0000)
Channel 2 (1008) EVT_MESSAGE_CHANGE (52)
Channel 2 (1008) 201:
Channel 2 (1008)
Channel 2 (1008)
Channel 2 (1006) EVT_DIGIT_PRESSED(2) //phone (x201) dialed "2"
Channel 2 (102a) EVT_DISPLAY_CLEAR(0x0000)
Channel 2 (1006) EVT_DIGIT_PRESSED(0) //phone (x201) dialed "0"
Channel 2 (1006) EVT_DIGIT_PRESSED(2) //phone (x201) dialed "2"
Channel 2 (1008) EVT_MESSAGE_CHANGE (52)
Channel 2 (1008) 20
Channel 2 (1008)
Channel 2 (1008)
Channel 2 (102a) EVT_DISPLAY_CLEAR(0x0000)
Channel 1 (101f) EVT_RING_ON(0)
Channel 2 (1001) EVT_LIGHT_ON(0x0000000000000100)(GREEN 0)
Channel 2 (1033) EVT_LIGHT_VERY_FASTFLASHING(0x0217)
Channel 1 (1033) EVT_LIGHT_VERY_FASTFLASHING(0x0100)
Channel 1 (1033) EVT_LIGHT_VERY_FASTFLASHING(0x0217)
Channel 1 (102a) EVT_DISPLAY_CLEAR(0x0000)
Channel 1 (1008) EVT_MESSAGE_CHANGE (52)
Channel 1 (1008) CALL FROM 201
Channel 1 (1008)
Channel 1 (1008)
Channel 2 (1008) EVT_MESSAGE_CHANGE (52)
Channel 2 (1008) 202:Ringing
Channel 2 (1008) CBK MSG
Channel 2 (1008)
Channel 1 (11efa40) EVT_OFFHOOK //phone (x202) picked up
Channel 1 (104a) EVT_AUDIO_CHANGE (0x0000000000000005)(Handset TRAN
Speaker TRAN )
Channel 2 (104a) EVT_AUDIO_CHANGE (0x0000000000000000)()
Channel 2 (102a) EVT_DISPLAY_CLEAR(0x0000)
Channel 1 (1020) EVT_RING_OFF(0)
Channel 2 (1002) EVT_LIGHT_OFF(0x0000000000000217)(RED 23)
Channel 1 (1001) EVT_LIGHT_ON(0x0000000000000100)(GREEN 0)
Channel 1 (1002) EVT_LIGHT_OFF(0x0000000000000217)(RED 23)
Channel 1 (102a) EVT_DISPLAY_CLEAR(0x0000)
Channel 2 (1008) EVT_MESSAGE_CHANGE (52)
Channel 2 (1008) 202:
Channel 2 (1008) CONF LISTEN MUTE
Channel 2 (1008)
Channel 1 (1008) EVT_MESSAGE_CHANGE (52)
Channel 1 (1008) 201:
Channel 1 (1008) CONF LISTEN MUTE
Channel 1 (1008)
Channel 1 (11efa40) EVT_ONHOOK //phone (x202) hung up
Channel 1 (104a) EVT_AUDIO_CHANGE (0x0000000000000000)()
Event Sequences
• 701
Samsung Event Sequences
PHONE MAP
SAMSUNG
11 1A-1X
EVT_FUNCTION_BUTTON_PRESSED
SubReasons: 0x00000000-0x00000023
2A-2C
EVT_SOFT_BUTTON_PRESSED
SubReasons:
0x00000001 -or-
0x00000002 -or-
0x00000003
_______________________
3
MENU EVT_MENU_BUTTON_PRESSED
2A 2B 2C
3
4A–4L
1A 1B 1C 1D 1E 1F EVT_DIGIT_PRESSED
Subreasons: Correspond to digit pressed
* - 0x0000002A
1G 1H 1I 1J 1K 1L # - 0x00000023
______________________
5
1M 1N 1O 1P 1Q 1R EVT_SPEAKER_BUTTON_PRESSED
Subreason: 0x00000000
1S 1T 1U 1V 1W 1X 6
EVT_TRANSFER_BUTTON_PRESSED
Subreason: 0x00000000
7
4A 4B 4C EVT_REDIAL_BUTTON_PRESSED
1 2 3 6 Subreason: 0x00000000
8
4D 4E 4F TRANSFER EVT_PAGE_BUTTON_PRESSED
Subreason: 0x00000000
4 5 6 7 9
EVT_MESSAGE_BUTTON_PRESSED
4G 4H 4I REDIAL Subreason: 0x00000000
7 8 9 8
10
EVT_HOLD_BUTTON_PRESSED
4J 4K 4L PAGE Subreason: 0x00000000
11
#
* 0
5
9
MESSAGE
10
EVT_MESSAGE_CHANGE
Subreason: 0x00000000
PHONE MAP
_______________________
ASPECT 1A–1F
EVT_SOFT_BUTTON_PRESSED
Subreasons: 0x00000000–0x00000005
________________________
2A EVT_HOLD_BUTTON_PRESSED
2B EVT_READY_BUTTON_PRESSED
2C EVT_TRANSFER_BUTTON_PRESSED
2D EVT_RELEASE_BUTTON_PRESSED
2E EVT_CONFERENCE_BUTTON_PRESSED
2F EVT_WRAPUP_BUTTON_PRESSED
1A 1B 1C 1D 1E 1F
2G EVT_SPEAKER_BUTTON_PRESSED
________________________
3A–3L
2A L1 2B L2 3A 3C 4A EVT_DIGIT_PRESSED
L8 L11
ABC DEF
Subreasons: Correspond to digit pressed
HOLD READY 1 2 3 OUTSIDE SUPERVISOR 4B
LINE1 ________________________
2C 2D 3D 3F 4A
L3 GHI JKL MNO L9 4C L12
TRANSFER RELEASE 4 5 6 OUTSIDE MESSAGES 4D
EVT_LINE_BUTTON_PRESSED
3G 3I
LINE2
Subreason: 0x00000000
2E 2F L4 PRS TUV WXY
L10 4E L13 4B
7 8 9 EVT_SUPERVISOR_BUTTON_PRESSED
CONFERENCE WRAP-UP INSIDE
LINE
HELP 4F
3J 3L 4C
EVT_LINE_BUTTON_PRESSED
L5
MIC
L6
SPK
2F
* 0 #
Subreason: 0x00000001
4D
EVT_MESSAGE_BUTTON_PRESSED
L7 4E
EVT_LINE_BUTTON_PRESSED
Subreason: 0x00000002
4F
EVT_HELP_BUTTON_PRESSED
ASPECT
_______________________ _______________________
Each light has 4 possible events: ON, OFF, FLASHING, and FASTFLASHING. L1 EVT_HOLD_LIGHT_xx Subreason : 0x00000n00
The subreason listed to the right of each event remains the same for all L2 EVT_READY_LIGHT_xx Subreason : 0x00000n00
4 of the possible events. The subreason bit field is structured as follows: L3 EVT_RELEASE_LIGHT_xx Subreason : 0x00000n00
XXXX XARG where x is reserved for future use and when L4 EVT_WRAPUP_LIGHT_xx Subreason : 0x00000n00
A = 1 it designates an Amber light L5 EVT_MIC_LIGHT_xx Subreason : 0x00000n00
R = 1 it designates a Red light L6 EVT_SPEAKER_LIGHT_xx Subreason : 0x00000n00
G = 1 it designates a Green light L7 EVT_CALLWAITING_LIGHT_xx Subreason : 0x00000n00
L8 EVT_LINE_LIGHT_xx Subreason : 0x00000n00
L9 EVT_LINE_LIGHT_xx Subreason : 0x00000n001
L10 EVT_LINE_LIGHT_xx Subreason : 0x00000n02
L11 EVT_SUPERVISOR_LIGHT_xx Subreason : 0x00000n00
L12 EVT_MESSAGE_LIGHT_xx Subreason : 0x00000n00
L13 EVT_HELP_LIGHT_xx Subreason : 0x00000n0
Ai-Logix, Inc.
704 •
SmartWORKS Developer’s Guide
A EVT_CALL_CONNECTED 600
API’s Presented Alphabetically 68 EVT_CALL_HELD 601
API’s Presented with PBX Support 68 EVT_CALL_REJECTED 601
APIs Presented Logically 80 EVT_CALL_RELEASED 601
Architecture Overview 15 EVT_CALL_RESUMED 601
Aspect Phone Map 703 EVT_CALL_RETRIEVED 601
Audio Jack Functions 132 EVT_CALL_SUSPENDED 601
Avaya Definity 686 EVT_CALLID_DROPPED 601
Avaya Definity Phone Map 686 EVT_CALLID_MSGLEN 601
Avaya Merlin Magix Phone Map 687 EVT_CALLID_START 601
B EVT_CALLID_STOP 601
Board Information Functions 143 EVT_CC_ALERT_IND 604
Board Numbering 17 EVT_CC_CALL_ABANDONED 608
Board Type Naming 30 EVT_CC_CALL_CONNECTED 609
EVT_CC_CALL_HELD 610
C
EVT_CC_CALL_REJECTED 610
Call Connection Functions 160
EVT_CC_CALL_RELEASED 612
Channel Functions 204
EVT_CC_CALL_RESUMED 613
Channel Numbering 17
EVT_CC_CALL_RETRIEVED 614
Contact Ai-Logix 6
EVT_CC_CALL_SUSPENDED 615
Control Data 59
EVT_CC_CONNECT_CONF 616
Control Functions 234
EVT_CC_DISC_CONF 620
CT Bus Functions 492
EVT_CC_DISC_IND 622
D EVT_CC_INFO_IND 626
Data Structures 52 EVT_CC_PROGRESS_IND 630
D-Channel Event Codes 52 EVT_CC_USER_INFO 635
Developers Note 14 EVT_CC_USERINFO_IND 637
E EVT_CFWD 639
Environment 10 EVT_CFWD_CANCELED 639
Ericsson Phone Map 689 EVT_CONF_BUTTON_PRESSED 640
Event Codes 44 EVT_CONF_BUTTON_RELEASED 640, 742, 769, 780
event codes EVT_CONFERENCE_LIGHT_FASTFLASHING 641
user defined 593 EVT_CONFERENCE_LIGHT_FLASHING 641
Event Codes Presented Alphabetically 593 EVT_CONFERENCE_LIGHT_OFF 642
Event Control 25, 37 EVT_CONFERENCE_LIGHT_ON 641
Event Functions 239 EVT_CONFERENCE_LIGHT_QUICKFLASH 642
EVT_AIS_ALARM 594 EVT_CONFERENCE_LIGHT_VERY_FASTFLASHING 642
EVT_ALERTING_AUTO_ANSWER 597 EVT_CONNECTED 642
EVT_ANSWER_BUTTON_PRESSED 595 EVT_CPM_STOP 643
EVT_ANSWER_LIGHT_FASTFLASHING 596, 650, EVT_DEVICE_READ_ERROR 645
673, 730 EVT_DEVICE_SEEK_ERROR 646
EVT_ANSWER_LIGHT_FLASHING 597 EVT_DEVICE_WRITE_ERROR 646
EVT_ANSWER_LIGHT_OFF 597, 604 EVT_DIALED 646
EVT_ANSWER_LIGHT_ON 597 EVT_DIGIT 647
EVT_ANSWER_LIGHT_Q UICKFLASH 597 EVT_DIGIT_DROPPED 647
EVT_ANSWER_LIGHT_VERY_FASTFLASHING 597 EVT_DIGIT_PRESSED 648
EVT_AUDIO_CHANGE 597 EVT_DIGIT_RELEASED 648
EVT_AUDIO_OFF 599 EVT_DIGITENABLE 649
EVT_AUDIO_ON 599 EVT_DISCONNECTED 651
EVT_AUTO_ANSWER 599 EVT_DISK_FULL 651
EVT_AUTO_ANSWER_CANCELED 599 EVT_DISK_WRITE_ERROR 651
EVT_BOARD_PANIC_ERROR 600 EVT_DISPLAY 652
EVT_BREAK_BUTTON_PRESSED 600 EVT_DISPLAY_CLEAR 652
EVT_CALL_ABANDONED 600 EVT_DISPLAY_CLOCK 652
EVT_DISPLAY_MESSAGE 653 EVT_MFTONE 699
EVT_DSPRESET 658 EVT_MFTONE_DROPPED 699
EVT_EOF 659 EVT_MIC_LIGHT_FASTFLASHING 701
EVT_ERROR 659 EVT_MON_ACTIVITY 702
EVT_EXIT_BUTTON_PRESSED 659 EVT_MON_BUSY 703
EVT_FAX_ERROR 660 EVT_MON_BUSY_TRUNK 727
EVT_FAX_PHASED_COMP 660 EVT_MON_DIAL 707, 708, 779
EVT_FAXRECVEOP 660 EVT_MON_DRINGBACK 711
EVT_FEATURE_BUTTON_PRESSSED 660, 662 EVT_MON_FAX 712, 713, 714
EVT_FEATURE_BUTTON_RELEASED 663 EVT_MON_RINGBACK 716
EVT_FEATURE_HEADER_ERROR 662 EVT_MON_SILENCE 720
EVT_FEATURE_LIGHT_FASTFLASHING 661 EVT_MON_SIT 720, 721, 722, 723, 724, 725, 726
EVT_FEATURE_LIGHT_FLASHING 662 EVT_MUTE_BUTTON_PRESSED 729
EVT_FINISHED_PLAY 662 EVT_MVIP_ALARM 731
EVT_FUNCTION_LIGHT_FASTFLASHING 667 EVT_NEXT_BUTTON_PRESSED 732
EVT_H100_MASTER_A_ALARM 671 EVT_NO_EFFECT 732
EVT_H100_MASTER_B_ALARM 671 EVT_NOT_AVAILABLE 732
EVT_HELD 673 EVT_NOT_SUPPORTED 733
EVT_HELP_BUTTON_PRESSED 674 EVT_OFFHOOK 733
EVT_HOLD_BUTTON_PRESSED 676 EVT_ONHOOK 733
EVT_HOLD_BUTTON_RELEASED 676 EVT_OUTGOING_SIGCHANGE 734
EVT_HOLD_LIGHT_FLASHING 678 EVT_PBX_DCH 739
EVT_IDLE 678 EVT_PHN_DCH 739
EVT_INCOMING_SIGCHANGE 678 EVT_PREVIOUS_BUTTON_PRESSED 739
EVT_INDEX_PLAYED 679 EVT_RECALL_BUTTON_PRESSED 744
EVT_INTERDIGIT 681 EVT_REDIAL_BUTTON_PRESSED 744
EVT_LIGHT_FASTFLASHING 682 EVT_REDIAL_BUTTON_RELEASED 744
EVT_LIGHT_FLASHING 682 EVT_REJECTED 745
EVT_LINE_BUTTON_PRESSED 682 EVT_RELEASE_BUTTON_PRESSED 745
EVT_LINE_LIGHT_FASTFLASHING 683 EVT_RELEASE_BUTTON_RELEASED 745
EVT_LOCRCMF_ALARM 684 EVT_RELEASE_LIGHT_FASTFLASHING 746
EVT_LOF_ALARM 684 EVT_RELEASE_LIGHT_FLASHING 746
EVT_LOGON_BUTTON_PRESSED 685 EVT_RELEASED 746
EVT_LOOP_DROP 685 EVT_REORDER 747
EVT_LOOP_ON 685 EVT_RESUMED 748
EVT_LOOP_REVERSE 686 EVT_REVERSAL 748
EVT_LOOP_STOP 686 EVT_RING_LIGHT_FASTFLASHING 748
EVT_LOOPON_RECORD 687 EVT_RING_LIGHT_FLASHING 748
EVT_LOS_ALARM 688 EVT_RING_OFF 749
EVT_LOSMF_ALARM 689 EVT_RING_ON 749
EVT_LVOLTAGE_NOTOFFHOOK 691 EVT_RINGS 749
EVT_LVOLTAGE_OFFHOOK 690, 692 EVT_RX_HDLC_ACTIVE 752
EVT_LVOLTAGE_RECORD 692 EVT_SET_BUSY 756
EVT_MASTER_PLL_ALARM 693 EVT_SET_BUSY_CANCELED 756
EVT_MAX_ACTIVITY 693 EVT_SETPAR_DONE 756
EVT_MAX_SILENCE 694 EVT_SOFT_BUTTON_PRESSED 757
EVT_MAXBYTES 694 EVT_SOFT_LIGHT_FASTFLASHING 759
EVT_MAXDIGITS 695 EVT_SPEAKER_BUTTON_PRESSED 759
EVT_MAXTIME 695 EVT_SPEAKER_BUTTON_RELEASED 759
EVT_MENU_BUTTON_PRESSED 695, 696 EVT_SPEAKER_LIGHT_FASTFLASHING 760, 762
EVT_MENU_LIGHT_FASTFLASHING 696 EVT_STOP 762
EVT_MESSAGE_BUTTON_PRESSED 696 EVT_STREAMIN_DROPPED 764
EVT_MESSAGE_CHANGE 697 EVT_STREAMIN_START 764
EVT_MESSAGE_LIGHT_FASTFLASHING 698 EVT_STREAMIN_STOP 765
EVT_STREAMIN_WATERMARK 765 Microsoft IDE debug mode 10
EVT_STREAMOUT_COMP 766 Misc. Functions 81
EVT_STREAMOUT_EMPTY 766 MT_EVENT 61
EVT_STREAMOUT_PAUSED 766 MT_IO_CONTROL 52
EVT_STREAMOUT_RESUMED 767 MTAddSummationInput 535
EVT_STREAMOUT_START 767 MTAGCControl 305, 306
EVT_STREAMOUT_STOP 768 MTAGCStatus 307, 308
EVT_STREAMOUT_WATERMARK 768 MTAJListen 136
EVT_SUPERVISOR_LIGHT_FLASHING 770 MTAJTalk 134
EVT_SUSPENDED 770 MTArmCTAlarm 496
EVT_SYS_ERROR 771 MTArmFramerAlarm 102
EVT_TERMSILENCE 774 MTArmMasterAlarm 493
EVT_TERMVOLTAGE_NOTOFFHOOK 773 MTAVCControl 314
EVT_TONEP_DONE 775 MTAVCStatus 316
EVT_TONEPERR 775 MTBlinkBoard 154
EVT_TRANSFER_BUTTON_PRESSED 775 MTCallStringA 207
EVT_TRANSFER_BUTTON_RELEASED 776 MTCallStringAsync 207
EVT_TRANSFER_LIGHT_FASTFLASHING 777 MTCallStringEx 207
EVT_TRANSFER_LIGHT_FLASHING 778 MTCC_ConnectRequest 178
EVT_TS16RAI_ALARM 778 MTCC_ConnectResp 181
EVT_UP_DOWN 778 MTCC_DiscRequest 183
EVT_USER_INFO 779 MTCC_FacilityRequest 186
EVT_UTONE_OFF 779 MTCC_GetStatusByCh 194
EVT_UTONE_ON 779 MTCC_GetStatusByRef 196
EVT_UTONE_TON 779 MTCC_ResumeRequest 189
EVT_VOICE_RECORD 779 MTCC_SuspendRequest 187
EVT_VOX_OFF 779 MTCC_UserInfoRequest 188
EVT_WORK_BUTTON_PRESSED 780 MTClearBoardEventCallback 247
EVT_WRAPUP_BUTTON_PRESSED 780 MTClearDigits 227
EVT_WRAPUP_LIGHT_FLASHING 781 MTClearDTMFDigits 227
EVT_YELLOW_ALARM 782 MTClearEventCallback 256, 284, 285
F MTClearFramerStatistic 118, 119, 121, 122
Figure MTClearMFTones 228
AGC Results, 290 MTClearPriorityEventCallback 257
MTClearUsrTone 437, 438
AGC Static Transfer Characteristics, 288
MTClearUsrToneParams 437
Flow Control 36
MTCloseBoard 157
Function Completion 23
MTCloseChannel 245
Function Types 22
MTControlDigits 229
G MTControlToneQ 229, 230, 231
Gain/Volume Functions 287 MTDialString 211
General Termination Control 54 MTDialStringAsync 211
Global Channel Index (GCI) Functions 317 MTDialStringEx 211
H MTDisableACTD 402
HIGHPASS Filter Functions 320 MTDisableCallerID 214
L MTDisableFramerABCDSignalingEvent 125
Logical Card Model 15 MTDisableMixing 408
Loop Voltage Functions 516 MTDisableMixingDetect 411
M MTDisarmCTAlarm 497
MakeWaveGSMHeader 565 MTDisarmFramerAlarm 104
MakeWavePCMHeader 566 MTDisarmMasterAlarm 494
Media Access with Device IO Functions 323 MTEnableACTD 401, 403, 404
Media Format Naming 28 MTEnableCallerID 215
Media Formats 27 MTEnableFramerABCDSignalingEvent 123
MTEnableMixingDetect 410 MTGetGCIMap 319
MTEventControl 258 MTGetGenRegs 375
MTFlushCallerID 218 MTGetHookState 562
MTFlushEvents 259, 270 MTGetInputs 505
MTGetACTDParams 398, 400 MTGetLastErrorA 82, 84, 85
MTGetACTDRegs 398, 400 MTGetLastErrorW 83
MTGetAdapterDescription 569 MTGetLastTerm 472
MTGetAdapterInfo 144, 147, 159 MTGetLCDetectState 521
MTGetAdapterXInfo 148 MTGetLVDetectState 520
MTGetAGC 296, 297 MTGetMasterAlarmStatus 495
MTGetAJListen 140 MTGetMixingDetectStatus 412
MTGetAJMap 133 MTGetMixingStatus 409
MTGetAJTalk 139 MTGetMoni 479
MTGetAlertTone 461 MTGetMVIPAlarmStatus 498
MTGetAlertToneParams 461 MTGetNET 99
MTGetAVC 309 MTGetNGXFramerStatistic 114
MTGetBoardAssemblyInfo 152 MTGetOutput 509
MTGetBoardOEMInfo 150 MTGetOutputSource 244
MTGetBoardOpenStatus 158 MTGetPHYStatistics 202
MTGetCallerID 217 MTGetPSTN 367
MTGetCallerIDStatus 216 MTGetPSTNParams 367
MTGetCallStatus 219 MTGetPxdParams 415
MTGetCCStatistics 201 MTGetPxdRegs 415
MTGetChannelEvent 262 MTGetRingDetectState 522
MTGetChannelInfo 260 MTGetStatistics 271
MTGetChannelOpenStatus 246 MTGetStatus 266
MTGetChannelOwner 280 MTGetStreamingConfig 355
MTGetChannelStatus 266 MTGetSummationAVC 546
MTGetCpmMode 432 MTGetSummationGain 542
MTGetCPMSigSwitch 444 MTGetSummationInfo 530
MTGetCpmTone 424 MTGetSummationInputs 538
MTGetCpmToneParams 424 MTGetSummationOutput 540
MTGetCTAlarmStatus 498 MTGetSummationVolume 544
MTGetCTMasterClock 90 MTGetSysInfo 551
MTGetCTNetrefSource 94 MTGetSystemInfo 551
MTGetCTRoute 501 MTGetT1FramerStatistic 110
MTGetCTSlaveClockMode 96 MTGetTerm 476
MTGetCTSlotConnection 336 MTGetTimeSlotRxSignaling 127
MTGetDataLinkStatistics 199 MTGetTimeSlotTxSignaling 131
MTGetDataLinkStatus 198 MTGetToneDetectParams 382, 383
MTGetDetectRegs 382, 383 MTGetToneGenParams 375, 384, 386, 388, 389
MTGetDigits 221 MTGetUsrTone 435, 436
MTGetDigitsAsync 221 MTGetUsrToneMode 444
MTGetDigitsEx 221 MTGetUsrToneParams 435
MTGetDLLVersion 557, 558 MTGetVersion 555
MTGetE1FramerStatistic 112 MTGetVolume 311
MTGetEventFilters 253, 254 MTHighpassFilterControl 321
MTGetFramerABCDSignalingEventStatus 126 MTHighpassFilterStatus 322
MTGetFramerAlarmArmStatus 106 MTOffHook 560
MTGetFramerAlarmStatus 107 MTOnHook 561
MTGetFramerOutput 511 MTOpenBoard 156
MTGetFraming 116 MTOpenChannel 240
MTGetGain 301, 302 MTPlayBuffer 338
MTGetGCI 318 MTPlayBufferAsync 338
MTPlayBufferEx 338 MTSetCTRoute 499
MTPlayDevice 327 MTSetCTSlaveClockMode 95
MTPlayDeviceAsync 327 MTSetDetectRegs 376
MTPlayDeviceEx 327 MTSetDeviceIO 324
MTPlayFile 340 MTSetECControl 416, 417, 418, 419, 420, 422
MTPlayFileAsync 340 MTSetEventCallback 264
MTPlayFileEx 340 MTSetEventFilters 251
MTPlayIndex 344 MTSetEvents 251
MTPlayIndexAsync 344 MTSetFramerOutput 512
MTPlayIndexEx 344 MTSetGain 299
MTPlayTone 468 MTSetGenRegs 373
MTPlayToneAsync 468 MTSetInputs 503
MTPlayToneEx 468 MTSetMoni 477
MTPlayUsrTone 468 MTSetNET 100
MTPutBoardEvent 250, 281 MTSetNET1, MTSetNET2 97
MTPutChannelEvent 241 MTSetOutput 508
MTPutEvent 241 MTSetOutputSource 242
MTReadDigit 224 MTSetPriorityEventCallback 248
MTReadDTMFTone 225 MTSetPSTN 369
MTReadMFTone 226 MTSetPSTNParams 369
MTRecBuffer 347 MTSetPxdEcho 416
MTRecBufferAsync 347 MTSetPxdParams 413
MTRecBufferEx 347 MTSetRoute 499
MTRecDevice 329 MTSetStreamingConfig 354
MTRecDeviceAsync 329 MTSetSummationAVC 545
MTRecDeviceEx 329 MTSetSummationGain 541
MTRecFile 349 MTSetSummationVolume 543
MTRecFileAsync 349 MTSetTerm 473
MTRecFileEx 349 MTSetTimeSlotTxSignaling 129
MTRemoveSummationInput 537 MTSetToneDetectParams 376, 379
MTResetAJListen 142 MTSetToneGenParams 373
MTResetAJTalk 141 MTSetUsrTone 439, 441
MTResetBoardStatistics 275 MTSetUsrToneMode 443
MTResetCpmToneParams 429, 452, 455, 457 MTSetUsrToneParams 439
MTResetCTRoute 502 MTSetVolume 310
MTResetFramerOuput 515 MTStartAlertTone 465
MTResetInputs 507 MTStartLink 550
MTResetOutput 510 MTStartMUX 332
MTResetRoute 502 MTStartMUXOnChannel 570, 574, 575, 577, 578
MTResetStatistics 273 MTStartStreaming 356
MTResetSummation 532 MTStartSummation 533
MTReturnEventBuffer 567 MTStepGain 303, 304
MTSetACTDParams 393, 396 MTStepVolume 312
MTSetACTDRegs 393, 396 MTStopAlertTone 466
MTSetAGC 293, 294 MTStopBlinkBoard 155
MTSetAlertTone 463 MTStopChannel 235
MTSetAlertToneParams 463 MTStopCurrentFunction 237
MTSetCpmMode 431 MTStopLink 554
MTSetCPMSigSwitch 443 MTStopMUX 335
MTSetCpmTone 426, 449, 451 MTStopMUXOnChannel 334
MTSetCpmToneMode 431 MTStopStreaming 365
MTSetCpmToneParams 426 MTStopSummation 534
MTSetCTMasterClock 88 MTStreamBufIn 360
MTSetCTNetrefSource 92 MTStreamBufOut 358
MTStreamBufPause 362 W
MTStreamBufResume 363 Wave File Support 27
MTSummationAVCControl 547 Wave Header Utility 564
MTSummationAVCStatus 548 Windows Event Viewer 32
MTSysShutdown 554
MTSysStartup 550
MTWaitForAdapterEvent 276
MTWaitForChannelEvent 278, 286
MTWink 563
Mux/MVIP bus Routines 331
N
NEC Electra Elite Phone Map 695
NEC NEAX Phone Map 697
Nortel Meridian Phone Map 695
NV_Wrap.h 14
P
Play Data 60
Play Functions 337
Play/Record Data 60
Pointer Checking 24
Preliminary Information 9
R
Record Data 60
Record Functions 346
Resource Queues 22
Return Codes 24, 42
Ring Detection Status Functions 516
S
SDK Contents 10, 11
SDK Developer’s Notes 10
SDK Overview 10
SDK System Requirements 10
Siemens Phone Map 699, 700
Signal Termination Control 54
SmartControl Applet Load Status 11
SmartView Load Status 11
Stream Functions - Wave Streaming 352
Streaming - Stream Control 364
Structure Functions 366
Summation Functions 529
System Definitions 37
System Functions 549
System Overview 10
T
Terminate cards (T1 RBS, ISDN) 177, 185, 190
Termination Control 54
Termination/Monitor Functions 471
Tone Functions - Alert Tones 460
Tone Functions - CPM 423
Tone Functions - Play Tones 467
Trunk Specific APIs 559
U
UNICODE Support 25