Nothing Special   »   [go: up one dir, main page]

SmartWORKS Developers Guide

Download as pdf or txt
Download as pdf or txt
You are on page 1of 814

Cover

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

Chapter 2 · SmartWORKS Overview . . . . . . . . . . . . . . . . . . . . 9


9

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

Chapter 3 · API Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . 21


21

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

Chapter 4 · Writing An Application . . . . . . . . . . . . . . . . . . . 35


35

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

Chapter 5 · Function Reference Library . . . . . . . . . . . . . . . . 67


67

API’s Presented Alphabetically with Product Support . . . . . . . . . . . . . . . . . . . . . . . 68


APIs Presented Logically . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 80
Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 80
Misc. Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 81
Introduction - Setting a Board’s Clock Source . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 86
Audio Jack Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 132
Board Information Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 143
Call Connection Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 160
Call Processing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 161
SmartWORKS RBS Signaling Protocols . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 171
Terminate cards (T1 RBS, ISDN) functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 177
Terminate cards (ISDN) Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 185
Passive cards (ISDN) Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 190
Introduction: Channel Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 204
Control Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 234
Event Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 239
Gain/Volume Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 287
Introduction: Automatic Gain Control . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 288
Global Channel Index (GCI) Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 317
HIGHPASS Filter Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 320
Mux/MVIP bus Routines . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 331
Play Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 337
Record Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 346
Stream Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 352
Structure Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 366
Introduction: Activity Detect (ACTD) Control . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 390
Cpm Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 423
Tone Functions - Alert Tones . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 460
Tone Functions - Play Tones . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 467
Termination/Monitor Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 471
Configuration Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 480
CT Bus Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 492
Loop Voltage / Loop Current / Ring Detection Status Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 516
Summation Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 529
System Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 549
Trunk Specific APIs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 559
Table of Contents SmartWORKS Developer’s Guide · III

Wave Header Utility . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 564


Firmware Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 571
Introduction: Using Firmware APIs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 572
SmartWORKS PCM Specific APIs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 579

Chapter 6 · Event Code Library . . . . . . . . . . . . . . . . . . . . . 591


591

Appendix A · Event Sequences . . . . . . . . . . . . . . . . . . . . . . 685


685

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.

About This Documentation


This document applies to the following Ai-Logix products:

Product Name Part Number Status

SmartWORKS VR3200 910-0303-001 Retired

SmartWORKS VR3209 910-0303-002 Released

SmartWORKS VR6400 910-0301-001 Retired

SmartWORKS VR6409 910-0321-001 Released

SmartWORKS AT409 910-0328-001 Released

SmartWORKS AT809 910-0318-001 Released

SmartWORKS AT1600 910-0309-001 Retired

SmartWORKS AT1609 910-0309-002 Released

SmartWORKS DP3200 910-0308-001 Retired

SmartWORKS DP3209 910-0308-002 Released

SmartWORKS DP6400 910-0304-001 Retired

SmartWORKS DP6409 910-0324-001 Released

SmartWORKS NGX800 910-0314-001 Released

SmartWORKS NGX1600 910-0314-002 Released

SmartWORKS NGX2400 910-0314-003 Released

SmartWORKS MX80 910-0315-001 Released


(Expansion)
Welcome
• 3
Release Update History

Product Name Part Number Status

SmartWORKS PT409 910-0307-002 Released

SmartWORKS PT800 910-0305-001 Retired

SmartWORKS PT809 910-0320-001 Released

SmartWORKS PT1600 910-0306-001 Retired

SmartWORKS PT1609 910-0319-001 Released

SmartWORKS LD 101 910-0805-001 Released

SmartWORKS LD 409 910-0801-001 Released

SmartWORKS LD 409H 910-0807-001 Released

SmartWORKS LD 809 910-0802-001 Released

SmartWORKS LD 809X 910-0808-001 Beta

SmartWORKS LD 1609 910-0803-001 Released

SmartWORKS LD 2409 910-0804-001 Released

SmartWORKS DT3200 910-0312-001 Retired

SmartWORKS DT3209 910-0325-001 Released

SmartWORKS DT6400 910-0313-001 Retired

SmartWORKS DT6409 910-0323-001 Released

SmartWORKS DT6409TE 910-0323-002 Released

SmartWORKS DT3209TE 910-0325-002 Released

SmartWORKS PCM 3209 910-0330-001 Beta

SmartWORKS PCM 6409 910-0329-001 Beta

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.

Release Update History


SMARTWORKS 3.5
Added support for SmartWORKS PCM and LD809X boards. Beta support for new
PBXs: Panasonic (Vox and Dchannel), EADS 4-wire support, and a new line card is
supported with the Ericsson MD110.
Ai-Logix, Inc.
4 •
SmartWORKS Developer’s Guide

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

Document Version Control


The following has been added to this document since the last release:

TABLE 1: VERSON CONTROL

Page Description
10 Section added in the Developer’s Notes: Preventing Errors
on Shutdown.

485 MTADAPTER_CONFIG.TDMEncoding was inproperly


documented. Correct values are 1 for u-law, 2 for A-law.

143 MTADAPTER_INFO.TDMSignalling updated to show u-law


is defined as 1, and A-law defined as 2.

101 Corrected documentation regarding return values when


using MTArmFramerAlarm(). When using the NGX, the
return value MT_RET_CHANNEL_NOT_OPENED is
possbile.

Event Dictionary Removed EVT_SIGNAL_CLIPPING from documentation.

608 Added definition of MT_CC_CALL_INFO structure to


documentation where EVT_CALL_ALERTING is discussed.

56 EVT_DIGITENABLE now is reported with the termination


of all background functions when a digit is set as a
terminating condition

645 EVT_DIGITENABLE now is reported with the termination


of all background functions when a digit is set as a
terminating condition

27 Updated media format naming table to clarify the use of


G726 MSB first format.

15 The Board Numbering description has been improved.


Ai-Logix, Inc.
6 •
SmartWORKS Developer’s Guide

TABLE 1: VERSON CONTROL

Page Description
26 A note was added explaining the SmartWORKS .wav
header support when using MTPlayFile().

52 MaxTime and MaxBytes fields of the MT_IO_CONTROL


structure is not supported when streaming.

143 Corrected definition of the TDMSignalling parameter in


the MTADAPTER_INFO structure.

372 Added explanation for calculating the low_ampl and


high_ampl parameters in the MT_GENREGS structure.

482,484 MtSetAdapterConfig() - corrected definition for Config


parameter, MTGetAdapterInfo() - modified the
MTADAPTER_INFO structure (removed NumFramers
parameter, and corrected the type for
FWVersionExpected, and FWVersion parameters.

57 Updated the START_LOOPON,


START_LVOLTAGE_MIDDLE,
START_LVOLTAGE_OFFHOOK fields on the
MT_IO_CONTROL structure.

Chapter 6 Added new D-channel events.

575-586 New APIs added for SmartWORKS PCM boards.

Entire Document Changed product names to reflect new branding.

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.

To request an online help account please contact technical support at


support@ai-logix.com.

SALES AND GENERAL INFORMATION


For sales and general information, use the following contact methods:
Welcome
• 7
Contacting Ai-Logix

• Call us at 732.469.0880 or toll free from the USA at 800.648.3647.


• Fax us at 732.469.2298.
• E-mail us at sales@ai-logix.com.
• Visit our web site at www.ai-logix.com.

HEADQUARTERS MAILING ADDRESS—USA


Ship packages or send certified mail to us at the following address:
Ai-Logix, Inc.
27 World’s Fair Drive
Somerset, NJ 08873
Ai-Logix, Inc.
8 •
SmartWORKS Developer’s Guide
Chapter 2
SmartWORKS Overview
Ai-Logix, Inc.
10 •
SmartWORKS Developer’s Guide

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).

MICROSOFT IDE DEBUG MODE


The following applies to the SmartWORKS SDK version 2.0.0 and older:
The Microsoft IDE does not detach applications from associated dynamic linked
libraries when Stop Debugging (Shift+F5) is requested. The termination of the
SmartWORKS DLL leaves the interface between the DLL and driver in unclosed
states. If the encode or decode interface is active at such a time, Windows crashes
because the hardware interrupt is not serviced. This only happens in Microsoft IDE
debug mode.

PREVENTING ERRORS DURING SHUTDOWN


When using SmartWorks version 3.2.3 or greater inside of a Windows service, the
following steps must be followed to prevent a system hang on shut down.
1. Upon initialization, the SERVICE_ACCEPT_SHUTDOWN flag must be specified in
order to tell the operating system to send the SERVICE_CONTROL_SHUTDOWN
notification. This is done during initialization of the service by setting the
SERVICE_ACCEPT_SHUTDOWN bit of the SERVICE_STATUS.dwControlsAccepted
field. This would be done in the CServiceModule::Init function of a Visual Studio
6.0 AppWizard based application:
m_status.dwControlsAccepted = SERVICE_ACCEPT_STOP | SERVICE_ACCEPT_SHUTDOWN;

2. The SERVICE_CONTROL_SHUTDOWN notification should be handled by setting


a SERVICE_STOP_PENDING status. This is to allow time for the SmartWorks DLL
to be properly shutdown. The default time of 20 seconds allocated to a service
to shutdown by the OS should be enough time for an MTSysShutdown() call to
complete. However, this time interval can be increased using the
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\WaitToKillService-
SmartWORKS Overview
• 11
SDK Overview

Timeout registry setting, or using the SERVICE_STATUS.dwWaitHint field when


setting the SERVICE_STOP_PENDING status.
3. Perform any and all cleaning up of the SmartWORKS DLL (MTSysShutdown()),
immediately after the CServiceModule::Run() function call in the ServiceMain
routine.

ENSURING THE SDK IS OPERATIONAL


CHECKING THE DRIVER STATUS
When the SmartWORKS driver is invoked, it searches for SmartWORKS cards. When
the card is successfully initialized, the CR17 LED is turned off and LEDs CR1 to CR16
are illuminated. (The CR number varies with each product. Refer to the User Guide
for the exact LED number). With a SmartWORKS DP card, the two trunk status LEDs
illuminate immediately after a successful board initialization.
When a SmartWORKS board fails initialization, the CR17 LED blinks, but the
SmartWORKS driver is loaded nonetheless. An Error message about the failure is
listed in the Windows Event Viewer under the Source name NtiDrv. These messages
will help Ai-Logix technical support to locate the problem.
As each board is unique, the use of LEDs varies per SmartWORKS product. See the
User Guide guide for LED locations on all SmartWORKS products.

RUNNING THE SMARTVIEW DEMO APPLICATION


Running the SmartView demo program can help determine if the SmartWORKS
Driver/DLL has been properly loaded. To do this view the total number of channels
displayed in the SmartView application. If no channels appear, it is likely that the
SmartWORKS card is either not present, not supported, not initialized, or the driver
is not loaded.

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.

TROUBLESHOOTING DURING INSTALLATION


Complete trouble shooting information is provided on a per product basis in the
SmartWORKS User’s Guide.

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

Board Name Release Number


For information on upgrading firmware, see the SmartWORKS User’s Guide.

FOLDERS AND FILES


The following files, organized by folder, are copied onto the PC when SmartWORKS
is installed.
SmartWORKS Overview
• 13
SDK Overview

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.

ENSURING USER APPLICATION COMPATIBILITY WITH THE SDK


The SmartWORKS API provides the capability of checking the version of the SDK
that the user application is compiled with and comparing it to the version of the Ai-
Logix SDK that is currently running. These values are returned via a SmartWORKS
API. This can be accomplished at run time to protect the user application from
running on an older version of the SmartWORKS SDK.
In SDK header files, there is version information defined in file "SysLimits.h" as
VER_MAJOR, VER_MINOR, and VER_INTERNAL. The user application should be
written to hold these values.
Then, at run time, the application can call for the SDK values on the SmartWORKS
boards. (Use API MTSysGetVersion()). If the returned values do not match the
values stored in the application the end user can be alerted of incompatible
software.
SmartWORKS Overview
• 15
Architecture Overview

PLUG AND PLAY (PNP) CAPABILITIES


When the application is running, a newly initialized board can be recognized. When
this occurs, a system event is generated (EVT_SYS_BOARD_ADDED).
To use this feature, the user application must be collecting system events. Enable
this with the APIs MTSysWaitforEvent() or MTSysSetEventCallback(). Once the
event is generated it is recommended that the user application invoke the
MTGetSystemInfo() API to obtain board statistics. If multiple applications are
running, all applications should invoke this API to obtain statistics and fully
recognized the board.

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.

THE SMARTWORKS LOGICAL CARD MODEL


The figure below is a representative diagram of the SmartWORKS DSP channel
architecture. This is a logical representation of the voice resource channel found on
all SmartWORKS products. The diagram shows major functional blocks and how
they are interconnected.
Ai-Logix, Inc.
16 •
SmartWORKS Developer’s Guide

The following is a summary of the elements of the SmartWORKS Logical Channel


Model. Please refer to the SmartWORKS User’s Guide for a detailed explanation of
these elements.

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).

DTMF, MF, ACTIVITY DETECTION


Each logical channel has two sets of DTMF, MF and activity detectors, one for each
of the two voice data inputs. The primary input has an additional Caller ID detector
and Call Progress Monitor (CPM). The CPM has pre-programmed profiles for typical
call progress tones used in North America.

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.

Board and Channel Numbering


PHYSICAL BOARD NUMBERING
When the SmartWORKS driver loads, it scans all PCI slots of the system to locate
Ai-Logix boards. As the boards are located, the driver assigns Physical Board
Numbers to each. These board numbers are assigned sequentially from zero and
are linked to the address (or slot number) of the physical PCI slot the card is located
in.
An Ai-Logix SmartWORKS board with the lowest address becomes Physical Board 0.
The board located in the PCI slot with the next higher address will become Physical
Board 1. This process is repeated until all PCI slots are scanned.
This PCI slot may or may not be the absolute lowest numbered PCI slot in the
system; it is simply the lowest in relation to the other PCI slots with boards inserted
into them. The PCI address or slot number is generally noted on the system
motherboard or passive back plane.

ADDING A NEW BOARD TO THE SYSTEM


When a new SmartWORKS board is added to an existing system, board numbering
MAY be impacted. This depends on the actual physical location of the new board
and the PC’s BIOS. Users are encouraged to monitor board and channel numbering
each time a system is restarted.

CONTROLLING BOARD NUMBERING


An API is available where users may control board numbering. Invoke
MTSetAdapterConfig() to control board presentation in the PresentationPreference
field.

BOARD AND CHANNEL NUMBERING


The SmartWORKS API supports up to 32 physical boards and/or up to 512 full
duplex channels within a system. The API functions refer to a specific board and or
channel within the system using one of two numbering schemes: physical board
numbers, and Global Channel Index (logical channel numbers). All board numbers
Ai-Logix, Inc.
18 •
SmartWORKS Developer’s Guide

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.

GLOBAL CHANNEL INDEX


During initialization, as the Physical Boards are numbered, the driver will build a list
of the logical channels available in the system called the Global Channel Index (GCI).
This list is the primary interface the API will use to refer to the channel resources in
the system.
The Global Channel Index (GCI) is numbered sequentially from 0 or 1 (depending on
how the user has configured this setting in the Smart Control panel) and is in
ascending order of the Physical Board numbers. The maximum GCI is currently
limited to 512.
Certain API functions will allow the developer to reference all channels
simultaneously by using the nChannel = -1 (if GCI index = 0) or nChannel = 0 (if the
GCI index = 1).
For Example:
Function MTSetEventCallback() takes channel number -1 or 0, and registers the
callback function for all available channels.
The API has a several commands that can be used to determine the relationship
between the GCI and the physical channels on each board. The MTGetGCI() and
MTGetGCIMap() command will match a GCI indexed channel to its physical
board channel location.
For Example:
If MTGetGCIMap(08, pBOARD, pBOARDTYPE, pGCI) returns with *pBOARD=0,
and
*pGCI=0, this indicates GCI channel 08 resides on board 0 as its first channel.
However, MTGetGCI(0,0,pGCI) should return with *pGCI=08.

DEFINITION OF NI, DR, AND CHANNEL


An NI can be either a digital network interface from T1/E1, or an analog network
interface from an analog interface card. A DR is the DSP resource on a SmartWORKS
card; SmartWORKS VR cards have either 32 or 64 DRs depending on the VR model. A
Channel is a DR paired with an NI, or a DR only, i.e. a SmartWORKS VR6400 has 64
channels.
CHANNEL MAPPING
In SmartWORKS, a channel is a DR, preferably mapped with an NI if one exists.
Hence, a channel is indexed through its DR indexing. A channel mapping can also
be termed as adding NI to a channel, i.e. DR.
SmartWORKS Overview
• 19
Board and Channel Numbering

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

Though SmartWORKS supports dynamic channel mapping, the flexibility of


mapping between NI and DR should include the following rules:
1)For NI from E1 with R2 signaling, the DR has to be on the same SmartWORKS card;
2)For NI from T1 with robbed-bit signaling, the DR has to be on the same
SmartWORKS card;
3)For NI from ISDN network, the DR can be on any SmartWORKS card controlled by
the same DLL/Driver;
4)For NI from an analog network (e.g. analog interface card without any DSP
resources), the DR can only be assigned from a SmartWORKS VR card by the user of
the SmartWORKS API.
When a DR is not mapped with an NI, one non-MVIP expansion bus global time slot
is still allocated for this DR. This is shown below.
TimeSlot x1
Channel # C1 NI #N1 TimeSlot y1 DR #D1

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

MVIP TIMESLOT ALLOCATION


Although the SmartWORKS DLL/Driver may not have the knowledge of the system
view of the MVIP time slot assignment, an effort is added to check that
SmartWORKS does not connect two transmits to one MVIP time slot.
SmartWORKS offers functions where the application user can directly assign the
MVIP time slot to DR or NI. SmartWORKS VR also offers functions to connect
channels without the application user being concerned with MVIP time slot.
SmartWORKS allocates its assigned MVIP time slots during the following situations:
1)Connecting channels across different SmartWORKS boards.
2)Connecting channels on the same SmartWORKS board if one of the channels has
MVIP time slot assigned and one of the channels does not.
DEFAULT MAPPING
SmartWORKS can be a resource or network card.
The SmartWORKS VR supports no NI interface and a channel contains DR only. With
SmartWORKS DP card, each channel is made of pairing NI to DR to the minimum of
these two. The number of NIs can be found through MTGetAdapterInfo() function.
Each NI can be indexed through a combination of board identification and NI
number. DRs are indexed through channel indexing.
Chapter 3
API Overview
Ai-Logix, Inc.
22 •
SmartWORKS Developer’s Guide

API/DLL Structure
This section provides a high level view of the SmartWORKS API.

SMARTWORKS FUNCTION TYPES


IMMEDIATE AND BACKGROUND FUNCTIONS
SmartWORKS API functions are broken into two categories: Immediate and
Background.

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.

NOTE - For a complete listing of SmartWORKS return codes, see “Return


Codes” on page 42

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.

PRESERVE DATA BUFFER


For some functions like MTRecBuffer() or MTGetDigits(), the application needs to
pass the buffer pointer to the API and wait for the API to fill in the data buffer.
Because of this, the user application must preserve the data buffer until the
termination event is received. However, the user application does not need to
preserve the MT_IO_CONTROL structure until the termination event is received.
Once the API returns, the DLL maintains a copy of the MT_IO_CONTROL structure
for the API being called.

FUNCTION COMPLETION NOTIFICATION


Function completion notification events are broken into two categories. Overlapped
events and asynchronous callback.

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

Take the play buffer function as an example. MTPlayBuffer() uses no notification


mechanism. The user application retrieves events from the event queue until it
encounters a playback specific event, which indicates completion of the
MTPlayBuffer() function.
API function MTPlayBufferEx() uses the overlapped mechanism. In this case the
user application provides an NT system event. DLL uses the signal when the
MTPlayBufferEx() function has completed. The user application should wait for the
signaling of the event and clear the event before it can be used again.

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.

NULL POINTER CHECKING


NULL pointers are not allowed in the SmartWORKS API. An error code of invalid
parameter (MT_RET_INVALID_PARAM) will be returned without executing the
requested API function.
For Example:
Entering a value of 0 for a pointer will be taken as a NULL pointer. No default
value will be assumed and the actual value you enter will be checked.
Though previous Ai-Logix products did allow NULL Pointers, the
SmartWORKS SDK does not.

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.

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 );

MT_RESULT MTCallStringW(const CHANNEL nChannel,


PCWSTR pCall_string,
const PMT_IO_CONTROL pIoCtl);
The following table shows how SmartWORKS maps the APIs depending on whether
UNICODE has been defined for the user application. If UNICODE is defined,
SmartWORKS will call the API with a ‘W’ suffix. If UNICODE is not defined,
SmartWORKS will call the API with an ‘A’ suffix.

TABLE 2: UNICODE/NON-UNICODE FUNCTION TABLE


Function UNICODE not defined UNICODE defined

MTCallString() MTCallStringA() MTCallStringW()


MTCallStringAsync () MTCallStringAsyncA() MTCallStringAsyncW()
MTCallStringEx() MTCallStringExA() MTCallStringExW()
MTDialString() MTDialStringA() MTDialStringW()
MTDialStringAsync() MTDialStringAsyncA() MTDialStringAsyncW()
Ai-Logix, Inc.
26 •
SmartWORKS Developer’s Guide

TABLE 2: UNICODE/NON-UNICODE FUNCTION TABLE


Function UNICODE not defined UNICODE defined

MTDialStringEx() MTDialStringExA() MTDialStringExW()


MTGetLastError() MTGetLastErrorA() MTGetLastErrorW()
MTRecFile() MTRecFileA() MTRecFileW()
MTRecFileEx() MTRecFileExA() MTRecFileExW()
MTRecFileAsync() MTRecFileAsyncA() MTRecFileAsyncW()
MTPlayFile() MTPlayFileA() MTPlayFileW()
MTPlayFileEx() MTPlayFileExA() MTPlayFileExW()
MTPlayFileAsync() MTPlayFileAsyncA() MTPlayFileAsyncW()
MTPlayIndex() MTPlayIndexA() MTPlayIndexW()
MTPlayIndexEx() MTPlayIndexExA() MTPlayIndexExW()
MTPlayIndexAsync() MTPlayIndexAsyncA MTPlayIndexAsyncW
API Overview
• 27
Media Formats

Media Formats
SmartWORKS supports the following media formats:

SmartWORKS Compatible CODECs


µ-law 8-bit PCM 64 k bps
A-law 8-bit PCM 64 k bps
µ-law PCM+ (recording only)
A-law PCM+ (recording only)
Linear signed 8-bit PCM 64 k bps *
Linear unsigned 8-bit PCM 64 k bps
Linear signed 16-bit PCM 128 k bps *
Linear unsigned16-bit PCM 128 k bps
Linear signed, 6 Khz, 16-bit PCM, 96 k bps
GSM 6.10 13 k bps
Microsoft GSM 13 k bps *
Dialogic (Oki) ADPCM 24 k bps
Dialogic (Oki) ADPCM 32 k bps
G.723.1 5.3 kbps
G.723.1 6.3 kbps**
G.729A 8 kbps
G.726 ADPCM
G.726 ADPCM 16, 24, 32, 40 kbps MSB

*Supports WAV headers


**Not supported on the NGX
+ Stereo Recording - Users must disable mixing on channel inputs

WAVE FILE SUPPORT


The SmartWORKS API supports Microsoft wave headers. Setting the appropriate
flag in the MT_IO_CONTROL.StartControl data structure controls the inclusion of a
header or data chunk descriptor in the media file.
WAVE_RIFFFMTDATA_CHUNK
add wave header of RIFF chunk, Fmt chunk, and
Data chunk
WAVE_DATACHUNK_ONLY
add data chunk descriptor only
For example, when format MT_MSGSM (Microsoft GSM) is selected without either of
the above flags, no wave chunk descriptor will be added in front of the first 65-byte
GSM packet.
If flag WAVE_RIFFFMTDATA_CHUNK is set, a GSM wave header will be added before
the first GSM voice packet.
Ai-Logix, Inc.
28 •
SmartWORKS Developer’s Guide

If flag WAVE_DATACHUNK_ONLY is set, then an 8-byte long Data chunk descriptor


will be added before the first GSM packet. Flag WAVE_RIFFFMTDATA_CHUNK
implies flag WAVE_DATACHUNK_ONLY.
SmartWORKS currently supports WAVE 16-bit LINEAR and WAVE Microsoft GSM.
In functions for streaming and device IO, wave headers are not supported.
MT_RET_INVALID_PARAM will be returned if either WAVE_RIFFFMTDATA_CHUNK
or WAVE_DATACHUNK_ONLY are specified when invoking streaming or device IO
functions. Use MakeWaveGSMHeader() and MakeWavePCMHeader() to insert
headers when desired.

WAVE FILE PLAYBACK


The MTPlayFile() function can playback files with a .wav header that were recorded
with the SmartWORKS SDK. Ai-Logix does not guarantee that files with .wav
headers generated by other recorders will be processed correctly by the
SmartWORKS SDK. Files packaged by another system may contain data in the
header that our SDK does not support. For example, the SmartWORKS SDK cannot
play files that contain information in the FACT section of the header. Also, files that
contain data chunk elements throughout the file do not playback correctly. Only
the first header (or data chunk) is processed. From here the SmartWORKS SDK plays
the file until end of file is reached.

MEDIA FORMAT NAMING


The supported voice media formats are defined with an MT_ prefix and can be
found in NtiData.h.

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

Board Type Naming


Ai-Logix SmartWORKS boards are defined in NtiData.h as follows:

TABLE 3: BOARD TYPE NAMING


Board Name Actual Product Name Description
VR6400 SmartWORKS VR6400 64 channel voice resource card, SmartDSP VR
VR3200 SmartWORKS VR3200 32 channel voice resource card, SmartDSP VR
VR3209 SmartWORKS VR3209 32 channel G729A-compatible voice resource
card, SmartDSP VR
VR6409 SmartWORKS VR6409 64 channel G729A-compatible voice resource
card, SmartDSP VR
DT3200_T1_CARD SmartWORKS DT3200 24 channel T1 terminate card
DT3200_E1_CARD SmartWORKS DT3200 30 channel E1 terminate card
DT6400_T1_CARD SmartWORKS DT6400 48 channel T1 terminate card
DT6400_E1_CARD SmartWORKS DT6400 60 channel E1 terminate card
DT3209_T1_CARD SmartWORKS DT3209 24 channel T1 terminate card
G729A-compatible
DT3209_E1_CARD SmartWORKS DT3209 30 channel E1 terminate card
G729A-compatible
DT6409_T1_CARD SmartWORKS DT6409 48 channel T1 terminate card
G729A-compatible
DT6409_E1_CARD SmartWORKS DT6409 60 channel E1 terminate card
G729A-compatible
DT3209TE_T1_CARD SmartWORKS DT3209 24 channel T1 terminate card
G729A-compatible
DT3209TE_E1_CARD SmartWORKS DT3209 30 channel E1 terminate card
G729A-compatible
DT6409TE_T1_CARD SmartWORKS DT6409 48 channel T1 terminate card
G729A-compatible
DT6409TE_E1_CARD SmartWORKS DT6409 60 channel E1 terminate card
G729A-compatible
ANALOG_T1600 SmartWORKS AT1600 16 channel analog terminate card
ANALOG_T409 SmartWORKS AT409 4 channel analog terminate card
G729A-compatible
ANALOG_T809 SmartWORKS AT809 8 channel analog terminate card
G729A-compatible
ANALOG_T1609 SmartWORKS AT1609 16 channel analog terminate card
G729A-compatible
DP3200_T1_CARD SmartWORKS DP3200 24 channel T1 high impedance call logging
card
DP3200_E1_CARD SmartWORKS DP3200 30 channel E1 high impedance call logging
card
DP6400_T1_CARD SmartWORKS DP6400 48 channel T1 high impedance call logging
card
DP6400_E1_CARD SmartWORKS DP6400 60 channel E1 high impedance call logging
card
API Overview
• 31
Board Type Naming

TABLE 3: BOARD TYPE NAMING


Board Name Actual Product Name Description
DP3209_T1_CARD SmartWORKS DP3209 24 channel T1 high impedance call logging
card, G729A-compatible
DP3209_E1_CARD SmartWORKS DP3209 30 channel E1 high impedance call logging
card, G729A-compatible
DP6409_T1_CARD SmartWORKS DP6409 48 channel T1 high impedance call logging
card, G729A-compatible
DP6409_E1_CARD SmartWORKS DP6409 60 channel E1 high impedance call logging
card, G729A-compatible
ANALOG_PT409 SmartWORKS PT409 4 channel G729A-compatible analog passive
card
ANALOG_PT800 SmartWORKS PT800 8 channel analog passive card
ANALOG_PT809 SmartWORKS PT809 8 channel G729A-compatible analog passive
card
ANALOG_PT1600 SmartWORKS PT1600 16 channel analog passive card
ANALOG_PT1609 SmartWORKS PT1609 16 channel G729A-compatible analog
passive card
NGX_CARD SmartWORKS NGX 8 channel modular digital station tap base
card
MX80 8 channel expansion for SmartWORKS NGX
ANALOG_LD101 SmartWORKS LD 101 2 channel high/low impedance analog call
logging card (one trunk channel, one station
channel)
ANALOG_LD409 SmartWORKS LD 409 4 channel high/low impedance analog call
logging card
ANALOG_LD409H SmartWORKS LD 409h 4 channel high/low impedance analog call
logging card with H.100 bus
ANALOG_LD809 SmartWORKS LD 809 8 channel high/low impedance analog call
logging card with H.100 bus
ANALOG_LD809X SmartWORKS LD 809X 8 channel high/low impedance analog call
logging card with H.100 bus
ANALOG_LD1609 SmartWORKS LD 1609 16 channel high/low impedance analog call
logging card with H.100 bus
ANALOG_LD2409 SmartWORKS LD 24 channel high/low impedance analog call
logging card with H.100 bus
PCM6409_32T_CARD SmartWORKS PCM 6409 dual T1/E1 terminate card with PCM option
PCM3209_32T_CARD SmartWORKS PCM 3209 single T1/E1 terminate card with PCM option
Ai-Logix, Inc.
32 •
SmartWORKS Developer’s Guide

Windows Event Viewer


Following is a list of events that may appear in the Windows Event Viewer. Each
listing has a description of the event next to it. This is not an exhaustive list of
Windows events, only a list of SmartWORKS-specific events.
In the first table is a list of events stemming from the NtiDrv.sys, the SmartWORKS
Driver. Driver issues can be Hardware, Firmware, or Firmware/Driver incompatibility
issues.

TABLE 4: WINDOWS EVENT MESSAGES FROM NTIDRV.SYS

Event Message Description


Error locating SmartWORKS hardware At least one SmartWORKS board needs to be
present (hardware problem: no recognizable
board)
Hardware initialization timed out for brd # Board # initialization timed out (Firmware
problem: firmware unable to finish initialization)
Unsupported hardware detected for brd # Board # format ID error (hardware problem:
setup error)
Incompatible (V#.#.# and up required) FW on brd # Old firmware on board # (Firmware-driver
incompatibility problem: need to update
firmware to specified version)
Board PANIC code at 0x10 for brd # Board # firmware runs into problem (code at
0x10), contact Ai-Logix (firmware problem)
SmartWORKS driver loaded nevertheless Driver loaded in spite of the error, LED CR17
flashing (probable follow up message to errors
2-5)
SmartWORKS driver loaded Driver loaded successfully (if no errors-normal)
SmartWORKS driver unloaded Driver unloaded (if no errors-normal)
API Overview
• 33
Windows Event Viewer

The next list of event messages stem from the NtiDrv.dll, the SmartWORKS API. API
issues can be API, Application, Firmware, or Hardware issues.

TABLE 5: WINDOWS EVENT MESSAGES FROM NTIDRV.DLL

Event Message Description


MVIP not specified MVIP not selected in SmartControl
Clear MUX Timed out Start MUX timed out [API function time-
out MTStartMUX()]
Clear MUX on channel # Timed out Start MUX on channel # timed out [API
function time-out
MTStartMUXOnChannel(#)]
Init MUX Timed out Stop MUX timed out [API function time-
out MTStopMUX()]
Init MUX on channel # Timed out Stop MUX on channel # timed out [API
function MTStopMUXOnChannel(#) has
timed out]
Event Callback for Ch # dropped due to queue full Event callback on channel # dropped
(System problem: Event Callback queue
full-contact Ai-Logix)
Completion Callback for Ch # dropped due to queue full Completion callback on channel #
dropped (System problem: Completion
Callback queue full-contact Ai-Logix)
Ch # timed out StreamBufIn Streaming in error on channel #
(API error: contact Ai-Logix)
Ch # timed out StreamBufOut Streaming out error on channel #
(API error: contact Ai-Logix)
Brd # event 0x1234 dropped due to queue full Board # event 0x1234 dropped
(Application error: must clear event
queue)
Ch # event 0x5678 dropped due to queue full Channel # event 0x5678 dropped
(Application error: must clear event
queue)
DLL attached error status 0xabcd SmartWORKS API load failed with code
0xabcd
DLL detached successfully SmartWORKS API unloaded successfully
(Normal)
DLL detached error status 0xabcd SmartWORKS API unload failed with code
0xabcd
NTI DLL attached with maximum log count set to 100 SmartWORKS API loaded successfully
(Normal)

With the occurrence of any other error, call Ai-Logix.


Ai-Logix, Inc.
34 •
SmartWORKS Developer’s Guide
Chapter 4
Writing An Application
Ai-Logix, Inc.
36 •
SmartWORKS Developer’s Guide

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.

Applications usually start with Next, the MT_IO_CONTROL


MTGetSysInfo() to refresh Structure should be configured to
information about system manage the recording criteria (by
resources. Activity Detection, by Caller ID,
etc.), recording medium, etc.
(Note that once
channels are open
Next, resources are reserved by and the MUX has When the previous steps are
the application using been started on complete, the system is ready for
MTSysStartup(), MTOpenBoard(), them, new channels activity. The application should
or MTOpenChannel(). opened are not call a Media API (e.g.
recognized by the MTRecFile()) to record data
MUX. Stopping and based on the criteria in the
starting the MUX MT_IO_CONTROL structure.
again will reset all
channels. To avoid
this and append
channels to the
application, use
MTOpenChannel() to Does the
open a new channel, MT_IO_CONTROL
and structure provide
MTStartMUXOnCha NO
instruction for when to
nnel() to activate the Stop Recording?
Callback should be established MUX on that channel
with MTSetCallback() at this point, without interrupting If NO,
so that the applciation can be previously opened MTStopChannel() or
notified with events as they occur. channels.) MTStopCurrentFunction()
can be called to stop
recording.

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()

At this point, various commands


can be used to release resources.
MTSysShutdown() will release all
system resources.
Writing An Application
• 37
Event Control

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:

TABLE 6: EVENT INFORMATION AND CONTROL


MTClearBoardEventCallback()
MTClearEventCallback()
MTClearPriorityEventCallback()
MTEventControl
MTFlushEvents()
MTGetChannelEvent()
MTGetEventFilters()
MTPutChannelEvent()
MTSetBoardEventCallback()
MTSetEventCallback()
MTSetEventFilters() (prev. MTSetEvents)
MTSetPriorityEventCallback()
MTSysSetEventCallback()
MTSysClearEventCallback()
MTSysWaitForEvent()
MTWaitForAdapterEvent()
MTWaitForChannelEvent() (prev. MTWaitFor-
Event)

FULL EVENT QUEUE


When events are dropped due to a full event queue, the message ch n event 0xAB
dropped due to full queue will be posted through the Windows Event viewer, where n
is the channel number and 0xAB is the event code.
Ai-Logix, Inc.
38 •
SmartWORKS Developer’s Guide

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>

int main(int argc, char *argv[])


{
int totalChannels;
MT_RESULT r;
int chan =1;//this assumes GCI index = 1
MT_EVENT event;
int Code, Reason;
char callerIDbuf[128];
MTSYS_INFO sysInfo;
r=MTSysStartup();
if(r!=MT_RET_OK)
{
printf(“MT system failed to start”);
return 0;
}
Writing An Application
• 39
Event Control

ULONG size = sizeof(sysInfo);


r=MTGetSystemInfo(&sysInfo,&size);
if(r==MT_RET_OK)
totalChannels=sysInfo.NumChans;
else
{
printf("MTGetSystemInfo failed...\n");
return 0;
}

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;
}

CALL BACK FUNCTION


The second and preferred method of reading the event queue is to use a call back
function. A call back function must be registered with the operating system by the
application and will be invoked when the specified event occurs. When a call back
function is invoked, events are passed as parameters back to the application. A call
back function does not require the application to poll for 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 DataLength field is used to identify the
size of the buffer. When event information is retrieved, the user application must
invoke MTReturnEventBuffer() to release the 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 0x02086600. In this scenario,
the field ptrXtraBuffer is set by the SmartWORKS DLL to identify the buffer holding
the extra information and the XtraBufferLength indicates the length of data in the
buffer.
Writing An Application
• 41
Event Control

The following is an example of a basic Call Back method:

// include files
#include<NTiAPI.h>
#include<NTiEvent.h>

// callback
CINTERFACE void APICallback(CHANNEL iCh,int EventCount,PMT_EVENT pMt,LPARAM
lParam)
{
int Code,Reason;

for(int i=0 ; i < EventCount; i++)


{
Code= pMt[i].EventCode;
Reason= pMt[i].SubReason;

switch(Code)
{
case EVT_DIGIT:
break;
case EVT_CC_DISC_CONF:
break;
...
...
}
}
}

// How to set callback for channels.


// register callback for channels
// gci is gci index which you set using control pannel and we assume that
it is set to 1.

MTSetEventCallback(0,(MTCALLBACK)APICallback,0);
Ai-Logix, Inc.
42 •
SmartWORKS Developer’s Guide

System Wide Definitions


RETURN CODES
All API functions return a code of type MT_RET_... for the status of the API
function's execution. It is vital that the user application checks the status of each call
to see if it was successful.
NOTE: All return codes are passed to the user application as a hex value. To obtain a
text desciption use the API MTGetReturnCodeDescription().
All SmartWORKS return codes are listed below:

SMARTWORKS RETURN CODES1


Return Code Hex value Meaning
MT_EXCEPTION 0xE000220FL An exception occurred during the API call
MT_RET_API_THREAD_PROTECTED 0xE0002019L API is referred by other thread
MT_RET_BAD_CURSOR 0xE0002031L Invalid index offset
MT_RET_BAD_JOIN 0xE0002029L Invalid crosspoint coordinates
MT_RET_BOARD_INUSE 0xE0002018L Board device in use by another application
MT_RET_BOARD_NOT_OPENED 0xE0002016L Board device not opened for access
MT_RET_BUSY 0xE0002010L Channel is busy
MT_RET_CANNOT_CREATE_EVTQEVENT 0xE0002205L Unable to create event for the event queue
MT_RET_CANNOT_CREATE_MUTEX 0xE000220EL Mutex creation failed
MT_RET_CHANNEL_INUSE 0xE0002017L Channel device not opened for access
MT_RET_CHANNEL_NOT_OPENED 0xE0002015L Channel device not opened for access
MT_RET_COMPAT_NOTSUPPORTED 0xE000220CL Compatibility mode is not supported in this
implementation
MT_RET_DATA_TRUNCATED 0x60002036L Buffer does not have space for API request
MT_RET_DEVICE_NOTFOUND 0xE0002200L Voice interface device was not found
MT_RET_EVTQMUTEX_ABANDONED 0xE0002208L The event queue synchronization mutex was
abandoned by another thread
MT_RET_EXTENDED_ERROR 0xE0002024L Extended error
MT_RET_FORMAT_NOT_SUPPORTED 0xE0002001L Media format is not supported
MT_RET_IDLE 0xE0002011L Channel is idle
MT_RET_BOARD_INCOMPATIBLE_BINFILE 0xE0002043L file type does not match board type
MT_RET_INTERNAL_ERROR 0xE0002201L Internal DLL error
MT_RET_INVALID_BINFILE 0xE0002042L image file version cannot be retrieved
MT_RET_INVALID_BOARD 0xE0002008L Board number is out of range
MT_RET_INVALID_BUSTYPE 0xE0002030L Bus type is invalid
MT_RET_INVALID_CHANNEL 0xE0002009L Channel number is out of range
MT_RET_INVALID_DEVICE_IO 0xE0002013L Invalid Device IO setting
Writing An Application
• 43
System Wide Definitions

SMARTWORKS RETURN CODES1 (CONTINUED)


Return Code Hex value Meaning
MT_RET_INVALID_EVENT_QUEUE 0xE0002207L Invalid event queue
MT_RET_INVALID_FILEINDEX 0xE000220AL The MT_IO_CONTROL FileIndex field is out of
range for the file
MT_RET_INVALID_FILENAME 0xE0002210L Invalid filename
MT_RET_INVALID_FUNC 0xE0002006L Function code is not valid
MT_RET_INVALID_HW_INT 0xE0002007L Bad hardware IRQ at initialization
MT_RET_INVALID_PARAM 0xE0002012L Invalid argument passed to function
MT_RET_IO_PENDING 0x60002033L Background I/O operation is in progress or
queued.
MT_RET_ISDNPT_BAD_TRUNK_NUMBER 0xE0002216L ISDN channel not found
MT_RET_ISDNPT_CALL_NOT_FOUND 0xE0002215L ISDN channel not found
MT_RET_ISDNPT_CHANNEL_NOT_FOUND 0xE0002214L ISDN channel not found
MT_RET_LIB_LOAD_FAILED 0XE0002040L driver load failed
MT_RET_MALFUNCTION 0xE0002005L Hardware failed during initialization
MT_RET_MISSING_TERMINATOR 0xE0002212L A terminating entry was not found in an array
argument.
MT_RET_MUX_OFF 0xE0002028L Multiplexer system was not started
MT_RET_MUX_ON 0xE0002027L Multiplexer system was already started
MT_RET_MUX_THREAD_PROTECTED 0xE000201AL MUX is referred by other thread
MT_RET_NO_ASSOC_EVTQ 0xE0002209L No event queue has been associated with
channel
MT_RET_NO_DIGIT 0xE0002002L No digit available
MT_RET_NO_MEM 0xE0002206L An operation could not be completed due to
insufficient memory or an error occurred
while attempting to allocate memory
MT_RET_NO_MUX 0xE0002026L Multiplexer is not available
MT_RET_NOT_AVAILABLE 0xE0002014L Feature is not available
MT_RET_NOT_APPLICABLE 0xE000201D This feature is available, but is currently not
enabled.
MT_RET_NOT_ENOUGH_BUFSPACE 0x60002035L StreamOut does not have enough buffering
space for API request
MT_RET_NOT_ENOUGH_DATA 0x60002034L StreamIn does not have enough data for API
request
MT_RET_NOT_STARTED 0xE0002004L Voice system not started
MT_RET_OK 0x00000000L No error
MT_RET_QFULL 0xE0002032L Invalid index offset
MT_RET_SERVICE_ALREADY_STARTED 0xE0002204L Requested service already started
MT_RET_SERVICE_NOT_STARTED 0xE0002203L Voice service not started
Ai-Logix, Inc.
44 •
SmartWORKS Developer’s Guide

SMARTWORKS RETURN CODES1 (CONTINUED)


Return Code Hex value Meaning
MT_RET_SERVICE_STOPPED 0x60002213L Voice service stopped or terminated
MT_RET_STARTED 0xE0002003L Voice system already started
MT_RET_STREAMIN_THREAD_PROTECTED 0xE000201BL STREAMIN is referred by other thread
MT_RET_STREAMOUT_THREAD_PROTECTED 0xE000201CL STREAMOUT is referred by other thread
MT_RET_UNKNOWN_DEVICE_ERROR 0xE0002202L Unknown device error
MT_RET_UNKNOWN_IOTRANS_HANDLE 0xE000220DL The handle in the IO_TRANS structure was not
obtained through the Ai-Logix API file open
functions
MT_RET_VERSION_MISMATCH 0xE0002211L Version mismatch
MT_RET_ZERO_FILELENGTH 0xE000220BL The MT_IO_CONTROL FileLength field is zero
MT_TIMEOUT 0xC0040013L Wait for event timed out
MT_XRET_BADFUNCTION 0xE0002120L Bad function
MT_XRET_BADHANDLE 0xE0002114L Bad handle
MT_XRET_BADPARAM 0xE0002121L Invalid argument passed to function
MT_XRET_QEMPTY 0xE0002119L Event queue is empty
MT_XRET_QFULL 0xE0002118L Event queue is full (has reached maximum
limit)

1. All return codes are defined in the NtiErr.h file.

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().

All event codes are defined below:


Board Type
AT - SmartWORKS AT
DT - SmartWORKS DT
PT - SmartWORKS PT
DP - SmartWORKS DP
NGX - SmartWORKS NGX
LD - SmartWORKS LD
Writing An Application
• 45
System Wide Definitions

PCM - SmartWORKS PCM


Event Type
B - Board event
C - Channel event
S - System event
R - Regular, non-terminating event
T - Terminating event
M - Monitor event
MC - Monitor cadence event
1 - This event could indicate a possible interrupt or address conflict, or true
technical failure.
2 - End of File (EVT_EOF or EVT_MAXBYTES) is also reported during
MTPlayIndex() when all segments are played.
3 - For information purposes only and will occur in an idle state.
4 - These events may be enabled or disabled with the function
MTSetMoni().
When a function terminates with the EVT_CPM_STOP code, the SubReason
parameter of the MT_EVENT block indicates the precise reason.

SMARTWORKS EVENT CODES


Board Hex Dec Event Type Description
All 0x01 1 EVT_MAXDIGITS C/T Maximum DTMF digits
received
All 0x02 2 EVT_TERMDIGIT C/T Terminating DTMF digit
received
All 0x03 3 EVT_STOP C/T User stopped
All 0x04 4 EVT_SYS_ERROR C/T System response error
All 0x05 5 EVT_MAXBYTES C/T Max bytes reached on play or
record
All 0x06 6 EVT_ERROR C/T Hardware failure
(1)
All 0x07 7 EVT_MAXTIME C/T Max time reached
AT, LD, 0x08 8 EVT_OFFHOOK C Offhook complete
NGX
All 0x09 9 EVT_DIALED C/T Dialing complete
All 0x0A 10 EVT_MAX_SILENCE C/R/ Maximum silence received
M
All 0x0B 11 EVT_EOF C/T EOF reached on playback
(2)
Ai-Logix, Inc.
46 •
SmartWORKS Developer’s Guide

SMARTWORKS EVENT CODES (CONTINUED)


Board Hex Dec Event Type Description
AT, LD 0x0C 12 EVT_LOOP_STOP C/T Terminate by drop in loop
current
All 0x0D 13 EVT_DISK_FULL C/T Disk full
AT, LD, 0x0E 14 EVT_ONHOOK C Onhook complete
NGX
All 0x0F 15 EVT_DISK_WRITE_ERROR C/T File write error
All 0x10 16 EVT_BOARD_PANIC_ERROR /B/R Board Panic error
All 0x11 17 EVT_TERMSILENCE C/T Termination silence reached on
play or record
AT, LD, DT 0x12 18 EVT_CPM_STOP C/T Call analysis termination
AT, LD 0x13 19 EVT_LOOP_REVERSE C/R/ Loop current battery reversal
M/4
AT, LD 0x14 20 EVT_LOOP_DROP C/R Loop current dropped
(3)
AT, PT, LD 0x15 21 EVT_RINGS C/R Ring received
All 0x16 22 EVT_MON_ACTIVITY C/R Silence off, activity on
All 0x17 23 EVT_MON_SILENCE C/R Silence on, activity off
All 0x18 24 EVT_IDLE C Channel back in IDLE state
DP, DT, 0x19 25 EVT_FRAME_HEADER_ERROR C/T Frame header error, function
NGX terminated
AT, LD 0x1A 26 EVT_LOOP_ON C/R Loop current on event
0x1B 27 EVT_FRAME_DATA_ERROR TBA TBA. When more file formats
are added.
AT, LD 0x1C 28 EVT_LVOLTAGE_REVERSAL C/T Indicates a voltage change of
state
All 0x1D 29 EVT_DIGITENABLE C/T Terminated by enabled DTMF
digit
All 0x1E 30 EVT_INTERDIGIT C/T Interdigit delay exceeded
All 0x1F 31 EVT_MAX_ACTIVITY C/R/ Terminated by a max non-
M silence
LD 0x20 32 EVT_LVOLTAGE_MIDDLE C/R/ Loop voltage between
M/4 ThrehsoldHigh and
ThresholdLow
LD 0x21 33 EVT_LVOLTAGE_ABOVEORBELOW C/R/ Loop voltage not in MIDDLE
M/4 state
LD 0x22 34 EVT_TERMLVOLTAGE_ABOVEORBELOW C/R/ Termination on loop voltage
M/4 state not in MIDDLE
PT 0x20 32 EVT_LVOLTAGE_OFFHOOK C/R/ Loop voltage detected
(EVT_LVOLTAGE_MIDDLE) M/4
Writing An Application
• 47
System Wide Definitions

SMARTWORKS EVENT CODES (CONTINUED)


Board Hex Dec Event Type Description
PT 0x21 33 EVT_LVOLTAGE_NOTOFFHOOK C/R/ Loop voltage dropped
(EVT_LVOLTAGE_ABOVEORBELOW) M/4
PT 0x22 34 EVT_TERMLVOLTAGE_NOTOFFHOOK C/T Termination on loop voltage
(EVT_TERMLVOLTAGE_ABOVEORBELOW) changed to notoffhook
LD 0x23 35 EVT_LVOLTAGE_ABOVE Loop voltage above
ThresholdHigh
LD 0x24 36 EVT_LVOLTAGE_BELOW Loop voltage below
ThresholdLow
All 0x25 37 EVT_SETPAR_DONE N/A Parameter updated
None 0x26 38 EVT_WINKDONE C/R/ Wink protocol complete
T
All 0x27 39 EVT_DIGIT_DROPPED C/R Received DTMF digit dropped
due to queue full
the queue allows a maximum
of 256 digits
All 0x28 40 EVT_DIGIT C/R Received DTMF digit queued,
the queue allows a maximum
of 256 digits
PT, LD 0x2B 43 EVT_LCURRENT_REVERSAL Loop current reversal
All 0x2F 47 EVT_TONEPERR C/R Tone generation template error
All 0x30 48 EVT_TONEP_DONE C/T Tone generation complete
All 0x31 49 EVT_MFTONE_DROPPED C/R Received MF(R2) tone dropped
due to queue full
All 0x32 50 EVT_MFTONE C/R Received MF(R2) tone queued
PT, LD 0x33 51 EVT_LVOLTAGE_RECORD C/R Recording started on detection
of loop voltage offhook
All 0x35 53 EVT_VOICE_RECORD C/R Recording started on detection
of voice
AT, LD 0x36 54 EVT_LOOPON_RECORD C/R Recording started on detection
of loop current
All 0x37 55 EVT_STREAMIN_WATERMARK C/R Data ENCODE streaming
watermark reached
All 0x38 56 EVT_STREAMOUT_WATERMARK C/R Data DECODE streaming
watermark reached
All 0x39 57 EVT_STREAMIN_START C/R Data ENCODE streaming
started
All 0x3A 58 EVT_STREAMOUT_START C/R Data DECODE streaming
started
All 0x3B 59 EVT_STREAM_MAXSIL C/R Max silence during data
streaming
All 0x3C 60 EVT_STREAMIN_STOP C/T Data ENCODE streaming
stopped
Ai-Logix, Inc.
48 •
SmartWORKS Developer’s Guide

SMARTWORKS EVENT CODES (CONTINUED)


Board Hex Dec Event Type Description
None 0x3D 61 EVT_STREAMIN_COMP C/R Input streaming complete
None 0x3E 62 EVT_STREAMOUT_COMP C/R Output streaming complete
All 0x3F 63 EVT_STREAMIN_DROPPED C/R Input streaming data dropped
All 0x40 64 EVT_STREAMOUT_STOP C/T Data DECODE streaming
stopped
All 0x41 65 EVT_STREAMOUT_EMPTY C/R Output stream buffer empty
All 0x42 66 EVT_STREAMOUT_PAUSED C/R Output streaming paused
All 0x43 67 EVT_STREAMOUT_RESUMED C/R Output streaming resumed
All 0x45 69 EVT_INDEX_PLAYED C/R/ Indexed byte length played
2
All 0x4D 77 EVT_DEVICE_WRITE_ERROR C/T User device write error
All 0x4E 78 EVT_DEVICE_READ_ERROR C/T User device read error
All 0x4F 79 EVT_DEVICE_SEEK_ERROR C/T User device seek error
All 0x50 80 EVT_DSPRESET C/R DSP status event
All 0x51 81 EVT_NOT_AVAILABLE /BC/ Functionality not available or
R busy
All 0x52 82 EVT_NOT_SUPPORTED /BC/ Functionality not supported
R
All 0x53 83 EVT_NO_EFFECT /BC/ Functionality not necessary
R (already done)
PCM 0x54 84 EVT_LOSYNC_ALARM B Loss of Sync. alarm
DP, DT, 0x55 85 EVT_LOS_ALARM /B/R Loss Of Signal alarm
NGX
DP, DT 0x56 86 EVT_LOF_ALARM /B/R Loss Of Framer alarm
DP, DT 0x57 87 EVT_AIS_ALARM /B/R Alarm Indication alarm
DP, DT 0x58 88 EVT_YELLOW_ALARM /B/R Yellow Alarm
DP, DT 0x59 89 EVT_INCOMING_SIGCHANGE C/R Change of Signaling Bits
(ABCD) on incoming line
DT 0x5A 90 EVT_OUTGOING_SIGCHANGE C/R Change of Signaling Bits
(ABCD) on outgoing line
All, except 0x5B 91 EVT_MVIP_ALARM /B/R MVIP error detected
LD 409
All 0x5C 92 EVT_MASTER_PLL_ALARM /B/R Master PLL error detected
DP, DT 0x5D 93 EVT_LOSMF_ALARM /B/R E1: Loss Of Signaling
Multiframe Alignment alarm
DP, DT 0x5E 94 EVT_LOCRCMF_ALARM /B/R E1: Loss Of CRC Multiframe
Alignment alarm
DP, DT 0x5F 95 EVT_TS16RAI_ALARM /B/R E1: Timeslot 16 Remote Alarm
Indication alarm
Writing An Application
• 49
System Wide Definitions

SMARTWORKS EVENT CODES (CONTINUED)


Board Hex Dec Event Type Description
All 0x66 102 EVT_H100_MASTER_A_ALARM B H100 Master A clock error
detected
All 0x67 103 EVT_H100_MASTER_B_ALARM B H100 Master B clock error
detected
DP, NGX 0x6E 110 EVT_CALL_ALERTING C ISDN Call Alerting
EVT_CC_CALL_ALERTING
DP, NGX 0x6F 111 EVT_CALL_CONNECTED C ISDN Call Connected
EVT_CC_CALL_CONNECTED
DP, NGX 0x70 112 EVT_CALL_RELEASED C ISDN Call Released
EVT_CC_CALL_RELEASED
DP, NGX 0x71 113 EVT_CALL_SUSPENDED C ISDN Call Suspended
EVT_CC_CALL_SUSPENDED
DP, NGX 0x72 114 EVT_CALL_RESUMED C ISDN Call Resumed
EVT_CC_CALL_RESUMED
DP, NGX 0x73 115 EVT_CALL_HELD C ISDN Call Held
EVT_CC_CALL_HELD
DP, NGX 0x74 116 EVT_CALL_RETRIEVED C ISDN Call retrieved from Hold
EVT_CC_CALL_RETRIEVED
DP, NGX 0x75 117 EVT_CALL_ABANDONED C ISDN Call abandoned by the
EVT_CC_CALL_ABANDONED caller
DP, NGX 0x76 118 EVT_CALL_REJECTED C ISDN Call rejected by
EVT_CC_CALL_REJECTED destination
DP 0X77 119 EVT_CALL_USER_INFO C ISDN user info
EVT_USER_INFO
EVT_CC_USERINFO_IND
DT 0x78 120 EVT_CC_CONNECT_IND B Incoming call Indication
DT 0x79 121 EVT_CC_INFO_IND B ISDN called party digits
DT 0x7A 122 EVT_CC_PROGRESS_IND B ISDN call progress Indication
DT 0x7B 123 EVT_CC_DISC_IND B Disconnect Indication
DT 0x7C 124 EVT_CC_DISC_CONF B Disconnect Confirmation
DT 0x7D 125 EVT_CC_CONNECT_CONF B Connect Confirmation
DT 0x7E 126 EVT_CC_ALERT_IND B ISDN Alert Indication
DT 0X7F 127 EVT_CC_FACILITY_IND B ISDN Facility Indication
DT 0X80 128 EVT_CC_FACILITY_CONF B ISDN Facility Confirmation
DT 0X6D 109 EVT_SUSPEND_CONF B ISDN Suspend Confirmation
DT 0X6C 108 EVT_RESUME_CONF B ISDN Resume Confirmation
All 0x81 129 EVT_MON_BUSY C/R Monitor busy cadence cycle
EVT_MON_BUSY1 (4)
Ai-Logix, Inc.
50 •
SmartWORKS Developer’s Guide

SMARTWORKS EVENT CODES (CONTINUED)


Board Hex Dec Event Type Description
All 0x82 130 EVT_MON_BUSY_TRUNK C/R Monitor trunk busy cycle
EVT_MON_BUSY2 (4)

All 0x88 136 EVT_MON_DIAL C/R/ Monitor Dial1 signal


EVT_MON_DIAL1 MC
(4)
All 0x89 137 EVT_MON_DIAL2 C/R/ Monitor Dial2 signal
MC
(4)
All 0x8A EVT_MON_DIAL3 C/R/ Monitor Dial3 signal
MC
(4)
All 0x8E 142 EVT_MON_RINGBACK C/R/ Monitor Ring back
EVT_MON_RINGBACK1 MC
(4)
All 0x8F 143 EVT_MON_DRINGBACK C/R/ Monitor Double Ring back
EVT_MON_RINGBACK2 MC
(4)
All 0x90 144 EVT_MON_SIT C/R/ Monitor Intercept signal
EVT_MON_SIT1 MC SIT1
(4)
All 0x84 132 EVT_MON_SIT2 C/R/ Monitor Intercept signal
MC SIT2
(4)
All 0x85 133 EVT_MON_SIT3 C/R/ Monitor Intercept signal
MC SIT3
(4)
All 0x86 134 EVT_MON_SIT4 C/R/ Monitor Intercept signal
MC SIT4
(4)
All 0x87 135 EVT_MON_SIT5 C/R/ Monitor Intercept signal
MC SIT5
(4)
All 0x8C 140 EVT_MON_CALLWAITING C/R/ Monitor Calwaiting signal
MC
(4)
All 0x8D 141 EVT_MON_RECEIVEOFF C/R/ Monitor Receive off signal
MC
(4)
All 0x91 145 EVT_MON_FAX C/R/ Monitor Fax1 signal
EVT_MON_FAX1 MC
(4)
All 0xAB 171 EVT_MON_FAX2 C/R/ Monitor Fax2 signal
MC
(4)
Writing An Application
• 51
System Wide Definitions

SMARTWORKS EVENT CODES (CONTINUED)


Board Hex Dec Event Type Description
All 0x92 146 EVT_MON_REVERSAL C/R/ Monitor polarity reversal
MC
(4)
All 0x93 147 EVT_MON_VOICE C/R/ Monitor voice
MC (human or machine)
(4)
All 0x94 148 EVT_MON_NOVOICE C/R/ Monitor loss of voice
MC
(4)
All 0x95 149 EVT_MON_MACHINE C/R/ Monitor answer machine
MC
(4)
All 0x96 150 EVT_MON_HUMAN C/R/ Monitor Human voice
MC
(4)
All 0x97 151 EVT_CALLID_DROPPED C/R/ CallerID detected and dropped
MC due to queue full
All 0x98 152 EVT_CALLID_STOP C/R/ CallerID end detected
MC
None 0x9F 159 EVT_RECOFFHOOK C/R Recording offhook
All 0xA0 160 EVT_REVERSAL C/R Loop current reversal
All 0xAA 170 EVT_MON_SIGNAL_CYCLE C/R/ used to count one complete
MC cycle of CPM or Usr signal
(4)
All 0xC8 200 EVT_SYS_SYNCTIME_OLD S resync time
All 0xC9 201 EVT_SYS_SYNCTIME_NEW S resync time
All 0xCA 202 EVT_SYS_BOARD_ADDED S new board added to system
All 0xCB 203 EVT_SYS_BOARD_REMOVED S -not implemented yet-
Ai-Logix, Inc.
52 •
SmartWORKS Developer’s Guide

D-CHANNEL EVENT CODES AND PBX SUPPORT (NGX ONLY)


A listing of the D-channel events returned to the user per PBX is now available on
online support. Refer to the Files and Documents section and look for the NGX PBX
Matrix folder.

Using Data Structures


Structures are used to pass parameters to or from the application. Only a pointer to
the structure is passed, not the whole structure. The application fills an input
structure and passes the pointer to the API, which reads or copies the information.
The application also passes a pointer to the output structure which the API fills with
the requested information.
All input structures are buffered in the API. This means that the application can only
destroy or reuse the structure after it has been populated by the function. Voice
buffers and DTMF buffers used by a background function must stay in existence
until the application receives a terminating event for that function.
As noted earlier, all entries in an input structure that are reserved, not needed, or
not used must be set to zero to ensure future compatibility.

ZERO OUT PARAMETERS


Not all functions use all parameters. In cases where not all parameters are used, the
value of unused parameters should always be set to zero.
There are several ways to “zero out” unused parameters:
One way is to make a default structure with the most commonly used
parameters set to a default value and the rest to zero. You would then copy this
structure to a local structure where specific values are filled in.
Another way is to always zero out the structure before filling in the values.
This section defines two structures that are used by many of the SmartWORKS APIs:
MT_IO_CONTROL and MT_EVENT. For exact structure definitions refer to the
NtiData.h header files and API definitions in the next chapter of this book.

NOTE - The structures in the following sections do not include reserved


parameters.
Writing An Application
• 53
Using Data Structures

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

GENERAL TERMINATION CONTROL


MAXTIME
The maximum time, in milliseconds, that a background function can be active.
This parameter causes an EVT_MAXTIME event. NOTE: This termination
condition is not supported when streaming.

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.

SIGNAL TERMINATION CONTROL


MAXSILENCE
For termination of background functions (play function only), this variable
specifies the maximum silence allowed in milliseconds. If this period of no
signal is exceeded, the function terminates. If a recording is terminated by this
event, an EVT_TERMSILENCE event is generated. This parameter cannot be
used for play functions.

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

TERM_USE_CHANNEL_ONLY Terminate this background function using the


termination conditions set at the channel level using
MTSetTerm().
TERM_USE_TASK_ONLY Terminate this function using the termination conditions
set with the TermEnable field of the IO_CONTROL
structure. Ignore the termination conditions set at the
channel level with MTSetTerm().
*If other background tasks are running with a mode that supports event reporting,
monitoring events are still generated.

Backwards Compatibility
To support older versions of the SmartWORKS API, (3.2 and earlier) the following modes are
still accepted:

Mode - 3.2 or earlier Later Releases


CPMMODE_NONE MONI_USE_CHANNEL_ONLY |
TERM_USE_NONE
CPMMODE_MONI MONI_USE_CHANNEL_AND_TASK |
TERM_USE_NONE
CPMMODE_COMP MONI_USE_CHANNEL_ONLY |
TERM_USE_CHANNEL_AND_TASK

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

MTSetTerm() Control Subreason XtraInfo


TERM_LOOP_DROP CPM_MON_LOOP_DROP
TERM_MON_SIL CPM_MON_SILENCE
TERM_MON_ACT CPM_MON_ACTIVITY
TERM_MON_DIAL*+ CPM_MON_DIAL(1-3)
TERM_MON_BUSY*+ CPM_MON_BUSY The Index of the signal (normal
busy or trunk busy)
TERM_CONNECT+ (Using MTCallString()) CPM_MON_HUMAN,
CPM_MON_CONNECT CPM_MON_MACHINE
------------------------------
------------------------------------
(Using MTDialString())
CPM_MON_HUMAN
CPM_MON_MACHINE
TERM_NO_ANSWER+ CPM_NO_ANSWER
TERM_INTERCEPT*+ CPM_MON_INTERCEPT
TERM_NOR_SILENCE CPM_MON_MAX_SILENCE
CPM_MAX_SILENCE
TERM_NOR_ACTIVITY CPM_MON_MAX_ACTIVITY
CPM_MAX_ACTIVITY
TERM_LVOLTAGE_ CPM_MON_LVOLTAGE_DROP
ABOVEORBELOW
TERM_LVOLTAGE_ (same as TERM_LVOLTAGE_
NOTOFFHOOK ABOVE_OR_BELOW
TERM_MON_UTONE+ CPM_MON_UTONE Index Id
TERM_MON_CALLWAITING+ CPM_MON_CALLWAITING
TERM_MON_RECEIVEOFF+ CPM_MON_RECEIVOFF
TERM_MON_DIAL1+ CPM_MON_DIAL1
TERM_MON_DIAL2+ CPM_MON_DIAL2
TERM_MON_DIAL3+ CPM_MON_DIAL3
TERM_MON_BUSY1+ CPM_MON_BUSY1
TERM_MON_BUSY2+ CPM_MON_BUSY2
TERM_MON_FAX1+ CPM_MON_FAX1
TERM_MON_FAX2+ CPM_MON_FAX2
TERM_MON_SIT1+ CPM_MON_SIT1
TERM_MON_SIT2+ CPM_MON_SIT2
TERM_MON_SIT3+ CPM_MON_SIT3
TERM_MON_SIT4+ CPM_MON_SIT4
TERM_MON_SIT5+ CPM_MON_SIT5
* These bits are maintained for backwards compatibility. New development
should not use these options.
+ Call Progress Monitoring (CPM) must be enabled to detect these conditions
Writing An Application
• 57
Using Data Structures

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:

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_CALLWAITI
NG
RECEIVEOFF MONI_RECEIVEOFF EVT_MON_RECEIVEOF
F
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_DRINGBAC
K)
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_CY
CLE
SIT1 MONI_SIT1 EVT_MON_SIT1
SIT2 MONI_SIT2 EVT_MON_SIT2
SIT3 MONI_SIT3 EVT_MON_SIT3
SIT4 MONI_SIT4 EVT_MON_SIT4
SIT5 MONI_SIT5 EVT_MON_SIT5
DIAL1 MONI_DIAL1 EVT_MON_DIAL1
DIAL2 MONI_DIAL2 EVT_MON_DIAL2
DIAL3 MONI_DIAL3 EVT_MON_DIAL3
MONI_VOICE EVT_MON_VOICE
EVT_MON_HUMAN
EVT_MON_MACHINE
EVT_MON_NOVOICE
MONI_REVERSAL EVT_MON_REVERSAL
*These options have been maintained for backwards compatibility. They are not rec-
ommended for new development.
Ai-Logix, Inc.
58 •
SmartWORKS Developer’s Guide

DIGIT TERMINATION CONTROL


MAXDIGITS
The background function terminates if the DTMF queue contains MaxDigits or
more digits, resulting in an EVT_MAXDIGITS event. If there are digits in the DTMF
queue this can cause the MTGetDigits() to terminate immediately. If this is
undesirable, call the MTClearDTMFDigits() function first.
Only DTMF digits detected on the primary channel are used for termination control.
On NGX and DP, the primary channel corresponds to the incoming direction, i.e.
from CO to CPE.

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.

Note: If a recording is terminated with an EVT_MAXDIGITS,


EVT_TERMDIGIT, or EVT_DIGITENABLE event, the last 200ms (the last
digit) of the recording is truncated. If any background function is
terminated with an EVT_MAXDIGITS, EVT_TERMDIGIT or
EVT_DIGITENABLE event, the terminating digit can be found in the
SubReason field of the MT_EVENT structure. ‘
Writing An Application
• 59
Using Data Structures

MISCELLANEOUS CONTROL DATA


STARTCONTROL
This field specifies the controls used for record or play.

TABLE 8: STARTCONTROL

Bit Control Definition

0 Reserved Set to 0

1 PROMPT_TONE* A prompt tone will be played before recording. ToneDuration field


sets the length of this tone

2 INTER_DIGIT_DELAY 1 - Inter-digit delay starts after the first digit ·


0 - Inter-digit delay starts immediately

3 REPEAT_TONE Repeat the playing of tones through MTPlayTone()

4 START_ACTD* Activity triggered Recording. Automatically starts recording upon


activity detection, event EVT_ACTD_RECORD will be issued

5. START_LOOPON Loop Recording: Automatically starts recording upon loop current


detection and issues EVT_LOOPON_RECORD.
If CPM termination for loop drop is not enabled, then recording
automatically stops upon loop drop and EVT_LOOP_STOP is
reported. If CPM termination is enabled, then EVT_CPM_STOP is
reported.

6 N/A Previously reserved for NOAGC which has been obsoleted

7 ALERTTONE_ON* Plays Alert tone during Call logging

8 SILENCE_TRUNCATION* Not to record the terminating silence

9 SILENCE_SUPRESSION Suppress silence during recording. This is to be added later

10 START_LVOLTAGE_MIDDLE* Start recording on detection of loop voltage MIDDLE state. This is


available on SmartWORKS LD only. If CPM termination for voltage
------------------------------------- is not enabled, then recording automatically stops when voltage is
above or below thresholds and
START_LVOLTAGE_OFFHOOK* EVT_TERM_VOLTAGE_ABOVEORBELOW is reported. If CPM
termination is enabled, then EVT_CPM_STOP is reported.
-----------------------------------------------
Recording starts on detection of loop voltage and event
EVT_LVOLTAGE_RECORD will be issued (PT boards only). If CPM
termination for voltage is not enabled, then recording
automatically stops with an onhook condition and
EVT_TERM_VOLTAGE_NOTOFFHOOK is reported. If CPM
termination is enabled, then EVT_CPM_STOP is reported.

11 Reserved Set to 0

12 GSM_FRAME34 Use NVDSP compatible 34-byte GSM frame length

13. WAVE_RIFFFMTDATA_CHUNK Add wave header, not available on streaming and DeviceIO
functions
Ai-Logix, Inc.
60 •
SmartWORKS Developer’s Guide

TABLE 8: STARTCONTROL (CONTINUED)

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.

16-31 Reserved Set to 0.

*These fields are reserved for record functions only.

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.

PLAY/RECORD SPECIFIC DATA


FILEINDEX
The file starting offset for record/play APIs. This field does not need to be populated for
for playindex APIs.

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

Type Name Function


LARGE_INTEGER(WIN32) TimeStamp Time stamp when the event occurred. In
timeval (Linux) FILETIME format (WIN32) or in
gettimeofday() format (Linux)

ULONG UserStatus User defined value

ULONG EventCode The event code

ULONG SubReason Extended event information

ULONG XtraInfo Extra information such as termination


enable, etc.

ULONG FuncCode The function that generated this event. See


below for a definition of each FuncCode.

ULONG Board Board the event occurred on

ULONG Channel Channel the event occurred on

PVOID PtrBuffer Pointer to event associated buffer, if any

ULONG DataLength Size of exercised data of the associated


buffer, if any

PVOID ptrXtraBuffer* pointer to buffer containing extra


information

ULONG XtraBufferLength* Length of ptrXBuffer

ULONG XtraDataLength* Length of data put into the prtXtraBuffer


by the DLL.
Ai-Logix, Inc.
62 •
SmartWORKS Developer’s Guide

TABLE 9: MT_EVENT (CONTINUED)

Type Name Function


ULONG EventFlag Flag for XtraBuffer information:
Bit 0X00000001
1- Appl. created this event
0 - DLL created this event
Bit 0x00000002:
1 - Appl. allocated the buffer
0 - DLL allocated the buffer
Bit 0x000000004
1 - data has been truncated
0 - data has not been truncated

* 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

For line transition events such as EVT_LOOP_ON, EVT_MON_ACTIVITY,


EVT_MON_SILENCE, EVT_OFFHOOK, EVT_ONHOOK, and EVT_REVERSAL, this
field contains timing information about the previous state in 1 ms units, with a
maximum of 65535 ms.

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

Next, the following methods used to encode/decode data are defined:


#define BUFFER_BASE 0x0100 // Buffer I/O
#define FILE_BASE 0x0200 // File I/O
#define DEVICE_BASE 0x0400 // Device I/O
#define STREAM_BASE 0x0800 // Streaming I/O

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.

Hexadecimal FuncCode Description

0x1100 F_RECB Record to Buffer

0x1200 F_RECF Record to file

0x1400 F_RECD Record to device

0x1800 F_RECS Record to stream buffer

0x2100 F_PLAYB Playback from buffer


Ai-Logix, Inc.
64 •
SmartWORKS Developer’s Guide

Hexadecimal FuncCode Description

0x2200 F_PLAYF Playback from file

0x2201 F_PLAYFI Indexed Playback from file

0x2400 F_PLAYD Playback from device

0x2800 F_PLAYS Playback from stream buffer

0x1801 F_RECS_START Start record to stream buffer

0x2801 F_PLAYS_START Start playback from stream buffer

0x1001 F_GETDTMFS Get DTMF digits

0x2001 F_PLAYDTMFS Play DTMF digits (using MTDialString())

0x2002 F_PLAYTONES Play tones

0x0000 F_IDLE Idle

0x2004 F_CallDTMFS MTCallString()

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

Length of the ptrXBuffer. This is further explained where MTReturnEventBuffer() is


discussed in the Functional Reference Library.

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

API’s Presented Alphabetically with Product Support


Below is a table showing which SmartWORKS hardware products support the many
SmartWORKS API functions
.

TABLE 10: API FUNCTION STATUS AND PRODUCT SUPPORT

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 * * *

MTAGCControl() - see MTChInputAGCControl() 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

TABLE 10: API FUNCTION STATUS AND PRODUCT SUPPORT (CONTINUED)

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

TABLE 10: API FUNCTION STATUS AND PRODUCT SUPPORT (CONTINUED)

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 * * * * * * * *

MT Clear Usr Tone() O * * * * * * * *


-see MTClearUsrToneParams()

MTClearUsrToneParams() P * * * * * * * *

MTCloseBoard() F * * * * * * * *

MTCloseChannel() F * * * * * * * *

MTControlToneQ() - see MTChInputToneDetectControl() O * * * * * * * *


Function Reference Library
• 71

TABLE 10: API FUNCTION STATUS AND PRODUCT SUPPORT (CONTINUED)

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 * * * * * * * *

MTDisableACTD() - see MTChInputACTDControl() O * * * * * * * *

MTDisableCallerID() F * * * * * * * *

MTDisableFramerABCDSignalingEvent() F * *

MTDisableMixing() F * * * * * * * *

MTDisableMixingDetect() - see MTChinputToneDetect- O * * * * * * * *


Control() or MTChInputACTDControl()

MTDisarmCTAlarm() F * * * * * * * *

MTDisarmFramerAlarm() F * * * *

MTEnableACTD() - see MTChInputACTDControl() O * * * * * * * *

MTEnableCallerID() F * * * * * * * *

MTEnableFramerABCDSignalingEvent() F * *

MTEnableMixing() F * * * * * * * *

MTEnableMixingDetect() - see MTChinputToneDetect- O * * * * * * * *


Control() or MTChInputACTDControl()

MTEventControl() F * * * * * * * *

MTFlushCallerID() F * * * * * * * *

MTFlushEvents() F * * * * * * * *

MTGetACTDDetectPower() - O * * * * * * * *
see MTChInputACTDDetectPower()

MTGetACTDParams() - see MTChInputGetACTDParams() O * * * * * * * *

MTGetAdapterConfig() F * * * * * * * *

MTGetAdapterDescription() F * * * * * * * *

MTGetAdapterEEPROMConfig() F * * * * * * * *

MTGetAdapterInfo() F * * * * * * * *

MTGetAdapterStatusDescription() F * * * * * * * *

MTGetAdapterXInfo() F * * * * * * * *

MTGetAGC() - see MTChInputGetAGC() F * * * * * * * *


Function Reference Library
• 72

TABLE 10: API FUNCTION STATUS AND PRODUCT SUPPORT (CONTINUED)

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

TABLE 10: API FUNCTION STATUS AND PRODUCT SUPPORT (CONTINUED)

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 * * *

MTGetGain() - see MTChInputGetGain() F * * * * * * * *

MTGetGCI() F * * * * * * * *

MTGetGCIMap() F * * * * * * * *

MTGetHookState() F * *

MTGetInputs() F * * * * * * * *

MTGetLastErrorA() F * * * * * * * *

MTGetLastErrorW() F * * * * * * * *

MTGetLastTerm() F * * * * * * * *

MTGetLCDetectState F * *
Function Reference Library
• 74

TABLE 10: API FUNCTION STATUS AND PRODUCT SUPPORT (CONTINUED)

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

TABLE 10: API FUNCTION STATUS AND PRODUCT SUPPORT (CONTINUED)

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

TABLE 10: API FUNCTION STATUS AND PRODUCT SUPPORT (CONTINUED)

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

TABLE 10: API FUNCTION STATUS AND PRODUCT SUPPORT (CONTINUED)

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 * * * *

MTSetACTDParams() - see MTChInputSetACTDParams() F * * * * * * * *

MTSetAdapterConfig() F * * * * * * * *

MTSetAdapterEEPROMConfig() F * * * * * * * *

MTSetAdapterToDefault() F * * * * * * * *

MTSetAGC() - see MTChInputSetAGC() 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 * * * *

MTSetGain() - see MTChInputSetGain() F * * * * * * * *

MTSetInputs() F * * * * * * * *
Function Reference Library
• 78

TABLE 10: API FUNCTION STATUS AND PRODUCT SUPPORT (CONTINUED)

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 * * *

MTStepGain() - see MTChInputStepGain() F * * * * * * * *

MTStepVolume() F * * * * * * * *
Function Reference Library
• 79

TABLE 10: API FUNCTION STATUS AND PRODUCT SUPPORT (CONTINUED)

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 * * * * * * *

1 These APIs are not available on the LD101 station port


Function Reference Library
• 80
Introduction

APIs Presented Logically


The following section, organized in logical order, provides a detailed description of
each API.

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

INTRODUCTION - SETTING A BOARD’S CLOCK SOURCE

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

Set Clock Source

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

MTSetCTMasterClock YES Obtain clock


Clock Source = CLOCK_SOURCE_NET1 from trunk?

Select which Framer to use as


clock source
MTSetNET()

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

nBoard board index number


BusType MUX_MVIP or MUX_H100
ClockSource source for the specified master, ignored
when MODE_SLAVE is specified
Possible ClockSource values are:
CLOCK_SOURCE_OSC 1
CLOCK_SOURCE_CT_NETREF 2
MUX_H100 only
CLOCK_SOURCE_SEC8K 2
MUX_MVIP only
CLOCK_SOURCE_CT_H100 3
MUX_H100 only
CLOCK_SOURCE_NET1 4
CLOCK_SOURCE_NET2 5
CLOCK_SOURCE_NET3 6
Board support:

LD, VR, NGX, DT, DP, CLOCK_SOURCE_OSC


AT, PT
NGX CLOCK_SOURCE_CT_NETREF
NGX CLOCK_SOURCE_SEC8K
NGX CLOCK_SOURCE_CT_H100
NGX, DT, DP CLOCK_SOURCE_NET1
NGX CLOCK_SOURCE_NET2
NGX CLOCK_SOURCE_NET3
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
Function Reference Library
• 93
Introduction

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_INVALID_BUSTYPE Invalid bus type was specified
Events
None
Function Reference Library
• 94
Introduction

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

nBoard board index number


BusType MUX_H100
Clock 0 for clock A (default), 1 for clock B,
MODE_CLOCK_A or MODE_CLOCK_B
fAutoSwitch true (default) to enable auto switching
to the alternate clock if the selected
clock is invalid
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Error in clock parameter
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
• 96
Introduction

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

MT_RET_BOARD_NOT_OPENED Board device not opened for access


MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 99
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.

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.

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

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 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
• 102
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.

The possible framer alarm enables are:


T1 Framer Alarm Enables:
ALARM_LOS for Loss of Signal alarm
ALARM_LOF for Loss of Frame alarm
ALARM_AIS for Alarm Indication Signal alarm
ALARM_YELLOW for YELLOW alarm (Remote Alarm Indica-
tion - RAI)
E1 Framer Alarm Enables:
ALARM _LOS for Loss of Signaling Multiframe Align-
ment alarm
ALARM_LOSMF for Loss of Signaling Multiframe Align-
ment alarm enable. This alarm is not
used when configured for Basic E1.
ALARM _LOCRCMF for Loss of CRC Multiframe Alignment
alarm. This alarm is not used when con-
figured for Basic E1.
ALARM _TS16RAI for Time Slot 16 Remote Alarm
Indication alarm. This alarm is not
used when configured for ISDN or
DASS2.
ALARM_YELLOW for YELLOW alarm (Remote Alarm Indica-
tion - RAI)
NGX Framer Alarm Enables:
ALARM _LOS for Loss of Signaling Multiframe Align-
ment alarm

NOTE: A definition of each alarm is available where the API


MTGetFramerAlarmStatus() is defined.
Prototype
MT_RESULT MTArmFramerAlarm(
const BOARD nBoard,
const USHORT nFramer,
const ULONG AlarmEnable
Function Reference Library
• 103
Introduction

);
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.

The possible framer alarm enables are


T1 Framer Alarm Enables:
ALARM_LOS for Loss of Signal alarm
ALARM_LOF for Loss of Frame alarm
ALARM_AIS for Alarm Indication Signal alarm
ALARM_YELLOW for YELLOW alarm
E1 Framer Alarm Enables
ALARM _LOSMF for Loss of Signaling Multiframe Align-
ment alarm
ALARM _LOCRCMF for Loss of CRC Multiframe Alignment
alarm
ALARM _TS16RAI for Time Slot 16 Remote Alarm
Indication alarm
ALARM_LOS Loss of Signal alarm
ALARM_YELLOW for YELLOW alarm
NGX Framer Alarm Enables:
ALARM _LOS for Loss of Signaling Multiframe Align-
ment alarm
Prototype
MT_RESULT MTDisarmFramerAlarm(
const BOARD nBoard,
const USHORT nFramer,
const ULONG AlarmEnable
);
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
Function Reference Library
• 105
Introduction

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
EVT_LOS_ALARM
EVT_LOF_ALARM
EVT_AIS_ALARM
EVT_YELLOW_ALARM
EVT_LOSMF_ALARM
EVT_LOCRCMF_ALARM
EVT_TS16RAI_ALARM
Function Reference Library
• 106
Introduction

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.

A non-zero value in field of LOS_Alarm, LOF_Alarm, AIS_Alarm, or


YELLOW_Alarm indicates the framer has detected that alarm and
the alarm condition has not cleared.
Prototype
MT_RESULT MTGetFramerAlarmStatus(
const BOARD nBoard,
const USHORT nFramer,
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)
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.
Structure
In T1 mode, framer status MT_FRAMER_STATUS is defined as
follows:

TABLE 11: MT_FRAMER_STATUS - T1


Type Name Purpose

UCHAR nFramer Framer index


UCHAR LOS_Alarm LOS alarm detected and is still present. This
may indicate that the incorrect signal is being
received (wrong configuration) or the trunk is
unplugged.
UCHAR LOF_Alarm LOF alarm detected. The framer alignment of
the Rx signal is incorrect possibly due to a weak
signal, or bit errors. This alarm is also present
while the framer is synching upon start-up and
clears after 30 seconds.
Function Reference Library
• 108
Introduction

TABLE 11: MT_FRAMER_STATUS - T1


Type Name Purpose

UCHAR AIS_Alarm Alarm Indication Signal (AIS) alarm detected.


Transmitted to the NI upon a loss of originating
signal or a sever disruption.
UCHAR YELLOW_Alarm Yellow alarm, also known as the Remote Alarm
Indicator (RAI). Communicates a loss of signal
or an out of frame to the far end.
UCHAR SMFAE Not applicable, E1 only
UCHAR SMFCRC4E Not applicable, E1 only
UCHAR TS16RAI_alarm Not applicable, E1 only

In E1 mode, framer status MT_FRAMER_STATUS is defined as


follows:

TABLE 12: MT_FRAMER_STATUS - E1


Type Name Purpose

UCHAR nFramer Framer index


UCHAR LOS_Alarm LOS alarm detected and is still present. This
may indicate that the incorrect signal is being
received (wrong configuration) or the trunk is
unplugged.
UCHAR LOF_Alarm not applicable
UCHAR AIS_Alarm not applicable
UCHAR Yellow_Alarm Yellow alarm, also known as the Remote Alarm
Indicator (RAI). This data is obtained from Bit 3
of Timeslot 0 (odd frames only). Communicates
a loss of signal or an out of frame to the far end.
UCHAR SMFAE Indicates signaling MF alignment error. The
received alignment bits (bits 1-7 of even
frames, timeslot 0) are not aligned to the local
system. This field is not used when config-
ured for Basic E1.
UCHAR SMFCRC4E Indicates a CRC-4 MF (Cycle Redundancy) error
- the occurrence of a received set of check bits
that differ from the locally generated code. The
E Bits ( Bit 1 of Frames 13 and 15 of Timeslot 0)
is set to 1 to indicate an alarm state. Each E bit
represents one sub-frame.This field is not
used when configured for Basic E1.
UCHAR TS16RAI_alarm Timeslot 16 RAI indicator. A Remote Alarm Indi-
cator (RA) indicating a remote side signaling
multi-frame error. Bit 6 of Timeslot 16 is set to 1
(alarm state) when signaling bits (bits 0-3 of
framer 0 TS 16) are not aligned.
This field is not valid when configured for ISDN
DASS2 and the data should be ignored.
Function Reference Library
• 109
Introduction

In NGX mode, framer status MT_FRAMER_STATUS is defined as


follows:

TABLE 13: MT_FRAMER_STATUS - NGX


Type Name Purpose
UCHAR nFramer N/A
UCHAR LOS_Alarm LOS alarm detected and is still present. This
may indicate that the incorrect signal is being
received (wrong configuration) or the trunk is
unplugged.
UCHAR LOF_Alarm N/A
UCHAR AIS_Alarm N/A
UCHAR YELLOW_Alarm N/A
UCHAR LOSMF_Alarm N/A
UCHAR LOCRC4MF_alarm N/A
UCHAR TS16RAI_alarm N/A

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:

TABLE 14: MT_T1_FRAMER_STAT


Type Name Purpose

ULONG FrameErr; Framing bit error


In T1 mode, a framing bit error is
defined as an Fe-bit error when using
ESF, and a framing bit error when
using SF.
ULONG OutofFrameErr; Out of frame error
In T1 mode, OutOfFrameErr indicates
the number out of frame alignment
events that occurred during the previ-
ous accumulation interval. The count
is incremented each time a severely
erred framing event forces a reframe.
ULONG BitErr; Bit errors
In T1 mode, BitErr contains the number of
bit error events that
occurred during the previous accumula-
tion interval. A bit error event is defined as
a CRC-6 error when using ESF, a framing
bit error when using SF.
Function Reference Library
• 111
Introduction

TABLE 14: MT_T1_FRAMER_STAT


Type Name Purpose

ULONG LineCode_ZeroRunErr; Line Code Violation count


LineCode_ZeroRunErr bits indicate the
number of LCV error events that occurred
during the previous accumulation inter-
val. An LCV event is defined as the occur-
rence of a bipolar violation or excessive
zeros.

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.

The framer index is 0 for the first framer.


Prototype
MT_RESULT MTGetE1FramerStatistic(
const BOARD nBoard,
const USHORT nFramer,
PMT_E1_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_E1_FRAMER_STAT structure.
Structure
For E1 mode, the framer status MT_E1_FRAMER_STAT is defined as
follows:

TABLE 15: MT_E1_FRAMER_STAT


Type Name Purpose

ULONG FASErr; Framing bit error


In E1 mode, the count is either num-
ber of FAS (frame alignment signal)
bits.
ULONG FarEndBlockErr; Far end block errors (FEBE)
In E1 mode, FarEndBlockErr indicates the
number of far end block error
events that occurred during the previous
accumulation interval. FEBE
counts are suppressed when the E1
framer has lost frame alignment.
Function Reference Library
• 113
Introduction

TABLE 15: MT_E1_FRAMER_STAT


Type Name Purpose

ULONG CRCErr; In E1 mode, CRCErr indicates the num-


ber of CRC error events that
occurred during the previous accu-
mulation interval. CRC error events are
suppressed when the framer is out of
CRC-4 multiframe alignment.
ULONG LineCode_ZeroRunErr; Line Code Violation count
LineCode_ZeroRunErr bits indicate the
number of LCV error events that occurred
during the previous accumulation inter-
val. An LCV event is defined as the occur-
rence of a bipolar violation or excessive
zeros.

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

TABLE 16: MT_NTTE_STATISTICS


Type Name Purpose

ULONG NTErr* PBX error. Indicates packets from PBX with


bad data and listed as errors. These can result
from random bad packets, or bad line condi-
tions.
ULONG TEErr* phone error. Indicates packets from the phone
with bad data and listed as error. These can result
from random bad packets or bad line condi-
tions.
ULONG SyncErr* Indicates a complete loss of signal
float NTAmpl PBX amplitude in volts. This is not an error indica-
tion, rather it is a true reading of current voltage
levels.
Function Reference Library
• 115
Introduction

TABLE 16: MT_NTTE_STATISTICS


Type Name Purpose

float TEAmpl Phone amplitude in volts. This is not an error indi-


cation, rather it is a true reading of current voltage
levels.
float Noise Noise amplitude in volts. Recommended noise
amplitude should be below 80 mv. If the noise is
above this value, verify cable lengths, taps, and
punchdown connections.
UCHAR SignalClipStatus Indicates clipping status since last call to API (sta-
tus clears after each API call). A returned value of 0
indicates normal conditions. If the clipping value is
high, change gain. If there are clipping errors then
this will impact the other readings, first clear these
errors then get NGX Framer Statistics again to ver-
ify the other readings.

* Only these fields cleared when the MTClearFramerStatistics() API is called.


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_INVALID_PARAM Error in function pointer
MT_TIMEOUT Wait for event timed out
MT_RET_BUSY Board is busy
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
• 116
Introduction

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:.

TABLE 17: MT_FRAMER_STATE


Type Name Purpose

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.

The MT_FRAMER_STAT structure is defined where the


MTGetT1FramerStatistic() and the MTGetE1FramerStatistic()
APIs are explained.
When MTClearFramerStatistic() is called on the SmartWORKS
NGX, the MT_NTTE_FRAMER_STAT structure is used. This structure
is defined where the MTGetNGXFramerStatistic() is explained.
Note that only the following elements are cleared: NTErr, TEErr, and
SyncErr.
Prototype
MT_RESULT MTClearFramerStatistic(
const BOARD nboard,
const USHORT nFramer
);
Parameters

nboard board index


nFramer framer index
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
• 119
Introduction

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

nBoard Board index number


nFramer Framer number
LoopbackMode Valid mode Id. See description above.
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 not opened for access
MT_RET_NOT_AVAILABLE Driver is not loaded
Function Reference Library
• 120
Introduction

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

nBoard Board index number


nFramer Framer number
pLoopbackMode Pointer to the buffer containing the
LoopbackMode information
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 not opened for access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 122
Introduction

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

nBoard Board index number


nFramer Framer number
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 not opened for access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 123
Introduction

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()");

A complete code example is available on the Ai-Logix website:


http://www.ai-logix.com/support.html
Function Reference Library
• 125
Introduction

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

EVT_OUTGOING_SIGCHANGE and EVT_INCOMING_SIGCHANGE are gen-


erated.
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

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()");

A complete code example is available on the Ai-Logix website:


http://www.ai-logix.com/support.html
Function Reference Library
• 129
Introduction

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:

Value Bit Designation

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;
}

A complete code example is available on the Ai-Logix website:


http://www.ai-logix.com/support.html
Function Reference Library
• 131
Introduction

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

AUDIO JACK FUNCTIONS


(Mux/MVIP Bus Routines)
Function Reference Library
• 133
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 stream may have the following values:


0 - 15 MVIP bus selected
0 - 31 H.100 bus selected

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

BOARD INFORMATION FUNCTIONS


Function Reference Library
• 144
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:

local_board = global_board - MTSYS_INFO.startBoard.

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:

TABLE 18: MTADAPTER_INFO


Type Name Description

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

TABLE 18: MTADAPTER_INFO


Type Name Description

ULONG Option1 bit 0: WAV


bit 1: MVIP
bit 2: Volume/Pitch
bit 3: MF
bit 4: Silence Compression
ULONG Option2 bit 0: Caller ID
bit 1: Conference
bit 2: Call Logging
bit 4: FAX
bit 6: Pulse detection
ULONG Digirate Digitizing rate
ULONG Bandwidth Channel bandwidth
ULONG PCISlot PCI slot number
ULONG PCIBusNumber PCI bus number
ULONG BoardType Board Type of DUAL_T1_PASSIVE_HI_CARD, etc. All board types are
defined in the NtiData.h file.
UCHAR BusType MUX_H100, MUX_MVIP, or MUX_NONE
UCHAR MasterMode Board Master Mode of the following:
0: slave board
1: MVIP master, or H100 Master A
2: H100 Master B
UCHAR MasterClock Master clock source reference value of CLOCK_SOURCE_OSC, and
etc. All board clock reference codes are defined in the NtiData.h file.
UCHAR Sec8kNetrefClock MVIP Sec8K or H100 Netref clock output
0: Disabled, output tri-stated
1, 3 - 4: Type of clock reference of CLOCK_SOURCE_OSC, etc. All
board clock reference codes are defined in the NtiData.h file.
UCHAR NumSummations Number of summation resource on board, if any
UCHAR StartSummation Index of the first on board summation resource
UCHAR NumAudios Number of audio jack resource on board, if any
UCHAR StartAudio Index of the first on board audio jack resource
UCHAR TDMSignaling CT TDM bus signaling: ULAWPXD for u-law (defined as 1), ALAWPXD
for A-law (defined as 2)
UCHAR ConfigurationID Adapter Configuration Index (i.e. SwitchIndex)
UCHAR res[3] Reserved
MT_VERSION FWVersionExpected 0x02040b05 is Version 2.4.11.5, i.e. major version 2, minor version 4,
point of release version 11, and build version 5.

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

MT_RET_NOT_AVAILABLE Driver is not loaded


Events
None

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

See also: MTGetSystemInfo()


Function Reference Library
• 147
Introduction

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

TABLE 19: MT_ADAPTER_XINFO


Type Name Function
ULONG BoardNumber Board index in SDK, i.e. SystemIndex, 0 for
the 1st board
USHORT NumFramers Number of local framers: 0 - 4
UCHAR FramerSignaling[4] Signaling for the max. of 4 framers. All
signaling values are defined in the
NtiData.h file.
UCHAR FramerProtocol[4] Protocol variant for the max. of 4 framers.
All protocol values are defined in the
NtiData.h file.
USHORT NumTrunks Number of trunks on board: 0 - 2
UCHAR TrunkChannelCount[2] Number of channels on each trunk
UCHAR TrunkSignaling[2] Signaling for the max. of 2 trunks
UCHAR TrunkProtocol[2] Protocol variant for the max. of 2 trunks.
All values are defined in the NtiData.h file.
UCHAR TrunkInterfaceSide[2] Terminal/Network side support for 2
trunks:
0 = SUPPORT_TE, Terminal side support
1 = SUPPORT_NT, Network side support
UCHAR TrunkNFASId[2] Signaling NFAS Group Index
Function Reference Library
• 149
Introduction

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:

TABLE 20: MTOEM_INFO


Type Name Description

CHAR OEMInfo[OEM_INFO_LEN] NULL terminated string


with OEM information,
maximum size 64 bytes
CHAR Copyright[OEM_INFO_LEN] NULL terminated string
with copyright informa-
tion, maximum size 64
bytes

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

See also: MTGetBoardAssemblyInfo()


Function Reference Library
• 152
Introduction

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

TABLE 21: MT_SERIAL_INFO


Type Name Description

CHAR AssemblyNumber NULL terminated string, maximum size 16


bytes
CHAR HWRevision NULL terminated string of hardware revi-
sion number, maximum size 4 bytes
CHAR SerialNumber NULL terminated string of board serial
number, maximum size 8 bytes
CHAR AssemblyCode NULL terminated string of assembly code,
maximum size 4 bytes
CHAR DateCode NULL terminated string of manufacturing
date, maximum size 8 bytes

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

See also: MTGetBoardOEMInfo()


Function Reference Library
• 154
Introduction

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 CONNECTION FUNCTIONS


Some boards of the SmartWORKS family support a Call Control API for the purpose
of managing active calls. The Call Control API is used primarily on the SmartWORKS
DT board to provide terminate support. The SmartWORKS DP card also relies on this
API to receive call indications for passive monitoring.

SMARTWORKS CALL CONTROL API


The SmartWORKS Call Control API is an abstraction layer that provides application
developers the interface to issue outgoing calls, receive and accept incoming calls,
and tear down calls without requiring an extensive knowledge of the signaling
protocol. The SmartWORKS Call Control API provides a powerful interface for all
signaling protocols.
Function Reference Library
• 161
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

Request Confirmation Indication Response

SmartWORKS

FIGURE 22: CALL PROCESSING


Function Reference Library
• 162
Introduction

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()

EVT_CC_CONNECT_CONF Call is connected


end to end

FIGURE 23: INCOMING CALLS


Function Reference Library
• 163
Introduction

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

EVT_CC_CONNECT_CONF Call is connected


end to end

FIGURE 24: OUTGOING CALLS

CALL SCREENING AND NUMBER PRESENTATION


The SmartWORKS API allows users to control outbound calling presentation or
screening. These options are controlled by the PresScrnInd field in the
MT_CC_CONNECT_REQ structure. This field relies as two bits to control presentation
and screening (user must apply OR logic, one can use presentation OR screening).
The least significant bit controls screening while the most significant bit controls
presentation. All fields are defined in the NTIDataCC.h file. The table below provides
an explanation of each field:
Function Reference Library
• 164
Introduction

TABLE 25: OUTBOUND SCREENING AND PRESENTATION OPTIONS

Bit Name Description

Screening Options

0x00 MT_CC_USR_NOTSCREENED Calling number is not screened

0x01 MT_CC_USR_VERIFIED_PASSED Calling number is verified by the local switch. If


number is not valid, the call is passed through
but flagged as such for the far end

0x02 MT_CC_USR_VERIFIED_FAILED Calling number is verified by the local switch. If


number is not valid, the call is not passed
through

0x03 MT_CC_NET_PROVIDED A calling number known by the local switch is


displayed to the far end

Presentation Options

0x00 MT_CC_PRES_ALLOWED Calling number is presented to far side

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

APPLICATION INITIATED CALL CLEARING


The diagram below shows the Call Control exchange for a typical call tear down
initiated by a user application:
1 · The application formats an MT_CC_DISC_REQ structure and calls the API
function MTCC_DiscRequest().
2 · The polling or callback mechanism notifies the application that the call tear
down is complete and that the resources are available via the
EVT_CC_DISC_CONF event.

Application Initiated Call Clearing


User Application SmartWORKS
MTCC_DiscRequest

tEVT_CC_DISC_CONF

FIGURE 26: APPLICATION INITIATED CALL CLEARING

NETWORK INITIATED CALL CLEARING


The user application is notified of a network initiated call clearing request via
EVT_CC_DISC_IND. Upon receipt of this event, the application considers the call
released and the resources available. No application response is necessary for this
event.
EVENTS GENERATED WHEN PASSIVE MONITORING
The following section provides examples of which events are generated by the
passive call control system:
Function Reference Library
• 166
Introduction

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.

SUPPLEMENTARY SERVICES FOR ISDN TERMINATE SUPPORT


Information elements are collected to provide the following supplementary
services:

Call Hold /Call Retrieve Call transfer

Call Forward on Busy Charging

Call Forward unconditional Recall

Call Forward on No Reply Three party Conference

Suspend/Resume Malicious Call ID

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)

BASIC CALL SETUP


The following illustrates call setup as implemented on the DT card.
Function Reference Library
• 171
Introduction

SMARTWORKS RBS SIGNALING PROTOCOLS


The SmartWORKS DT supports Robbed Bit Signaling (RBS) protocols. Several
variants of each protocol are also supported.

ROBBED BIT SIGNALING


The Robbed Signaling protocol stack allows SmartWORKS DT cards to connect to T1
trunks using the following RBS variants:
• E&M Immediate Start
• E&M Wink Start
• Loop Start FXS
• Loop Start FXO
The E&M Immediate Start and Wink Start variants are symmetrical, meaning that
the customer premises uses the same variant as the central office. The Loop Start
FXS and FXO variants are not symmetrical, meaning that one side uses the FXS
variant and the other side must use the FXO variant.
CONFIGURATION PARAMETERS
The variants mentioned above use Dual Tone Multi Frequency (DTMF) digits for
dialing. Optimization of the call connection delay is provided by the following
configuration parameters:
• Maximum Inter-digit Time
• DID Maximum number of digits
These two parameters are provided in the trunk configuration, and affect all
channels on a trunk.
RBS IMPLEMENTATION CHARACTERISTICS
Incoming Calls
When the inbound side detects a line seizure (E&M Wink Start or E&M Immediate) or
a ring indication (Loop Start), the RBS stack indicates a call presence to the
application via the EVT_CC_CONNECT_IND event and starts a 10 second timer that
listens for digits. If no digits are detected within 10 seconds, the RBS stack notifies
the application that this call doesn't have a called party number via the
EVT_CC_INFO_IND event. If the called party number is valid, the application accepts
the request and establishes the call connection. If the called party number is invalid,
the request is refused and a connection is not established.
RBS is an in-band signaling method that extracts the least significant bit of certain
DS0 frames and uses them as signaling bits to monitor the ON-HOOK/OFF-HOOK
status of the line. In the Wink Start variant, when a phone receiver is picked-up or
goes off-hook by the calling party, the public switched telephone network (PSTN)
verifies that it’s ready to process a request (i.e. the called party digits) by going
off-hook for approximately 200 ms, and then going back on-hook. This process is
known as sending a wink.
When the called party digits are received, the called party goes off-hook and the call
connection is established. Once the calling party hangs-up, the RBS stack notifies
the application that the call connection is released at which point line resources are
made available via the EVT_CC_DISC_IND event.
Function Reference Library
• 172
Introduction

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

RBS protocol to Call Control API Mapping


This section shows how the SmartWORKS RBS implementation maps the Call
Control API to each RBS protocol variant.

E&M Immediate
Call Control RBS Stack RBS Stack Call Control

MTCC_ConnectRequest Off hook EVT_CC_CONNECT_IND

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

MTCC_DiscRequest On hook EVT_CC_DISC_IND

EVT_CC_DISC_CONF On hook

Outgoing Incoming

FIGURE 27: E&M IMMEDIATE


Function Reference Library
• 174
Introduction

E&M Wink
Call Control RBS Stack RBS Stack Call Control

MTCC_ConnectRequest Off hook EVT_CC_CONNECT_IND

EVT_CC_PROGRESS_IND WINK

DTMF Digits EVT_CC_INFO_IND


User Application

User Application
EVT_CC_CONNECT_CONF Off hook MTCC_ConnectResp

EVT_CC_CONNECT_CONF

MTCC_DiscRequest On hook EVT_CC_DISC_IND

EVT_CC_DISC_CONF On hook

Outgoing Incoming

FIGURE 28: E&M WINK


Function Reference Library
• 175
Introduction

Loop Start FXS-FXO


FXS FXO

Call Control RBS Stack RBS Stack Call Control

MTCC_ConnectRequest Off hook EVT_CC_CONNECT_IND

EVT_CC_PROGRESS_IND

DTMF Digits EVT_CC_INFO_IND


User Application

User Application
EVT_CC_CONNECT_CONF MTCC_ConnectResp

EVT_CC_CONNECT_CONF

MTCC_DiscRequest On hook EVT_CC_DISC_IND

EVT_CC_DISC_CONF

Outgoing Incoming

FIGURE 29: LOOP START FXS-FXO


Function Reference Library
• 176
Introduction

Loop Start FXO-FXS


FXO FXS

Call Control RBS Stack RBS Stack Call Control

MTCC_ConnectRequest Ring EVT_CC_CONNECT_IND

EVT_CC_PROGRESS_IND

EVT_CC_INFO_IND
User Application

User Application
EVT_CC_CONNECT_CONF Off hook MTCC_ConnectResp

EVT_CC_CONNECT_CONF

MTCC_DiscRequest On hook EVT_CC_DISC_IND

EVT_CC_DISC_CONF On hook

Outgoing Incoming

FIGURE 30: LOOP START FXO-FXS


Function Reference Library
• 177
Introduction

TERMINATE CARDS (T1 RBS, ISDN) FUNCTIONS


The following APIs are used for Terminate ISDN (PRI) on the DT cards.

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.

Outgoing Call Control shown with call progress indicators.

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.

Incoming call shown with application responses:

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

An application initiated call release:

MTCC_ConnectResp()

EVT_

A network initiated call release:

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

TERMINATE CARDS (ISDN) FUNCTIONS


Ai-Logix, Inc.
186 •
SmartWORKS Developer’s Guide

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

PASSIVE CARDS (ISDN) FUNCTIONS


These APIs are used on the SmartWORKS DP, and the SmartWORKS NGX cards to
control passive ISDN capabilities.

NOTE: The SmartWORKS DP card supports ISDN PRI while the


SmartWORKS NGX supports ISDN BRI.

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

CALL CONTROL INDICATIONS


The board issues the following indications to the upper user application:
• Call Connected Indication
• Call Cleared Indication
• Call Held Indication
• Call Retrieved Indication
• Call Rejected Indication
• Call Abandoned Indication
All these indications are events in the SmartWORKS MT_EVENT structure. When a
channel receives one of these events, the MT_EVENT fields are set as follows:
1 · The TimeStamp field of the MT_EVENT structure indicates a time stamp of when
the event occurred
2 · The EventCode field indicates the CC event code value as defined in the file
NtiEvent.h
3 · The channel field indicates the channel on which the event happened
4 · The PtrBuffer field carries a pointer to an MT_CC_CALL_INFO structure
containing all the available information about the call. This structure is defined
in the file NtiDataCC.h
5 · The DataLength field contains the size of the MT_CC_CALL_INFO structure

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:.

TABLE 31: MT_CC_CALL_INFO


Type Name Function
ULONG CallRef A unique value assigned by the user’s
application for each call.
ULONG CallSource Only 2 values are possible
MT_CC_INCOMING_CALL or
MT_CC_OUTGOING_CALL
ULONG CallState State of the call. Call states are defined
in the NtiDataCC.h file.
ULONG CallTrunk The trunk where the call occurred.
ULONG CallDuration The total length of the call
ULONG Layer1Coding Layer1 coding on B channel, defined in
NtiDataCC.h file.
ULONG Cause The cause of the last release. Cause types
are defined in the NtiDataCC.h file.
MT_CC_CHANNEL_ID ChannelId This structure is defined on the next
pages.
MT_CC_PARTY_NUMBER CallerNumber This structure is defined on the next
pages. If no number has been obtained,
the number of digits field = 0.
MT_CC_PARTY_SUBADDR CallerSubAddr This structure is defined on the next
pages. If no number has been obtained,
the number of digits field = 0.
MT_CC_PARTY_NUMBER CalledNumber This structure is defined on the next
pages. If no number has been obtained,
the number of digits field = 0.
MT_CC_PARTY_SUBADDR CalledSubAddr This structure is defined on the next
pages. If no number has been obtained,
the number of digits field = 0.
MT_CC_PARTY_NUMBER ConnectedNumber This structure is defined on the next
pages. If no number has been obtained,
the number of digits field = 0.
MT_CC_PARTY_SUBADDR ConnectedSubAddr This structure is defined on the next
pages. If no number has been obtained,
the number of digits field = 0.
Ai-Logix, Inc.
192 •
SmartWORKS Developer’s Guide

TABLE 31: MT_CC_CALL_INFO


Type Name Function
MT_CC_PARTY_NUMBER RedirectingNumber This structure is defined on the next
pages. If no number has been obtained,
the number of digits field = 0.
MT_CC_CALL_IDENTITY CallIdentity This structure is defined on the next
pages.

CHANNEL IDENTIFICATION STRUCTURE


.

Table 32: MT_CC_CHANNEL_ID


Type Name Function
int Pref_Excl Preferred or Exclusive
int InterfaceId Trunk Number
int TimeSlot Time slot within the trunk

The Pref_Excl field is only for terminate products (SmartWORKS).


The InterfaceId field provides the trunk number where the B-channel resides.
The TimeSlot field provides the TDM time slot that is mapped to the SmartWORKS
DP resource channel.
PARTY NUMBER STRUCTURE
This structure is used to indicate the calling party number (also called caller number),
the called party number and the connected number..

Table 33: MT_CC_PARTY_NUMBER


Type Name Function
int TypeOfNumber Numbering Type :UNKNOWN,
NATIONAL, SUBSCRIBER or
ABBREVIATED
int NumberingPlan UNKNOWN, NATIONAL,
PRIVATE_PLAN, DATA_PLAN,
TELEX_PLAN
int NumberOfDigits Gives the size of the digits field.
This field varies from 0 to
MAX_PARTY_DIGITS, which is 32
UCHAR Digits[MT_CC_MAX_PARTY_DIGITS] The called number digits

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

Table 34: MT_CC_PARTY_SUBADDR


Type Name Function
int NumberOfDigits The number of digits in called
number. This field varies from 0 to
MAX_PARTY_DIGITS, which is 32
int SubAddrType See below.
int OddEvenInd See below.
UCHAR Digits[MT_CC_MAX_SUBADDR_DIGITS] The called number digits

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
.

Table 35: MT_CC_CALL_IDENTITY


Type Name Function
int Length The length of the call identity string
UCHAR Identity[MT_CC_MAX_IDENTITY_SIZE The call identity string
Ai-Logix, Inc.
194 •
SmartWORKS Developer’s Guide

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

A complete code example is available on the Ai-Logix website:


http://www.ai-logix.com/support.html
Ai-Logix, Inc.
198 •
SmartWORKS Developer’s Guide

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.

The counts returned correspond to the total number since the


channel was last opened. The MT_PHY_STATS structure separates
incoming and outgoing data. Incoming data is presented first.
Prototype
MT_RESULT MTGetPHYStatistics (
const BOARD nBoard,
const USHORT nTrunk,
PMT_PHY_STATS const pPHYStats, (defined in the NtiDataCC.h
file)
PULONG const pLength
);
Parameters
nBoard Board Number
nTrunk Trunk Number within the specified
Trunk
pPHYStats a pointer to an MT_PHY_STATS structure
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MT_PHY_STATS structure.
Structure
The MT_PHY_STATS structure is defined as follows:
Incoming
RxOverflowCnt the count of received overflow errors
due to too much incoming traffic on the
Ai-Logix board
InvalidFramesCnt the count of invalid frames received
from incoming traffic. These may be due
to CRC errors or truncated frames. Typi-
cally this indicates a problem with the
Ai-Logix board
ValidFramesCnt the total count of valid frames received
in the incoming direction
Outgoing
RxOverflowCnt the count of received overflow errors
due to too much outgoing traffic on the
Ai-Logix board
InvalidFramesCnt the count of invalid frames received
from outgoing traffic. These may be due
to CRC errors or truncated frames. Typi-
cally this indicates a problem with the
Ai-Logix board
Function Reference Library
• 203
Introduction

ValidFramesCnt the total count of valid frames received


in the outgoing direction.
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Error in one of the passed parameters
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Ai-Logix, Inc.
204 •
SmartWORKS Developer’s Guide

INTRODUCTION: CHANNEL FUNCTIONS


All channels within Ai-Logix boards are numbered using GCI indexing sequentially
from 1 to the number of available channels. The logical total channel count is
defaulted to 512, which is the maximum physical channels supported by the DLL.
NtiDrv.dll supports channels up to the minimum of this logical count and the actual
physical channels available on the SmartWORKS boards in the platform.

If the logical channel count is set to 16 on a platform of 2 SmartWORKS VR cards, the


total number of channels accessible through the API is 16 even though the total
number of physical channels is 128. On the other hand, if the logical channel count
is set to 256, the total number of channels accessible is 128 since the total count of
physical channels available is 128.
The logical total channel count can be changed through the Smart Control applet.
CALLERID CONTROL
SmartWORKS boards enable caller ID detection by default. How CallerID control is
managed depends on the type of network:
Analog / Digital PBX CallerID Control
This process is used by SmartWORKS AT, SmartWORKS PT and SmartWORKS NGX
boards. One exception being if the NGX board is used on a BRI network, refer to the
ISDN callerID section below.
There are two events that support the caller ID function: EVT_CALLID_DROPPED
and EVT_CALLID_STOP. The EVT_CALLID_STOP event notifies the application that
the SmartWORKS board has finished retrieving caller ID data and the received data
is successfully queued. The SubReason field of event EVT_CALLED_STOP contains
the length of the caller ID packet, XtraInfo field contains the first 4 bytes of the caller
ID data packet. Each channel is allowed to queue up to 15 caller ID information.
EVT_CALLID_DROPPED indicates that good caller ID information is dropped due to
queue full.
Each channel can queue up to 15 caller ID packets. API function, MTGetCallerID() is
provided to retrieve caller ID information only.

TABLE 36: CALLERID CONTROL


MTDisableCallerID()
MTEnableCallerID()
MTFlushCallerID()
MTGetCallerID()
MTGetCallerIDStatus()

ISDN CallerID Control


This process is used by SmartWORKS DT, SmartWORKS DP, and SmartWORKS NGX
(when tapping ISDN BRI networks only). When using ISDN ConnectionID and
CalledPartyAddr information is stored in the call control structures (MT_CC_).
To obtain callerID information use MTSetEventCallback() or
MTSetBoardEventCallback(). ISDN events are reported as channel events on
SmartWORKS DP, SmartWORKS NGX, plus SmartWORKS DT cards configured for
RBS. Otherwise, all ISDN events reported on the SmartWORKS DT card are reported
as board events.
Function Reference Library
• 205
Introduction

DTMF/MF AND TONE CONTROL


SmartWORKS boards are equipped to send and receive DTMF digits, handle
incoming digits, and dial numbers.
Dialing a string is accomplished by passing a string with valid DTMF digits or control
characters and invoking one of the dial functions. Valid digits are 0 - 9 and ABCD#*.
Control characters are as follows:
& - Generates a hook flash (SmartWORKS AT and SmartWORKS LD only)
, (comma) - Inserts a pause
T - Switches back to DTMF dialing mode
W - Signals that the SmartWORKS board must wait for a dial tone before dialing the
remainder of the string. (Call Progess Monitoring must be enabled:
MTCPMControl().
H - Take the line OFF_HOOK if it is ON_HOOK (SmartWORKS AT and SmartWORKS
LD only)

The function MTDialString() is used to dial a string of digits. MTCallString() is a


background function that automatically calls a number. This function takes the
channel off hook, waits for dial tone, dials the number, and then determines if the
call is answered.
When a SmartWORKS board detects a DTMF digit, the EVT_DIGIT event is issued
with the digit information in the SubReason field. The digit is then stored in a
separate queue (per channel) called the DTMF queue. A digit stays in the queue
until the application discards or retrieves it. If the application never issues a DTMF
retrieval call [MTReadDigit()] the SmartWORKS API will continue to store all
detected digits until the DTMF queue for that channel is full. The DTMF queue is 65
digits deep for each channel. Should a received digit be dropped due to a full queue
the EVT_DIGIT_DROPPED event is issued.
The same applies to Ai-Logix boards that support MF tones. Events EVT_MFTONE
and EVT_MFTONE_DROPPED report MF tone detection and queuing. SmartWORKS
boards have the capability to differentiate whether the DTMF or MF tone is
detected on the primary input or the attached secondary input. This information is
also queued along with the tone. Functions MTReadDTMFTone() and
MTReadMFTone() retrieve the queued tone along with the channel information.
MTClearDTMFDigits() clears the DTMF queue while MTClearMFTones() clears the
MF queue. MTReadDigit(), MTReadDTMFTone(), and MTReadMFTone() return the
next digit/tone in the queue, if there is one.
MTGetDigits() is a background function that receives a string of digits. The
application must pass the address of a buffer where the received digits can be
stored. The required MT_IO_CONTROL structure specifies the termination
conditions. Possible termination conditions are a maximum number of digits, a
certain termination digit, exceeding a time limit, exceeding a time limit between
digits, etc. This function can terminate immediately if a specified termination digit
or number of digits are already in the queue.
Ai-Logix, Inc.
206 •
SmartWORKS Developer’s Guide

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

MTCallString(), MTCallStringAsync(), MTCallStringEx()


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. ie, MTCallStringA or
MTCallStringW.
Description
MTCallString() is a background function that automatically calls a
number. This function takes the channel off hook, waits for dial
tone, dials the number and switches to CPM completion mode to
determine if the call is answered.
NOTE: Both Call Progress Monitoring (CPM) and Voice Detection
must be enabled before MTCallString() can be invoked.
Since MTCallString() is a background function, it is controlled with
parameters set in the IO_CONTROL structure. Only the CPM_MODE,
MaxTime, TermEnable, and MoniEnable fields are used by
MTCallString(). The CPM_MODE field behaves exactly like the
media task settings. Here the user sets whether monitoring and
termination conditions are based on channel level settings, task
only, or both. The user application is responsible for initializing the
IO_CONTROL structure to proper settings. If a zero (0) is passed into
the CPM_MODE field then the setting TERM_USE_NONE and
MONI_USE_CHANNEL_ONLY is applied.

Since it is a background function, MTCallString() stops in the event


that a termination condition is met. When a termination condition
exists, this background functions stops and the event
EVT_CPM_STOP is generated. The SubReason and XtraInfo fields of
the MT_EVENT structure indicate the exact CPM termination type
(e.g. CPM_BUSY, CPM_NO_ANSWER, CPM_NO_RINGBACK,
CPM_CONNECT, CPM_INTERCEPT, CPM_NO_DIAL). The FuncCode
field identifies that MTCallString() has terminated. When certain
line conditions are detected, MTCallString() places the channel
back ON_HOOK and then the function terminates. If the call
remains connected, the user application is responsible for placing
the channel back ON_HOOK.
A complete description, including examples of call scenarios is
available in the application note: Managing CPM Events.

MTCallString() is only supported on ANALOG_FXO_LS type


channels on the SmartWORKS AT1600 card and
ANALOG_VFXO_LS_E types on the SmartWORKS LD card.

MTCallString(), MTCallStringAsync(), and MTCallStringEx() will


actually map to modified versions of themselves depending on
whether or not UNICODE is defined for the user application. See
“UNICODE Support” for more information about APIs affected by
defining UNCODE in a user application.
Ai-Logix, Inc.
208 •
SmartWORKS Developer’s Guide

Asynchronous Call Back


Any API that ends with the suffix Async uses callback as its
completion notification method. Each requires a completion
routine from the user application. The SmartWORKS function
completion routine mechanism is implemented in the same fashion
as a WindowsNT system function completion. In addition to the
completion routine address, the application also passes a
parameter of type LPARAM to the SmartWORKS DLL/Driver, which
passes the parameter back, without change, to the LPARAM
parameter.
Function Reference Library
• 209
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

MTDialString(), MTDialStringAsync(), MTDialStringEx()


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. ie, MTDialStringA or
MTDialStringW.
Description
MTDialString() is a background function that dials the specified
string. The default dialing is in DTMF mode and can be switched to
MF mode with the M control character. Change to pulse dialing
mode with the P control character. The string must be zero
terminated. The maximum length of the string buffer is 128 bytes,
therefore, the maximum nu5 mber of string characters is 127. This
function does not perform Call Progress Monitoring.
Option '&', and ‘H' are supported only on ANALOG_FXO_LS and
ANALOG_VFXO_LS_E channels. The MT_IO_CONTROL.MaxTime field
is used for caller to specify the maximum time to wait for option 'W'
or 'L'.
MTDialStringEx() and MTDialStringAsync() are functionally the
same as MTDialString(). MTDialStringEx() uses overlapped
structure to carry the event pointer for DLL to signal the application
of the completion of this background function;
MTDialStringAsync() uses a call back function as the completion
notification mechanism. The long word user parameter will be
passed, without altering, as a parameter to the application provided
completion function.
MTDialString(), MTDialStringAsync(), and MTDialStringEx() 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.

Asynchronous Call Back


Any API that ends with the suffix Async uses callback as its
completion notification method. Each requires a completion
routine from the user application to notify completion of the
requested API. The SmartWORKS function completion routine
mechanism is implemented in the same fashion as a WindowsNT
system function completion. In addition to the completion routine
address, the application also passes a parameter of type LPARAM to
the SmartWORKS DLL/Driver, which passes the parameter back
without change.
Ai-Logix, Inc.
212 •
SmartWORKS Developer’s Guide

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

W Wait for dial tone, this is only supported


on ANALOG_FXO_LS(SmartWORKS AT)
or ANALOG_VFXO_LS_E
(SmartWORKS LD) channels. (NOTE:
Call Progress Monitoring must be
enabled for dial tone detection).
H Used to go OFF_HOOK if the line is
ON_HOOK
L Wait for loop current detected
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_CHANNEL_NOT_OPENED Channel device not opened
for access
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
EVT_DIALED

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.

Each successive call to MTEnableCallerID() will set the detection


sensitivity to the level specified. The default value of 0x80 provides
moderate sensitivity for typical applications. Reducing the value to
0x02 provides detection of low-level signals but may decrease the
noise immunity of the detection algorithm.
Scenario
When caller ID detection is enabled, EVT_CALLID_STOP signals the
reception of a well formed 1200 bps FSK data packet. The packet
formats for both on-hook and off-hook (call waiting, caller ID) are
supported.

Upon reception of event EVT_CALLID_STOP, use MTGetCallerID() to


retrieve the data packet.
Prototype
MT_RESULT MTEnableCallerID (
const CHANNEL nChannel,
const USHORT nLevel
);
Parameters
nChannel channel number
nLevel signal sensitivity level (0x02 - 0x80)
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
EVT_CALLID_DROPPED
EVT_CALLID_STOP
Ai-Logix, Inc.
216 •
SmartWORKS Developer’s Guide

MTGetCallerIDStatus()
Description
CallerID detection operation state and level is retrieved for the
specified channel.

The caller ID detection operation state can be the following values:


1 caller ID detection is enabled on the channel
0 caller ID detection is disabled on the channel

The caller ID detection signal sensitivity level is between 0x02 and


0x80.
Prototype
MT_RESULT MTGetCallerIDStatus (
const CHANNEL nChannel,
PUSHORT const pState,
PUSHORT const pLevel
);
Parameters
nChannel channel number
pState Operation state:
1 = caller ID is enabled
0 - caller ID is disabled
pLevel Signal sensitivity level: 0x02-0x80.
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
• 217
Introduction

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.

Each channel can queue up to 15 caller ID data packets. All caller ID


information packets are queued in full, i.e. from the packet type
byte to the checksum byte.
Scenario
Event EVT_CALLID_STOP displays the length of the received caller
ID data packet in the SubReason field. User applications can use this
information to allocate the buffer size for MTGetCallerID().
Prototype
MT_RESULT MTGetCallerID (
const CHANNEL nChannel,
PUSHORT const pStringLen,
PUCHAR const pIDString
);
Parameters
nChannel Channel Number
pStringLen length of buffer provided and length of
packet on return
pIDString pointer to buffer for caller ID data string
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.
218 •
SmartWORKS Developer’s Guide

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

MTGetDigits(), MTGetDigitsAsync(), MTGetDigitsEx()


Description
MTGetDigits() is a background function that waits for one of the
termination conditions as specified by the MT_IO_CONTROL
structure. Set the buffer parameter of MT_IO_CONTROL to point to
a buffer where the API will place the received digits. Set the length
parameter to the size of the buffer. When this function terminates,
the string will be zero terminated, even if no digits are received. If a
digit matches a termination condition, all preceding digits plus the
terminating digit will be stored to the user buffer. If any other
termination event occurs before a digit termination, all received
digits are stored into the buffer.

It’s possible at the start of this function that a digit termination


condition already exists because digits may already be in the queue.
The background function transfers the digits and terminates
immediately. If this happens, there may still be digits in the queue
that were received after the terminating digit.

MTGetDigitsEx() and MTGetDigitsAsync() are functionally the


same as MTGetDigits(). The difference is the applied completion
notification mechanism. MTGetDigits() specifies no completion
notification. The user application receives events, such as
EVT_TERMDIGIT, EVT_MAXDIGITS and etc., based on the
termination condition. MTGetDigitsEx() uses the Windows
overlapped structure to pass into the API the event the application
must wait for to complete the request. When DTMF digit collection
terminates, the API issues a signal to the user application to
examine the digit result in the provided digit buffer.
MTGetDigitsAsync() uses call back notification, where at the
termination of a request, the provided completion function will be
invoked with the channel index, termination event, and the user
provided long word parameter.
NOTE:
When MTGetDigits(), MTGetDigitsAsync(), or MTGetDigitsEx() is
called, the event EVT_DIGIT_PRESSED will no longer be sent as due
to the fact that the digits pressed will be sent to a buffer until the
particular API terminates. When the API terminates, a termination
event will be sent and the digits in the buffer will be available for
use by the user application.

Asynchronous Call Back


Any API that ends with the suffix Async uses callback as its
completion notification method. Each requires a completion
routine from the user application to notify completion of the
requested API. The SmartWORKS function completion routine
mechanism is implemented in the same fashion as a WindowsNT
system function completion. In addition to the completion routine
address, the application also passes a parameter of type LPARAM to
the SmartWORKS DLL/Driver, which, in turn, passes the parameter
back without change to the LPARAM parameter.
Ai-Logix, Inc.
222 •
SmartWORKS Developer’s Guide

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.

When queued, information about whether the DTMF digit is


received on the primary or the secondary channel is also recorded.
Digit direction buffer is provided to retrieve the DTMF digit
direction info. It could be of the following values:
0 Primary channel
1 Secondary channel
Prototype
MT_RESULT MTReadDTMFTone (
const CHANNEL nChannel,
const PUCHAR pTone,
const PUCHAR pDirection
);
Parameters
nChannel channel number
pTone pointer to a character DTMF digit buffer
pDirection pointer to a character DTMF digit direc-
tion buffer
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.
226 •
SmartWORKS Developer’s Guide

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.

When queued, information about whether the MF tone is received


on the primary or the secondary channel is also recorded. Tone
direction buffer is provided to retrieve the MF tone direction info. It
could be of the following values:
0 Primary channel
1 Secondary channel
Prototype
MT_RESULT MTReadMFTone (
const CHANNEL nChannel,
const PUCHAR pTone,
const PUCHAR pDirection
);
Parameters
nChannel channel number
pTone pointer to a character MF tone buffer
pDirection pointer to a character MF tone direction
buffer
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
• 227
Introduction

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:

Q_DISABLED Tone detection on the specified queue is disabled;


no event reporting and tone queuing performed.
Q_FLUSH Tone detection on the specified queue is enabled
without tones queued. Tones are reported through channel events.
Q_KEEP Tone detection on the specified queue is enabled
with tones queued. Tones are also reported through channel
events.
Prototype
MT_RESULT MTControlToneQ (
const CHANNEL nChannel,
const UCHAR toneType,
const ULONG queueControl
);
Parameter
nChannel channel number
toneType tone type, TYPE_DTMF or TYPE_MF
queueControl queue control
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: MTSetToneDetectParams()


Ai-Logix, Inc.
230 •
SmartWORKS Developer’s Guide

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:

Q_DISABLED Tone detection on the specified queue is disabled;


no event reporting and tone queuing performed.
Q_FLUSH Tone detection on the specified queue is enabled
without tones queued. Tones are reported through channel events.
Q_KEEP Tone detection on the specified queue is enabled
with tones queued. Tones are also reported through channel
events.
Prototype
MT_RESULT MTChInputToneDetectControl (
const CHANNEL nChannel,
const SHORT nInput,
const UCHAR toneType,
const ULONG queueControl
);
Parameter
nChannel channel number
nInput Input index: 0=primary,1=secondary
toneType tone type, TYPE_DTMF or TYPE_MF
queueControl queue control
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: MTSetToneDetectParams()


Function Reference Library
• 231
Introduction

MTChInputToneDetectStatus()
Description
Retreives the queue control status of each input per channel.

Possible values for queue control are as follows:

Q_DISABLED Tone detection on the specified queue is disabled;


no event reporting and tone queuing performed.
Q_FLUSH Tone detection on the specified queue is enabled
without tones queued. Tones are reported through channel events.
Q_KEEP Tone detection on the specified queue is enabled
with tones queued. Tones are also reported through channel
events.
Prototype
MT_RESULT MTChInputToneDetectStatus (
const CHANNEL nChannel,
const SHORT nInput,
const UCHAR toneType,
PULONG const pQueueStatus
);
Parameter
nChannel channel number
nInput Input index: 0=primary,1=secondary
toneType tone type, TYPE_DTMF or TYPE_MF
pQueueStatus Pointer to the queue status value
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: MTSetToneDetectParams()


Ai-Logix, Inc.
232 •
SmartWORKS Developer’s Guide

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.

This function will always return a success return code of


MT_RET_OK. If there is a current function, event EVT_STOP will be
issued when that function is aborted. After flushing all functions (if
any), two EVT_IDLE status events will always be issued to signal the
channel state (idle): one for record, the other for playback.
Scenario
If the specified channel is performing both recording and playing
simultaneously, two EVT_STOP events will be issued: one for
stopping the recording function, the other for stopping the
playback of the function.

In addition, if the channel is also performing the MTGetDigits()


function, a third EVT_STOP event will be issued for stopping digit
collection.
Prototype
MT_RESULT MTStopChannel (
const CHANNEL nChannel
);
Parameter
nChannel channel number to be stopped
Return Codes
MT_RET_OK No error
MT_RET_IDLE Channel is idle
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_STOP
EVT_IDLE
See Also: MTStopCurrentFunction()
Ai-Logix, Inc.
236 •
SmartWORKS Developer’s Guide

CODE EXAMPLE
Code Example MTStopChannel()
if(handleMT(MTStopChannel(channel),"MTStopChannel() channel %d",channel))
{
wait = true;
while(wait)
Sleep(20);
}

A complete code example is available on the Ai-Logix website:


http://www.ai-logix.com/support.html
Function Reference Library
• 237
Introduction

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.

To stop all functions in a channel, use MTStopChannel().

The Event EVT_STOP will be issued when the current function is


aborted. However, if there is no current function, the MT_RET_IDLE
return code will be returned.
Scenario
If the specified channel is performing both recording and playing
simultaneously, two EVT_STOP events will be issued: one for
stopping the recording function, the other for stopping the
playback of the function.

In addition, if the channel is also performing the MTGetDigits()


function, a third EVT_STOP event will be issued for stopping digit
collection.
Prototype
MT_RESULT MTStopCurrentFunction (
const CHANNEL nChannel,
const ULONG fOperation
);
Parameters
nChannel Channel Number
fOperation MT_ENCODE (MT_RECORD),
MT_DECODE (MT_PLAY), or
MT_COLLECT_DTMF
Return Codes
MT_RET_OK No error
MT_RET_IDLE Channel is idle
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_STOP
Ai-Logix, Inc.
238 •
SmartWORKS Developer’s Guide

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);

A complete code example is available on the Ai-Logix website:


http://www.ai-logix.com/support.html
Function Reference Library
• 239
Introduction

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().

The MT_EVENT structure is explained in the previous chapter.


Prototype
MT_RESULT MTPutChannelEvent(
const CHANNEL nChannel,
PMT_EVENT const pMTEvent,
PULONG const pLength
);
Parameters
nChannel channel 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_OK No error
MT_RET_QFULL On event queue full
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.
242 •
SmartWORKS Developer’s Guide

MTSetOutputSource()
Description
MTSetOutputSource() selects the source of channel output from
either the decoder (default) or the mixed inputs to the channel.

Possible output source values are:


CHANNEL_DEVICE - The default decoder
AUDIO_STREAM - The mixed input (NT+TE)
PRIMARY_INPUT - Incoming signal (NT)
SECONDARY_INPUT - Outgoing signal (ET)
(See the “SmartWORKS Logical Card Model” in the SmartWORKS
User’s Guide)
The following diagram shows the logical use of the
MTSetOutputSource() API.
Function Reference Library
• 243
Introduction

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.

Possible output source values are:


CHANNEL_DEVICE - The default decoder
AUDIO_STREAM - The mixed input (NT+TE)
PRIMARY_INPUT - Incoming signal (NT)
SECONDARY_INPUT - Outgoing signal (ET)

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.

Should the user application need to release all resources (boards,


channels, TDM timeslots, etc.), it is suggested to do so with
MTSysShutdown(). This function is not used unless a specified
channel must be closed.
Prototype
MT_RESULT MTCloseChannel(
const CHANNEL nChannel
);
Parameters
nChannel channel number
Return Code
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
See Also: MTSysShutdown()
Ai-Logix, Inc.
246 •
SmartWORKS Developer’s Guide

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.

The bits are defined as follows:

TABLE 37: EVENT ENABLE PARAMETER


Bit Define Enables event

0 SE_LCURRENT_CHANGE EVT_LOOP_DROP, EVT_LOOP_ON 0x0001


1 SE_RING EVT_RINGS 0x0002
2 SE_ACT EVT_MON_ACTIVITY, EVT_MAX_ACTIVITY 0x0004
3 SE_SIL EVT_MON_SILENCE, EVT_MAX_SILENCE 0x0008
4 SE_OFFH EVT_OFFHOOK 0x0010
5 SE_ONH EVT_ONHOOK 0x0020
7 SE_WKRECV [obsoleted] 0x0080
8 SE_LREV EVT_REVERSAL 0x0100
9 SE_LVOLTAGE_CHANGE EVT_LVOLTAGE_OFFHOOK, EVT_LVOLTAGE_NOTOFFHOOK 0x0200

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

NOTE: The default event bit enable setting is 0 (all off).


Ai-Logix, Inc.
252 •
SmartWORKS Developer’s Guide

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

TABLE 38: EVENT QUEUING ACTIONS


Action Value Usage

MT_GEVT_ENABLE 1 Enable event queue for all channels


MT_GEVT_DISABLE 2 Disable event queue for all channels
MT_GEVT_FLUSHQUEUE 3 Flush event queue for all channels

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

TABLE 39: MTCHAN_TS STRUCTURE


Type Name Function

SHORT Framer -1 for no association


SHORT Timeslot -1 for no association

TABLE 40: MTCHAN_INFO STRUCTURE


Type Name Function

ULONG Type Channel type of VR64, VR32, DP, etc. All


channel types are defined in the NtiData.h
file.
ULONG Variant Channel variant such as protocol, phone
type, etc.
ULONG LoadStatus Board load status from driver. All load sta-
tus codes are defined in the NtiData.h file.
Function Reference Library
• 261
Introduction

TABLE 40: MTCHAN_INFO STRUCTURE


Type Name Function

ULONG nAssociatedTS Number of timeslots associated with this


channel
MTCHAN_TS AssociatedTS[2] Associated timeslot information. This
structure is defined in the NtiData.h file as
the following:
Framer = -1 for no association
Timeslot = -1 for no association
CHAR BusType CT bus of MUX_MVIP, MUX_H100, or
MUX_NONE
CHAR StreamSpeed CT bus data rate for the 1st 16 streams
CHAR Res1 CT bus signaling: 0 for u-law, 1 for A-law
CHAR Res2 Reserved

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.

The event structure is defined as:


LARGE_INTEGER TimeStamp
ULONG UserStatus
ULONG EventCode
ULONG SubReason
ULONG XtraInfo
ULONG Board
ULONG Channel
ULONG PtnBuffer
PVOID DataLength
The MT_EVENTstructure is explained in the previous chapter.
Prototype
MT_RESULT MTGetChannelEvent (
const DWORD dwTimeoutMs,
PMT_EVENT const pMTEvent,
PULONG const pLength
);
Parameters
dwTimeoutMs Maximum waiting time in (ms), this
value must be at least 20 ms, -1 equals
no timeout
pMTEvent pointer to 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_OK No error
MT_TIMEOUT Wait for event timed out
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
Function Reference Library
• 263
Introduction

MT_RET_INVALID_PARAM Invalid argument passed to


function
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Ai-Logix, Inc.
264 •
SmartWORKS Developer’s Guide

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:

If your GCI starting index (configured in Smart Control) is set to 0,


set the GCI parameter to -1

If your GCI starting index is set to 1, set the GCI parameter to 0

When a callback function is invoked, the function does not need to


use MTWaitForChannelEvent() to retrieve the queued events.
Events are passed in the array pointed to by the PMT_EVENT
parameter. User applications should not release the memory for the
event array.
Scenario
MTClearEventCallback() 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 MTSetEventCallback (
const CHANNEL nChannel,
MTCALLBACK const Callback,
const LPARAM lParam
);
Parameters
nChannel channel number
Callback pointer to callback function
lParam user parameter to be returned on call-
back
Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
Function Reference Library
• 265
Introduction

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
Ai-Logix, Inc.
266 •
SmartWORKS Developer’s Guide

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:

TABLE 41: MTCHAN_STATUS


Type Name Function

ULONG EventEnable Transition event enabled for event reporting


ULONG Status Current channel status. All status values are
defined in the NtiData.h file.
ULONG CurrentDecFunction Current decode function defined with prefix F_
ULONG CurrentEncFunction Current encode function defined with prefix F_
ULONG Bytes Bytes processed for current task incuding
encode and decode
ULONG PreviousEvent Previous termination event
ULONG RecordedBytes Previously recorded (encode) bytes
ULONG PlayedBytes Previously played (decode) bytes
USHORT DTMFCount Number of DTMF digits queued
USHORT MFCount Number of MF (R2 or R1) tones queued
ULONG Error Last error code
ULONG LineStatus Status of the phone line. All line status values are
defined in the NtiData.h file.
ULONG CpmResult Last CPM termination type
Function Reference Library
• 267
Introduction

EventEnable The application can switch event reporting of


specific event on or off by setting a bit with
MTSetEventFilters(). Field EventEnable reflects
this setting. The bits are defined by SE_... (Refer to
the MTSetEventFilters() section).
Status Status reflects the current API function the speci-
fied channel is performing. The values of this field
are defined in the table below.

TABLE 42: STATUS


Bit Define

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

CurrentDecFunction Current recording function on decoder


CurrentEncFunction Current recording function on encoder
Bytes The current number of bytes that is transferred to
or from the channel during play and/or record. In
the situation where the channel is performing
play and record at the same time, this counter
records the combined data count. After comple-
tion, this count is retained in the RecordedBytes
and PlayedBytes fields.
PreviousEvent The event that terminated the previous back-
ground function.
RecordedBytes Number of previously recorded bytes
PlayedBytes Number of previously played bytes
DTMFCount The number of received DTMF digits queued for
this channel.
Ai-Logix, Inc.
268 •
SmartWORKS Developer’s Guide

MFCount The number of received MF tones queued for this


channel.
Error If a function terminated because of an error, this
parameter holds the error code. This field is
cleared after each call to MTGetChannelStatus().
LineStatus The line status with various status bits assigned
explained below.
CpmResult If a CPM condition terminated a background
function, an EVT_CPM_STOP event is generated
with a SubReason code that specifies the exact
termination. The SubReason code is stored in the
CpmResult field. This parameter is cleared after
each call to MTGetChannelStatus().
Line Status definitions:

TABLE 43: LINE DEFINITIONS


Bit Define Bit set if...
0 LINE_CPM_COMP In CPMMODE_COMP (enhanced)
1 LINE_POLARITY Tip-Ring polarity is negative
(enhanced)
2 LINE_RINGBACK CPM detects ringback
3 LINE_ON_HOOK The line is on-hook
4 LINE_NO_RINGS No incoming rings are detected
5 LINE_NO_LOOP No loop current is present
6 LINE_DTMF DTMF signal is currently present
7 LINE_SILENT No activity (no signal) is present.
8 LINE_NO_LVOLTAGE_OFFHOOK No loop voltage offhook present
9 LINE_NO_DIAL

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.

This API must be used in cooperation with MTResetStatistics().


Prototype
MT_RESULT MTGetStatistics (
const CHANNEL nChannel,
PMTRUNTIME_STATISTICS const pRunTimeStat,
PULONG const pLength
);
Parameters
nChannel channel number
pRunTimeStat pointer to the PMTRUNTIME_STATISTICS
structure
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the
PMRUNTIME_STATISTICS structure.
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_NOT_AVAILABLE Driver is not loaded
Events
None
Ai-Logix, Inc.
272 •
SmartWORKS Developer’s Guide

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.

This API must be used in cooperation with MTResetStatistics().


Prototype
MT_RESULT MTGetBoardStatistics (
const BOARD nBoard,
PMTRUNTIME_STATISTICS const pRunTimeStat,
PULONG const pLength
);
Parameters
nBoard board number
pRunTimeStat pointer to the PMTRUNTIME_STATISTICS
structure
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the
PMRUNTIME_STATISTICS structure.
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_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 273
Introduction

MTResetStatistics()

Note - ResetStatistics works only when there is no PanicCode recorded


Description
This API enables the user application to reset the channel runtime
statistics.
There is no requirement for the application to have access rights of
the specified channel. It is up to the application to maintain this
cooperation between threads and the application while collecting
runtime statistics for debugging reference.

This API is used in cooperation with MTGetStatistics().


Prototype
MT_RESULT MTResetStatistics (
const CHANNEL nChannel
);
Parameter
nChannel channel number
Structure
The following explains the MTRUNTIME_STAT structure:
Indicates Firmware is in trouble:.

Type Name Function


ULONG PanicCode Panic code for technical support

Indicates the Driver and Firmware are incompatible:

Type Name Function


ULONG UnknownEvent Unknown event
ULONG UnknownRsp Unknown response
ULONG CmdError Command error

Indicates that the application fails to retrieve information from the queue::

Type Name Function


ULONG EventQueueOverflow Channel event queue overflow
ULONG DTMFQueueOverflow Channel DTMF queue overflow
ULONG MFQueueOverflow Channel MF queue overflow
ULONG CIDQueueOverflow Channel Caller ID queue overflow
Ai-Logix, Inc.
274 •
SmartWORKS Developer’s Guide

Indicates the host ran into performance problems::

Type Name Function


ULONG EncodeOverflow Channel record overflow
ULONG DecodeUnderflow Channel playback underflow

Indicates the firmware is having trouble::

Type Name Function


ULONG EncodeTimeout Channel record timeout
ULONG DecodeTimeout Channel playback timeout

For HDLC packets::

Type Name Function


ULONG HDLCStreamError Firmware detects bad HDLC stream

Reserved field::

Type Name Function


ULONG Reserved[48] Reserved for SDK internal use

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.

No access ownership of the specified board is required.


Prototype
MT_RESULT MTResetBoardStatistics (
const BOARD nBoard
);
Parameters
nBoard board number
Return Codes
MT_RET_OK No error
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Ai-Logix, Inc.
276 •
SmartWORKS Developer’s Guide

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.

The MT_EVENTstructure is explained in the previous chapter. The


event structure MT_EVENT is defined as:
LARGE_INTEGER TimeStamp
ULONG EventCode
ULONG SubReason
ULONG XtraInfo
ULONG FuncCode
SHORT Board
SHORT Channel
PVOID PtnBuffer
ULONG DataLength
Scenario
Currently, the SDK has one thread per all callbacks and one thread
per all completion callbacks. This is ok for a single processor host.
However, when the SDK is applied to a multiple processor host, user
application can take advantage of polling and implement its own
callback per thread per resource. This would dramatically increase
the operating system time slices for all callbacks.
Prototype
MT_RESULT MTWaitForAdapterEvent (
const BOARD nBoard,
const DWORD dwTimeoutMs,
PMT_EVENT const pMTEvent,
PULONG const pLength
);
Parameters
nBoard board index, 0 for the 1st board
dwTimeoutMs Maximum waiting time in (ms), this
value must be at least 20 ms, -1 equals
no timeout
pMTEvent pointer to MT_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_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
Function Reference Library
• 277
Introduction

MT_RET_INVALID_BOARD Board number is out of range


MT_RET_BOARD_NOT_OPENED Board device not opened for
access
MT_TIMEOUT Wait for event timed out
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_NOT_AVAILABLE Driver is not loaded
Events
None
See Also: MTWaitForChannelEvent()
Ai-Logix, Inc.
278 •
SmartWORKS Developer’s Guide

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.

The MT_EVENTstructure is explained in the previous chapter.


Scenario
Currently, the SDK has one thread per all callbacks and one thread
per all completion callbacks. This is ok for a single processor host.
However, when the SDK is applied to a multiple processor host, user
application can take advantage of polling and implement its own
callback per thread per resource. This would dramatically increase
the operating system time slices for all callbacks.
Developer’s Note
The pLength parameter is defined as a pointer to a long word. When
called, the user sets the size of the buffer they provide, when
returned, the SDK puts in the size of valid data it retrieved.
Therefore, when TIMEOUT, the "size" will be set to zero to indicate
that SDK retrieved no valid data. This is why the pLength parameter
is defined as a pointer to a long word so that both sides can read/
write into it.
Prototype
MT_RESULT MTWaitForChannelEvent (
const CHANNEL nChannel,
const DWORD dwTimeoutMs,
PMT_EVENT const pMTEvent,
PULONG const pLength
);
Parameters
nChannel channel number
dwTimeoutMs Maximum waiting time in (ms), this
value must be at least 20 ms, -1 equals
no timeout.
pMTEvent pointer to MT_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_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
Function Reference Library
• 279
Introduction

MT_RET_INVALID_CHANNEL Channel number is out of range


MT_RET_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_TIMEOUT Wait for event timed out
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_NOT_AVAILABLE Driver is not loaded
Events
None
Ai-Logix, Inc.
280 •
SmartWORKS Developer’s Guide

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.

No access ownership of the specified channel is required.


Prototype
MT_RESULT MTGetChannelOwner (
const CHANNEL nChannel,
int * const pPid
);
Parameters
nChannel Channel Number
pPid pointer for the process ID of the channel
owner
Returned Codes
MT_RET_OK No error
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 281
Introduction

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().

When a callback function is invoked, the function does not need to


use MTWaitForAdapterEvent() to retrieve the queued events.
Events are passed in the array pointed to by the PMT_EVENT
parameter. User applications should not release the memory for the
event array.
Scenario
MTSetBoardEventCallback() behaves the same as
MTSetEventCallback().
MTClearBoardEventCallback() 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 MTSetBoardEventCallback (
const BOARD nBoard,
MTCALLBACK const Callback,
const LPARAM lParam
);
Parameters
nBoard board number, 0 for the 1st board, -1 for
all boards
Callback pointer to callback function
lParam user parameter to be returned on call-
back
Function Reference Library
• 283
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_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.

The MT_EVENTstructure is explained in the previous chapter.


Scenario
Currently, the SDK has one thread per all callbacks and one thread
per all completion callbacks. This is ok for a single processor host.
However, when the SDK is applied to a multiple processor host, user
application can take advantage of polling and implement its own
callback per thread per resource. This would dramatically increase
the operating system time slices for all callbacks.
Prototype
MT_RESULT MTSysWaitForEvent (
const DWORD dwTimeoutMs,
PMT_EVENT const pMTEvent,
PULONG const pLength
);
Parameters
dwTimeoutMs Maximum waiting time in (ms), this
value must be at least 20 ms, -1 equals
no timeout.
pMTEvent pointer to MT_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_OK No error
MT_TIMEOUT Wait for event timed out
Events
None
Function Reference Library
• 287
Introduction

GAIN/VOLUME FUNCTIONS
Ai-Logix, Inc.
288 •
SmartWORKS Developer’s Guide

INTRODUCTION: AUTOMATIC GAIN CONTROL


Each channel is equipped with an automatic gain control (AGC) function, which is
disabled by default. Use MTSetAGC() or MTChInputSetAGC() to equalize incoming
signals, then MTSetGain() can be used to adjust to the final desired level.
MTSetGain() is an optional step.
AUTOMATIC GAIN CONTROL
The operation of AGC is controlled by four parameters:
• Target amplitude
• Maximum Amplification (MA)
• Attack slew rate
• Decay slew rate
The static transfer characteristics of AGC is shown below.
Figure 5·1: AGC Static Transfer Characteristics

Static Transfer Characteristics


Output (dBm)

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

Figure 5·2: AGC Results

AGC (Automatic Gain Control)


Test Input: Pulse of -6dBm for 250ms followed by pulse of -26dBm for 4s
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

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

RECOMMENDED GAIN SETTINGS


The following table shows recommended AGC settings for both phone (digital and
analog) and radio networks.

TABLE 44: RECOMMENDED GAIN SETTINGS

Maximum
Type of Network Target Amplitude Attack Decay
Amplitude

phone -6 400 4 30

radio -6 400 1* 30

*A small decay is required on a radio network to minimize squelch.


Function Reference Library
• 291
Introduction

MTSetGain() can be used to adjust the equalized audio level. If MTEnableMixing()


is enabled, this modifies the level of audio after the incoming signal on both the
primary and secondary inputs have been combined.
REDUCING BACKGROUND NOISE
At times background noise appears on the line when both parties are silent.
Background noise may be described as a loud distortion or hissing that is present in
the recording when both parties are silent. Modifying AGC parameters can reduce
background noise. Background noise is typically at a low energy level. Reducing the
Maximum Amplification parameter limits the allowable gain applied to low level
signals. As a result low energy signals, such as background noise, will not be
amplified to the level defined by the Target Amplitude parameter. The following
diagram illustrates this point:
Figure 5·1: Reducing Background Noise

Reducing Background Noise


Output Maximum Amplification = 18 dB

Incoming signal Outgoing signal


with gain applied

Target
-12 dBm

-22dBm Maximum Amplification


threshold has been met

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

Background noise is present on the line at a low


signal level. By reducing the amount of allowable
maximum gain, low level signals will not be
amplified to the level defined by the Target
Amplitude parameter.
Attack
400
Decay
4
Use MTSetGain() to adjust the equalized audio level to the dB required by your
application.

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.

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 MTChInputSetAGC() (
const CHANNEL nChannel,
const SHORT nInput,
const SHORT pTMA,
const SHORT pAGCR,
const SHORT pDGCR,
const SHORT pMA
);
Parameters
nChannel channel number
nInput Input index, 0=primary, 1=secondary
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
Function Reference Library
• 295
Introduction

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.
296 •
SmartWORKS Developer’s Guide

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.

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 MTChInputGetAGC (
const CHANNEL nChannel,
const SHORT nInput,
PSHORT const pTMA,
PSHORT const pAGCR,
PSHORT const pDGCR,
PSHORT const pMA
);
Parameters
nChannel channel number
nIndex Input Index: 0=primary, 1=secondary
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
Ai-Logix, Inc.
298 •
SmartWORKS Developer’s Guide

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.

Setting the gain to -50 dB is equal to muting the channel input.


NOTE: For a complete explanation of gain control refer to
“Introduction: Automatic Gain Control” on page 288 .
Prototype
MT_RESULT MTSetGain (
const CHANNEL nChannel,
const SHORT Gain
);
Parameters
nChannel channel number
Gain gain value: -50dB to +24dB. 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

CODE EXAMPLE
Code Example MTSetGain()
handleMT(MTSetGain(channel,gain),"MTSetGain() channel %d",channel);

if(handleMT(MTGetGain(channel,&gain),"MTGetGain() channel %d",channel))


cout << "Gain = " << gain << endl << endl;

A complete code example is available on the Ai-Logix website:


http://www.ai-logix.com/support.html
Ai-Logix, Inc.
300 •
SmartWORKS Developer’s Guide

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.

Setting the gain to -50 dB is equal to muting the channel input.


NOTE: For a complete explanation of gain control refer to
“Introduction: Automatic Gain Control” on page 288 .
Prototype
MT_RESULT MTChInputSetGain (
const CHANNEL nChannel,
const SHORT nInput,
const SHORT Gain
);
Parameters
nChannel channel number
nInput Input Index: 0=primary, 1=secondary
Gain gain value: -50dB to +24dB. 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
Function Reference Library
• 301
Introduction

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.

Setting the gain to -50 dB is equal to muting the channel input.


NOTE: For a complete explanation of gain control refer to
“Introduction: Automatic Gain Control” on page 288 .
Prototype
MT_RESULT MTGetGain (
const CHANNEL nChannel,
const PSHORT pGain
);
Parameters
nChannel channel number
pGain gain value: -50 dB to +24dB
gain < -50 dB equals muting,
default = 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

CODE EXAMPLE
MTGetGain()
if(handleMT(MTGetGain(channel,&gain),"MTGetGain() channel %d",channel))
cout << "Gain = " << gain << endl << endl;

A complete code example is available on the Ai-Logix website:


http://www.ai-logix.com/support.html
Ai-Logix, Inc.
302 •
SmartWORKS Developer’s Guide

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.

Setting the gain to -50 dB is equal to muting the channel input.


NOTE: For a complete explanation of gain control refer to
“Introduction: Automatic Gain Control” on page 288 .
Prototype
MT_RESULT MTChInputGetGain (
const CHANNEL nChannel,
const SHORT nInput,
const PSHORT pGain
);
Parameters
nChannel channel number
nInput Input Index: 0=primary, 1=secondary
pGain gain value: -50 dB to +24dB
gain < -50 dB equals muting,
default = 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
Function Reference Library
• 303
Introduction

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.

Setting the gain to -50 dB is equal to muting the channel input. No


minimum value is checked.
NOTE: For a complete explanation of gain control refer to
“Introduction: Automatic Gain Control” on page 288 .
Prototypes
MT_RESULT MTStepGain (
const CHANNEL nChannel,
const SHORT step
);
Parameters
nChannel channel number
step step mode for gain, 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
Ai-Logix, Inc.
304 •
SmartWORKS Developer’s Guide

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

MTSetGain() and MTChInputSetGain() 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’s input to 6dB
and closes the channel, the gain setting is left at 6dB until an
application sets it to a different value.

Setting the gain to -50 dB is equal to muting the channel input. No


minimum value is checked.
NOTE: For a complete explanation of gain control refer to
“Introduction: Automatic Gain Control” on page 288 .
Prototypes
MT_RESULT MTChInputStepGain (
const CHANNEL nChannel,
const SHORT nInput,
const SHORT step
);
Parameters
nChannel channel number
nInput Input Index: 0=primary, 1=secondary
step step mode for gain, 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
• 305
Introduction

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);

if(handleMT(MTGetVolume(channel,&volume),"MTGetVolume() channel %d",channel))


cout << "Volume = " << volume << endl <<
endl;

A complete code example is available on the Ai-Logix website:


http://www.ai-logix.com/support.html
Function Reference Library
• 311
Introduction

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;

A complete code example is available on the Ai-Logix website:


http://www.ai-logix.com/support.html
Ai-Logix, Inc.
312 •
SmartWORKS Developer’s Guide

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;

SHORT step = -1;

cout << "Setting..." << endl


<< "step = " << step << endl << endl;

handleMT(MTStepVolume(channel,step),"MTStepVolume() channel %d, step


%d",channel,step);

if(handleMT(MTGetVolume(channel,&volume),"MTGetVolume() channel %d",channel))


cout << "Volume = " << volume << endl <<
endl;

A complete code example is available on the Ai-Logix website:


http://www.ai-logix.com/support.html
Ai-Logix, Inc.
314 •
SmartWORKS Developer’s Guide

MTAVCControl()
Description
MTAVCControl() enables or disables the output AVC of the
specified channel. AVC parameters are set through MTSetAVC().

AVC control is disabled by defalt.


If a channel's AVC is enabled, opening/closing of a channel is not
going to change this state.
Prototype
MT_RESULT MTAVCControl (
const CHANNEL nChannel,
const BOOLEAN fOn
);
Parameters
nChannel channel number
fOn TRUE for enable AVC; FALSE for disable
AVC
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
• 315
Introduction

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

GLOBAL CHANNEL INDEX (GCI) FUNCTIONS


BOARD AND CHANNEL NUMBERING
The SmartWORKS API supports up to 16 physical boards and/or up to 256 full
duplex channels within a system. The API functions refer to a specific board and or
channel within the system using one of two numbering schemes: physical board
numbers, and Global Channel Index (logic channel numbers). All board numbers
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.
GLOBAL CHANNEL INDEX
During initialization, as the Physical Boards are numbered, the driver will build a list
of the logical channels available in the system called the Global Channel Index (GCI).
This list is the primary interface the API will use to refer to the channel resources in
the system.
The Global Channel Index (GCI) is numbered sequentially from 0 or 1 (depending on
how the user has configured this setting in the Smart Control panel) and is in
ascending order of the Physical Board numbers. The maximum GCI is currently
limited to 512.
Certain API functions will allow the developer to reference all channels
simultaneously by using the nChannel = -1 (if GCI index = 0) or nChannel = 0 (if the
GCI index = 1).
For Example:
Function MTSetEventCallback() takes channel number -1 or 0, and registers the
callback function for all available channels
GCI FUNCTIONS
The API has a several commands that can be used to determine the relationship
between the GCI and the physical channels on each board. The MTGetGCI() and
MTGetGCIMap() command will match a GCI indexed channel to its physical board
channel location.
For Example:
If MTGetGCIMap(65, pBOARD, pBOARDTYPE, pGCI) returns with *pBOARD=0, and
*pGCI=0, this indicates GCI channel 65 resides on board 0 as its first channel.
However, MTGetGCI(0,0,pGCI) should return with *pGCI=65.
Ai-Logix, Inc.
318 •
SmartWORKS Developer’s Guide

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

HIGHPASS FILTER FUNCTIONS


Function Reference Library
• 321
Introduction

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

MEDIA ACCESS WITH APPLICATION PROVIDED DEVICE IO FUNCTIONS


This group of APIs allows the user application to specify its own device read, write,
and seek functionality for reading and writing recorded voice data. This gives the
user application the ability to integrate the SmartWORKS API with a custom device
that supports the Microsoft Windows device interface such as: open(), close(),
read(), write() and seek().
MTSetDeviceIO() sets the user device I/O entries within SmartWORKS. The user
device I/O is enabled through MTPlayDevice(), MTPlayDeviceIndex() and
MTRecDevice() with file handle set within MT_IO_CONTRL.FileHandle field. It is the
user application's responsibility to open associated file before enabling the
SmartWORKS media function to access the file through device IO API functions.
Following is a list of Media Control API functions:

TABLE 6: MEDIA CONTROL


MTGetStreamingConfig()
MTPlayBuffer()
MTPlayBufferAsync()
MTPlayBufferEx()
MTPlayDevice()
MTPlayDeviceAsync()
MTPlayDeviceEx()
MTPlayFile()
MTPlayFileAsync()
MTPlayFileEx()
MTPlayIndex()
MTRecBuffer()
MTRecBufferAsync()
MTRecBufferEx()
MTRecDevice()
MTRecDeviceAsync()
MTRecDeviceEx()
MTRecFile()
MTRecFileAsync()
MTRecFileEx()
MTSetDeviceIO()
MTSetStreamingConfig()
MTStartStreaming()
MTStopStreaming()
MTStreamBufIn ()
MTStreamBufOut ()
MTStreamBufPause ()
MTStreamBufResume ()
Ai-Logix, Inc.
324 •
SmartWORKS Developer’s Guide

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().

MTDEVICEIO and MTDEVICESEEK are defined as:


#typedef BOOL (*MTDEVICEIO)(PVOID const fHandler, PVOID
const pBuf,
ULONG const nByteCount, PULONG const
pByteAccessed)
#typedef DWORD (*MTDEVICESEEK)(PVOID const fHandler, ULONG
const
nByteCount, int const fDirection)
MTDEVICESEEK is defined as a function which positions the device
and returns the position. Parameter fDirection is for the origin of the
seek: 0 for the beginning of the device, 1 for the current position of
the device, -1 for the end of the device.
Prototype
MT_RESULT MTSetDeviceIO (
const CHANNEL nChannel,
const MTDEVICEIO DeviceRead,
const MTDEVICEIO DeviceWrite,
const MTDEVICESEEK DeviceSeek
);
Parameters
nChannel channel number
DeviceRead pointer to user device read function
DeviceWrite pointer to user device write function
DeviceSeek pointer to user device seek function
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
Function Reference Library
• 325
Introduction

MT_RET_CHANNEL_NOT_OPENED Channel device not opened for


access
Events
None
Ai-Logix, Inc.
326 •
SmartWORKS Developer’s Guide

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.

This API is supported for all recording, on all channels.


Prototype
MT_RESULT MTStartCurrentFunction (
const CHANNEL nChannel,
const ULONG fOperation
);
Parameters
nChannel channel number
fOperation Operation of MT_ENCODE, MT_DECODE,
and/or MT_COLLECT_DTMF
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_CHANNEL_NOT_OPENED Channel device not opened for
access
MT_RET_IDLE Channel is idle
Events
None
Function Reference Library
• 327
Introduction

MTPlayDevice(), MTPlayDeviceAsync(), MTPlayDeviceEx()


Description
MTPlayDevice() is a background function that plays data retrieved
through user provided device read function. The handle of the user
device is passed through MT_IO_CONTROL.FileHandle field.

Asynchronous Call Back


Any API that ends with the suffix Async uses callback as its
completion notification method. Each requires a completion
routine from the user application to notify completion of the
requested API. The SmartWORKS function completion routine is
implemented in the same fashion as a WindowsNT system function
completion. In addition to the completion routine address, the
application also passes a parameter of type LPARAM to the
SmartWORKS DLL/Driver, which passes the parameter back without
change to the LPARAM parameter.
Prototype
MT_RESULT MTPlayDevice (
const CHANNEL nChannel,
const PMT_IO_CONTROL pIoCtl
);
MT_RESULT MTPlayDeviceEx (
const CHANNEL nChannel,
const PMT_IO_CONTROL pIoCtl,
const LPOVERLAPPED pOverlapped
);
MT_RESULT MTPlayDeviceAsync (
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 overlapped structure
lParam user defined parameter
pCompletionRoutine completion routine address
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Invalid argument passed to
function
Ai-Logix, Inc.
328 •
SmartWORKS Developer’s Guide

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
MT_RET_IO_PENDING Background I/O operation is in
progress or queued
MT_RET_BUSY channel busy
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_INVALID_DEVICE_IO Invalid Device IO setting
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
Events
MT_EVT_DEVICE_READ_ERROR
MT_EVT_DEVICE_SEEK_ERROR
Other termination events
See Also: MTPlayFile(), MTPlayBuffer()
Function Reference Library
• 329
Introduction

MTRecDevice(), MTRecDeviceAsync(), MTRecDeviceEx()


Description
MTRecDevice() is a background function that stores the recorded
data through user provided device write function. The handle of the
user device is passed through MT_IO_CONTROL.FileHandle field.
Prototype
MT_RESULT MTRecDevice (
const CHANNEL nChannel,
const PMT_IO_CONTROL pIoCtl
);
MT_RESULT MTRecDeviceEx (
const CHANNEL nChannel,
const PMT_IO_CONTROL pIoCtl,
const LPOVERLAPPED pOverlapped
):
MT_RESULT MTRecDeviceAsync (
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 overlapped structure
lParam user defined parameter
pCompletionRoutine completion routine address
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
MT_RET_IO_PENDING Background I/O operation is in
progress or queued
MT_RET_BUSY channel busy
MT_RET_INVALID_CHANNEL Channel number is out of range
MT_RET_INVALID_DEVICE_IO Invalid Device IO setting
Ai-Logix, Inc.
330 •
SmartWORKS Developer’s Guide

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
Events
MT_EVT_DEVICE_WRITE_ERROR
MT_EVT_DEVICE_SEEK_ERROR
Other termination events
See Also: MTRecFile(), MTRecBuffer()
Function Reference Library
• 331
Introduction

MUX/MVIP BUS ROUTINES


Ai-Logix, Inc.
332 •
SmartWORKS Developer’s Guide

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.

The default mapping of NI and DR for MUX type MUX_MVIP and


MUX_H100 is defined as follows:

NI(n) is mapped with DR(n) as Channel(n); NI(n+1) is mapped with


DR(n+1) as Channel(n+1).

Timeslot(16:n) is assigned as receive timeslot for DR(n);


timeslot(17:n) is assigned as receive timeslot for NI(n).

Channel(n) is composed by NI(n) receiving on timeslot(17:n),


transmitting on timeslot(16:n) and DR(n) receiving on timeslot(16:n)
and transmitting on timeslot(17:n).

No cross board mapping of NI and DR.

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.

Currently, MTSysStartup() will start the MUX as part of system


initialization.
Prototype
MT_RESULT MTStartMUX (
USHORT * const pTotalChans
);
Parameters
pTotalChans Pointer to integer that will be filled with
the number of channels in system
Return Codes
MT_RET_OK No error
MT_RET_INVALID_PARAM Error in function pointer
MT_RET_NO_MUX Multiplexer is not available %0
MT_RET_MUX_ON Multiplexer system was already
started
MT_TIMEOUT Wait for event timed out
MT_RET_NOT_AVAILABLE Driver is not loaded
Function Reference Library
• 333
Introduction

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.

Currently, MTSysShutdown() will stop the MUX as a part of system


shutdown.
Prototype
MT_RESULT MTStopMUX (
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_IDLE Channel is idle
MT_RET_NO_MUX Multiplexer is not available
Events
None
See Also: MTSysShutdown()
Ai-Logix, Inc.
336 •
SmartWORKS Developer’s Guide

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

MTPlayBuffer(), MTPlayBufferAsync(), MTPlayBufferEx()


Description
MTPlayBuffer() is a background function that plays back data from
an application buffer. The address of the buffer is specified by the
buffer parameter in MT_IO_CONTROL. The number of bytes to play
must be set in the length parameter. Also, the number of bytes must
be divisible by the frame size so that no data will be lost. For
example, if the frame size is 320 (16-bit linear voice format) then the
buffer length should be 320, 640, 960, 1280, and so on. If the buffer
length were set to, let’s say 650, then 10 bytes of data will be lost.
Below is a table of common voice formats, corresponding frame
sizes, and possible buffer lengths. It is not exhaustive, but should
illustrate the proper settings for buffer sizes.

Voice Format Frame Size Buffer lengths (in bytes)

16-bit linear 320 320, 640, 960, 1280...


PCM 160 160, 320, 480, 640...
MSGSM 65 65, 130, 195, 260...

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

pOverlapped pointer to OVERLAPPED structure


pCompletionRoutine completion routine address
lParam parameter to echo back
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
Events
EVT_MAXTIME
EVT_MAXBYTE
EVT_MAXDIGIT
EVT_TERMDIGIT
EVT_INTERDIGIT
Ai-Logix, Inc.
340 •
SmartWORKS Developer’s Guide

MTPlayFile(), MTPlayFileAsync(), MTPlayFileEx()

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);

string buffer = "C:\\recordings\\test.pcm";


// file to be played

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()");

A complete code example is available on the Ai-Logix website:


http://www.ai-logix.com/support.html
Function Reference Library
• 343
Introduction

CODE EXAMPLE
Code Example MTPlayFileAsync()
if(!handleMT(MTSysStartup(),"MTSysStartup()"))
exit(-1);

string buffer = "C:\\recordings\\test.pcm";


// file to be played

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()");

A complete code example is available on the Ai-Logix website:


http://www.ai-logix.com/support.html
Ai-Logix, Inc.
344 •
SmartWORKS Developer’s Guide

MTPlayIndex(), MTPlayIndexEx(), MTPlayIndexAsync()

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.

At the end of sending to decode the voice data specified in each


index entry, event EVT_INDEX_PLAYED will be issued. Normal
termination also applies to this API. Therefore, at the termination of
a normal playback, possible events would be EVT_EOF,
EVT_MAXTIME, and EVT_MAXBYTE. EVT_TERMDIGIT and
EVT_INTERDIGIT indicate that playback was terminated due to
anticipated user interruption.
Prototype
MT_RESULT MTPlayIndex (
const CHANNEL nChannel,
PCSTR - (A) pFileName,
PCWSTR - (W)
PCMT_INDEX_TABLE pIxTable,
const PMT_IO_CONTROL pIoCtl
);
MT_RESULT MTPlayIndexEx (
const CHANNEL nChannel,
PCSTR - (A) pFileName,
PCWSTR - (W)
PCMT_INDEX_TABLE pIxTable,
const PMT_IO_CONTROL pIoCtl,
const LPOVERLAPPED pOverlapped
);
MT_RESULT MTPlayIndexAsync(
const CHANNEL nChannel,
PCSTR - (A) pFileName,
PCWSTR - (W)
PCMT_INDEX_TABLE pIxTable,
Function Reference Library
• 345
Introduction

const PMT_IO_CONTROL pIoCtl,


const MTCOMPLETE pCompletionRoutine,
const LPARAM lParam
);
Parameters
nChannel channel number
pFileName ASCII file name
pIxTable pointer to an MT_INDEX_TABLE struc-
ture that specifies the data to play
pIoCtl pointer to a MT_IO_CONTROL struc-
ture (defined in the previous chapter of
this book).
pOverlapped pointer to overlapped structure
pCompletionRoutine completion function address
lParam application defined parameter
Structure
Structure MT_INDEX_TABLE is defined as follows:

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

MTRecBuffer(), MTRecBufferAsync(), MTRecBufferEx()


Description
MTRecBuffer() is a background function that starts recording to
the application buffer. The buffer address is passed in the buffer
parameter of the MT_IO_CONTROL structure. The size of the buffer
must be set in the length field. Also, the number of bytes must be
divisible by the frame size so that no data will be lost. For example, if
the frame size is 320 (16-bit linear voice format) then the buffer
length should be 320, 640, 960, 1280, and so on. If the buffer length
were set to, let’s say 650, then 10 bytes of data will be lost. Below is a
table of common voice formats, corresponding frame sizes, and
possible buffer lengths. It is not exhaustive, but should illustrate the
proper settings for buffer sizes.

Voice Format Frame Size Buffer lengths (in bytes)

16-bit linear 320 320, 640, 960, 1280...


PCM 160 160, 320, 480, 640...
MSGSM 65 65, 130, 195, 260...

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

pOverlapped pointer to overlapped structure


pCompletionRoutine completion routine address
lParam parameter to echo back
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
Events
EVT_MAXTIME
EVT_MAXBYTE
EVT_MAXDIGIT
EVT_TERMSILENCE
EVT_TERMDIGIT
See Also: MTPlayBuffer()

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);
}

A complete code example is available on the Ai-Logix website:


http://www.ai-logix.com/support.html
Function Reference Library
• 349
Introduction

MTRecFile(), MTRecFileAsync(), MTRecFileEx()

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.

MTRecFile(), MTRecFileAsync(), and MTRecFileEx() 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.
Scenario
Should this function be called with no control set in
MT_IO_CONTROL’s structure then the user application will need to
apply MTStopChannel(), or MTStopCurrentFunction() to stop the
recording.
Prototype
MT_RESULT MTRecFile (
const CHANNEL nChannel,
PCSTR - (A) pFileName,
PCWSTR - (W)
PMT_IO_CONTROL const pIoCtl
);
MT_RESULT MTRecFileEx (
const CHANNEL nChannel,
PCSTR - (A) pFileName,
PCWSTR - (W)
PMT_IO_CONTROL const pIoCtl,
const LPOVERLAPPED pOverlapped
);
MT_RESULT MTRecFileAsync (
const CHANNEL nChannel,
PCSTR - (A) pFileName,
PCWSTR - (W)
Ai-Logix, Inc.
350 •
SmartWORKS Developer’s Guide

PMT_IO_CONTROL const pIoCtl,


const MTCOMPLETE pCompleteRoutine,
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
pCompleteRoutine completion function address
lParam application defined parameter
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_MAXBYTE
EVT_MAXTIME
EVT_MAXDIGIT
EVT_TERMDIGIT
EVT_TERMSILENCE
See Also: MTPlayFile()
Function Reference Library
• 351
Introduction

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);

A complete code example is available on the Ai-Logix website:


http://www.ai-logix.com/support.html

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);
}

A complete code example is available on the Ai-Logix website:


http://www.ai-logix.com/support.html
Ai-Logix, Inc.
352 •
SmartWORKS Developer’s Guide

STREAM FUNCTIONS
Function Reference Library
• 353
Introduction

INTRODUCTION: DATA STREAMING


Instead of specifying the size of a recording, the application program could use a
streaming function to enable voice data buffering. Then use stream in and stream
out API functions to copy and queue voice block one by one until the application
disables streaming operation.
SmartWORKS API functions for streaming control are MTSetStreamingConfig(),
MTStartStreaming() and MTStopStreaming(). The record and playback equivalent
APIs are MTStreamBufIn() and MTStreamBufOut(). Additional decode control APIs
are MTStreamBufPause() and MTStreamBufResume().
Start streaming enables API internal buffering. The default internal buffer size is
64K, which would buffer about 8 seconds of 8-bit PCM encoded voice. This internal
buffer size can be changed through MTSetStreamingConfig(). When the internal
buffer overflows, the application will be notified through event
EVT_STREAMIN_DROPPED. No new voice data will be queued until the application
issues an action to retrieve the queued data. Event EVT_STREAMOUT_EMPTY
notifies the user application that the decode playback streaming is short of voice
data and silence is played.
A watermark can be set when streaming is started. If set, event
EVT_STREAMIN_WATERMARK or EVT_STREAMOUT_WATERMARK will be issued as
an indication of streaming progress.
When streaming is used with termination (specified through MT_IO_CONTROL
parameter), data buffering will stop when termination occurs. NOTE: MaxBytes and
MaxTime cannot be used for termination limits when streaming. A termination
event is issued. Both streamed data and the streaming buffer are kept until the user
application either retrieves all streamed data or issues a stop streaming to flush the
streamed data. Streaming buffer will be released in both cases. The return code for
MTStreamBufIn() will be MT_RET_SERVICE_STOPPED to indicate that all data in
streaming buffer has been read out and streaming task is now relinquished. For
example, say a streaming task is started with silence termination set to 500 milli-
second. At the detection of 500 milli-seconds of no activity, termination event of
EVT_TERMSILENCE will be issued and the collection of data will stop. However, all
the previously collected data are still kept in the streaming buffer.
For example:
Assume that the size of data left in the streaming buffer is 40K at the time of silence
detection, if the user application issues MTStreamBufIn() with a 32K buffer, then
32K of the streamed data will be moved into user buffer, the return code for
MTStreamBufIn() will be MT_RET_OK and an event of EVT_STREAMIN_COMP will
be issued. On the next call of MTStreamBufIn() call, only 8K of streamed data will be
moved into user buffer, return code will be MT_RET_SERVICE_STOPPED, and no
event will be issued. At the completion of the second call of MTStreamBufIn(), the
streaming task along with the associated streaming buffer is released from SDK.

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().

A watermark can be set in the MT_IO_CONTROL.Length field. Once


set, event EVT_STREAMIN_WATERMARK or
EVT_STREAMOUT_WATERMARK will be issued.

Regardless of the number supplied as the watermark byte count,


the DLL rounds it up or down to make it a multiple of the number of
frames of the specified format. Alternately, the watermark byte
count can be specified as 0 if the user wishes to disable watermark
reporting.

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

MT_RET_INTERNAL_ERROR SDK timed out while queueing


decode data
MT_RET_BUSY Channel is busy
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_STREAMOUT_COMP
Ai-Logix, Inc.
360 •
SmartWORKS Developer’s Guide

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

MT_RET_IO_PENDING Streaming still in startup pro-


cess
MT_RET_SERVICE_NOT_STARTED Streaming is not started
MT_RET_INTERNAL_ERROR SDK timed out while queueing
decode data
MT_RET_BUSY Channel is busy
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_NOT_ENOUGH_DATA The amount of collected data
does not satisfy request with
timeout set to 0
MT_RET_SERVICE_NOT_STARTED Streaming not started
MT_RET_SERVICE_STOPPED Streaming data is read after ter-
mination occurs
MT_RET_INVALID_PARAM Error in function pointer
Events
EVT_STREAMIN_COMP
Ai-Logix, Inc.
362 •
SmartWORKS Developer’s Guide

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

STREAMING - STREAM CONTROL


Function Reference Library
• 365
Introduction

MTStopStreaming()
Description
Stops the streaming of data.
The parameter Action specifies how it should be stopped.

Stop mode MT_STREAM_STOP_NOW aborts streaming


immediately. The process is killed without fetching data from the
buffer.
Stop mode MT_STREAM_STOP_DELAY stops streaming after the
currently queued streaming buffer function completes. You are
required to get all the data using MTStreamBufIn() since streaming
does not technically stop until all the data has been fetched from
the buffer.
Prototype
MT_RESULT MTStopStreaming(
const CHANNEL nChannel,
const USHORT Action,
const USHORT StopMode
);
Parameters
nChannel channel number
Action stream action of the following:
MT_STREAM_INPUT
MT_STREAM_OUTPUT
StopMode stop mode of: MT_STREAM_STOP_NOW
MT_STREAM_STOP_DELAY
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
EVT_STREAMIN_STOP
EVT_STREAMOUT_STOP
Ai-Logix, Inc.
366 •
SmartWORKS Developer’s Guide

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.

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
Return Code
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_BUSY Decode (playback) streaming is
not paused
MT_RET_INVALID_PARAM 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
Ai-Logix, Inc.
368 •
SmartWORKS Developer’s Guide

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.

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
Structure

TABLE 8: MT_PSTN
Type Name Purpose Default Units

USHORT flash_char Flash character & ascii


USHORT flash_time Flash time 500 1 ms
USHORT wink_delay Wink delay 150 1ms
USHORT wink_time Wink time 150 1ms
USHORT pause_char Pause character , ascii
USHORT pause_time Pause time 2000 1 ms
USHORT pulse_on Pulse dialing on-hook length 40 1 ms
USHORT pulse_off Pulse dialing off-hook length 60 1 ms
USHORT pulse_delay_time Pulse dialing inter-digit delay 1000, 1 ms
valid value: 10-2550
USHORT loop_deglitch Minimum glitch on or off 50 1 ms
USHORT loop_delay Loop event delay 10 1 ms
Ai-Logix, Inc.
370 •
SmartWORKS Developer’s Guide

TABLE 8: MT_PSTN
Type Name Purpose Default Units

USHORT ring_on_time Ring on duration 300 1 ms


USHORT ring_off_time Ring off duration 500 1 ms
USHORT ring_reset duration (ms) to reset ring count 8000 1 ms
to 0
USHORT ring_count Ring cycle to report event 1
USHORT ring_trigger Ring detection in leading(0) or 0 flag
tailing(1)
USHORT ring_autoanswer Auto-answer (0=disable, 0 flag
1=enable)
USHORT cpm_start_delay CPM analysis delay after dialing 1000 1 ms
USHORT offhook_delay off-hook event delay 500 1 ms
USHORT min_rings_no_answer Minimum cycles to report no answer 4
USHORT max_sig_time Maximum continuous signal 6500 ms
time
USHORT max_sil_time Maximum continuous silence 40000 ms
time
USHORT ring_deglitch debouncing time for ring detec- 320 for ms
tion ANALOG_FXO_LS_E
160 ms
ANALOG_VFXO_LS_E
50 for other channel
types*
valid value: 10-2550
USHORT reserved[3];

ANALOG_VDS_E for channels on PT809, ANALOG_FXO_LS_E for


channels on AT809, ANALOG_VFXO_LS_E is dedicated for channels
on LD809 and LD409.
flash_char character used to designate hook-flash
flash_time length of hook-flash
wink_time wink delay and duration
loop_deglitch minimum loop glitch time ranged from
10 to 2550 ms
loop_delay With MTCallString(), the channel dials a
number and goes into
CPMMODE_COMP mode. A delay is
started during which a loop current
drop will not be reported as connect,
but as a regular loop drop. This is to pre-
vent false CPM_CONNECT or
EVT_LOOP_STOP messages. This param-
eter sets the delay.
ring_count minimum ring cycle to report ring event
Function Reference Library
• 371
Introduction

ring_trigger ring detection on leading or trailing sig-


nal cycle
cpm_start_delay the delay time to report CPM event after
dialing
offhook_delay delay time to report the EVT_OFFHOOK
event when a channel goes to the off-
hook state
min_rings_no_answer the number of ringbacks or double ring-
backs before a no answer is reported
max_sig_time the maximum continuous signal
time before no-ringback is reported.
This also sets the activity timeout for
CPM_NO_RINGBACK
max_sil_time the maximum continuous silence time
before no-ringback is reported
Ring_deglitch minimum ring deglitch time ranged
from 10 to 2550 ms; applicable only
to ANALOG_VDS, ANALOG_FXO_LC ,
and ANALOG_VFXO_LS_E
default values are:
160 ms - LD board
50 ms - PT board
320 ms - AT board
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.
372 •
SmartWORKS Developer’s Guide

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;
}

A complete code example is available on the Ai-Logix website:


http://www.ai-logix.com/support.html
Function Reference Library
• 373
Introduction

MTSetToneGenParams()
This API was formerly called MTSetGenRegs()
Description
MTSetToneGenParams() sets the DTMF/MF tone generation
parameters defined in MT_GENREGS structure as follows.

Note: MF is not supported in current version.


Prototype
MT_RESULT MTSetToneGenParams (
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

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
Structure

NOTE: If any values are set to 0, the application will replace them with the
default setting.

TABLE 9: MT_GENREGS - DEFAULT FOR ALL BOARDS


Type Name Purpose Default Units

USHORT width Tone duration time 100 ms


USHORT gap Inter-tone duration 50 ms
USHORT low_ampl Amplitude for low 10156 (-7dBm)
frequency
USHORT high_ampl Amplitude for high 10156 (-7dBm)
frequency

width The length of a DTMF or MF tone in ms unit. this


field cannot be 0
gap The inter-digit length between two tones in ms
unit
Ai-Logix, Inc.
374 •
SmartWORKS Developer’s Guide

low_ampl The amplitude for tone low frequency. The ampli-


tude of the output sinewave is proportional to
the value of this parameter (range 0 to 0x7FFF)
with a digital milliwatt corresponding to an appli-
tude of approximately 0x5900.
high_ampl The amplitude for tone high frequency. See
explanation of the low_ampl parameter for more
information.

TABLE 10: MT_GENREGS - DEFAULT FOR AT AND LD BOARDS


Type Name Purpose Default Units

USHORT width Tone duration time 75 ms


USHORT gap Inter-tone duration 75 ms
USHORT low_ampl Amplitude for low 9500(-7.6dBm)
frequency
USHORT high_ampl Amplitude for high 12000
frequency (-5.6dBm)

width The length of a DTMF or MF tone in ms


unit. This field cannot = 0.
gap The inter-digit length between two
tones in ms unit
low_ampl The amplitude for tone low frequency
high_ampl The amplitude for tone high frequency
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
• 375
Introduction

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.

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
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_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
Ai-Logix, Inc.
376 •
SmartWORKS Developer’s Guide

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.

All zero parameters are ignored.


This API sets the same tone detection parameters for the primary
input of the channel or both inputs if mixing is enabled. To set these
parameters on a per input basis use
MTChInputSetToneDetectParams().
Scenario
Each channel (primary and secondary) is equipped with a DTMF
detector. The detector has been optimized for high immunity to
talk-off and the ability to reliably detect short signals (40 ms). All 16
DTMF digits can be detected.

Users have the option of setting detection to occur at the beginning


of the signal (leading edge) or after the signal ended (trailing edge).
MTSetToneDetectParams() API allows user to specify leading or
trailing edge detection. Leading edge detection creates a scenario
where start of detection is reported as soon as the detection
hardware has detected a valid digit. When trailing edge detection is
selected, the reporting of detection occurs after the DTMF signal
ends.

Start of detection is always reported at the end of the digit or 100


ms after the beginning of the digit, whichever occurs first.

The detector has a dynamic range of -38 dBm to 0 dBm, acceptable


twist is set to
8 dB forward and 4 dB reverse, frequency variation is +/- 1.5% for
detection and
+/- 2.5% for rejection.
Use this API to configure DTMF and MF detection settings. Use the
second parameter to specify whether TYPE_DTMF or TYPE_MF is to
be configured.
Prototype
MT_RESULT MTSetToneDetectParams (Parameters
const CHANNEL nChannel,
const UCHAR Type,
PMT_DETECTREGS const pRegs,
PULONG const pLength
);
nChannel channel number
Function Reference Library
• 377
Introduction

Type tone type:


0 = TYPE_DTMF
1 = 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_DETECTREGS structure.

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
Structure
Structure MT_DETECTREGS is defined as follows:

TABLE 11: MT_DETECTREGS


Type Name Purpose Default Units

USHORT subtype Tone type specification MF_R2


USHORT trigger Trailing or leading edge LEADING_EDGE flag
detection TRAILING_EDGE

subtype This field specifies the tone types of R1


and R2. This field only applies when tone
type is set to TYPE_MF:
Values are:
0 = SUBTYPE_MF_R1 - MF R1 tone detec-
tion
all other values = SUBTYPE_MF_R2 - MF
R2 tone detection
This parameter is ignored for DTMF
tones.
trigger This flag specifies if a valid DTMF or MF
digit is to be reported on the leading
edge or the trailing edge of the DTMF
signal. If leading edge is selected, the
digit will be reported as soon as the
detection hardware has detected a valid
digit.
Values are:
1 = TRAILING_EDGE - trailing edge
detection
2 = LEADING_EDGE - leading edge
detection
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
Ai-Logix, Inc.
378 •
SmartWORKS Developer’s Guide

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.

All zero parameters are ignored.


This API sets the tone detection parameters per each input per
channel. One can still use MTSetToneDetectParams() to set the
same values for both channel inputs.
Scenario
Each channel (primary and secondary) is equipped with a DTMF
detector. The detector has been optimized for high immunity to
talk-off and the ability to reliably detect short signals (40 ms). All 16
DTMF digits can be detected.

Users have the option of setting detection to occur at the beginning


of the signal (leading edge) or after the signal ended (trailing edge).
MTChInputSetToneDetectParams() API allows user to specify
leading or trailing edge detection. Leading edge detection creates a
scenario where start of detection is reported as soon as the
detection hardware has detected a valid digit. When trailing edge
detection is selected, the reporting of detection occurs after the
DTMF signal ends.

Start of detection is always reported at the end of the digit or 100


ms after the beginning of the digit, whichever occurs first.

The detector has a dynamic range of -38 dBm to 0 dBm, acceptable


twist is set to
8 dB forward and 4 dB reverse, frequency variation is +/- 1.5% for
detection and
+/- 2.5% for rejection.
Use this API to configure DTMF and MF detection settings. Use the
second parameter to specify whether TYPE_DTMF or TYPE_MF is to
be configured.
Prototype
MT_RESULT MTChInputSetToneDetectParams (Parameters
const CHANNEL nChannel,
const SHORT nInput,
const UCHAR Type,
PMT_DETECTREGS const pRegs,
PULONG const pLength
);
nChannel channel number
nInput Input index: 0=primary, 1=secondary
Ai-Logix, Inc.
380 •
SmartWORKS Developer’s Guide

Type tone type:


0 = TYPE_DTMF
1 = 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_DETECTREGS structure.

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
Structure
Structure MT_DETECTREGS is defined as follows:

TABLE 12: MT_DETECTREGS


Type Name Purpose Default Units

USHORT subtype Tone type specification MF_R2


USHORT trigger Trailing or leading edge LEADING_EDGE flag
detection TRAILING_EDGE

subtype This field specifies the tone types of R1


and R2. This field only applies when tone
type is set to TYPE_M:
Values are:
0 = SUBTYPE_MF_R1 - MF R1 tone detec-
tion
all other values = SUBTYPE_MF_R2 - MF
R2 tone detection
This parameter is ignored for DTMF
tones.
trigger This flag specifies if a valid DTMF or MF
digit is to be reported on the leading
edge or the trailing edge of the DTMF
signal. If leading edge is selected, the
digit will be reported as soon as the
detection hardware has detected a valid
digit.
Values are:
1 = TRAILING_EDGE - trailing edge
detection
2 = LEADING_EDGE - leading edge
detection
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
Function Reference Library
• 381
Introduction

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

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
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_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
• 383
Introduction

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

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
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_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
Ai-Logix, Inc.
384 •
SmartWORKS Developer’s Guide

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.

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
Structure
Structure MT_DTMF_DETECTPARAMS is defined as follows:

TABLE 13: MT_DTMF_DETECTPARAMS


Type Name Purpose Default Units

USHORT min_detect_time Min. time to detect a DTMF 40 ms


tone, 40 - 100 ms
USHORT max_report_time Max. time to report lead- 100 ms
ing edge detection of a
DTMF tone. Value must fall
within the range of
min_detect_time to 100

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

MT_RET_INVALID_PARAM 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
Ai-Logix, Inc.
386 •
SmartWORKS Developer’s Guide

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.

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
Structure
Structure MT_DTMF_DETECTPARAMS is defined as follows:

TABLE 14: MT_DTMF_DETECTPARAMS


Type Name Purpose Default Units

USHORT min_detect_time Min. time to detect a DTMF 40 ms


tone, 40 - 100 ms
USHORT max_report_time Max. time to report lead- 100 ms
ing edge detection of a
DTMF tone. Value must fall
within the range of
min_detect_time to 100

Return Codes
MT_RET_OK No error
MT_RET_INVALID_CHANNEL Channel number is out of range
Function Reference Library
• 387
Introduction

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_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
Ai-Logix, Inc.
388 •
SmartWORKS Developer’s Guide

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.

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
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_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
• 389
Introduction

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.

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
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_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
Ai-Logix, Inc.
390 •
SmartWORKS Developer’s Guide

INTRODUCTION: ACTIVITY DETECT (ACTD) CONTROL


The Activity detector measures input signal energy in a 20 ms sample. The energy
measurement is then converted to average power and the result is compared
against two programmable thresholds:
• The silence threshold (MT_ACTPARAMS.threshold_low)
• The activity threshold (MT_ACTPARAMS.threshold_high)
where MT_ACTPARAMS.threshold_high must be greater than or equal to
MT_ACTPARAMS.threshold_low.
The result of this comparison is processed by the ACT state machine. This machine
has three states:
• StReset
• StSilence
• StActivity
When the detector is disabled, it is held in stReset. Enabling the detector causes it to
change to the stSilence state, the Silence Timer to be started from zero, and the
Activity Timer to remain reset. Disabling the detector puts it in the stReset state.
Whenever the detector is in the stSilence state and the silence timer reaches the
Maximum Silence Duration (MT_ACTPARAMS.max_silence), the silence timer is
restarted from zero. If Activity Detection events are enabled, a Maximum Silence
Period Detected (EVT_MAX_SILENCE) event is issued with SubReason field
containing the value of the silence timer before it was restarted.
Whenever the detector is in the stActivity state and the activity timer reaches the
Maximum Activity Duration (MT_ACTPARAMS.max_activity), the activity timer is
restarted from zero. If Activity Detection events are enabled, a Maximum Activity
Period Detected (EVT_MAX_ACTIVITY) event is issued with a SubReason field
containing the value of the activity timer before it was restarted.
Whenever the detector is in the stSilence state, and the measured input signal
energy remains above MT_ACTPARAMS.threshold_high for the Minimum Activity
Duration (MT_ACTPARAMS.min_activity), the detector changes to the stActivity
state, the activity timer is restarted from timActivityMinimum, and the silence timer
remains reset. If Activity Detection events are enabled, a Minimum Activity Period
Detected (EVT_MON_ACTIVITY) event is issued with SubReason field containing the
value of the silence timer when the energy level crossed above the threshold.
Whenever the detector is in the stActivity state and the measured input signal
energy remains below MT_ACTPARAMS.threshold_low for the Minimum Silence
Duration (MT_ACTPARAMS.min_silence), the detector changes to the stSilence
state, the silence timer is restarted from timSilenceMinimum, and the activity timer
remains reset. If Activity Detection events are enabled, a Minimum Silence Period
Detected (EVT_MON_SILENCE) event is issued with a parameter containing the
value of the activity timer when the energy level crossed below the threshold.
Function Reference Library
• 391
Introduction

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

- 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
• 393
Introduction

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

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
Structure
MT_ACTPARAMS structure is defined as follows:

TABLE 15: MT_ACTPARAMS


Type Parameter Description

FLOAT threshold_low Silence threshold 0 to -60.0 dBm, default -51.0


dBm
FLOAT threshold_high Activity threshold 0 to -60.0 dBm, default -48.0
dBm
USHORT min_silence min. silence deglitch time, default 40 ms
USHORT max_silence max silence duration, default 30000 ms
USHORT min_activity min. activity duration, default 40 ms
USHORT max_activity max activity duration, default 10000 ms

threshold_high Value for Activity High threshold, ranged


from 0.0 to -60.0 dBm. Must be greater
than or equal to threshold_low.
threshold_low Value for Activity Low threshold, ranged
from 0.0 dBm to -60.0 dBm. Must be less
than or equal to threshold_high.
Ai-Logix, Inc.
394 •
SmartWORKS Developer’s Guide

min_silence This is silence deglitching parameter


and, if not zero, specifies the minimum
time, that silence have to be present
before the EVT_MON_SILENCE event is
issued.
min_activity This is activity deglitching parameter
and, if not zero, specifies the minimum
time, that activity have to be present
before the EVT_MON_ACTIVITY event is
issued. Since activity is measured across
20 ms intervals, the min_activity value
should be rounded down to 20 ms.
max_silence This is silence period parameter and, if
not zero, specifies the maximum time,
that silence have to be present before
the EVT_MAX_SILENCE event is issued.
Event EVT_MAX_SILENCE will be issued
every specified period of max_silence of
time until activity is detected.
max_activity This is activity period parameter and, if
not zero, specifies the maximum time,
that activity have to be present before
the EVT_MAX_ACTIVITY event is issued.
Event EVT_MAX_ACTIVITY will be issued
every specified period of max_activity of
time until silence is detected.
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_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
• 395
Introduction

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

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
Structure
MT_ACTPARAMS structure is defined as follows:

TABLE 16: MT_ACTPARAMS


Type Parameter Description

FLOAT threshold_low Silence threshold 0 to -60.0 dBm, default -51.0


dBm
FLOAT threshold_high Activity threshold 0 to -60.0 dBm, default -48.0
dBm
USHORT min_silence min. silence deglitch time, default 40 ms
USHORT max_silence max silence duration, default 30000 ms
USHORT min_activity min. activity duration, default 40 ms
USHORT max_activity max activity duration, default 10000 ms

threshold_high Value for Activity High threshold, ranged


from 0.0 to -60.0 dBm. Must be greater
than or equal to threshold_low.
threshold_low Value for Activity Low threshold, ranged
from 0.0 dBm to -60.0 dBm. Must be less
than or equal to threshold_high.
Function Reference Library
• 397
Introduction

min_silence This is silence deglitching parameter


and, if not zero, specifies the minimum
time, that silence have to be present
before the EVT_MON_SILENCE event is
issued.
min_activity This is activity deglitching parameter
and, if not zero, specifies the minimum
time, that activity have to be present
before the EVT_MON_ACTIVITY event is
issued. Since activity is measured across
20 ms intervals, the min_activity value
should be rounded down to 20 ms.
max_silence This is silence period parameter and, if
not zero, specifies the maximum time,
that silence have to be present before
the EVT_MAX_SILENCE event is issued.
Event EVT_MAX_SILENCE will be issued
every specified period of max_silence of
time until activity is detected.
max_activity This is activity period parameter and, if
not zero, specifies the maximum time,
that activity have to be present before
the EVT_MAX_ACTIVITY event is issued.
Event EVT_MAX_ACTIVITY will be issued
every specified period of max_activity of
time until silence is detected.
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_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
Ai-Logix, Inc.
398 •
SmartWORKS Developer’s Guide

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

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
Return Code
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_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
• 399
Introduction

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

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
Return Code
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_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
• 401
Introduction

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

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
Structure
The MT_PSTNPXD structure is defined as follows:

TABLE 17: MT_PSTNPXD


Type Name Purpose Default Units

SHORT volume output volume 0 dB


SHORT gain input gain 0 dB
USHORT g165enable echo cancellation enable switch 0
USHORT g165adapt echo adaptation switch 1

volume output volume in dB, ranged from


-50dB to +24dB
gain input gain in dB, ranged from -50dB to
+24dB
g165enable echo cancellation enable switch (avail-
able only on terminate channels):
disabled = 0
enabled = 1
g165adapt echo adaptation enable switch (avail-
able only on terminate channels):
disabled = 0
enabled = 1
Ai-Logix, Inc.
414 •
SmartWORKS Developer’s Guide

On a channel where echo cancellation is not supported,


g165enable and g165adapt will be set to 0.
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
• 415
Introduction

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

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
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_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
Ai-Logix, Inc.
416 •
SmartWORKS Developer’s Guide

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

See Also: MTSetPxdParams()


Function Reference Library
• 417
Introduction

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

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
Structure
The PMT_ECPARAMS structure is defined as follows::

TABLE 18: PMT_ECPARAMS


Type Name Description

SHORT max_comfort_noise Comfort noise range: -40 to -66 dBm


(reserved) inclusive, -66dBm is the default
SHORT fEnableNLP Controls the Non Linear Processing
switch: 1 for enable, 0 for disable(default)
This switch replaces a residual echo with
comfort noise at the level defined with
the max_comfort_noise parameter

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

MT_RET_INVALID_PARAM Invalid argument passed to


function
Events
None
Ai-Logix, Inc.
422 •
SmartWORKS Developer’s Guide

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

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
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_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
Events
None
Function Reference Library
• 423
Introduction

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.

The MT_CPMTONE structure is defined where the API


MTSetCpmToneParams() is explained.
Prototype
MT_RESULT MTGetCpmToneParams (
const CHANNEL nChannel,
const USHORT Index,
const PMT_CPMTONE pCpm,
PULONG const pLength
);
Parameters
nChannel channel number
Index CPM tone index 0 -14
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

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
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
• 425
Introduction

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()");

A complete code example is available on the Ai-Logix website:


http://www.ai-logix.com/support.html
Ai-Logix, Inc.
426 •
SmartWORKS Developer’s Guide

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.

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
Structure
The MT_CPMTONE structure is defined as follows::

TABLE 19: MT_CPMTONE


Type Name Description

USHORT index Signal Tone Index ID


0-14
When a EVT_MON_ is generated for this
signal, the Index ID is reported in the
XtraInfo field of the MT_EVENT structure.
USHORT signalname CPM_DIAL1, etc. The options for this field
are defined in the NtiData.h file. Setting
this field determines the type of event
generated. If CPM_DIAL1 is selected, the
event MON_DIAL is generated for this sig-
nal.
Function Reference Library
• 427
Introduction

TABLE 19: MT_CPMTONE


Type Name Description

USHORT signaltype Tone type (CPM_TONE, SIT_TONE). The


options for this field are defined in the
NtiData.h file.
CPM_SIGNAL signal CPM tone specification:
USHORT fEnable;
USHORT fDetectSIT;
USHORT fDetectLate;
USHORT fDetectCycle;
USHORT fDetectLost;
USHORT nCycleDetect;
USHORT Freq[MAX_CPM_FREQ];*
CPM_PULSE Pulse[MAX_CPM_PULSE];

*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;

cout << "Setting..." << endl


<< "signame = " << cpmtone.signalname << endl
<< "sigtype = " << cpmtone.signaltype << endl
<< endl;

A complete code example is available on the Ai-Logix website:


http://www.ai-logix.com/support.html
Function Reference Library
• 429
Introduction

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.

The mode has two possible values:


0 = disable all CPM signal profiles (each signal profile must then be
enabled individually)
1 = reset all signal profiles to factory default

To enable a signal, use MTChCPMSignalControl() or use


MTGetCPMToneParams(), modify the fEnable flag to true, then use
MTSetCPMToneParams() to set this value.

Each board is shipped with default (North American) signal profiles.


If a signal profile is modified using the Control Panel, the factory
default settings are written over. Signal profiles set by using
MTSetCpmToneParams() do not modify factory default settings.
When the SmartWORKS DLL is first loaded, the factory default
settings are pulled in and used as channel signal profiles.

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.

The mode has two possible values:


0 = disable all CPM signal profiles (each signal profile must then be
enabled individually)
1 = reset all signal profiles to factory settings.

To enable a signal, use MTChCPMSignalControl() or use


MTChGetCPMSignalParams(), modify the fEnable flag to true, then
use MTChSetCPMSignalParams() to set this value.

Each board is shipped with default (North American) signal profiles.


If a signal profile is modified using the Control Panel, the factory
default settings are written over. Signal profiles set by using
MTChSetCpmSignalParams() do not modify the factory defaults.

When the SmartWORKS DLL is first loaded, these factory settings


are used to set the channel signal profiles.
NOTE: When this API is used, the Call State Machine is not reset.
Prototype
MT_RESULT MTChResetCpmSignalParams (
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
Function Reference Library
• 431
Introduction

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.

A monitor enable, controlled through MTSetMoni(), controls the


CPM monitor condition. A termination enable, controlled through
MTSetTerm(), controls the CPM termination conditions.
MTGetCpmMode() retrieves the current channel status.

NOTE: Using MTSetChannelToDefault() resets CPM and Voice


Detection to enabled.
Prototype
MT_RESULT MTSetCpmMode (
const CHANNEL nChannel,
const USHORT Mode
);
Parameters
nChannel Channel Number
Mode CPM enabled or disabled:
0 = CPM is disabled
non zero = CPM is 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 Error in pointer
Events
None
See Also: MTSetMoni(); MTSetTerm()
Ai-Logix, Inc.
432 •
SmartWORKS Developer’s Guide

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.

NOTE: Using MTSetChannelToDefault() resets CPM and Voice


Detection to enabled.
Prototype
MT_RESULT MTGetCpmMode (
const CHANNEL nChannel,
const PUSHORT pMode
);
Parameters
nChannel Channel Number
pMode pointer to the CPM status field:
0 = disabled
non zero = 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 Error in pointer
Events
None
Function Reference Library
• 433
Introduction

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.

A monitor enable, controlled through MTSetMoni(), controls the


CPM monitor condition. A termination enable, controlled through
MTSetTerm(), controls the CPM termination conditions.
MTGetCpmStatus() retrieves the current channel status.

NOTE: Using MTSetChannelToDefault() resets CPM and Voice


Detection to enabled.
Prototype
MT_RESULT MTChCPMControl (
const CHANNEL nChannel,
const PUSHORT Mode
);
Parameters
nChannel Channel Number
Mode set CPM status:
0 = disabled
non zero = 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 Error in pointer
Events
None
See Also: MTSetMoni(); MTSetTerm()
Ai-Logix, Inc.
434 •
SmartWORKS Developer’s Guide

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.

NOTE: Using MTSetChannelToDefault() resets CPM and Voice


Detection to enabled.
Prototype
MT_RESULT MTChCPMStatus (
const CHANNEL nChannel,
const PUSHORT pMode
);
Parameters
nChannel Channel Number
pMode pointer to the CPM statusl:
0 = disabled
non zero = 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 Error in pointer
Events
None
Function Reference Library
• 435
Introduction

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

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
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 pointer
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
Ai-Logix, Inc.
436 •
SmartWORKS Developer’s Guide

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

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
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 pointer
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
• 437
Introduction

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

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
Structure
The MT_USRTONE structure is defined as follows:

TABLE 20: MT_USRTONE


Type Name Description

MT_CPMTONE Tone Tone specifications as defined in the


MT_CPMTONE structure. Refer to explanation
below.
UCHAR asCPMTone Treat this tone as the specified CPM tone:
0 = USR_NONE,Report EVT_UTONE_ON
1 = USR_DIAL, Report EVT_MON_DIAL
2 = USR_RINGBACK Report EVT_MON_RINGBACK
3 = USR_BUSY Report EVT_MON_BUSY
4 = USR_FAX Report EVT_MON_FAX
5 = USR_SIT Report EVT_MON_SIT
6 = USR_LOOPOFF Report EVT_MON_LOOPOFF
7 = USR_DIGIT, Report EVT_DIGIT and the speci-
fied digit through DTMF queue
UCHAR useDigit The digit placed in the DTMF queue if asCPMTone
is set to USR_DIGIT
Ai-Logix, Inc.
440 •
SmartWORKS Developer’s Guide

The MT_CPMTONE structure is defined as follows:

TABLE 21: MT_CPMTONE


Type Name Description

USHORT index Signal Tone Index ID


15-19
When a EVT_UTONE_ON, or
EVT_UTONE_OFF is generated for this sig-
nal, the Index ID is reported in the
XtraInfo field of the MT_EVENT structure.
USHORT signalname This field is currently not used when creat-
ing a Usr tone.
USHORT signaltype Tone type (USR_TONE). The options for
this field are defined in the NtiData.h file.
CPM_SIGNAL signal CPM tone specification:
USHORT fEnable;
USHORT fDetectSIT;
USHORT fDetectLate;
USHORT fDetectCycle;
USHORT fDetectLost;
USHORT nCycleDetect;
USHORT Freq[MAX_CPM_FREQ];*
CPM_PULSE Pulse[MAX_CPM_PULSE];

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

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
Structure
The MT_USRTONE structure is defined as follows:

TABLE 22: MT_USRTONE


Type Name Description

MT_CPMTONE Tone Tone specifications as defined in the


MT_CPMTONE structure. Refer to explanation
below.
UCHAR asCPMTone Treat this tone as the specified CPM tone:
0 = USR_NONE,Report EVT_UTONE_ON
1 = USR_DIAL, Report EVT_MON_DIAL
2 = USR_RINGBACK Report EVT_MON_RINGBACK
3 = USR_BUSY Report EVT_MON_BUSY
4 = USR_FAX Report EVT_MON_FAX
5 = USR_SIT Report EVT_MON_SIT
6 = USR_LOOPOFF Report EVT_MON_LOOPOFF
7 = USR_DIGIT, Report EVT_DIGIT and the speci-
fied digit through DTMF queue
UCHAR useDigit The digit placed in the DTMF queue if asCPMTone
is set to USR_DIGIT
Ai-Logix, Inc.
442 •
SmartWORKS Developer’s Guide

The MT_CPT_TONE structure is defined as follows:

TABLE 23: MT_CPT_TONE


Type Name Description

USHORT index Signal Tone Index ID


15-19
When a EVT_UTONE_ON, or
EVT_UTONE_OFF is generated for this sig-
nal, the Index ID is reported in the
XtraInfo field of the MT_EVENT structure.
USHORT signalname This field is currently not used when creat-
ing a Usr tone.
USHORT signaltype Tone type (USR_TONE). The options for
this field are defined in the NtiData.h file.
CPM_SIGNAL signal CPM tone specification:
USHORT fEnable;
USHORT fDetectSIT;
USHORT fDetectLate;
USHORT fDetectCycle;
USHORT fDetectLost;
USHORT nCycleDetect;
CPM_FIlTER Filter[MAX_CPM_FREQ];*
CPM_PULSE Pulse[MAX_CPM_PULSE];

Refer to the applicationi note: Understanding Signal Profiles for more


information about creating/modifying signal profiles.
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
• 443
Introduction

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.

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
Structure
The MT_CPT_TONE structure is defined as follows::

TABLE 24: MT_CPT_TONE


Type Name Description

USHORT index 0-14: CPM tone. This Signal Index ID is


reported in the XtraInfo field of the
MT_EVENT structure when the
EVT_MON_ event is generated.
USHORT signalname CPM_DIAL1, etc. The options for this field
are defined in the NtiData.h file. Setting
this field determines the type of event
generated. If CPM_DIAL1 is selected, the
event MON_DIAL is generated for this sig-
nal.
Ai-Logix, Inc.
450 •
SmartWORKS Developer’s Guide

TABLE 24: MT_CPT_TONE


Type Name Description

USHORT signaltype Tone type (CPM_TONE, SIT_TONE). The


options for this field are defined in the
NtiData.h file.
CPT_SIGNAL signal CPM signal specification:
USHORT fEnable;
USHORT fDetectSIT;
USHORT fDetectLate;
USHORT fDetectCycle;
USHORT fDetectLost;
USHORT nCycleDetect;
CPM_FILTER Filter[MAX_CPM_FREQ]*
CPM_PULSE Pulse[MAX_CPM_PULSE]*;

*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.

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
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.
452 •
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.

The mode has two possible values:


0 = disable all CPM tone detection (each signal profile must then be
enabled individually)
1 = reset to the settings which are currently stored in the registry.

To enable a signal, use MTChCPMSignalControl() or use


MTChGetCPMSignalParams(), modify the fEnable flag to true, then
use MTChSetCPMSignalParams() to set this value.

Each board is shipped with default (North American) signal profiles.


These parameters are stored in the registry of the computer. If a
signal profile is modified using the Control Panel, the new settings
are pushed to this registry, and factory default settings are lost.
Signal profiles set by using MTChSetCpmSignalParams() do not
modify registry settings.
NOTE: When this API is used, the Call State Machine is not reset.
Prototype
MT_RESULT MTChResetCpmSignalParams (
const CHANNEL nChannel,
const UCHAR Mode
);
Parameters
nChannel Channel Number
Mode CPM signal mode
0 = all CPM signals disabled
1 = reset to registry settings
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
• 453
Introduction

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()).

If it is necessary to modify a single value, the application should first


obtain all the Voice Detect parameters by calling
MTChGetVoiceDetectParams(), modify the desired parameters and
write back all the parameters to the channel.
Prototype
MT_RESULT MTChSetVoiceDetectParams (
const CHANNEL nChannel,
PMT_VOICEDETECTPARAMS const pVoiceDetectParams,
const PULONG pLength
);
Parameters
nChannel Channel Number
pVoiceDetectParams pointer to the
MT_VOICEDETECTPARAMS structure
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MT_VOICEDETECTPARAMS struc-
ture

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
Structure
The MT_VOICEDETECTPARAMS structure is defined as follows:

TABLE 25: MT_VOICEDETECTPARAMS


Type Name Description Default Units

ULONG threshold_power the minimum voice-band power required -36 dBm


for voice detection
USHORT relative_threshold the minimum proportion of band pass fil- 65 ------
ter power required for detection in any
given filter
USHORT threshold_filter_count the number of band-pass filters where the 5 int (1-10?)
relative_threshold must be met for voice
detection
Ai-Logix, Inc.
456 •
SmartWORKS Developer’s Guide

TABLE 25: MT_VOICEDETECTPARAMS


Type Name Description Default Units

USHORT no_voice_min length of time there is no voice activity to 1000 ms


determine the voice has stopped speak-
ing
USHORT reset the minimum length silence (no voice 15000 ms
detection) required to reset CPM voice
detect. If a voice is detected, new events
are generated.
USHORT voice_min the minimum time voice activity is 100 ms
required before the application generates
a voice detected event
USHORT machine_min the minimum voice activity required to 3000 ms
determine that an answer machine has
been detected

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()).

If it is necessary to modify a single value, the application should first


obtain all the Voice Detect parameters by calling
MTChGetVoiceDetectParams(), modify the desired parameters and
write back all the parameters to the channel.
Prototype
MT_RESULT MTChGetVoiceDetectParams (
const CHANNEL nChannel,
PMT_VOICEDETECTPARAMS const pVoiceDetectParams,
const PULONG pLength
);
Parameters
nChannel Channel Number
pVoiceDetectParams pointer to the
MT_VOICEDETECTPARAMS structure
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MT_VOICEDETECTPARAMS struc-
ture
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
Ai-Logix, Inc.
458 •
SmartWORKS Developer’s Guide

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

TONE FUNCTIONS - ALERT TONES


Function Reference Library
• 461
Introduction

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:

TABLE 26: MT_ALERTTONE


Type Name Purpose

float amplitude Amplitude in dBm, 3.0 dBm to -60.0 dBm


USHORT frequency Frequency in Hz.
USHORT cycle_duration Alert tone interval, Repeat duration in unit of
20ms; eg. 750->15sec.
USHORT tone_duration Duration in 20 ms unit for this tone.
USHORT first_cycle_duration Duration in 20 ms unit for the first cycle only.

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

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
• 463
Introduction

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.

Cycle - Interval at which tone repeats


Duration - Time length of tone and/or silence

Please note, each board implements this feature differently. The


SmartWORKS AT and DT along with the SmartWORKS PT and LD
puts the tone out onto the line. The SmartWORKS NGX, and DP
won’t play the tone out onto the line, however, it will be recorded
with the converstation.
Prototype
MT_RESULT MTSetAlertToneParams (
const CHANNEL nChannel,
const PMT_ALERTTONE pAlert,
PULONG const pLength
);

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
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:

TABLE 27: MT_ALERTTONE


Type Name Purpose

float amplitude Amplitude in dBm, 3.0 dBm to -60.0 dBm


USHORT frequency Frequency in Hz
USHORT cycle_duration Alert tone interval, Repeat duration in unit of
20ms; eg. 750->15sec
USHORT tone_duration Duration in 20 ms unit for this tone
Ai-Logix, Inc.
464 •
SmartWORKS Developer’s Guide

TABLE 27: MT_ALERTTONE


Type Name Purpose

USHORT first_cycle_duration Duration in 20 ms unit for the first cycle only

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:

TABLE 28: MT_ALERTTONE


Type Name Purpose

float amplitude Amplitude in dBm, 3.0 dBm to -60.0 dBm


USHORT frequency Frequency in Hz
USHORT cycle_duration Alert tone interval, Repeat duration in unit of
20ms; eg. 750->15sec
USHORT tone_duration Duration in 20 ms unit for this tone
USHORT first_cycle_duration Duration in 20 ms unit for the first cycle only

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:

TABLE 29: MT_ALERTONE


Type Name Purpose

float amplitude Amplitude in dBm, 3.0 dBm to -60.0 dBm


USHORT frequency Frequency in Hz
USHORT cycle_duration Alert tone interval, Repeat duration in unit of
20ms; eg. 750->15sec
USHORT tone_duration Duration in 20 ms unit for this tone
USHORT first_cycle_duration Duration in 20 ms unit for the first cycle only

The alert tone occurs at the end of a cycle.


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
• 467
Introduction

TONE FUNCTIONS - PLAY TONES


Ai-Logix, Inc.
468 •
SmartWORKS Developer’s Guide

MTPlayTone(), MTPlayToneAsync(), MTPlayToneEx()


This API was formerly called MTPlayUsrTone()
Description
Each of these APIs starts a DLL background function to play the
specified tone(s). A return of MT_RET_IO_PENDING indicates the
successful queuing of the background task inside the channel
function queue. At the completion of the function, an event will be
added to the channel event queue.

The OVERLAPPED structure provides to the DLL an application


created event. The user application waits for an event to signal the
completion of the background function.

MTCALLBACK and LPARAM provide the DLL the address of the API
completion routine and the user expected parameter for invoking
the completion routine.

The tone structure is defined using the data structure


MT_PLAYTONE, whose address is recorded into the Buffer field of
the structure MT_IO_CONTROL. MT_IO_CONTROL.Length field
contains the byte size of the MT_PLAYTONE array. To play one tone,
set MT_IO_CONTROL.Length field to the size of MT_PLAYTONE; to
play twenty tones, set MT_IO_CONTROL.Length to twenty times of
the size of MT_PLAYTONE structure.

Flag REPEAT_TONE can be set in MT_IO_CONTROL.StartControl field


to specify a repeat playing of the tones. The supported maximum
repeat tones is 10. Tone repetition can be terminated either
through a termination condition such as DTMF detected, or
application termination through MTStopChannel().

MAX_REPEAT_TONE_COUNT - The maximum number of tones to


play in MTPlayTone() repeat mode set through
MT_IO_CONTROL.StartControl field with bit REPEAT_TONE set.

To generate a dial tone until a DTMF is detected, set the tone


duration to 3 seconds, set the silence duration to 0, set the
REPEAT_TONE flag, and set the MT_IO_CONTROL.MaxDigits to 1.
Scenario
Use this API function to play dial tone, SIT tone, ring-back tone, etc.
Prototype
MT_RESULT MTPlayTone (
const CHANNEL nChannel,
const PMT_IO_CONTROL pIoCtl
);
MT_RESULT MTPlayToneEx(
const CHANNEL nChannel,
Function Reference Library
• 469
Introduction

PMT_IO_CONTROL const pIoCtl,


const LPOVERLAPPED pOverlapped
):
MT_RESULT MTPlayToneAsync(
const CHANNEL nChannel,
PMT_IO_CONTROL const 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 OVERLAPPED structure
pCompletionRoutine pointer to completion routine
lParam parameter to echo back to completion
routine
Structure
Structure MT_PLAYTONE is defined as the following.

TABLE 30: MT_PLAYTONE


Type Name Purpose

float ampl1 Amplitude 1 in dBm, 3.0 dBm to -60.0 dBm


USHORT freq1 Frequency 1 in Hz (300 Hz to 3400 Hz, 0 is
also valid)
float ampl2 Amplitude 2 in dBm (+3.0 dbm to -60.0 dbm)
USHORT freq2 Frequency 2 in Hz ((300 Hz to 3400 Hz, 0 is
also valid)
USHORT durtone Duration in 125 us of generated tone
USHORT dursilence Duration in 125 us of post tone silence

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

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
Events
EVT_TONEP_DONE
EVT_MAX_DIGIT
EVT_TERMDIGIT
EVT_TERMSILENCE
Function Reference Library
• 471
Introduction

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

NOTE: Termination conditions can also be set for a specific task


using the TermEnable field of the MT_IO_CONTROL structure.
Ai-Logix, Inc.
474 •
SmartWORKS Developer’s Guide

The following bits can be put together with “OR” to enable


termination. The following table lists each termination conditions,
plus the correcsponding Subreason and XtraInfo field generated
when the EVT_CPM_STOP event is reported:
MTSetTerm() Control Subreason XtraInfo
TERM_LOOP_DROP CPM_MON_LOOP_DROP
TERM_MON_SIL CPM_MON_SILENCE
TERM_MON_ACT CPM_MON_ACTIVITY
TERM_MON_DIAL*+ CPM_MON_DIAL The Index of the signal
TERM_MON_BUSY*+ CPM_MON_BUSY The Index of the signal
(normal busy or trunk busy)
TERM_CONNECT+ (Using MTCallString()) CPM_MON_HUMAN,
CPM_CONNECT CPM_MON_MACHINE
------------------------------------ ------------------------------
(Using other background
functions)
CPM_MON_HUMAN
CPM_MON_MACHINE
TERM_NO_ANSWER+ CPM_NO_ANSWER
(use only with MTCallString())
TERM_INTERCEPT*+ CPM_MON_INTERCEPT The index of the signal
TERM_NOR_SILENCE CPM_MON_MAX_SILENCE
CPM_MAX_SILENCE
TERM_NOR_ACTIVITY CPM_MON_MAX_ACTIVITY
CPM_MAX_ACTIVITY
TERM_LVOLTAGE_ CPM_MON_LVOLTAGE_DROP
ABOVEORBELOW
TERM_LVOLTAGE_ (same as TERM_LVOLTAGE_
NOTOFFHOOK ABOVE_OR_BELOW
TERM_MON_UTONE+ CPM_MON_UTONE The Index of the signal
TERM_MON_CALLWAITING+ CPM_MON_CALLWAITING
TERM_MON_RECEIVEOFF+ CPM_MON_RECEIVOFF
TERM_MON_DIAL1+ CPM_MON_DIAL1
TERM_MON_DIAL2+ CPM_MON_DIAL2
TERM_MON_DIAL3+ CPM_MON_DIAL3
TERM_MON_BUSY1+ CPM_MON_BUSY1
TERM_MON_BUSY2+ CPM_MON_BUSY2
TERM_MON_FAX1+ CPM_MON_FAX1
TERM_MON_FAX2+ CPM_MON_FAX2
TERM_MON_SIT1+ CPM_MON_SIT1
TERM_MON_SIT2+ CPM_MON_SIT2
TERM_MON_SIT3+ CPM_MON_SIT3
TERM_MON_SIT4+ CPM_MON_SIT4
TERM_MON_SIT5+ CPM_MON_SIT5
*This option has been maintained for backwards compatibility. New development
should not use these options.
+ Call Progress Monitoring must be enabled to detect these line conditions:
MTChCPMControl() (or MTSetCPMMode if using v. 3.2 or earlier).
Function Reference Library
• 475
Introduction

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.

NOTE: MONI_REVERSAL is not a CPM signal. Call Progress


Monitoring does not have to be enabled to detect this line
condition.

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

SIT3 MONI_SIT3 EVT_MON_SIT3


SIT4 MONI_SIT4 EVT_MON_SIT4
SIT5 MONI_SIT5 EVT_MON_SIT5
DIAL1 MONI_DIAL1 EVT_MON_DIAL1
DIAL2 MONI_DIAL2 EVT_MON_DIAL2
DIAL3 MONI_DIAL3 EVT_MON_DIAL3
MONI_VOICE EVT_MON_VOICE
EVT_MON_HUMAN
EVT_MON_MACHINE
EVT_MON_NOVOICE
MONI_REVERSAL EVT_MON_REVERSAL
*These options have been maintained for backwards compatibility. New development
should not use these options.
Prototype
MT_RESULT MTSetMoni (
const CHANNEL nChannel,
const ULONG MoniEnable
);
Parameters
nChannel channel number
MoniEnable 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
Function Reference Library
• 479
Introduction

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.

NOTE: Bits can also be set in conjunction with a specific


background function using the MoniEnable field of the
IO_CONTROL structure.
Prototype
MT_RESULT MTGetMoni (
const CHANNEL nChannel,
const PULONG pMoniEnable
);
Parameters
nChannel Channel number
pMoniEnable pointer to value of 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.
480 •
SmartWORKS Developer’s Guide

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

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
Structure
The MTSYS_CONFIG structure is defined as follows:

TABLE 31: MTSYS_CONFIG - GENERAL SYSTEM PARAMETERS


Type Name Description

ULONG SDKCompiledWith SDK version the application is compiled


with,
default 0x02070000, i.e. ver 2.7.0.0
ULONG APILogCount Max. number of event-log entry allowed,
default 100, 0 for no limitation
ULONG SDKLogLevel [not supported yet]
ULONG APITraceLevel [not supported yet]
API_TRACE_ERROR_RET 0x00000001,
Trace return code != (MT_RET_OK or
MT_RET_IO_PENDING)
API_TRACE_CALLBACK 0x00000002,
Trace callback only
API_TRACE_ALLAPI 0x00000004,
Trace all API calls
API_TRACE_ALL 0xFFFFFFFF,
trace on
ULONG SDKChannel Max. number of channel allowed, default
MAX_CH_DEVICES
Function Reference Library
• 483
Introduction

TABLE 31: MTSYS_CONFIG - GENERAL SYSTEM PARAMETERS


Type Name Description

UCHAR GCIStartingIndex 0 or 1, default 0


UCHAR HaltOnStartupError [0 or 1, not supported yet]
UCHAR FlagDataTruncated 0 or 1 for APIs to return
MT_RET_DATA_TRUNCATED, default 0
UCHAR SteppedRun [Not implemented yet]
UCHAR SysRes[4] Reserved

TABLE 32: MTSYS_CONFIG - CT BUS PARAMETERS


Type Name Description

UCHAR H100StreamSpeed H100 stream speed of CT_2MHz,


CT_4MHz, or CT_8MHz
UCHAR BusSegmentation 0 for no bus segmentation supported
USHORT MVIPStartSlot Starting MVIP timeslot: 0 to 511
USHORT MVIPTotalSlot Max. number of MVIP slot allowed: 0 to
512
UCHAR SysRes2[2] Reserved.

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.

The MTADAPER_CONFIG structure is defined where the API


MTSetAdapterConfig() is explained.
Prototype
int MTGetAdapterConfig (
PMTADAPTER_CONFIG const Config,
PULONG const pLength
);
Parameters
Config A variable for the type of structure
pLength Set by the user application, this is a
pointer to the size of the given buffer
for the MTADAPTER_CONFIG structure

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
Return Codes
This API returns 0 on success. For registry values that are not
configured, the default values will be returned.
Function Reference Library
• 485
Introduction

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().

The adapter index should be in field


MTADAPTER_CONFIG.SystemIndex before calling this API
NOTE : Structure MTADAPTER_CONFIG has a field
OffhookImpedance added for LDA off-hook impedance
configuration. The proper values are 0 to 3.
Prototype
int MTSetAdapterConfig (
MTADAPTER_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

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
Structure
The MTADAPTER_CONFIG structure is defined as follows:

TABLE 33: MTADAPTER_CONFIG


Type Name Description

ULONG SystemIndex Adapter index on PCI bus presented by OS, 0 -


(MAX_BRD_DEVICES-1)
ULONG AdapterType This field is read only: VR6400, VR6409, and etc.
UNKNOWN_CARD for no board in index 'Syste-
mIndex'
General Adapter Parameters
Function Reference Library
• 487
Introduction

TABLE 33: MTADAPTER_CONFIG


Type Name Description

UCHAR MasterMode MODE_SLAVE(default), MODE_MASTER, or


MODE_MASTER_B
UCHAR MasterClock Master clock source reference value, default,
CLOCK_SOURCE_OSC
UCHAR Sec8kNetrefClock MVIP Sec8K or H100 Netref clock output,
default, SPRM_SOURCE_DISABLE
UCHAR PresentationPreference Board ordering preference for the associated
adapter: Range: 0..MAX_BRD_DEVICES
(default)
Not implemented for Linux yet
General CT Bus Parameters
ULONG CTBusType MUX_MVIP
MUX_H100
MUX_NONE(default)
ULONG TDMEncoding 1 for u-law, 2 for A-law
ULONG CTBusSegmentIndex Bus segment index the associated adapter is on
Interface Parameters
ULONG SMSize Shared memory size in bytes, min MIN_SMSIZE,
default 8K
NGX Parameters
Index 0 for base card, 1 for the 1st daugh-
ter card, 2 for the 2nd daughter card
ULONG CTBusTermination 0 for disable, others for enable
ULONG PBXType[MAX_DC] PBX supported. Refer to the NtiData.h file for a
complete list of valid values.
ULONG DChOption[MAX_DC] 0 for D-channel disabled
ULONG Termination[MAX_DC] 0 for Hi-Z, 1 for 120 ohm
DT/DP Trunk Parameters
Index 0 for 1st trunk and etc.
ULONG E1Option T1_OPTION for T1, E1_OPTION for E1
ULONG Framing[MAX_TRUNKS] FRM_E1_G704(default), FRM_T1_SF, etc.
ULONG LineCoding[MAX_TRUNKS] LC_AMI(default), LC_E1_HDB3, or LC_T1_B8ZS
ULONG T1LineBuildOut[MAX_TRUNKS] LBO_T1_15DB(default), etc.
ULONG E1LineBuildOut[MAX_TRUNKS] LBO_E1_120OHM(default) or LBO_E1_75OHM
ULONG ZeroCodeSupression[MAX_TRUNKS] ZCS_NONE(default), ZCS_GTE, etc. Refer to the
NtiData.h file for a complete list of valid values
defined for the MT_FRAMER_STATE.ZCS field.
ULONG ProtocolSignaling[MAX_TRUNKS] SIGNALING_NONE
SIGNALING_ISDN
SIGNALING_NFAS
SIGNALING_RBS (T1 only on SmartWORKS DT)
Ai-Logix, Inc.
488 •
SmartWORKS Developer’s Guide

TABLE 33: MTADAPTER_CONFIG


Type Name Description

UCHAR MasterMode MODE_SLAVE(default), MODE_MASTER, or


MODE_MASTER_B
UCHAR MasterClock Master clock source reference value, default,
CLOCK_SOURCE_OSC
UCHAR Sec8kNetrefClock MVIP Sec8K or H100 Netref clock output,
default, SPRM_SOURCE_DISABLE
UCHAR PresentationPreference Board ordering preference for the associated
adapter: Range: 0..MAX_BRD_DEVICES
(default)
Not implemented for Linux yet
General CT Bus Parameters
ULONG CTBusType MUX_MVIP
MUX_H100
MUX_NONE(default)
ULONG TDMEncoding 1 for u-law, 2 for A-law
ULONG CTBusSegmentIndex Bus segment index the associated adapter is on
Interface Parameters
ULONG SMSize Shared memory size in bytes, min MIN_SMSIZE,
default 8K
NGX Parameters
Index 0 for base card, 1 for the 1st daugh-
ter card, 2 for the 2nd daughter card
ULONG CTBusTermination 0 for disable, others for enable
ULONG PBXType[MAX_DC] PBX supported. Refer to the NtiData.h file for a
complete list of valid values.
ULONG DChOption[MAX_DC] 0 for D-channel disabled
ULONG Termination[MAX_DC] 0 for Hi-Z, 1 for 120 ohm
DT/DP Trunk Parameters
Index 0 for 1st trunk and etc.
ULONG E1Option T1_OPTION for T1, E1_OPTION for E1
ULONG Framing[MAX_TRUNKS] FRM_E1_G704(default), FRM_T1_SF, etc.
ULONG LineCoding[MAX_TRUNKS] LC_AMI(default), LC_E1_HDB3, or LC_T1_B8ZS
ULONG T1LineBuildOut[MAX_TRUNKS] LBO_T1_15DB(default), etc.
ULONG E1LineBuildOut[MAX_TRUNKS] LBO_E1_120OHM(default) or LBO_E1_75OHM
ULONG ZeroCodeSupression[MAX_TRUNKS] ZCS_NONE(default), ZCS_GTE, etc. Refer to the
NtiData.h file for a complete list of valid values
defined for the MT_FRAMER_STATE.ZCS field.
ULONG ProtocolSignaling[MAX_TRUNKS] SIGNALING_NONE
SIGNALING_ISDN
SIGNALING_NFAS
SIGNALING_RBS (T1 only on SmartWORKS DT)
Function Reference Library
• 489
Introduction

TABLE 33: MTADAPTER_CONFIG


Type Name Description

ULONG ProtocolVariant[MAX_TRUNKS] E1 & T1: (example PROTOCOL_ISDN_ETS300


national 2
At&t 5ESS
DMS 100
NTT
Austel 1
Q.SiG
RBS (T1 only): (example
PROTOCOL_RBS_LOOP_FXO)
E&M Wink
E&M Immediate
Loop_FXS
Loop_FXO
ULONG ISDNInterfaceSide[MAX_TRUNKS] SUPPORT_TE(default) or SUPPORT_NT
ULONG RBSMaxDigits[MAX_TRUNKS] Default 10
ULONG RBSInterDigitTime[MAX_TRUNKS] Min 10. Default 3000, in unit of ms
ULONG RBSDialingDelay[MAX_TRUNKS] Min 300, Default 1000, in unit of ms
ULONG NFASIndex[MAX_TRUNKS] 0 to (MAX_NFAS - 1)
LD Board
ULONG OffhookImpedance 0 = FCC_600, FCC 600 ohms resistive
1 = ETSI_270, ETSI 270 ohm+750 ohm || 0.15
micro-F
2 = AUSTRALIA_220, Australia 220 ohm+680
ohm || 0.12 micro-F
3 = CHINA_200, China 200 ohm+680 ohm || 0.1
micro-F

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

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
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_INVALID_PARAM Invalid argument passed to
function

NOTE: When using MTSetAdapterEEPROMConfig(), if the user passes


information that is longer than 128 bytes, the data will be truncated. When
using MTGetAdapterEEPROMConfig(), the application returns the value, with
a pLength of 128 bytes.
Function Reference Library
• 491
Introduction

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.

NOTE: For backwards compatability with older Ai-Logix products, the


LENGTH parameter for Set APIs allows the SDK to set up to the specified
size. The rest of parameters are not changed. MT_RET_OK is returned.
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_INVALID_PARAM Invalid argument passed to
function

NOTE: When using MTSetAdapterEEPROMConfig(), if the user passes


information that is longer than 128 bytes, the data will be truncated. When
using MTGetAdapterEEPROMConfig(), the application returns the value, with
a pLength of 128 bytes.
Ai-Logix, Inc.
492 •
SmartWORKS Developer’s Guide

CT BUS FUNCTIONS

CT BUS / MUX CONTROL


The MUX system type is either MUX_MVIP, or MUX_H100, or MUX_NONE. This MUX
type is added as a registry configurable parameter for the SmartWORKS DLL under
the name CTBusType.
The SmartWORKS hardware can be either a resource card or a network card when
equipped with a T1/E1 card. The MUX interface on SmartWORKS is designed to
switch board Network Interfaces (NI), DSPs (DR) and Channels.
Function Reference Library
• 493
Introduction

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

Note - MTDisarmCTAlarm() is provided as a macro that redirects to this API


Ai-Logix, Inc.
498 •
SmartWORKS Developer’s Guide

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

Note - MTGetCTAlarmStatus() is provided as a macro that redirects to this


API
Function Reference Library
• 499
Introduction

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.

If the CT bus type is H.100, the number of timeslots available per


streams (0 - 31) 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
Use Supervise APIs to monitor remote conversations on the same
CT bus.
Prototype
MT_RESULT MTSetInputs(
const CHANNEL nChannel,
const int iStream1,
const int iSlot,
const int iStream2,
const int iSlot2
);
Parameters
nChannel channel number
iStream1 channel primary input connection
stream, Index of TDM stream: 0 - 15 for
MVIP
iSlot1 channel primary input connection
timeslot:
0 to 31 for MVIP
number varies for H.100 (see above)
-1 for not connected
iStream2 channel secondary input connection
stream, Index of TDM stream: 0 - 15 for
MVIP
iSlot2 channel secondary input connection
timeslot:
0 to 31 for MVIP
number varies for H.100 (see above)
-1 for not connected
Ai-Logix, Inc.
504 •
SmartWORKS Developer’s Guide

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.

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
Use Supervise APIs to monitor remote conversations on the same
CT bus.
Prototype
MT_RESULT MTGetInputs (
const CHANNEL nchannel,
int * const pStream,
int * const pSlot1,
int * const pStream2,
int * const pSlot2
):
Parameters
nchannel channel number
pStream1 channel primary input connection
stream, Pointer for TDM stream index: 0 -
15, -1 for not connected
pSlot1 channel primary input connection
timeslot:
0 to 31 for MVIP
number varies for H.100 (see above)
when stream is -1, a board counter is
returned for the slot value
pStream2 channel secondary input connection
stream, Pointer for TDM stream index: 0 -
15, -1 for not connected
pSlot2 channel secondary input connection
timeslot:
0 to 31 for MVIP
number varies for H.100 (see above)
when stream is -1, a board counter is
returned for the slot value
Ai-Logix, Inc.
506 •
SmartWORKS Developer’s Guide

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.

Before developing applications that work in 4-wire scenarios, it is


important to understand how framing and timeslot numbering was
implemented on the SmartWORKS NGX product. The following
diagram and table are used to illustrate framing and timeslot
numbering. A standard 2-wire implementation is compared to a 4-
wire implementation. A mapping table is also provided:
Function Reference Library
• 513
Introduction

The following table maps framer and timeslot numbering between


a 2-wire implementation versus a 4-wire.

FRAMER AND TIMESLOT NUMBERING (FRAMERS 0-3)

Framer Timeslot 2 Wire Line 4 Wire Line


0 0 NT B1 1 NT B1 1

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 -- --

.
.
.

Framer Timeslot 2 Wire Line 4 Wire Line


23 0 NT B1 24 NT B2 12

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

nSlot Index of framer slot: 1-24 for T1, 0-31 for


E1
iStream Index of TDM stream: 0-15 for MVIP, 0-31
for H100
iSlot Index of TDM slot on a stream: 0-31 for
MVIP
Return Codes
MT_RET_NOT_AVAILABLE Driver is not loaded
Events
None
Function Reference Library
• 515
Introduction

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

LOOP VOLTAGE / LOOP CURRENT / RING DETECTION STATUS FUNCTIONS

An explanation of Loop Voltage / Current on SmartWORKS boards


The following provides an overview of how loop voltage / current is managed when
using the SmartWORKS API.
SMARTWORKS AT CARDS
The SmartWORKS AT hosts 16 line interface modules. Each line interface has a
forward and reverse loop current detector, ring detector, and a hook switch.
Each SmartWORKS AT channel has its own analog line interface module that is
capable of incoming ring signal detection, forward and reverse loop current
detection, alert tone generation, and voice band signal monitoring. This line
interface operates in both ON-HOOK and OFF-HOOK mode.
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
channels.
Line Status:
Line status for AT card is represented through status bits LINE_ONHOOK and
LINE_NO_LOOP.
Event Filtering:
Event filtering of SE_LCURRENT_CHANGE yields events of EVT_LOOP_ON,
EVT_LOOP_DROP, and EVT_LOOP_REVERSE for both AT channels. Event filtering of
SE_LREV is obsolete and is 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_LOOP_DROP for AT
channel. The starting of a media task based on START_LOOPON implies the
termination of LOOP_DROP.
SMARTWORKS PT CARDS
Loop Voltage:
In PT channels whose detection is within a pre-fixed threshold high of 16V and a
pre-fixed threshold low of 3V, the loop voltage state is therefore defined into two
states: MIDDLE (e.g. OFFHOOK) and ABOVEORBELOW (e.g. NOTOFFHOOK).
Function Reference Library
• 517
Introduction

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).

With LDA’s capability of detecting the three states of loop voltage


change, LDA can detect the presence of a wink, a state the PT board
cannot. LDA can also provide current voltage reading, a capability
PT channel does not have. Default value for Threshold_high was
selected to maintain compatibility with SmartWORKS PT 1609.
The field loop_deglitch in MT_PSTN structure is for loop current de-
bouncing.
A complete explanation of loop voltage detection is provided at the
beginning of this section: Loop Voltage / Loop Current / Ring
Detection Status Functions. The following is a visual
representation of voltage states (ABOVE, BELOW, and MIDDLE).
Ai-Logix, Inc.
524 •
SmartWORKS Developer’s Guide

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.

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.

The field loop_deglitch in MT_PSTN structure is for loop current de-


bouncing

A complete explanation of loop voltage detection is provided at the


beginning of this section: Loop Voltage / Loop Current / Ring
Detection Status Functions.
Prototype
MT_RESULT MTGetLVParams (
const CHANNEL nChannel,
const PSHORT pThreshold_low,
const PSHORT pThreshold_high,
const PUSHORT pmsDeglitchTime
);
Parameters
nChannel channel number
pThreshold_low LV threshold low: -60V to 60V
pThreshold_high LV threshold high: 60V to –60V
pmsDeglitchTime 10-2550 ms, in increments of 10 ms
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.
526 •
SmartWORKS Developer’s Guide

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.

A complete explanation of loop voltage detection is provided at the


beginning of this section: Loop Voltage / Loop Current / Ring
Detection Status Functions.
Prototype
MT_RESULT MTGetLVDetectValue (
const CHANNEL nChannel,
const PSHORT pValue
);
Parameters
nChannel channel number
pValue Current LV reading in increments of 2V
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
• 527
Introduction

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.

This API (MTSetReverseLoopPolarity()) is used to set a parameter if


the loop polarity on a line is reversed. First, use MTGetLVDetect() to
obtain the current ONHOOK voltage reading. If the voltage is
negative, then the loop polarity is reversed. Use this API to reverse
the loop polarity through a software change rather than a wiring
change.

A complete explanation of loop voltage detection is provided at the


beginning of this section: Loop Voltage / Loop Current / Ring
Detection Status Functions.
Prototype
MT_RESULT MTSetReverseLoopPolarity (
const CHANNEL nChannel,
const BOOLEAN fReversed
);
Parameters
nChannel channel number
fReversed FALSE for normal, TRUE for reversed
The default is normal when a channel is
opened.
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.
528 •
SmartWORKS Developer’s Guide

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

A complete explanation of loop voltage detection is provided at the


beginning of this section: Loop Voltage / Loop Current / Ring
Detection Status Functions.
Prototype
MT_RESULT MTGetReverseLoopPolarity (
const CHANNEL nChannel,
BOOLEAN * const pReversed
);
Parameters
nChannel channel number
pReversed Pointer of buffer for reversed polarity
reading
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
• 529
Introduction

SUMMATION FUNCTIONS
The following structure is used to hold summation information.
MTSUMMATION_INFO

tResource Resource subtype


iResource; Resource index in the system
iChGCI; GCI index of the channel which controls the
resource
iBoard; Index of the board where the resource
resides
iOnBoard Resource index within the board it resides
nInputs; Number of inputs this summation supports
Ai-Logix, Inc.
530 •
SmartWORKS Developer’s Guide

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:

TABLE 34: MT_SUMMATION_INFO


Type Name Function
int tResource Summation resource sub-type, if any
int iResource Summation resource system index
int iChGCI GCI index of the channel which
controls the summation resource
int iBoard System index of the board the
summation resides
int iOnBoard Summation index within the board it
resides
int nInputs Number of inputs for the summation
Function Reference Library
• 531
Introduction

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.

Valid gain values range from -50 dB to +24dB.

For summation resources, when an 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).

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.

The pInput parameter is a pointer to an integer specifying the total


number of inputs the caller intends to retrieve. This function always
works from the 1st input. For example, if this parameter sets the
total number to 5, input settings are retrieved for the inputs
numbered 0-4.

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

MT_RET_CHANNEL_NOT_OPENED Occurs when there's no owner-


ship of the specified summa-
tion function
Events
None
Ai-Logix, Inc.
540 •
SmartWORKS Developer’s Guide

MTGetSummationOutput()
Description
MTGetSummationOutput() retrieves the time slot connection for
the output on the specified summation function.

When the specified summation function is turned off, the returned


output time slot information will indicate that the output is not
connected. This is done by setting both the stream and time slot
values to -1.
Prototypes
MT_RESULT MTGetSummationInputs (
const int iSummation,
int * const pStream,
int * const pSlot,
PSHORT const pVolume
);
Parameters
iSummation Summation function index: 0 for the first
one
pStream Pointer for stream for the summation
output
pSlot Pointer for time slot for the summation
output
pVolume Pointer for the current volume for the
summation output
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 Occurs when there's no owner-
ship of the specified summa-
tion function
MT_RET_NOT_STARTED The specified output is not con-
nected
Events
None
Function Reference Library
• 541
Introduction

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.

Valid gain values range from -50 dB to +24dB.

For summation resources, when an 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 MTSetSummationGain (
const int iSummation,
const int iInput,
const SHORT Gain
);
Parameters
iSummation Summation function index: 0 for the first
one
iInput Index of summation input: 0 - 15 for 16
summation inputs
Gain The gain setting, which ranges from
-50dB to +24dB,
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.
542 •
SmartWORKS Developer’s Guide

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.

Valid gain values range from -50 dB to +24dB.

For summation resources, when an 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 MTGetSummationGain (
const int iSummation,
const int iInput,
const SHORT pGain
);
Parameters
iSummation Summation function index: 0 for the first
one
iInput Index of summation input: 0 - 15 for 16
inputs.
pGain Pointer to the gain setting
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
• 543
Introduction

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.

System status may be retrieved from MTGetSystemInfo(). Prior to


using MTSysStartup(), the value is SYSTEM_INITIALIZED. After
using MTSysStartup() the value will change to SYSTEM_STARTED.
This function must be called before any other API.
Prototype
MT_RESULT MTSysStartup (VOID)
Return Codes
MT_RET_OK no error
MT_RET_NOT_AVAILABLE Driver is not loaded
MT_RET_NOT_STARTED No system resource to be
started; usually occurs when all
resources are in use
Events
None
Function Reference Library
• 551
Introduction

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 35: MTSYS_INFO STRUCTURE


Type Name3 Purpose

ULONG Status System status:


1 = SYSTEM_INITIALIZED
2 = SYSTEM_STARTED
3 = SYSTEM_SHUTDOWN
UCHAR res0 Number of summation functions in the system
UCHAR NumAudios Number of Audio Jacks in system
USHORT NumBoards Number of boards in the system
USHORT NumChans Number of channels in the system
USHORT StartChan Starting internal MUX channel
UCHAR StartBoard Starting internal MUX board
UCHAR MuxBoards Total number of MUX boards
USHORT MuxSystem Type of MUX system:
1 = MUX_NONE, Board with NO MUX found
2 = MUX_H100, Board with H100 found
4 = MUX_MVIP, Board with MVIP found
USHORT MuxMVIPSlot Starting MVIP slot
USHORT MuxMVIPTotalSlot Total MVIP slots
USHORT MuxChans Total number of MUX channels
UCHAR MuxGroups Total number of MUX groups (this field is not used)
UCHAR GCIStartingIndex GCI Starting index: 0 or 1
Ai-Logix, Inc.
552 •
SmartWORKS Developer’s Guide

TABLE 35: MTSYS_INFO STRUCTURE (CONTINUED)


Type Name3 Purpose

CHAR H100StreamSpeed H.100 Data Rate for 1st 16 streams:


0 = CT_2MH, CT stream speed of 2 MHz
1 = CT_4MHz, CT stream speed of 4 MHz
2 = CT_8MH, CT stream speed of 8 MHz
CHAR MVIPStreamSpeed MVIP Data Rate for the 1st 16 streams: 0
CHAR CTBusSegmented CT Bus segmentation: 0 for not allowed
CHAR NumMVIPMasterBrd Number of MVIP master board
CHAR NumH100MasterABrd Number of H.100 master A board
CHAR NumH100MasterBBrd Number of H.100 master B board
CHAR NumSec8kNetrefBrd Number of Sec8k/Netref clock sourcing board
SHORT NumDllLoaded The NtiDrv DLL currently loaded

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

H100StreamSpeed H.100 Data Rate for first 16 streams: 0, 1


or 2
MVIPStreamSpeed MVIP Data Rate for the first 16 streams: 0
CTBusSegmented CT Bus segmentation: 0 for not allowed
NumMVIPMasterBrd MVIP master board number
NumH100MasterABrd H.100 master A board number
NumH100MasterBBrd H.100 master B board number
NumSec8kNetrefBrd Sec8k/Netref clock sourcing board num-
ber
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_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

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

See also: MTGetAdapterInfo()


Ai-Logix, Inc.
554 •
SmartWORKS Developer’s Guide

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.

TABLE 36: MT_VERSION


Type Name Function
UCHAR Major Major version number
UCHAR Minor Minor version number
USHORT Internal Internal number for special purposes
such as debugging, etc. For a
formal release, this number should
be 0.
USHORT Build Build number
UCHAR Release Release code, ‘A’ for Alpha, ‘B’ for Beta,
‘ ‘ (one blank space) for release
UCHAR Feature Feature code: ‘C’ for Check build,
‘D’ for Debug build, ‘ ‘ (one blank
space) for release build

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.

TABLE 37: MT_VERSION


Name Function
MT_VERSION VerKernelDriver
MT_VERSION VerAgentService
MT_VERSION VerNtiDrvDll
MT_VERSION VerMdcDll
MT_VERSION VerDcDecodeDll
MT_VERSION VerDBRIDecodeDll

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.

Two events are generated when synchronization is complete. One


event is generated with the old timestamp, and the second is
generated with the new timestamp. Both events are system events.
These events must be called using the system event callback APIs -
MTSetSysEventCallback() and MTWaitforSysEvent().
This API resynchronizes the host time with all SmartWORKs board(s)
in the platform provided that the application has access through
either the board or a channel. In the case of an NGX card, whose
board access is excluded from this resynchronization capability, the
application requires access of one NGX channel per NGX board.
If access to a SmartWORKs board is not present, SDK assumes that
time resynchronization is not required on this board.

If multiple applications are running, such as one application per


channel, this API needs to be called from each and every
application.
Prototype
MT_RESULT MTResyncTime (
VOID
);
Parameters
no parameters are required
Return Codes
MT_RET_OK no error
MT_RET_NOT_APPLICABLE the application does not have
access to any board or channel
resource
MT_RET_TIMEOUT Wait for event timed out
Events
EVT_SYS_SYNCTIME_OLD
EVT_SYS_SYNCTIME_NEW
Function Reference Library
• 559
Introduction

TRUNK SPECIFIC APIS


Ai-Logix, Inc.
560 •
SmartWORKS Developer’s Guide

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()].

This API is only available on ANALOG_FXO_LS channels on the


SmartWORKS AT or ANALOG_VFXO_LS _E channels on the
SmartWORKS LD.

If loop current starts flowing by going off-hook, EVT_OFFHOOK will


be followed by EVT_LOOP_ON, if enabled. If EVT_OFFHOOK is
disabled with the MTSetEvents() function, the application must poll
the line status field of MTCHAN_STATUS structure to determine
when this function terminates.
Prototype
MT_RESULT MTOffHook (
CHANNEL nChannel
);
Parameter
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_BUSY Channel is already off hook
Events
EVT_OFFHOOK
EVT_LOOP_ON
EVT_LOOP_REVERSE
Function Reference Library
• 561
Introduction

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()).

This API is only available on ANANLOG_FXO_LS channels on the


SmartWORKS AT and ANALOG_VFXO_LS_E type channels on the
SmartWORKS LD card.
Prototype
MT_RESULT MTOnHook (
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_BUSY Channel is already off hook
Events
EVT_ONHOOK
EVT_LOOP_DROP
Ai-Logix, Inc.
562 •
SmartWORKS Developer’s Guide

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.

This function can only be called when the channel is on-hook.

The timing of this function is controlled by two parameters that can


be set with the MTSetPSTNParams() function. The wink-delay
specifies the delay after issuing the function call before actually
going off-hook. The wink-time specifies the time that the channel
stays off-hook. Both parameters are specified in 1 ms units and have
a default value of 150 ms.
Prototype
MT_RESULT MTWink (
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_BUSY Channel is busy
Events
EVT_WINKDONE
See Also: MTSetPSTNParams()
Ai-Logix, Inc.
564 •
SmartWORKS Developer’s Guide

WAVE HEADER UTILITY


Function Reference Library
• 565
Introduction

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()");

A complete code example is available on the Ai-Logix website:


http://www.ai-logix.com/support.html
Ai-Logix, Inc.
566 •
SmartWORKS Developer’s Guide

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.

The ptrBuffer field of the MT_EVENT structure is used for two


purposes:
1. The SmartWORKS DLL has terminated a media function based on
a termination event. The ptrBuffer field indicates the pointer to the
data buffer on which the event happened.
2. An event that contains extra information was reported. These
events include call control events (EVT_CC_). In this scenario,
ptrBuffer field points to the buffer allocated by the SmartWORKS
DLL. When the event information is retrieved, the user application
must invoke MTReturnEventBuffer() to return the allocated buffer.
As of release, 2.8, a new method of handling events with extra
information is available. To enable this option use
MTSetSystemConfig() and set the CompiledWithSDK field to a value
greater than 0x02086600.
If the user application relies on the callback method: the
ptrXtraBuffer field is used to point to the buffer holding the exta
data and the XtraDataLength field identifies the data length. When
this new method of event handling is used, MTReturnEventBuffer()
should not be used.
When using the polling method: The SmartWORKS DLL no longer
allocates a buffer for the extra information. The user application
must now allocate and manage this buffer. In the MT_EVENT
structure set the pXtraBuffer field to identify the buffer created for
extra information, and set the buffer length with the
XtraBufferLength field. The XtraDataLength field is set by the
SmartWORKS DLL and shows the actual length of data passed into
the buffer. NOTE: If the actual data length exceeds the allocated
buffer length, the data is truncated. Bit 2 of the EventFlag field in the
MT_EVENT structure is set to 0x000000004 to notify the user
application that the data has been truncated. When this new
method of event handling is used, MTReturnEventBuffer() should
not be used.
Prototype
void MTReturnEventBuffer(
PVOID ptrBuffer
);
Parameters
ptrBuffer pointer to the buffer to return
Ai-Logix, Inc.
568 •
SmartWORKS Developer’s Guide

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

See Also: MTGetAdapterInfo()


Ai-Logix, Inc.
570 •
SmartWORKS Developer’s Guide

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().

Refer to MTStartMUX() for default MUX mapping on a specified


channel.
Prototype
MT_RESULT MTStartMUXOnChannel (
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_NO_MUX Multiplexer is not available
MT_TIMEOUT Wait for event timed out
Events
None
Function Reference Library
• 571
Introduction

FIRMWARE FUNCTIONS
Ai-Logix, Inc.
572 •
SmartWORKS Developer’s Guide

INTRODUCTION: USING FIRMWARE APIS


User applications can use the SmartWORKS API to update a board’s firmware. The
following rules must be adhered to:

• These APIs cannot be used with the SmartWORKS NGX

• In the event of error during the Update Flash operation, the user must restart
the driver

• These APIs are declared in a separate header file: NtiWFAPI.h

• 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

• It is recommended that the application invoking MTWFUpdateFirmware() is


a stand alone application. This API checks for any open threads on the board
before flashing the firmware. If any are found an error message is returned

• It is recommended that all applications with access to this board invoke


MTCloseBoard() before MTWFUpdateFirmware() is invoked

The diagram on the following page illustrates the steps required when updating a
board’s firmware:
Function Reference Library
• 573
Introduction

Flashing a board using the SmartWORKS API


Note: In this scenario MTWFUpdateFirmware() is running as a background function

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

Stop all applications and


restart board drivers
Ai-Logix, Inc.
574 •
SmartWORKS Developer’s Guide

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

MT_RET_BOARD_INUSE another application is currently


accessing the board, or the
board is currently in use
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
Events
None
Function Reference Library
• 577
Introduction

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

SMARTWORKS PCM SPECIFIC APIS


The following section contains APIs that are specific for use with the SmartWORKS
PCM boards.
Ai-Logix, Inc.
580 •
SmartWORKS Developer’s Guide

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

TABLE 38: MT_BOARD_PCM_SIGNAL STRUCTURE


Type Name Values

BOOL TxSignal false for Normal (default),


true for invert
BOOL RxSignal false for Normal (default),
true for invert
BOOL FrameSycnSignal false for Normal (default),
true for invert

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

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
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().
EVT_ABANDONED
Description: For the EVT_ABANDONED with Definity, the event indicates the far-end has disconnected from a connected call state. This is different
from the definition used when monitoring call states on a BRI network: the EVT_CC_CALL_ABANDONED occurs when the calling party disconnects
from the call attempt in the alerting state. The Definity only provides this message when the far-end hangs up first.
Structure:

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)

Event Code Library


of the
framer
reporting
the event

Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG

• 594
595 •
EVT_ANSWER_BUTTON_PRESSED

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Description: Indicates that the answer button has been pressed
Structure:

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

Sub-Reason(this field is populated only when light is flashing):

NOTE: These may vary depending on phone model and PBX.


Bits 0-7 = Light Number
Bits 8 = Green
Bit 9 = Red
Bit 10 = Amber

Event Code Library


Bits 11-31 = Reserved

• 596
597 •
EVT_ALERTING_AUTO_ANSWER

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Check for call alerting with auto answer enabled
Structure:

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

* Bit 0 = Handset transmit (Mic)


Bit 1 = Handset receive (Spkr)
Bit 2 = Speaker phone (handsfree) transmit (Mic)
Bit 3 = Speaker phone (handsfree) receive (Spkr)
Bits 4-31 = Reserved
~more information is available on the next page~
This field is a 31 bit field. Bits 4-31 are reserved. Transmit and receive are always in respect to the phone’s position. Transmit - phone to PBX, and
Receive - PBX to phone. The following table lists all possible options. Not all states are observed with each PBX.

TABLE 39: EVT_AUDIO_CHANGE BIT OPTIONS

Device State SPKR SPKR HDSET HDSET HEX VALUE


RECV TRANS RECV TRANS
(LSB)

All devices are off 0 0 0 0 0x0000

0 0 0 1 0x0001

0 0 1 0 0x0002

Handset active 0 0 1 1 0x0003

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

Handset & SPR receive 1 0 1 0 0x000A


only

1 0 1 1 0x000B

1 1 0 0 0x000C

1 1 0 1 0x000D

1 1 1 0 0x000E

Event Code Library


All devices are active 1 1 1 1 0x000F

• 598
599 •
EVT_AUDIO_OFF

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Description: Although this event exists in the header file, it is not currently supported by the SmarkWORKS API. Refer to EVT_AUDIO_CHANGE.

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

Event Code Library


• 600
601 •
EVT_CALLID_DROPPED

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Description: Indicates that CallerID was detected and 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_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

SubReason - Lenght of the full packet including the CRC


XtraInfo - the first 4 bytes of the packet

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

SubReason - Length of the full packet including the CRC


XtraInfo - the first 4 bytes of the packet
EVT_CALLWAITING_BUTTON_PRESSED
Indicates that the callwaiting button was pressed.
Structure:

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

Event Code Library


• 602
603 •
EVT_CALLWAITING_LIGHT_FASTFLASHING
EVT_CALLWAITING_LIGHT_FLASHING

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
EVT_CALLWAITING_LIGHT_OFF
EVT_CALLWAITING_LIGHT_ON
EVT_CALLWAITING_LIGHT_QUICKFLASH
EVT_CALLWAITING_LIGHT_VERY_FASTFLASHING
Purpose:
Indicates that the callwaiting 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

Sub-Reason(this field is populated only when light is flashing):

NOTE: These may vary depending on phone model and PBX.


Bits 0-7 = Light Number
Bits 8 = Green
Bit 9 = Red
Bit 10 = Amber
Bits 11-31 = Reserved
EVT_CC_CALL_ALERTING
EVT_CALL_ALERTING
Description: ISDN Alert Indication. Indicates a phone is ringing on a monitored line. 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_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.

Event Code Library


The MT_CALL_INFO structure is populated with more information. This structure, along with other information, is available where Passive cards
(ISDN) Functions is discussed.

• 604
605 •
SmartWORKS Developer’s Guide
Ai-Logix, Inc.
Type Name Purpose

ULONG CallRef The unique value assigned to this call by the


ISDN network.
ULONG CallSource Indicates whether this is an incoming or outgo-
ing call. Possbile values:
MT_CALL_INCOMING_CALL,
MT_CC_OUTGOING_CALL
ULONG CallState All call states are defined in the DataCC.h file.
ULONG CallTrunk On the Ai-Logix board, the trunk number
where this call is connected.
ULONG CallDuration The total call duration in units of
ULONG Layer1Coding All layer protocol values are defined in the
header file DataCC.h.
ULONG Cause The cause of the call state. All values are
defined in the DataCC.h file.
MT_CC_CHANNEL_ID ChannelId Information about the channel used on the Ai-
Logix board.
MT_CC_PARTY_NUMBER CallerNumber The phone number where this call originated.
MT_CC_PARTY_SUBADDR CalledSubAddr When available, the originating number’s
extension.
MT_CC_PARTY_NUMBER CalledNumber The number that was dialed.
MT_CC_PARTY_SUBADDR CalledSubAddr When available, the extension number of the
called phone.
MT_CC_PARTY_NUMBER ConnectedNumber When call forwarding is in use, this is the num-
ber where the call is actually connected.
MT_CC_PARTY_SUBADDR ConnectedSubAddr When call forwarding is in use, the extension of
the phone where the call is actually connected.
MT_CC_PARTY_NUMBER RedirectingNumber If the call was re-directed to another phone,
this is the number of the phone that initiated
the re-direction.
Type Name Purpose

MT_CC_CALL_IDENTITY CallIdentity When available, any name associated with this


phone.

Event Code Library


• 606
607 •
EVT_CC_ALERT_IND

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Description: ISDN Alert Indication, indicates a phone is ringing on the monitored line. 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_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.

Event Code Library


• 608
609 •
EVT_CC_CALL_CONNECTED
EVT_CALL_CONNECTED

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Description:Indicates that an ISDN call connected. 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_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.

Event Code Library


• 610
611 •
EVT_CC_CALL_REJECTED
EVT_CALL_REJECTED

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates that an ISDN call has been rejected. 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_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.

Event Code Library


• 612
613 •
EVT_CC_CALL_RESUMED
EVT_CALL_RESUMED

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates that an ISDN call has resumed. 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_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.

Event Code Library


• 614
615 •
EVT_CC_CALL_SUSPENDED
EVT_CALL_SUSPEN

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates that an ISDN call has been suspended. 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_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.

Event Code Library


The MT_CC_CONNECT_CONF structure is populated with this information:
typedef struct
{
int ConnectionId ;

• 616
int CallRef ;
617 •
int Flags ;

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
MT_CC_CHANNEL_ID ChannelId;
} MT_CC_CONNECT_CONF, * PMT_CC_CONNECT_CONF;
EVT_CC_CONNECT_IND
Indicates an incoming call. 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_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.

Event Code Library


The MT_CC_CONNECT_IND structure is populated with more information:
typedef struct
{

• 618
int CallRef ;
619 •
int SendingComplete ; NOTE: Used with RBS only.

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
int Flags ;
MT_CC_CHANNEL_ID ChannelId;
MT_CC_BEARER_CAPS BearerCaps;
MT_CC_PARTY_NUMBER CalledPartyAddr;
MT_CC_PARTY_SUBADDR CalledPartySubAddr;
MT_CC_PARTY_NUMBER CallingPartyAddr;
MT_CC_PARTY_SUBADDR CallingPartySubAddr;
MT_CC_U2U UserInfo ;
MT_CC_FACILITY Facility ;
} MT_CC_CONNECT_IND, * PMT_CC_CONNECT_IND;
EVT_CC_DISC_CONF
Indicates disconnect 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_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.

Event Code Library


The MT_CC_DISC_CONF structure is populated with this information:
typedef struct
{

• 620
int ConnectionId ;
621 •
int CallRef ;

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
int Cause ;
} MT_CC_DISC_CONF, * PMT_CC_DISC_CONF;
EVT_CC_DISC_IND
Indicates a disconnect. 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_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.

Event Code Library


The MT_CC_DISC_IND structure is populated with this information:
typedef struct
{
int ConnectionId ;

• 622
int CallRef ;
623 •
int Cause ;

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
MT_CC_U2U UserInfo ;
MT_CC_FACILITY Facility ;
} MT_CC_DISC_IND, * PMT_CC_DISC_IND;
EVT_CC_FACILITY_CONF
A facility 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_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.

Event Code Library


The MT_CC_FACILITY_CONF is populated with this information:
typedef struct
{

• 624
int ConnectionId ;
625 •
int CallRef ;

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
int AccessId ;
int Action ;
int Code ;
int NetCause ;
int Flags ;
MT_CC_CHANNEL_ID ChannelId;
MT_CC_PARTY_NUMBER CalledAddr;
MT_CC_PARTY_NUMBER CallingAddr;
MT_CC_VOICE_SUPSRV Voice ;
MT_CC_FACILITY Facility ;
} MT_CC_FACILITY_CONF, * PMT_CC_FACILITY_CONF;
EVT_CC_FACILITY_IND
A facility indication. 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_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.

Event Code Library


The MT_CC_FACILITY_IND structure is populated with this information:
typedef struct
{
int ConnectionId ;

• 626
int CallRef ;
627 •
int AccessId ;

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
int Action ;
int Code ;
int Flags ;
MT_CC_CHANNEL_ID ChannelId;
MT_CC_PARTY_NUMBER CalledAddr;
MT_CC_PARTY_NUMBER CallingAddr;
MT_CC_VOICE_SUPSRV Voice ;
MT_CC_FACILITY Facility ;

} 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.

Event Code Library


The MT_CC_INFO_IND structure is populated with this information:
typedef struct
{
int ConnectionId ;

• 628
int CallRef ;
629 •
int Flags ;

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
MT_CC_PARTY_NUMBER CalledPartyAddr;
} MT_CC_INFO_IND, * PMT_CC_INFO_IND;
EVT_CC_PROGRESS_IND
Indicates ISDN call progress. 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_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:

Event Code Library


typedef struct
{
int ConnectionId ;
int CallRef ;

• 630
int Flags ;
631 •
MT_CC_CHANNEL_ID ChannelId;

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
} MT_CC_PROGRESS_IND, * PMT_CC_PROGRESS_IND;
EVT_CC_RESUME_CONF
A ISDN call was resumed. 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_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.

Event Code Library


The MT_CC_RESUME_CONF structure is populated with this information:
typedef struct
{

• 632
int ConnectionId ;
633 •
int CallRef ;

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
int RetCode ;
int NetCause ;
MT_CC_CHANNEL_ID ChannelId;
MT_CC_CALL_IDENTITY CallIdentity ;

} 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.

The MT_CC_SUSPEND_CONF structure is populated with this information:


typedef struct
{
int ConnectionId ;
int CallRef ;

Event Code Library


int RetCode ;
int NetCause ;
MT_CC_CALL_IDENTITY CallIdentity ;

• 634
} MT_CC_SUSPEND_CONF, * PMT_CC_SUSPEND_CONF;
635 •
EVT_CC_USERINFO_IND
EVT_CC_USER_INFO

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
EVT_USER_INFO
Indicates user information. 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_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.

The MT_USER_INFO structure is populated with the following information:


typedef struct
{
int Length ;
UCHAR Info[MT_CC_MAX_USERINFO_SIZE] ;
} MT_CC_USERINFO, * PMT_CC_USERINFO ;

Event Code Library


• 636
637 •
EVT_CC_USERINFO_REQ

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates ISDN user information has been requested. 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_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.

The MT_CC_USERINFO_REQ structure is populated with this information:


typedef struct
{
int ConnectionId ;
int CallRef ;
MT_CC_USERINFO UserInfo ;

} MT_CC_USERINFO_REQ, * PMT_CC_USERINFO_REQ;

Event Code Library


• 638
639 •
EVT_CFWD

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates call forward activation
Structure:

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

Event Code Library


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 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

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
EVT_CONFERENCE_LIGHT_OFF
EVT_CONFERENCE_LIGHT_ON
EVT_CONFERENCE_LIGHT_QUICKFLASH
EVT_CONFERENCE_LIGHT_VERY_FASTFLASHING
EVT_CONFERENCE_LIGHT_WINK
Purpose:
Indicates that the conference light on the phone is fast 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_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

Sub-Reason(this field is only populated when light is flashing or winking):

NOTE: These may vary depending on phone model and PBX.


Bits 0-7 = Light Number
Bits 8 = Green
Bit 9 = Red
Bit 10 = Amber
Bits 11-31 = Reserved
EVT_CONNECTED
Indicates connection
Structure:

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

Event Code Library


• 642
643 •
EVT_CPM_STOP

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates a termination condition has been met. If a termination condition has been enabled (using MTSetTerm() or TermEnable field of the IO_CONTROL structure)
it results in an EVT_CPM _STOP. The associated background function(s) are terminated and the channel either enters into an idle state or executes the next
background function if one is queued. The termination condition is identified in the Subreason and XtraInfo fields. The media function that has been stopped is
identified in the FuncCode field. One CPM_STOP event is generated for each background function that has been stopped. NOTE: MTCallString() is a background
function. When a termination condition has been met, MTCallString() stops and a CPM_STOP event is generated.
Structure:

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.

Event Code Library


• 644
645 •
EVT_DESTINATION_BUSY

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates that the destination called is busy
Structure:

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

Event Code Library


In FileTIME 0-n/a EVT_DIALED 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

• 646
647 •
EVT_DIGIT

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates the received DTMF digit queued. 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 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

*Byte 0 = ASCII value of the digit pressed


Byte 1-31 = Reserved

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

*Bit 0 = ASCII value of the digit pressed


Bits 1-31 = Reserved
EVT_DIGIT_PRESSED
Indicates that a digit button was pressed
Structure:

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

*Bit 0 = ASCII value of the digit pressed


Bits 1-31 = Reserved

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

*Bit 0 = ASCII value of the digit pressed


Bits 1-31 = Reserved

Event Code Library


• 648
649 •
SmartWORKS Developer’s Guide
Ai-Logix, Inc.
EVT_DIGITENABLE
Indicates termination of a background function by an enabled DTMF digit
Structure:

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

Sub-Reason(this field is populated only when light is flashing):

NOTE: These may vary depending on phone model and PBX.


Bits 0-7 = Light Number
Bits 8 = Green
Bit 9 = Red
Bit 10 = Amber

Event Code Library


Bits 11-31 = Reserved

• 650
651 •
EVT_DISCONNECTED

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates a disconnect
Structure:

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.

Event Code Library


• 652
653 •
EVT_DISPLAY_MESSAGE

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Purpose:
Indicates whether any message (defined and saved on the PBX) has been displayed in the LCD on the phone.
Currently, only three lines of LCD text is passed over to the event files. Any messages larger than that will be truncated. When any data that is displayed
on the LCD, ie phone number, agent id, the EVT_MESSAGE_CHANGE event is generated.

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

Event Code Library


• 654
655 •
EVT_DIVERT_LIGHT_FASTFLASHING
EVT_DIVERT_LIGHT_VERY_FASTFLASHING

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
EVT_DIVERT_LIGHT_FLASHING
EVT_DIVERT_LIGHT_OFF
EVT_DIVERT_LIGHT_ON
EVT_DIVERT_LIGHT_QUICKFLASH
Purpose:
Indicates that the divert 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_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

Sub-Reason(this field is populated only when light is flashing):

NOTE: These may vary depending on phone model and PBX.


Bits 0-7 = Light Number
Bits 8 = Green
Bit 9 = Red
Bit 10 = Amber
Bits 11-31 = Reserved
EVT_DND_BUTTON_PRESSED
Indicates that the do not disturb button was pressed.
Structure:

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

Event Code Library


• 656
657 •
EVT_DND_LIGHT_FASTFLASHING
EVT_DND_LIGHT_VERY_FASTFLASHING

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
EVT_DND_LIGHT_FLASHING
EVT_DND_LIGHT_OFF
EVT_DND_LIGHT_ON
EVT_DND_LIGHT_QUICKFLASH
EVT_DND_LIGHT_MEDIUM_WINK
EVT_DND_LIGHT_WINK
Purpose:
Indicates that the do not disturb 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_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

Sub-Reason(this field is populated only when light is flashing or winking):

NOTE: These may vary depending on phone model and PBX.


Bits 0-7 = Light Number
Bits 8 = Green
Bit 9 = Red
Bit 10 = Amber
Bits 11-31 = Reserved
EVT_DOWNLOAD_STATUS
Not supported. Although this event exists in the header file, it is not currently supported by the SmartWORKS API.

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

Event Code Library


• 658
659 •
EVT_EOF

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates that the end of file was reached on playback.
Structure:

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

Event Code Library


format PRESSED Channel
ID (GCI)

Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG

• 660
661 •
EVT_FEATURE_LIGHT_FASTFLASHING
EVT_FEATURE_LIGHT_FLASHING

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
EVT_FEATURE_LIGHT_ON
EVT_FEATURE_LIGHT_OFF
EVT_FEATURE_LIGHT_QUICKFLASHING
EVT_FEATURE_LIGHT_VERY_FASTFLASHING
Purpose:
Indicates that a feature 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_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

Sub-Reason(this field is only populated when the light is flashing):

NOTE: These may vary depending on phone model and PBX.


Bits 0-7 = Light Number
Bits 8 = Green
Bit 9 = Red
Bit 10 = Amber
Bits 11-31 = Reserved
------------------------------------------
Alcatel phones do not have lights, instead pictures are presented on the phone display. The following bits are set:
Bits 0-7 = “Light” Number
Bits 8 = square, located on the right side of the display area
Bit 9 = music symbol
Bit 10 = square, located in the center of the display area
Bit 11 = handset symbol
Bit 12 = square, located on the left side of the display area
Bit 13 = alert symbol
Bits 14=31 Reserved

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

Event Code Library


format PRESSED Channel
ID (GCI)

Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG

* Bit 0 = Button number 0-255


Bits 1-31 = Reserved

• 662
663 •
EVT_FEATURE_BUTTON_RELEASED

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates thats a feature button has been released
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
format PRESSED Channel
ID (GCI)

Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG

* Bit 0 = Button number 0-255


Bits 1-31 = Reserved

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

Event Code Library


• 664
665 •
EVT_FLASH_LIGHT_FASTFLASHING
EVT_FLASH_LIGHT_VERY_FASTFLASHING

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
EVT_FLASH_LIGHT_FLASHING
EVT_FLASH_LIGHT_OFF
EVT_FLASH_LIGHT_ON
EVT_FLASH_LIGHT_QUICKFLASH
EVT_FLASH_LIGHT_MEDIUM_WINK
Purpose:
Indicates that the flash 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_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

Sub-Reason(this field is populated only when light is flashing or winking):

NOTE: These may vary depending on phone model and PBX.


Bits 0-7 = Light Number
Bits 8 = Green
Bit 9 = Red
Bit 10 = Amber
Bits 11-31 = Reserved
EVT_FRAME_DATA_ERROR
Indicates that a background function (playback) has terminated due to a frame data error
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 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

* Bit 0 = Button number 0-255


Bits 1-31 = Reserved

Event Code Library


• 666
667 •
EVT_FUNCTION_BUTTON_PRESSED

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Description: Indicates that the function button has been pressed
Structure:

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

Sub-Reason(this field is populated only when light is flashing):

Event Code Library


NOTE: These may vary depending on phone model and PBX.
Bits 0-7 = Light Number
Bits 8 = Green
Bit 9 = Red
Bit 10 = Amber
Bits 11-31 = Reserved (~ more information on nextpage~)

• 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

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Bit 9 = music symbol
Bit 10 = square, located in the center of the display area
Bit 11 = handset symbol
Bit 12 = square, located on the left side of the display area
Bit 13 = alert symbol
Bits 14=31 Reserved

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

Sub-Reason(this field is populated only when light is flashing):

NOTE: These may vary depending on phone model and PBX.


Bits 0-7 = Light Number
Bits 8 = Green
Bit 9 = Red
Bit 10 = Amber

Event Code Library


Bits 11-31 = Reserved

• 670
671 •
EVT_H100_MASTER_A_ALARM

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates H100 Master A clock error detection event. This event will be generated when it has been armed by an Arm H.100 Clock A Error Event command, and
CT812 reports an error condition on line CT_C8_A 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_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

Event Code Library


• 672
673 •
EVT_HANDSFREE_LIGHT_FASTFLASHING
EVT_HANDSFREE_LIGHT_VERY_FASTFLASHING

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
EVT_HANDSFREE_LIGHT_FLASHING
EVT_HANDSFREE_LIGHT_OFF
EVT_HANDSFREE_LIGHT_ON
EVT_HANDSFREE_LIGHT_QUICKFLASH
Purpose:
Indicates that the handsfree 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_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

Sub-Reason(this field is populated only when light is flashing):

NOTE: These may vary depending on phone model and PBX.


Bits 0-7 = Light Number
Bits 8 = Green
Bit 9 = Red
Bit 10 = Amber
Bits 11-31 = Reserved
EVT_HELP_BUTTON_PRESSED
Indicates that the help button has been pressed
Structure:

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

Event Code Library


• 674
675 •
EVT_HELP_LIGHT_FASTFLASHING
EVT_HELP_LIGHT_FLASHING

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
EVT_HELP_LIGHT_OFF
EVT_HELP_LIGHT_ON
EVT_HELP_LIGHT_QUICKFLASH
EVT_HELP_LIGHT_VERY_FASTFLASHING
Purpose:
Indicates that the help 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_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

Sub-Reason(this field is populated only when light is flashing):

NOTE: These may vary depending on phone model and PBX.


Bits 0-7 = Light Number
Bits 8 = Green
Bit 9 = Red
Bit 10 = Amber
Bits 11-31 = Reserved
EVT_HOLD_BUTTON_PRESSED
Indicates that the hold button has been pressed
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 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

Event Code Library


• 676
677 •
EVT_HOLD_LIGHT_FASTFLASHING
EVT_HOLD_LIGHT_FLASHING

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
EVT_HOLD_LIGHT_OFF
EVT_HOLD_LIGHT_ON
EVT_HOLD_LIGHT_QUICKFLASH
EVT_HOLD_LIGHT_VERY_FASTFLASHING
Purpose:
Indicates that the hold 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_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

Sub-Reason(this field is populated only when light is flashing):

NOTE: These may vary depending on phone model and PBX.


Bits 0-7 = Light Number
Bits 8 = Green
Bit 9 = Red
Bit 10 = Amber
Bits 11-31 = Reserved
EVT_IDLE
Indicates that the channel is in the IDLE state after the channel has flushed all operations
Structure:

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)

Event Code Library


DataLength:
the duration of the previous state in 10 ms units

• 678
679 •
EVT_INDEX_PLAYED

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates the indexed byte length played
Structure:

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

Event Code Library


• 680
681 •
EVT_INTERCOM_LIGHT_FASTFLASHING
EVT_INTERCOM_LIGHT_FLASHING

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
EVT_INTERCOM_LIGHT_ON
EVT_INTERCOM_LIGHT_OFF
EVT_INTERCOM_LIGHT_QUICKFLASH
EVT_INTERCOM_LIGHT_VERY_FASTFLASHING
Indicates that the intercom light on the phone is on, off, or flashing.
Structure:

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

* Subreason: (This field is only populated when the light is flashing)


Bits 0-7 = Light number
Bit 8 = Green light
Bit 9 = Red light
Bits 10-31 = Reserved

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

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
EVT_LIGHT_ON
EVT_LIGHT_OFF
EVT_LIGHT_QUICKFLASH
EVT_LIGHT_VERY_FASTFLASHING
Indicates that the light on the phone is on, off, or flashing.
Structure:

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

* Subreason: (This field is only populated when the light is flashing)


Bits 0-7 = Light number
Bit 8 = Green light
Bit 9 = Red light
Bits 10-31 = Reserved

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

Event Code Library


• 683
684 •
EVT_LOCRCMF_ALARM

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates a LOSS ofCRC Multiframe Alignment alarm (E1 only). 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_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

Event Code Library


SubReason:
Current & Previous state
DataLen:
Duration of previous state in ms.

• 685
686 •
EVT_LOOP_REVERSE

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates a Loop current battery reversal (current flow is ring to tip)
Structure:

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

Event Code Library


• 687
688 •
EVT_LOS_ALARM

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates a Loss of Signal alarm on the 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_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

Event Code Library


*SubReason:
Current & Previous voltage state

DataLen:
Duration of previous state in 10 ms increments

• 689
690 •
EVT_LVOLTAGE_BELOW

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates a loop voltage detected that falls above the below the set threshold (LowThreshold parameter used by 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 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

Event Code Library


• 691
692 •
EVT_LVOLTAGE_OFFHOOK
EVT_LVOLTAGE_MIDDLE

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates a loop voltage detected
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 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.

Event Code Library


• 693
694 •
EVT_MAX_SILENCE

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Issued by a channel device when activity detection is enabled and the silence timer has reached its specified maximum. Upon issuing this event, the silence timer is
reset to zero (0).
Structure:

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:

Event Code Library


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 PRESSED Channel
ID (GCI)

• 695
Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG
696 •
EVT_MENU_BUTTON_RELEASED

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates that a menu button has been released.
Structure:

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.

Event Code Library


• 697
698 •
EVT_MESSAGE_LIGHT_FASTFLASHING
EVT_MESSAGE_LIGHT_FLASHING

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
EVT_MESSAGE_LIGHT_ON
EVT_MESSAGE_LIGHT_OFF
EVT_MESSAGE_LIGHT_QUICKFLASH
EVT_MESSAGE_LIGHT_VERY_FASTFLASHING
EVT_MESSAGE_LIGHT_MEDIUM_WINK
Purpose:
Indicates that the message 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_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

Sub-Reason(This field is only populated when the light is flashing or winking):

NOTE: These may vary depending on phone model and PBX.


Bits 0-7 = Light Number
Bits 8 = Green
Bit 9 = Red
Bit 10 = Amber
Bits 11-31 = Reserved
EVT_MFTONE
Indicates that received MF(R2) tone has been queued
Structure:

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

Event Code Library


*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.

• 699
700 •
EVT_MIC_BUTTON_PRESSED

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates that a microphone button has been pressed
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 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

Sub-Reason(This field is only populated when the light is flashing):

NOTE: These may vary depending on phone model and PBX.


Bits 0-7 = Light Number
Bits 8 = Green
Bit 9 = Red

Event Code Library


Bit 10 = Amber
Bits 11-31 = Reserved

• 701
702 •
EVT_MODE_BUTTON_PRESSED

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates that a mode button has been pressed
Structure:

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

Event Code Library


• 703
704 •
EVT_MON_BUSY1

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates CPM detection of BUSY1 signal. The signal Index ID is passed in the XtraInfo field.
NOTE: EVT_MON_BUSY 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
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

Event Code Library


• 705
706 •
EVT_MON_CALLWAITING

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates CPM detection of CALLWAITING 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_ 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

*Total cycle count, incremented until the cycle is no longer detected.


EVT_MON_DIAL
EVT_MON_DIAL1, EVT_MON_DIAL2, EVT_MON_DIAL3
Indicates CPM detection of a dial tone on the line. The signal Index ID is passed in the XtraInfo field.
NOTE: As of release v3.3 this event has been obsoleted. When MONI_DIAL is enabled, then events EVT_MON_DIAL1, EVT_MON_DIAL2, and EVT_MON_DIAL3 are
generated respectively.
Structure:

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

Event Code Library


• 707
708 •
EVT_MON_DIAL1

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates CPM detection of a DIAL1 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_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

Event Code Library


• 709
710 •
EVT_MON_DIAL3

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates CPM detection of a DIAL3 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_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

Event Code Library


• 711
EVT_MON_FAX
EVT_MON_FAX1
Indicates CPM detection of a FAX1 signal. The signal Index ID is passed in the XtraInfo field.
NOTE: The event EVT_MON_FAX has been obsoleted as of v3.3 release. It has been mapped to EVT_MON_FAX1 for backwards compatibility.
Structure:

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

Event Code Library


• 712
713 •
EVT_MON_FAX1

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates CPM detection of a FAX1 signal. The signal Index ID is passed in the XtraInfo field.
NOTE: The event EVT_MON_FAX has been obsoleted as of v3.3 release. It has been mapped to EVT_MON_FAX1 for backwards compatibility.
Structure:

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:

Event Code Library


TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DaaLength

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

Event Code Library


In FileTIME 0-n/a EVT_MON_REVERSAL 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

• 716
717 •
EVT_MON_RINGBACK
EVT_MON_RINGBACK1

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates CPM detection of a RINGBACK1 signal. The signal Index ID is passed in the XtraInfo field.
NOTE: This event was obsoleted as of v3.3 release. It has been mapped to event EVT_MON_RINGBACK1 for backwards compatibility.
Structure:

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

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates CPM detection of a RINGBACK1 signal. The signal Index ID is passed in the XtraInfo field.
NOTE: The event EVT_MON_RINGBACK was obsoleted as of v3.3 release. It has been mapped to event EVT_MON_RINGBACK1 for backwards compatibility.
Structure:

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

Event Code Library


• 719
720 •
EVT_MON_SIGNAL_CYCLE

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Used as a counting mechanism when CPM or Usr signals that have a distinct ON/OFF cadence pattern have been detected. The MONI_SIGNAL_CYCLE bit must be
enabled as well as the fDetectCycle flag in the signal’s profile. This event is generated once for each complete cycle detected by the firmware. The SubReason field is
used as a counter.
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_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

Event Code Library


• 721
722 •
EVT_MON_SIT1

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates the CPM detection of a SIT1 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_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

Event Code Library


• 723
724 •
EVT_MON_SIT3

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates the CPM detection of a SIT3 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_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

Event Code Library


• 725
726 •
EVT_MON_SIT5

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates the CPM detection of a SIT5 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_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

Event Code Library


• 727
728 •
EVT_MON_UTONE

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates CPM detection of user defined signal (Usr Tone). The signal Index ID is passed in the XtraInfo field. This event is only generated if the Usr Tone has not been
defined with an alias.
Structure:

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

Event Code Library


• 729
730 •
EVT_MUTE_LIGHT_FASTFLASHING
EVT_MUTE_LIGHT_VERY_FASTFLASHING

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
EVT_MUTE_LIGHT_FLASHING
EVT_MUTE_LIGHT_OFF
EVT_MUTE_LIGHT_ON
EVT_MUTE_LIGHT_QUICKFLASH
EVT_MUTE_LIGHT_WINK
Purpose:
Indicates that the mute 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_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

Sub-Reason(this field is populated only when light is flashing or winking):

NOTE: These may vary depending on phone model and PBX.


Bits 0-7 = Light Number
Bits 8 = Green
Bit 9 = Red
Bit 10 = Amber
Bits 11-31 = Reserved
EVT_MVIP_ALARM
Indicates an MVIP alarm detected. This event will be generated when it has been armed by an Arm MVIP Error Event command, and CT812 reports an MVIP error
condition.
Structure:

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

Event Code Library


• 731
732 •
EVT_NEXT_BUTTON_PRESSED

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates that the Next button has been pressed
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 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:

Event Code Library


TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength

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

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates a change of Signaling Bits (ABCD) on outgoing line
Structure:

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

Event Code Library


• 735
736 •
EVT_PAGE_LIGHT_FASTFLASHING
EVT_PAGE_LIGHT_FLASHING

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
EVT_PAGE_LIGHT_OFF
EVT_PAGE_LIGHT_ON
EVT_PAGE_LIGHT_QUICKFLASH
EVT_PAGE_LIGHT_VERY_FASTFLASHING
Purpose:
Indicates that the page 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_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

Sub-Reason(this field is populated only when light is flashing):

NOTE: These may vary depending on phone model and PBX.


Bits 0-7 = Light Number
Bits 8 = Green
Bit 9 = Red
Bit 10 = Amber
Bits 11-31 = Reserved
EVT_PARK_BUTTON_PRESSED
Indicates that the park button was pressed. A 'park' is similar to a call on hold, except that once the call is 'parked' other extensions can access the
held call.
Structure:

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

Event Code Library


• 737
738 •
EVT_PARK_LIGHT_FASTFLASHING
EVT_PARK_LIGHT_FLASHING

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
EVT_PARK_LIGHT_OFF
EVT_PARK_LIGHT_ON
EVT_PARK_LIGHT_QUICKFLASH
EVT_PARK_LIGHT_VERY_FASTFLASHING
Purpose:
Indicates that the park 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_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

Sub-Reason(this field is populated only when light is flashing):

NOTE: These may vary depending on phone model and PBX.


Bits 0-7 = Light Number
Bits 8 = Green
Bit 9 = Red
Bit 10 = Amber
Bits 11-31 = Reserved
EVT_PAUSED_BUTTON_PRESSED
Indicates that the paused button has been pressed
Structure:

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

Event Code Library


• 739
740 •
EVT_PROGRAM_BUTTON_PRESSED

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates that the program button was pressed
Structure:

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

Sub-Reason(this field is populated only when light is flashing or winking):

NOTE: These may vary depending on phone model and PBX.


Bits 0-7 = Light Number
Bits 8 = Green

Event Code Library


Bit 9 = Red
Bit 10 = Amber
Bits 11-31 = Reserved

• 741
742 •
EVT_READY_BUTTON_PRESSED

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates that the ready button was pressed
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 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

Sub-Reason(this field is populated only when light is flashing):

NOTE: These may vary depending on phone model and PBX.


Bits 0-7 = Light Number
Bits 8 = Green
Bit 9 = Red
Bit 10 = Amber

Event Code Library


Bits 11-31 = Reserved

• 743
744 •
EVT_RECALL_BUTTON_PRESSED

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates that the Recall button has been pressed
Structure:

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

Event Code Library


• 745
746 •
EVT_RELEASE_LIGHT_FASTFLASHING
EVT_RELEASE_LIGHT_FLASHING

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
EVT_RELEASE_LIGHT_OFF
EVT_RELEASE_LIGHT_ON
EVT_RELEASE_LIGHT_QUICKFLASH
EVT_RELEASE_LIGHT_VERY_FASTFLASHING
Purpose:
Indicates that the release 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_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

Sub-Reason(this field is populated only when light is flashing):

NOTE: These may vary depending on phone model and PBX.


Bits 0-7 = Light Number
Bits 8 = Green
Bit 9 = Red
Bit 10 = Amber
Bits 11-31 = Reserved
EVT_REORDER
Indicates that the called destination doesn’t exist
Structure:

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

Event Code Library


• 747
748 •
EVT_RING_LIGHT_FASTFLASHING
EVT_RING_LIGHT_FLASHING

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
EVT_RING_LIGHT_ON
EVT_RING_LIGHT_OFF
EVT_RING_LIGHT_QUICKFLASH
EVT_RING_LIGHT_VERY_FASTFLASHING
Purpose:
Indicates that the ring 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_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

Sub-Reason(this field is only populated when the light is flashing):

NOTE: These may vary depending on phone model and PBX.


Bits 0-7 = Light Number
Bits 8 = Green
Bit 9 = Red
Bit 10 = Amber
Bits 11-31 = Reserved
EVT_RING_OFF
Indicates when the phone stops ringing. The phone ring cadence can be determined by calculating the time interval between EVT_RING_OFF and EVT_RING_ON
using the TimeStamp in the event structure
Structure:

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:

Event Code Library


TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength

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

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates that the ringtones button was pressed
Structure:

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

Sub-Reason(this field is populated only when light is flashing):

NOTE: These may vary depending on phone model and PBX.


Bits 0-7 = Light Number
Bits 8 = Green
Bit 9 = Red
Bit 10 = Amber

Event Code Library


Bits 11-31 = Reserved

• 751
752 •
EVT_SAVE_BUTTON_PRESSED

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates that the save button was pressed
Structure:

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

Sub-Reason(this field is populated only when light is flashing):

NOTE: These may vary depending on phone model and PBX.


Bits 0-7 = Light Number
Bits 8 = Green
Bit 9 = Red
Bit 10 = Amber

Event Code Library


Bits 11-31 = Reserved

• 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

Event Code Library


• 754
755 •
EVT_SCROLL_LIGHT_FASTFLASHING
EVT_SCROLL_LIGHT_VERY_FASTFLASHING

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
EVT_SCROLL_LIGHT_FLASHING
EVT_SCROLL_LIGHT_OFF
EVT_SCROLL_LIGHT_ON
EVT_SCROLL_LIGHT_QUICKFLASH
Purpose:
Indicates that the scroll 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_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

Sub-Reason(this field is populated only when light is flashing):

NOTE: These may vary depending on phone model and PBX.


Bits 0-7 = Light Number
Bits 8 = Green
Bit 9 = Red
Bit 10 = Amber
Bits 11-31 = Reserved
EVT_SELECT_BUTTON_PRESSED
Indicates that the select button has been pressed
Structure:

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

Event Code Library


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 CANCELED Channel
ID (GCI)

Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG

• 756
757 •
EVT_SHIFT_BUTTON_PRESSED

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates that the shift button has been pressed.
Structure:

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

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
EVT_SOFT_LIGHT_FLASHING
EVT_SOFT_LIGHT_OFF
EVT_SOFT_LIGHT_ON
EVT_SOFT_LIGHT_QUICKFLASH
Purpose:
Indicates that the soft 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_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

Sub-Reason(this field is populated only when light is flashing):

NOTE: These may vary depending on phone model and PBX.


Bits 0-7 = Light Number
Bits 8 = Green
Bit 9 = Red
Bit 10 = Amber
Bits 11-31 = Reserved
EVT_SPEAKER_BUTTON_PRESSED
Indicates that a speaker (or hands free) button has been pressed
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 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

Event Code Library


• 759
760 •
EVT_SPEAKER_LIGHT_FASTFLASHING
EVT_SPEAKER_LIGHT_FLASHING

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
EVT_SPEAKER_LIGHT_ON
EVT_SPEAKER_LIGHT_OFF
EVT_SPEAKER_LIGHT_QUICKFLASH
EVT_SPEAKER_LIGHT_VERY_FASTFLASHING
EVT_SPEAKER_LIGHT_MEDIUM_WINK
EVT_SPEAKER_LIGHT_WINK

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

Sub-Reason(this field is only populated when the light is flashing or winking):

NOTE: These may vary depending on phone model and PBX.


Bits 0-7 = Light Number
Bits 8 = Green
Bit 9 = Red
Bit 10 = Amber
Bits 11-31 = Reserved
EVT_SPEEDDIAL_BUTTON_PRESSED
Indicates that a speeddial button has been pressed
Structure:

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

Event Code Library


• 761
762 •
EVT_SPEEDDIAL_LIGHT_FASTFLASHING
EVT_SPEEDDIAL_LIGHT_FLASHING

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
EVT_SPEEDDIAL_LIGHT_ON
EVT_SPEEDDIAL_LIGHT_OFF
EVT_SPEEDDIAL_LIGHT_QUICKFLASH
EVT_SPEEDDIAL_LIGHT_VERY_FASTFLASHING
EVT_SPEEDDIAL_LIGHT_MEDIUM_WINK
EVT_SPEEDDIAL_LIGHT_WINK

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

Sub-Reason(this field is only populated when the light is flashing or winking):

NOTE: These may vary depending on phone model and PBX.


Bits 0-7 = Light Number
Bits 8 = Green
Bit 9 = Red
Bit 10 = Amber
Bits 11-31 = Reserved
EVT_STOP
Indicates that the specified background function on a channel has stopped when the function MTStopChannel() was invoked.
Structure:

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

Event Code Library


• 763
764 •
EVT_STREAMIN_DROPPED

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates input streaming data dropped.
Structure:

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:

Event Code Library


length of data dropped

• 765
766 •
EVT_STREAMOUT_EMPTY

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates output stream buffer empty
Structure:

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

Event Code Library


• 767
768 •
EVT_STREAMOUT_STOP

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates data DEcode streaming stopped
Structure:

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

Event Code Library


• 769
770 •
EVT_SUPERVISOR_LIGHT_FASTFLASHING
EVT_SUPERVISOR_LIGHT_FLASHING

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
EVT_SUPERVISOR_LIGHT_OFF
EVT_SUPERVISOR_LIGHT_ON
EVT_SUPERVISOR_LIGHT_QUICKFLASH
EVT_SUPERVISOR_LIGHT_VERY_FASTFLASHING
Purpose:
Indicates that the supervisor 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_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

Sub-Reason(this field is populated only when light is flashing):

NOTE: These may vary depending on phone model and PBX.


Bits 0-7 = Light Number
Bits 8 = Green
Bit 9 = Red
Bit 10 = Amber
Bits 11-31 = Reserved
EVT_SYS_BOARD_ADDED
Indicates that a board has been added to the system (newly initialized) after the user’s application began running. It is recommended that the user run
MTGetSystemInfo() to obtain new total board count. 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_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:

Event Code Library


TimeStamp UserStatus EventCode SubReason XtraInfo FuncCode Board Channel ptrBuffer DataLength

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

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Resynchronization completed. The timestamp of this event displays the new time after resynchronization. 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 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

Event Code Library


• 773
774 •
EVT_TERMSILENCE

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates termination of background function due to silence reached on play or record
Structure:

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

Event Code Library


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 PRESSED Channel
ID (GCI)

Large_INT ULONG ULONG ULONG ULONG ULONG USHORT USHORT PVOID ULONG

• 775
776 •
EVT_TRANSFER_BUTTON_RELEASED

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates that the Transfer button has been released
Structure:

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

Sub-Reason(this field is populated only when light is flashing or winking):

NOTE: These may vary depending on phone model and PBX.


Bits 0-7 = Light Number
Bits 8 = Green

Event Code Library


Bit 9 = Red
Bit 10 = Amber
Bits 11-31 = Reserved

• 777
778 •
EVT_TS16RAI_ALARM

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates Timeslot 16 Remote Alarm Indication alarm (E1 only)
Structure:

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

Event Code Library


In FileTIME 0-n/a EVT_VOICE_RECORD See Below* 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

• 779
*The field is populated with CPM_MON_VOICE which indicates that voice activity was detected on the line.
780 •
EVT_WINKDONE

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates winks protocol complete
Structure:

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

Sub-Reason(this field is populated only when light is flashing):

NOTE: These may vary depending on phone model and PBX.


Bits 0-7 = Light Number
Bits 8 = Green
Bit 9 = Red
Bit 10 = Amber

Event Code Library


Bits 11-31 = Reserved

• 781
782 •
EVT_YELLOW_ALARM

SmartWORKS Developer’s Guide


Ai-Logix, Inc.
Indicates yellow alarm(T1/E1 only). 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_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.

Avaya Definity Event Sequences


Refer to the NGX Integration Guide for detailed information about D-channel
observed when working with the Avaya Definity.
Event Sequences
• 687
Avaya Merlin Magix Event Sequences

Avaya Merlin Magix Event Sequences


Following is a list of events that can be expected using the NGX with an Avaya
Merlin Magix PBX. The recorded D-channel events have also been provided on CD
to demonstrate the sequence of events.

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

CHANNEL EVENT CAUSE


Channel 3 EVT_MESSAGE_CHANGE (17)
Channel 3
Channel 2 EVT_AUDIO_OFF(Handset 1) // phone (X102) hung up
Channel 2 EVT_ONHOOK
Channel 2 EVT_LIGHT_ON(RED 0)
Channel 2 EVT_MESSAGE_CHANGE (25)
Channel 2

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

Ericsson Event Sequences


Following is a list of events that can be expected using the NGX with an Ericsson
MD110 (D-channel) PBX. The recorded D-channel events have also been provided
on CD to demonstrate the sequence of events.

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

CHANNEL EVENT CAUSE


Channel 3
Channel 3 CALLBACK = 6
Channel 3 2006
Channel 3 CAB PAG TIMER
Channel 7 EVT_MESSAGE_CHANGE (84)
Channel 7 J VanPelt
Channel 7 EVT_MESSAGE_CHANGE (85)
Channel 7 2002
Channel 7 EVT_OFFHOOK //Phone (X2006) picked up
Channel 7 EVT_AUDIO_ON(Handset 1)
Channel 3 EVT_MESSAGE_CHANGE (84)
Channel 3 TIME & DATE NOT SET
Channel 3 EVT_MESSAGE_CHANGE (84)
Channel 3 TIME & DATE NOT SET
Channel 3
Channel 3 2006
Channel 3 ETE ACC
Channel 7 EVT_MESSAGE_CHANGE (84)
Channel 7 2002 J VanPelt
Channel 7 2002
Channel 3 EVT_MESSAGE_CHANGE (84)
Channel 3 TIME & DATE NOT SET
Channel 3
Channel 3 2006
Channel 3 ETE ACC TIMER
Channel 7 EVT_MESSAGE_CHANGE (84)
Channel 7 2002 J VanPelt
Channel 7 J VanPelt
Channel 3 EVT_MESSAGE_CHANGE (84)
Channel 3 TIME & DATE NOT SET
Channel 3
Channel 3 2006
Channel 7 EVT_MESSAGE_CHANGE (84)
Channel 7 TIME & DATE NOT SET
Channel 7 EVT_RING_OFF(1)
Channel 7 EVT_LIGHT_ON(RED 11)
Channel 3 EVT_ONHOOK //Phone (X2002) hung up
Channel 3 EVT_AUDIO_OFF(Handset 1)
Channel 7 EVT_AUDIO_OFF(Handset 1)
Channel 7 EVT_MESSAGE_CHANGE (85)
Channel 7 TIME & DATE NOT SET
Channel 7
Channel 7 EVT_LIGHT_OFF(RED 11)
Channel 3 EVT_MESSAGE_CHANGE (84)
Channel 3 TIME & DATE NOT SET
Channel 3 EVT_LIGHT_OFF(RED 11)
Channel 7 EVT_MESSAGE_CHANGE (84)
Channel 7 TIME & DATE NOT SET
Channel 3 EVT_MESSAGE_CHANGE (84)
Channel 3 TIME & DATE NOT SET
Channel 3
Channel 3 J VanPelt
Channel 7 EVT_MESSAGE_CHANGE (84)
Channel 7 TIME & DATE NOT SET
Channel 7
Channel 3 EVT_MESSAGE_CHANGE (84)
Channel 3 TIME & DATE NOT SET
Channel 3
Channel 3 J VanPelt 2002
{Continues on next page}
Event Sequences
• 691
Ericsson Event Sequences

CHANNEL EVENT CAUSE


Channel 7 EVT_MESSAGE_CHANGE (84)
Channel 7 TIME & DATE NOT SET
Channel 7 2006
Channel 3 EVT_MESSAGE_CHANGE (84)
Channel 3 TIME & DATE NOT SET
Channel 3 EVT_MESSAGE_CHANGE (84)
Channel 3 TIME & DATE NOT SET
Channel 3
Channel 3 J VanPelt 2002
Channel 3
Channel 3 EVT_MESSAGE_CHANGE (84)
Channel 3 TIME & DATE NOT SET
Channel 3
Channel 3 J VanPelt 2002
Channel 3
Channel 7 EVT_ONHOOK //Phone (X2006) hung up

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

Speaker Clear Transfer


1J 1P
Ai-Logix, Inc.
692 •
SmartWORKS Developer’s Guide

_______________________
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

Ericsson DBC501 1A–1F


EVT_FUNCTION_BUTTON_PRESSED
Subreasons:
1A - 0X0000000A
MD110 ERICSSON 1B - 0X00000002
1C - 0X00000004
1D - 0X00000005
1E - 0X00000006
1F - 0X00000007

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

Nortel Meridian Event Sequences


Refer to the NGX Integration Guide for detailed information about observed D-
channel when working with the Nortel Meridian.

NEC Electra Elite Event Sequences


Following is a list of events that can be expected using the NGX with an NEC Electra
Elite on the Nortel DTU-32D-2. The recorded D-channel events have also been
provided on CD to demonstrate the sequence of events.

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

NEC NEAX Event Sequences


Following is a list of events that can be expected using the NGX with an NEC NEAX
PBX. The recorded D-channel events have also been provided on CD to
demonstrate the sequence of events.

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

Siemens Event Sequences


Refer to the NGX Integration Guide for detailed information about D-channel
observed when working with the Siemens HiPath and HiCom.
Ai-Logix, Inc.
700 •
SmartWORKS Developer’s Guide

Samsung Event Sequences


Following is a list of events that can be expected using the NGX with a Samsung
DCS 8282 PBX.

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

Channel 2 (104a) EVT_AUDIO_CHANGE (0x0000000000000005)(Handset TRAN


Speaker TRAN )
Channel 2 (102a) EVT_DISPLAY_CLEAR(0x0000)
Channel 1 (102a) EVT_DISPLAY_CLEAR(0x0000)
Channel 1 (1008) EVT_MESSAGE_CHANGE (52)
Channel 1 (1008) 202:
Channel 1 (1008)
Channel 1 (1008)
Channel 1 (1028) EVT_DISPLAY_CLOCK(0x0000)
Channel 2 (1008) EVT_MESSAGE_CHANGE (52)
Channel 2 (1008) 202:Hang up
Channel 2 (1008)
Channel 2 (1008)
Channel 2 (11efa40) EVT_ONHOOK //phone (x202) hung up
Channel 2 (104a) EVT_AUDIO_CHANGE (0x0000000000000000)()
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 (1028) EVT_DISPLAY_CLOCK(0x0000)
Ai-Logix, Inc.
702 •
SmartWORKS Developer’s Guide

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

VOL. SPEAKER HOLD


Event Sequences
• 703
Aspect Event Sequences

Aspect Event Sequences


Following is a list of events that can be expected using the NGX with a Siemens PBX.
The recorded D-channel events have also been provided on CD to demonstrate the
sequence of events.

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

You might also like