US7068641B1 - Telephony and data network services at a telephone - Google Patents

Telephony and data network services at a telephone Download PDF

Info

Publication number
US7068641B1
US7068641B1 US09/307,356 US30735699A US7068641B1 US 7068641 B1 US7068641 B1 US 7068641B1 US 30735699 A US30735699 A US 30735699A US 7068641 B1 US7068641 B1 US 7068641B1
Authority
US
United States
Prior art keywords
command
telephone
manager
audio
data network
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired - Lifetime
Application number
US09/307,356
Inventor
William Allan
Robert S. Morley
Kris W. Kramer
Larry John David
Kenneth M. Orford
Peter P. Blatherwick
Robert M. Star
Kenneth J. Liang
Dariusz Otreba
Paul Provencal
Robert Joly
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
RPX Clearinghouse LLC
Original Assignee
Nortel Networks Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Nortel Networks Ltd filed Critical Nortel Networks Ltd
Priority to CA 2273657 priority Critical patent/CA2273657C/en
Assigned to NORTEL NETWORKS CORPORATION reassignment NORTEL NETWORKS CORPORATION ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: OTREBA, DARIUSZ, LIANG, KENNETH J., JOLY, ROBERT, BLATHERWICK, PETER P., DAVID, LARRY JOHN, ORFORD, KENNETH M., STAR, ROBERT M., ALLAN, WILLIAM, KRAMER, KRIS W., MORLEY, ROBERT S., PROVENCAL, PAUL
Priority to JP2000617632A priority patent/JP2002544718A/en
Priority to PCT/CA2000/000510 priority patent/WO2000069155A2/en
Priority to DE60032356T priority patent/DE60032356T2/en
Priority to EP00929151A priority patent/EP1180296B1/en
Priority to AU47364/00A priority patent/AU4736400A/en
Assigned to NORTEL NETWORKS LIMITED reassignment NORTEL NETWORKS LIMITED CHANGE OF NAME (SEE DOCUMENT FOR DETAILS). Assignors: NORTEL NETWORKS CORPORATION
Priority to US11/300,997 priority patent/US7660295B2/en
Publication of US7068641B1 publication Critical patent/US7068641B1/en
Application granted granted Critical
Priority to US12/646,404 priority patent/US8964727B2/en
Assigned to Rockstar Bidco, LP reassignment Rockstar Bidco, LP ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: NORTEL NETWORKS LIMITED
Assigned to ROCKSTAR CONSORTIUM US LP reassignment ROCKSTAR CONSORTIUM US LP ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: Rockstar Bidco, LP
Assigned to RPX CLEARINGHOUSE LLC reassignment RPX CLEARINGHOUSE LLC ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: BOCKSTAR TECHNOLOGIES LLC, CONSTELLATION TECHNOLOGIES LLC, MOBILESTAR TECHNOLOGIES LLC, NETSTAR TECHNOLOGIES LLC, ROCKSTAR CONSORTIUM LLC, ROCKSTAR CONSORTIUM US LP
Assigned to JPMORGAN CHASE BANK, N.A., AS COLLATERAL AGENT reassignment JPMORGAN CHASE BANK, N.A., AS COLLATERAL AGENT SECURITY AGREEMENT Assignors: RPX CLEARINGHOUSE LLC, RPX CORPORATION
Assigned to RPX CORPORATION, RPX CLEARINGHOUSE LLC reassignment RPX CORPORATION RELEASE (REEL 038041 / FRAME 0001) Assignors: JPMORGAN CHASE BANK, N.A.
Assigned to JEFFERIES FINANCE LLC reassignment JEFFERIES FINANCE LLC SECURITY INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: RPX CLEARINGHOUSE LLC
Anticipated expiration legal-status Critical
Assigned to RPX CLEARINGHOUSE LLC reassignment RPX CLEARINGHOUSE LLC RELEASE BY SECURED PARTY (SEE DOCUMENT FOR DETAILS). Assignors: JEFFERIES FINANCE LLC
Expired - Lifetime legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M7/00Arrangements for interconnection between switching centres
    • H04M7/006Networks other than PSTN/ISDN providing telephone service, e.g. Voice over Internet Protocol (VoIP), including next generation networks with a packet-switched transport layer
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M3/00Automatic or semi-automatic exchanges
    • H04M3/42Systems providing special services or facilities to subscribers
    • H04M3/42136Administration or customisation of services
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M1/00Substation equipment, e.g. for use by subscribers
    • H04M1/253Telephone sets using digital voice transmission
    • H04M1/2535Telephone sets using digital voice transmission adapted for voice communication over an Internet Protocol [IP] network

Definitions

  • This invention relates to the provision of telephony and corporate and public data network services at a telephone.
  • the system has application to internet protocol (IP) based telephony.
  • IP internet protocol
  • PBX private branch exchange
  • the PBX may exist in parallel with a local area network (LAN) which provides data services to a network of local computers. It has been contemplated to provision a LAN not only with computers but also with special telephones so that the network can provide telephony services in addition to data services thereby avoiding the need for parallel networks.
  • IP telephones connect to the LAN backbone as does a call manager (which is a server configured with call management software) and a gateway to the public switched telephone network (PSTN).
  • PSTN public switched telephone network
  • the IP telephones include a vocoder so that audio signals may be converted between analog and IP packets.
  • the call manager has a configuration file for each telephone on the LAN assigning call functions to certain of the buttons on the phone, which call functions will be handled by the call manager. Other call functions (e.g., “mute”) are handled by the telephone itself.
  • the call manager receives keypad digits from a calling phone on the LAN indicative of a called station, it sets up a call by instructing the calling phone to set up a Real-Time Protocol (RTP) audio stream to either the called telephone, if the called telephone is on the LAN, or to the gateway, if the called telephone is on the PSTN.
  • RTP Real-Time Protocol
  • the call manager is out of the loop unless the call manager receives a key press indication indicative of a call control function handled by the call manager, such as a call transfer, call hold, call forward, call park, multiple line appearance, or disconnect.
  • the present invention provides an IP telephone (IT) where preferably all of the keys are “soft” keys (i.e., they have no fixed function).
  • the network intelligence (NI) associates a configuration data structure with the IT which correlates the keys with functions, and, based on this, may control the display of the IT to indicate the current function of certain of the soft keys.
  • Some of the functions may be requests for data services at the telephone (e.g., video or programmed audio over the internet).
  • the NI sets up the service between the data source and the telephone. This may require associating a new configuration data structure with the keys of the IT.
  • the IT user may activate multiple data services through the NI. If none of the keys of the IT has a fixed function, the NI can more easily arrange for the provision of the services without conflicting with any telephony calls at the telephone.
  • an NI for a data network comprising a call service provider for, when connected to a plurality of data network telephones, facilitating provision of telephony services for said plurality of telephones.
  • the NI includes at least one service proxy for, when connected to a plurality of data sources, setting up services between said plurality of data sources and said plurality of telephones.
  • the NI includes a control messager for selectively sending a control message to enable a user input element of a given telephone of said plurality of telephones to locally control a function at said given telephone and a control message to disable a user input element of a given telephone of said plurality of telephones to locally control a function at said given telephone.
  • the call service provider includes a messager for sending messages with audio parameters over said data network to said plurality of telephones for controlling audio at said plurality of telephones, said audio parameters including transmission and reception filters.
  • a telephony system comprising: a plurality of telephones connected to a data network; a network intelligence connected to said network for facilitating provision of telephony services to said plurality of telephones and, where said network is also connected to a data source, for providing a data service between said plurality of telephones and said data source.
  • a telephone for a data network comprising: an audio processor for converting between analog audio and packets of audio data according with a data protocol for said data network; and a plurality of user input elements, each of which, when used, generating an event for transmission on said data network and each of which having an assignable function and not having any dedicated function, and no user input elements other than those of said plurality of user input elements.
  • a telephone for a data network comprising: a processor; a user input element associated with permanent function identifying indicia, said user input element operatively connected to said processor and free of any connection to any other operative elements of said telephone; said processor arranged for, when the telephone is connected to a data network and said user input element is operated, sending a user element operation message on the data network and taking no other action in response to operation of said user input element.
  • a telephone for a data network comprising: a plurality of user input elements, each of which, when used, generating an event for transmission on said data network and each of which having an assignable function and not having any dedicated function.
  • the telephone includes at least one timer arranged for timing when receiving an enabling message over said data network.
  • the telephone includes a memory; and a receiver for receiving a labelling message over said data network and for storing labels from said labelling message in memory.
  • the telephone includes a window manager for receiving messages from a plurality of network intelligences over said data network and for passing messages associated with a master network intelligence; blocking messages other than alarm messages and data port reservation messages from any other network intelligence.
  • a method of remotely managing a telephone connected to a data network comprising: receiving user input messages from said telephone over said data network, each user input message identifying a user input element actuated by a user; where one or more user input messages from said telephone indicate a called station, establishing a call between said telephone and said called station utilising a first service provider such that audio data may pass between said telephone and said called station, and updating a state of said telephone to a state of busy with a voice call; where, after establishment of said call, a further user input message is received and where a current function of a user input element identified in said further message indicates a service provided by a second service provider, if said state of said telephone is not incompatible with said function, sending a control message to said telephone to establish said service provided by said second service provider.
  • a method of managing a telephone connected to a data network comprising: based on user input messages from said telephone, establishing a voice call; based on one or more user input messages from said telephone received during pendency of said voice call, setting up at least one non-telephony data service between said telephone and at least one data source, at least where said at least one data service does not conflict with said voice call.
  • a method of remotely managing a telephone connected to a data network comprising: based on a user input message received from said telephone over said data network, retrieving a first configuration data structure for said telephone which correlates user input elements of said telephone with functions; based on at least one further user input message received from said telephone over said data network, retrieving a second configuration data structure for said telephone which correlates at least some user input elements of said telephone with functions different from those of said first configuration data structure.
  • a method of remotely managing a telephone over a data network comprising: receiving indications from said telephone over said data network; based on said indications, activating a plurality of data services on said data network; determining an active one of said plurality of data services and sending control messages to said telephone over said data network so that said telephone can provide said active data services; and based on further indications received from said telephone over said data network, sending control messages to said telephone to establish a voice call.
  • the invention comprises a computer readable medium storing computer executable instructions which, when loaded by a computing device connected to a data network to which at least one telephone is also connected, adapts the computing device to undertake methods of this invention.
  • FIG. 1 is a schematic diagram of a telephony system made in accordance with this invention
  • FIG. 2 is a functional block diagram of the software architecture for an IT of FIG. 1 ,
  • FIG. 3 is a functional block diagram of a portion of the system of FIG. 1 detailing the software architecture for the NI,
  • FIG. 4 is a functional block diagram detailing a portion of FIG. 3 .
  • FIG. 5 is a process flow diagram
  • FIG. 6 is another process flow diagram.
  • a telephony system 10 comprises a private IP network 12 connected to an NI 14 , ITs 16 a , 16 b , 16 c , a data service 11 , a telephone service 13 , a public switched telephone network (PSTN) gateway 18 , and a public IP network 19 .
  • PSTN gateway 18 connects to a PSTN 20 .
  • the public IP network 19 may include an IT 16 d , a data service 21 and a telephony service 23 .
  • the private IP network could be in the nature of a local area network (LAN), such as an ethernet, or a wide area network (WAN).
  • the public IP network could be an internet.
  • the NI is software which executes on a processing entity 15 comprising a central processing unit, memory and a network interface.
  • the processing entity may be a personal computer (PC), network server, or other general computer resource which may or may not be dedicated to running the NI.
  • the processing entity may be loaded with the NI from any computer readable medium, such as disk 17 , a tape, or a memory chip.
  • the NI may be down loaded from a remote source on the private or public IP network.
  • the processing entity 15 may be a dedicated processor, memory, and network interface into which the NI is embedded.
  • the IT reacts to events generated by a user (e.g., key presses, hook switch transitions) and reports these to the NI by sending IP messages over the private IP network in accordance with an elemental control protocol described hereinafter.
  • the IP messages are transported using the IP protocol suite (specifically, messages are transported over a reliable user datagram protocol—UDP—layer).
  • the NI which implements the functional model of the IT, reacts to these events and controls the function of the terminal (user interface, visual/audio feedback, audio hardware control etc.) by sending elemental control messages to the IT.
  • the IT software design can be static but the functional model of the IT may change, as new features and services become available, by simply changing the functional IT emulator software in the NI. This removes design complexity in the IT.
  • the IT does not execute industry evolving functional protocol stacks locally (e.g. H.323), the IT does not become obsolete as new versions of the protocols evolve. All evolving protocol dependant software is maintained in the NI where software updates are handled easily. In this model, the NI acts as a proxy agent for the IT by converting messages received from the IT to appropriate standard protocol.
  • All of the keys of the IT are “soft keys”, that is, the keys can be assigned a function within the NI. This facilitates the provision of, along with telephony services, services not usually associated with a telephony device, such as access to live or archival audio programming available over the IP network (e.g., REAL AUDIOTM), stock quotation updates, and web browsing.
  • telephony services services not usually associated with a telephony device, such as access to live or archival audio programming available over the IP network (e.g., REAL AUDIOTM), stock quotation updates, and web browsing.
  • the hardware of an IT 16 comprises a digital signal processor (DSP) 24 , a text display 26 , a set of keys (and a hookswitch) 28 , and an ethernet controller 30 (which includes a port to the private IP network).
  • DSP digital signal processor
  • These devices interface with a processor 33 which maintains, for each of the devices, a software driver 44 , 46 , 48 , and 50 , respectively.
  • An event originating at any of these devices passes to a software event interface 64 , 66 , 68 , and 70 for the respective devices.
  • the processor 33 may also establish a connection between the ethernet controller 30 and any of the other devices through an IP protocol stack 75 .
  • An event queue 74 receives inputs from the event interfaces and from a window manager 76 and outputs to an event dispatcher 78 .
  • the event dispatcher 78 outputs to functional element managers 80 and any associated stream handlers 82 created by the functional element managers.
  • the stream handlers of the functional element managers are interconnected with the IP protocol stack 75 and they, through their functional element managers 80 , output to the device drivers.
  • the functional element managers also output to the window manager 76 . Communication with the device drivers is through a real time operating system (RTOS) 84 .
  • the RTOS maintains the IP protocol stack 75 as well as software sockets 86 in the stack.
  • the DSP 24 is connected to speaker 90 and microphone 92 of handset 94 through a codec 96 (which is an analog-to-digital (A/D) and digital-to-analog (D/A) converter) and to handsfree speaker 97 and handsfree microphone 98 through codec 99 .
  • codec 96 which is an analog-to-digital (A/D) and digital-to-analog (D/A) converter
  • Each functional element manager 80 is designed to control a particular hardware device, group of hardware devices, or a specific set of book keeping tasks. These managers interact directly with the NI via elemental control messages to provide a control entry point to the IT. The managers provide two major capabilities:
  • the specific functional element managers are as follows: a broadcast manager; network manager; basic manager; key/indicator manager; audio manager; and display manager.
  • the broadcast manager is used to broadcast commands to all of the hardware devices of the IT.
  • the network manager provides terminal initialisation, network maintenance and encryption.
  • the basic manager provides an interface to query the status and operating parameters of the IT (e.g., the NI may query a hardware identifier).
  • the key/indicator manager is responsible for managing all of the keys, indicators and associated commands within the IT. Key press events, hook switch events, key/indicator status, icon states and LED cadencing are all governed by this manager.
  • the audio manager is responsible for all aspects of the audio including path setup, audio stream setup, and path maintenance.
  • the display manager controls the display of the IT.
  • the elemental control messages sent by the NI to the functional element managers and from the functional element managers to the NI follow IP and are, therefore, packetised messages.
  • the protocol for the messages contemplated for each of the functional element managers 80 is set out in Appendix A.
  • the managers sit on top of the RTOS 84 , which provides the hardware abstraction layer.
  • the RTOS provides priority based scheduling of system tasks; consistent application programming interfaces (APIs) for low level driver abstraction; inter-task communications primitives and data memory management control; and a tightly integrated transport control protocol/internet protocol (TCP/IP) stack, through which the ethernet driver 50 is controlled.
  • APIs application programming interfaces
  • TCP/IP transport control protocol/internet protocol
  • the RTOS may be replaced by a simple task manager. In such case, the functional element managers would require greater sophistication in order to handle the different APIs of the various device drivers.
  • the drivers are generally designed to be aware of two types of data—signalling events and media streams—and provide a separate API for each.
  • the ethernet driver 50 While all drivers except the ethernet driver 50 are controlled by the functional element managers, the ethernet driver 50 is controlled by the RTOS through the IP protocol stack 75 . All functional element manager communication with the ethernet driver 50 is therefore done indirectly by opening a socket 86 at one of the IP protocol layers 75 (e.g., a simple IP socket or a datagram-based UDP socket). Data from the functional element managers thus passes through an opened socket, down the IP protocol stack to the ethernet driver; conversely, the ethernet driver 50 passes received data to the IP stack, up to the socket API layer such that the element manager that had opened the socket will receive the data.
  • IP protocol layers 75 e.g., a simple IP socket or a datagram-based UDP socket
  • event queue 74 There is only one event queue 74 and all internal and external events (elemental control messages) are placed in that event queue. This ensures that all events acted upon by the IT will be processed based on order of arrival. Media streams, on the other hand, bypass the event queue, as described hereinafter.
  • the window manager 76 intercepts all incoming elemental control messages.
  • the purpose of the window manager is to allow the IT to be responsive to commands from more than one NI (and, as described hereinafter, in some instances to facilitate start-up). However, at any point in time, only one NI's commands are directed to the hardware resources. While a particular NI is controlling the IT resources, it has complete control of the IT (no resource sharing with other NIs). To gain access to a different NI, the user must activate that NI via the window manager. This forces the IT to switch the hardware resources to the newly activated NI providing a window to the IT.
  • NI ‘A’ no longer has control of the IT resources and must be informed of this condition.
  • the IT uses the “suspend Connection with Server” command from the elemental control message protocol for this purpose.
  • the IT uses “Resume Connection with Server” message to ‘start’ or ‘resume’ the session with NI′B′.
  • NI′B′ uses this message as a signal to refresh the display and other IT hardware components as required.
  • the elemental control message protocol provides the “Server Alarm” message.
  • the “Server Alarm” message allows a disconnected NI to signal an event and a text string to the IT.
  • the IT decodes the event, and informs the user of the pending event. The user may then decide to accept or reject the event.
  • the IT Upon reception of the event, the IT would suspend the current NI and switch to the new NI via “Suspend Connection with Server” and “Resume Connection with Server” messages as described above. If the user elects to reject the event, then the terminal sends a “Resume Connection with Server” message to the current NI to inform it that it needs to refresh the display.
  • the media streams associated with voice and or video are typically transported using UDP.
  • the setup of the media streaming with the far end device is performed by the NI on the IT's behalf.
  • the IP stack is operated locally by the IT.
  • NIs are added to the IT's list of supported NIs, there is no guarantee that a given UDP port number is available for a call setup session.
  • the NI must have previously reserved the UDP port via the “Reserve UDP Port Block” message.
  • the IT responds with the “Reserve UDP Port Block Report” message. Once a successful message exchange has taken place, the IT will guarantee that the reserved port numbers are not given out to other NIs.
  • NI 14 comprises an elemental control message event router 102 which receives inputs from ITs 16 a , 16 b , 16 c over the private IP network 12 and outputs to terminal emulators 110 a , 110 b , 110 c .
  • a terminal boot server 104 and an associated operations, administration, and maintenance (OA&M) manager 105 are connected for two-way communication with the private IP network 12 and with a terminal emulator manager 106 .
  • the terminal emulator manager manages the terminal emulators.
  • the terminal emulators are connected for two-way communication with the private IP network 12 on lines 114 and also output to the network through elemental control message formatter 108 .
  • the NI also includes configuration data structures 112 . Each configuration data structure correlates key codes with functions and, optionally, with text (or graphics) which explain the functions. Each configuration data structure also includes information sufficient to allow the launching of a service proxy for each of the functions.
  • a terminal emulator 110 is detailed in FIG. 4 .
  • emulator 110 comprises a number of service proxies 112 a , 112 b , 112 n .
  • Each service proxy comprises a service plug-in 116 which is connected for two-way communication with the private IP network on a line 114 .
  • the service proxies output to a context manager 120 .
  • the context manager is connected with an elemental control message driver 122 .
  • Elemental control message driver 122 receives inputs from the elemental control message router 102 and outputs to the elemental control message formatter 108 .
  • the context manager includes a state memory 121 which stores current state data for the IT emulated by the terminal emulator.
  • the “state” of the IT is the current status of elements of an IT, for example: “on hook”; “off hook”; “call on handset”; “call muted on handset”; “handsfree speaker connected”.
  • the context manager also has a memory 123 for a current configuration data structure.
  • the service proxies are launched as required based on information in the current configuration data structure in memory 123 .
  • the service proxies may be proxies for providing telephony or data services available at processing entity 15 , over the private IP network 12 (such as services 11 and 13 ), or over the public IP network 19 (such as services 21 and 23 ).
  • service proxies may provide basic telephony call services, a call messaging service, a directory number locating service (such as an LDAP—light weight Directory Access Protocol—service, which is described in IETF publications 1777, 1778, and 1823 ), a direction finding service (such as MAPQUESTTM), a stock market quotation service, an audio program service, and a personalized service.
  • a directory number locating service such as an LDAP—light weight Directory Access Protocol—service, which is described in IETF publications 1777, 1778, and 1823
  • a direction finding service such as MAPQUESTTM
  • stock market quotation service such as a stock market quotation service
  • audio program service such as a personalized service.
  • the network manager of the IT (which is one of the functional element managers 80 ), using the dynamic host configuration protocol (DHCP) tries to find an NI.
  • An appropriate message is therefore sent by IT 16 a to the NI.
  • the terminal boot server 104 of the NI recognises this message and prompts the terminal emulator manager 106 to launch a terminal emulator 110 a for IT 16 a .
  • terminal emulator 110 a looks to the configuration data structures 112 for an initial configuration data structure to associate with IT 16 a .
  • the configuration data structure is copied to memory 123 of the context manager 120 for the terminal emulator and will correlate each of the keys of IT 16 a with a function and may also correlate keys with text (or a graphic) describing one of the functions.
  • the NI then constructs elemental control reply messages to the IT 16 a which include commands to control elements of the IT. For example, the display of the IT 16 a could be written with text (or graphics) from the configuration data structure for the function of keys of the IT.
  • the DHCP is not available then, when an IT is first plugged in, it defaults to a temporary user input state where the window manager 76 is responsive to input from the keypad 28 .
  • a user may, via keypad 28 , input an IP address for the IT and an IP address for an NI (as will be appreciated by those skilled in the art, the user may also be required to input an IP address of a gateway and a sub-net mask).
  • the IT sends a “new IT” message to the NI IP address which was keyed in. This prompts the addressed NI to launch a terminal emulator, retrieve an initial configuration data structure for the new IT, and construct a reply message.
  • the window manager switches out of its temporary user input state.
  • an elemental control message is received from the NI by the ethernet controller, it is passed up to the event queue 74 where it propagates through to the event dispatcher 78 . The event dispatcher then dispatches the elemental control message to the appropriate functional element manager 80 for action.
  • the driver APIs are designed to allow the media to bypass the event queue and event dispatcher and instead communicate directly with a stream handler 82 registered with the driver.
  • the handling of a media stream begins with the NI sending appropriate elemental control messages to request processing of a new media stream.
  • the audio functional element manager would then start a new process, a stream handler 82 , to perform the stream processing task. If, for example, the elemental control message from the NI requested processing of an audio stream from a voice call, the functional element manager for the DSP 24 would open two stream handlers 82 : one for receive stream processing and one for transmit stream processing.
  • the receive stream handler would open a socket for the incoming stream of audio packets and the transmit stream handler would open a socket for an outgoing stream of audio packets. Both stream handlers would register the process identifier with the DSP driver.
  • the audio stream arriving at the socket opened by the receive stream handler would pass directly to the receive stream handler where it would be sent on to the DSP driver 44 with the appropriate stream identifier.
  • the driver would pass the audio stream to the DSP 24 which decompresses it; the stream is then converted to analog audio at codec 96 or 99 and passed to a speaker 90 or 97 of the IT.
  • the DSP 24 also compresses audio received from a microphone 92 or 98 of the phone after the audio is digitised by codec 96 or 99 .
  • the DSP driver upon reception of this audio data corresponding to a given stream identifier, signals the registered transmit stream handler matching the stream identifier; the transmit stream handler then reads the data from the DSP driver.
  • more than one stream handler per driver can register for media streams.
  • the stream handler responsible for managing the media stream opens, maintains and closes the required socket and hence writes the media packets directly to the socket.
  • the NI 14 launched a terminal emulator 110 a for IT 16 a that retrieved an initial configuration data structure for the IT which, amongst other designations, designates (i) one key of IT 16 a as a mute key to mute a transmit path, as is standard in telephony for a mute button, (ii) another key to request specialised call services, (iii) a further key to request telephone directory information, (iv) another key to request (street) directions, (v) another key to request stock market quotations, (vi) a key to request a specific audio program (such as a radio station), (vii) a key as a “quit” key for use in quitting a service, and (viii) keys to designate digits.
  • the mute button and digit keys are typically permanently so identified on IT 16 a .
  • the “quit” key may also be permanently marked.
  • the configuration data structure includes data which the NI uses to control the text display 26 of the IT 16 a to indicate the function of these keys.
  • the service proxy sends commands back down through the context manager and elemental control message driver so that the elemental control message formatter 108 is driven to generate a “Stream Based Tone On” message with appropriate parameters (S 402 ) to cause the audio manager of the IT to turn on a dial tone.
  • the NI considers the IT to be in an “off hook” state.
  • the user may press a digit key on the key pad. This results in a “key event” message to the NI which includes the key code for the key which was pressed (S 404 ).
  • the NI collects the digit, echoes the digit back to the IT 16 a for display in a “Display Data Write” message (S 406 ) and sends a “Stream Based Tone Off” message to turn off the dial tone (S 408 ).
  • the user may dial a series of digits, resulting in a like series of “Key Event” messages to the NI (S 410 , S 412 ) and a like series of “Display Data Write” messages from the NI (S 411 , S 413 ) to cause the IT to display these digits.
  • the basic call service proxy 112 b of the NI Once the basic call service proxy 112 b of the NI has collected a series of digits representing a called station on the private IP network, it obtains the IP address of the called station, here IT 16 c . The service proxy 112 b of the NI then queries the state memory 121 of emulator 110 c for IT 16 c to determine the state of IT 16 c . If IT 16 c is in an on hook state, the NI may then initiate the call with IT 16 c by sending a “Transducer Based Tone On” message to IT 16 c (S 416 ) with appropriate parameters to cause the audio manager of IT 16 c to generate a ring cadence.
  • the NI also sends such a message to IT 16 a (S 418 ) causing IT 16 a to generate a ring back tone. If the user of IT 16 c takes the phone off-hook, then IT 16 c sends an “Off Hook” message to the NI (S 420 ) causing the NI to send a “Stream Based Tone Off” message to IT 16 a (S 422 ) so that the ringing tone at IT 16 a ceases and also sends a “Stream Based Tone Off” message to IT 16 c (S 424 ) so that the ringing cadence at IT 16 c ceases.
  • the NI then sends (i) a “Connect Transducer” message (S 425 , 427 ) and (ii) an “Open Audio Stream” message to each of IT 16 a and IT 16 c (S 426 , S 428 ) so that (i) either the handset 94 or the handsfree speaker 97 and microphone 98 are connected at each IT and (ii) a voice session is set up between the phones. Thereafter each IT will send an “Open Audio Stream Report” message to the NI (S 430 , 432 ) and IP media stream packets will flow directly between the two phones (S 434 ).
  • Emulator 110 a refers to the current configuration data structure in memory 123 to access a service proxy application corresponding with the key code in the received “key event” message, in the current example, this is a stock quote service proxy application. The emulator 110 a then launches this service proxy as, say, service proxy 112 a .
  • Proxy 112 a then negotiates a connection with the server (i.e., the data source) providing this stock quote service, which server may be located on public data network 19 .
  • the remote server addresses packets of characters to the NI 14 .
  • Emulator 110 a of the NI then sends a “Display Data Write” message to IT 16 a (S 442 ) to pass the characters to the IT 16 a for display.
  • the user of IT 16 a may receive stock quotation information (which may occupy a portion of the display of the phone).
  • IT 16 a may be placed on hook. This results in an “On Hook” message being sent to the NI (S 446 ). This prompts the NI to send a “Close Audio Stream” message to each of IT 16 a and 16 c (S 448 , S 450 ). Thereafter, an “On Hook” message may be received from IT 16 c (S 452 ).
  • the user may press the “quit key” resulting in a “Key Event” message to the NI (S 454 ).
  • the NI responds with a “Clear Field” message to IT 16 a (S 456 ) to cause the portion of the display used for the stock quotation information to be cleared.
  • emulator 10 a of the NI would either suspend or terminate the stock market quotation proxy 112 a.
  • the user of IT 16 a may now decide she wishes to listen to the radio station indicated on the display as associated with a soft key. The user therefore presses this key resulting in a “Key Event” message being sent to the NI (S 600 ).
  • the emulator 110 a of NI 14 launches an audio program service proxy, say 112 b , which negotiates a connection between a remote server which is the source for the appropriate audio program and IT 16 a .
  • the emulator 110 a sends a “Connect Transducer” message to IT 16 a (S 602 ) indicating the new media stream should be directed to the handsfree speaker 97 and an “Open Audio Stream” message (S 604 ) to launch a receive stream handler which opens a socket for the incoming audio program packets from the remote server and directs them to the DSP driver. Additionally, the pressing of the audio program key causes the emulator 110 a to retrieve a new configuration data structure for IT 16 a which re-assigns the function of the mute button on the IT so that its function is to mute the receive path of the handsfree audio transducers rather than the transmit path.
  • the user may press the mute button to send a “Key Event” message to the NI (S 606 ); the NI responds with a “Mute/Unmute” message with a parameter causing the IT to mute the receive path (S 608 ).
  • the user of the IT may then conduct a conversation with the visitor and, thereafter, again press the mute key, so that the NI send a “Mute/Unmute” message with appropriate parameters such that the receive path for the audio program is again unmuted (S 610 , S 612 ).
  • the NI When the user wishes to stop listening to the audio program, she may end the service by pressing the “quit” key on the IT resulting in an “Key Event” message to the NI (S 614 ).
  • the NI responds with a “Connect Transducer” message which disconnects the handsfree speaker of the phone (S 616 ) and a “Close Audio Path” message to shut down the stream handler and associated socket for the audio program (S 618 ).
  • the NI retrieves the previous configuration data structure for IT 16 a so that the function of the mute button is internally re-assigned whereby it can be used to change the state of the IT to mute the transmit path.
  • the NI would send one or more Display Data Write messages to the IT 16 a to emulate a pop up window announcing the call (preferably with caller information) and asking the user to press a certain key to indicate that she wishes to take the call. This may be accompanied with a message which would result in a brief alerting tone at the IT.
  • the NI retrieves a new configuration data structure for the IT which includes an assignment of one of the keys to an indication that the call is to be taken. If the user did not press this key, once the caller hung up, the NI would clear the pop up window and restore the previous display contents.
  • the NI may suspend or terminate the audio program session and connect through the call, as afore described.
  • a second key could indicate that the call was to be taken and the audio program continued. If the user pressed this key, the NI sets up the voice call on the handset 94 , keeping the audio program on the handsfree speaker 97 . By deciding upon whether to interrupt the user, the NI may provide for a prioritisation of services.
  • a “Key Event” message would be sent to the NI. Recognising the current state of the phone as busy with a voice call, the NI would recognise providing the new audio stream would potentially conflict with the voice call. Consequently, the NI sends a notification to the user. For example, the NI could highlight the usage conflict in a Display Data Write message. Also, the NI retrieves a new configuration data structure for the IT which re-assigns one key of the phone as a “warning override” key.
  • the user could override the warning with the appropriate key press in which case the audio stream for the audio program is set up over the handsfree speaker 97 , as described in conjunction with the example of FIG. 6 .
  • the NI may assign a special key for the function of muting the handsfree speaker 97 , leaving a mute key to mute the voice call in the standard fashion.
  • the IT may simultaneously deal with audio streams from different sources. Indeed, the user could even take two separate voice calls at the IT: one on the handset and one on the handsfree speaker and microphone. In such instance, should a key be pressed requesting an audio program, the NI could either ignore the key event message as there is no way to provide this service without conflicting with the existing voice calls or could display options to the user for dealing with the conflict.
  • a directory number locator proxy which may be used to find telephone numbers over the public IP network. If a user of IT 16 a requested a search for a directory number (by pressing the appropriate key), the NI would launch a directory number locator proxy 112 a in terminal emulator 110 a . Possibly, this would also cause the NI to retrieve a new configuration data structure for the IT 16 a and send a “Display Data Write” message to the IT to display new functions for certain of the keys of the phone which would facilitate a user's use of the directory finding service. For example, the digit keys could be re-assigned to represent letters so that the user could key in a name.
  • the NI could respond with a list of “hits” through “Display Data Write” messages and retrieve another configuration data structure for the IT 16 a which assigns new functions to certain keys to allow handling of the list.
  • One of these new functions could be a “copy” function which may be used to copy information from one data service to another.
  • a user could copy a name from the list of “hits” to, say, a personal address book in a call messaging service.
  • Each configuration data structure tailored to a particular service will normally still provide keys by way of which the user could request other services.
  • a key to request stock market quotations this would cause the NI to launch a stock market quotation proxy 112 b in emulator 1110 a and, possibly, retrieve another new configuration data structure for the phone and overwrite portions of the display to indicate new key functions according to this new configuration data structure.
  • the last function key which is pressed sets the current configuration data structure for the phone, and a user could “toggle” amongst services.
  • a number of proxies may run on the terminal service emulator 110 a simultaneously but only the proxy most recently requested by a key press is the active proxy, the other proxies are in the background. From this it will be apparent that the NI provides an aggregation of services for the ITs, including many services not normally associated with a telephone.
  • the described text-based services were assumed to provide packets of characters to the NI.
  • Some services such as web pages on the world wide web, forward a file written in hypertext mark-up language (HTML) which file typically prompts down loading of further files to allow construction of a web page.
  • HTML hypertext mark-up language
  • the IT 16 may be provisioned with a graphics display along with an associated graphics driver and graphics event interface.
  • the ITs are provisioned with a graphics manager and the elemental message protocol is enhanced by the provision of graphics manager elemental control messages. This manager and the new messages will be very similar to the display manager and the display manager elemental control messages.
  • the protocol will include a “Graphics Data Write” message similar to the “Display Data Write” message.
  • the NI When a user requests a graphical service which uses the hypertext transfer protocol (HTTP), the NI will receive the HTML file and download necessary additional files to construct the web page. The NI will then encapsulate web page information in “Graphics Display Write” messages to cause the web page to be written to the graphical display of the IT. In so doing, the NI may also retrieve a new configuration data structure for the IT which will assign keys different functions, such as functions to navigate through the web page or request a hyperlink. If, for example, the NI receives “Key Event” messages indicating a hyperlink has been requested, the NI down loads information from the appropriate source(s) and updates the graphical display of the IT with new information received.
  • HTTP hypertext transfer protocol
  • the IT 16 b could assign one key to a request for a video program (such as a close captioned news program). Were this key on IT 16 b pressed, the NI would launch an appropriate proxy in emulator 110 b which would negotiate a connection between a remote server providing this video service and IT 16 b .
  • the NI would also send an appropriate elemental control message to IT 16 b which results in the video manager of IT 16 b opening a receive stream handler, registering it with the display driver and opening a socket 86 on the IP stack 75 . Thereafter, when the video stream reaches the ethernet controller 30 and is passed up to the socket, it is received by the receive video stream handler and passed down to the display driver. It will therefore be apparent that the user of IT 16 b could, while continuing with a voice call, view, for example, a close captioned news service.
  • the various proxies which may be launched in the terminal service emulator are written so as to be compatible with the protocol of the service provided on the remote server. These different protocols are therefore transparent to the ITs.
  • the IT may display text in association with each of its keys which includes function information provided by the NI.
  • certain keys found on the IT such as hold, mute, handsfree, volume control, screen navigation, and headset on/off keys, may be permanently labelled as such. Notwithstanding, these permanently labelled keys are soft keys since their function is assigned at the NI. Thus, their function may be re-assigned where necessary (such as described in conjunction with the foregoing example in respect of the mute key).
  • the ability to control all of the keys on the telephone ensures that the NI may provision the ITs with a variety of services, without conflicts amongst the services and without conflicting with voice calls.
  • the system of this invention could function even if some keys of an IT were “hard wired”.
  • the mute key of an IT could be hard wired to mute the transmit path of the phone.
  • the NI could still allow muting of the receive path through assigning this function to a soft key on the phone.
  • the telephone could equally have other user input elements, such as a touch screen (i.e., a screen where x and y co-ordinates are obtained from a touch sensitive matrix) and proximity or motion detectors. If so, appropriate protocol messages would log signalling “events” from these devices. Also, while the functions have been described as associated with single keys, it could be that the NI requires a series of key presses on the part of a user to request a function.
  • the DSP in each IT provides data compression. If the bandwidth of the network is sufficiently great, or if compression is accomplished in some other manner (such as with a network transcoder), the DSPs may be omitted.
  • the configuration data structures 112 may be different for each IT.
  • the configuration data structures may be based on user profiles. In this way, different phones on the private IP network may request services from a different set of services.
  • the NI may also provide the functional emulation for IT 16 d on public IP network 19 .
  • the NI could be directly connected to the public IP network 19 instead of to a private IP network and may provide the functional emulation for any ITs connected directly or indirectly to the public IP network.
  • the multi-service telephony system has been described in the context of an IP data network, the system could be adapted to function in the context of data networks following other data protocols. For example, rather than sending packetised data, the data network could employ a synchronous transfer mode for data.
  • the intelligence for the operation of the IT is located in the NI.
  • the functional model for the IT resides in the NI and the user interface is projected onto the IT using the elemental control protocol.
  • This model results in a slight delay at the IT whenever a key is pressed as a key event message must pass up to the NI and a response message must return from the NI to the IT before the IT takes action consequent on the key press. In most instances, this slight delay is entirely acceptable. In the case of receive volume adjustments, this delay is not preferred. Consequently, the elemental control message protocol allows the NI server to configure the terminal for local, receive volume control. This is accomplished using several messages.
  • a two-mode operation scheme allows the NI to specify whether the terminal has direct control over active-path volume adjustment or if the NI will assume control over the adjustments.
  • the two modes are defined as follows:
  • the NI can instruct the terminal to operate in either mode, by setting the “Adjust Volume” and “Automatic Adjustable Rx Volume Report” options of the “Audio Manager Options” elemental control message. If the “Adjustable Rx Volume Report” option of the “Audio Manager Options” message is enabled, the terminal will send an “Adjustable Rx Volume Report” message each time after a volume key is pressed by the user. This report informs the NI that the volume has been adjusted and indicates whether one of the rails (min./max. volume) has been reached. This provides a clean interface for NI visual feedback of user volume adjustments when the IT handles the volume control locally.
  • the NI uses the “Change Adjustable Rx Volume” message to adjust an active path receive volume when local volume control handling has been disabled.
  • the NI uses the “Adjust Default Rx Volume” message to change the default receive volume levels when a user is adjusting default volume levels from, for example, an options list.
  • the NI may set audio parameters for the handset or handsfree transducers (headset, where extant) in an audio parameter bank (APB) download message.
  • the “Select Adjustable Rx Volume” message can be used by the NI to set or change the active APB volume register. This is useful when multi-path calls are configured and the user wishes to adjust the volume of a specific register (i.e. receive volume register associated with a specific APB).
  • the “User Activity Timer” message is used to turn on or to turn off a timer, which reloads when any key is pressed. If the timer expires, meaning no keys were pressed, then the terminal sends the “User Activity Timer Expired” message.
  • the “User Activity Timer Download” command allows the NI to specify the time-out value.
  • a local call duration timer Another timer which may be present in the IT is a local call duration timer.
  • an IT may have a local time and date display (set by the NI) and will locally manage the current NI to which it responds (through the window manager). There are text strings displayed in conjunction with each of these functions. In order to maintain language independence with this local functionality, the NI downloads text strings in the appropriate language, as follows.
  • the Call Duration Timer uses the time & date fields to display its information.
  • the date field is used for displaying the Call Duration Timer label (i.e., a text string) that can be defined by the NI using the “Call Timer Label Download” command.
  • the elemental control message protocol provides a message which allows the NI to download a text string (or optionally an icon/bit map etc. as graphical display capabilities are deployed) to be used as the server identification tag in the local user interface.
  • the NI uses the “Server Identification Tag” message for this purpose.
  • An advantage of the elemental control message protocol is the control it provides the NI over the characteristics of audio at an IT.
  • the NI may control an IT to connect audio streams to a selected transducer pair (e.g., handset, headset or handsfree microphones and speakers).
  • the NI may control parameters of an audio stream by assigning an Audio Parameter Bank (APB).
  • the APB is a grouping of parameters that describes the characteristics of the audio stream.
  • the IT provides several APBs. Each APB can be configured by the NI. When setting up an audio stream, the NI controls where the audio stream terminates (i.e. which transducer pair to use), and which APB to associate with the audio stream.
  • An APB contains the following parameters:
  • the NI configures these APB parameters using the following elemental control message commands:
  • the elemental control message protocol allows the IT to implement handset detection algorithms and report the findings back to the NI via the “Handset Connected” and “Handset Disconnected” messages. This flexibility allows the terminal to detect specially designed handsets, for example extended frequency response handsets, and report this to the NI.
  • the NI upon receiving this message, could activate enhanced audio capabilities within the terminal to exploit the capabilities of the special handset. These enhanced audio capabilities could be used as a product differentiater in the market.
  • the elemental control message protocol allows the IT to be configured to switch to a new control protocol.
  • the terminal Upon receipt of the “Protocol Switch” message from the NI, the terminal could be directed to start communicating using the newly specified protocol instead of the elemental control message protocol of Appendix A. This would allow one terminal to be built that could be compatible with several distinct control protocols.
  • the elemental control message protocol allows the NI to query the IT for a ‘copyright’ identification string.
  • the NI queries the IT using the “Copyright” option of the “Query Network Manager” command.
  • the IT responds with the “Copyright Report” message.
  • the amount of information to be presented to a user may exceed the visible area of the display for the IT. This may typically occur when viewing e-mail, directories, or incoming callers logs. To accommodate such situations, the elemental control message protocol provides for page scrolling.
  • the NI may send a “page” of information via a “Page Download” message.
  • the IT saves this “page” of information locally and presents the first portion of the page on the display. If a user uses a page scrolling key (such as a key on a navigation cluster, or another key assigned to this purpose by the NI), on receiving the resulting “Key Event” message, the NI responds with a “Page Scroll” message, causing the IT to scroll to another portion of the “page”.
  • a page scrolling key such as a key on a navigation cluster, or another key assigned to this purpose by the NI
  • the elemental control message protocol allows the NI the disable specific portions of the display via the “Disable Display Field” message. Once disabled, all writes to this portion of the display are saved in an off-screen buffer but are not visible on the screen. To enable the field, the NI sends a second the “Disable Display Field” message with the associated field bit enabled. Once enabled, the previously ‘hidden’ information is displayed on the screen.
  • the Logical Icon Update command is used for updating the state of a logical icon.
  • the IT keeps a map of the association between logical and physical icons.
  • the NI sends this command to update the corresponding physical icon with the new state and cadence.
  • Logical Icon specifies logical ID of icon to be updated ID
  • ID specifies desired state of icon Icon Cadence Off On Flash Flicker Wink Twinkle Blink Downloadable cadence Time and Date Download
  • the Time and Date Download command is used to set the IT's time and date. This new time and date will overwrite the current time and date data stored in the IT.
  • the command contains the year, month, day, hours, minutes and seconds. All numbers are expressed in hexadecimal.
  • This command downloads the default character table configuration that the display manager uses. It specifies the mapping of the character tables to graphics tables and it also specifies which one of the graphics table is to be lock-shifted (code A0 to FF hex).
  • the Network Manager is responsible for configuring and maintaining the network connections between the NI and the IT.
  • the Soft Reset command is sent by the NI to reset the IT as well as the accessory ports. This command is intended to reset the IT data structures to their default states.
  • the Hard Reset command is sent when the NI wants to fully re-initialize the IT to its power-up default state.
  • the Query command is used to request the status or information from the Network Manager.
  • Diagnostic requests the diagnostic info command to be sent to the NI.
  • Managers requests the Manager's ID command to be sent to the NI.
  • Attributes requests the Attributes Info command to be sent to the NI.
  • RTCP requests the RTCP stats to be sent to the NI.
  • Options requests the Options status command to be sent to the NI.
  • Copyright requests the Copyright report containing a copyright string.
  • Sanity requests the IT to reply with a Sanity OK response. This insures that the IT is alive and well.
  • Network Manager Options requests the diagnostic info command to be sent to the NI.
  • Managers requests the Manager's ID command to be sent to the NI.
  • Attributes requests the Attributes Info command to be sent to the NI.
  • RTCP requests the RTCP stats to be sent to the NI.
  • Options requests the Options status command to be sent to the NI.
  • Copyright requests the Copyright report containing a copyright string.
  • Sanity requests the IT to reply
  • This command updates the programmable options supported at the IT by the Network Manager.
  • This command is used tell the IT which QoS features to make use of when communicating with the NI.
  • the NI uses this command to force the IT to reserve a continuous block UDP ports. Once the ports are successfully reserved the NI can make use of them without fear of interfering with other servers controlling the IT.
  • the command contains the number of ports to reserve and a starting port number.
  • the IT will reply to this command with the Reserved UDP Ports Report stating how many ports were successfully reserved and the starting port number.
  • the NI could use those reserved port numbers to open audio streams for example.
  • Number of UDP Number between 1 and 255 which ports to reserve indicates the number of UDP ports that the NI wants to reserve.
  • Starting UDP Indicates the number of the first UDP port number port of the block of ports to reserve. When set to 0 ⁇ 00, the IT chooses the starting UDP port.
  • This command is used by the NI to download a character string oriented tag which identifies the server.
  • the IT could place this information on the display to identify the active server for the user.
  • This command is used by the NI to configure the different source description items that are part of the SDES report of the RTCP protocol.
  • Source Description Name used to descibe the IT e.g. “Homer Doe's IT”
  • the NI sends this command to an IT that supports multiple protocols to force it to change control protocols.
  • the other protocols that the IT supports could have a similar command to enable a switch-back to UNIStim.
  • Protocol ID An identifier for different protocols Download Backup Server Information
  • This command is used by the NI to download network-related information regarding backup servers into the IT. Note this command supports the download of info for several backup servers.
  • Server ID Server identifier used to reference a specific backup server per the following parameters.
  • Server Port Port number an identified server uses for Number UNIStim channel.
  • Server IP IP address of the identified server is Address Server Switch
  • the NI sends this command to force the IT to stop accepting UNIStim commands from the current server and start listening to the server specified in the command.
  • This command assumes that the IT has been made aware of the new server's network address in the configuration process or through the Download Backup Server Information.
  • Server ID Server identifier used to reference a specific, previously identified server IT to NI Network Manager Commands
  • the Soft Reset Ack command is sent to the NI after the IT has been reset via the reception of the Soft Reset command.
  • the command will be transmitted only after a successful reset has been performed.
  • the Sanity OK command is used in response to a Query Sanity command. It indicates that the IT can still receive and transmit from/to the NI.
  • This command is used in response to the Query Network Manager (Attributes) command generated from the NI.
  • the IT replies by sending the Network Manager Attributes.
  • the Diagnostic Info command is sent after it has been requested by the Query Network Manager (Diagnostic) command or when an error occurs and the Diagnostic Command transmission has been enabled via the Network Manager Options command.
  • This command is sent from the IT after reception of the Query Network Manager (managers) command from the NI.
  • the IT replies with a list of all managers contained in the IT with the exception of the Network Manager and the Broadcast Manager.
  • a flag, for each manager, indicates if the manager is active or inactive.
  • the format of the command is as follows.
  • This command is sent after reception of the Query Network Manager (Options) command. It sends the setup of the options to the NI.
  • This command is used to respond to the Query Network Manager (Copyright) request from the NI. It provides the copyright information as an ASCII string.
  • the IT sends this unsolicited command to inform the NI that it is ready to accept commands from NI.
  • the transmission of this command can either be triggered by a power-up or by a user choosing to connect to a new NI after power-up.
  • the IT sends this unsolicited command to inform the NI that it will disconnect itself from the NI.
  • the transmission of this command is normally triggered by a user choosing to connect to a different NI. Typically, this is the last command that the NI will receive from the IT until the user chooses to switch back to the NI.
  • This command is sent to inform the NI of the UDP ports that have been reserved as a result of the Reserve UDP Port Block command.
  • the command payload reports the number of UDP ports reserved as well as the number of the first UDP port of the reserved block.
  • the Basic manager handles the IT maintenance functions.
  • the start selftest command is used for running a selftest in the IT.
  • the self tests are device specific. This message requires that the secure code of the IT be set using the Basic Managers Options (Secure Code) command.
  • the Query command is sent by the NI. It is used to request the status or information from the Basic manager.
  • Attributes requests the Attributes Info command to be sent Options requests the Options Status command to be sent F/W version requests the F/W version command to be sent H/W ID requests the IT H/W ID command to be sent (serial number, color and the release number) IT Type requests the IT Type command to be sent Selftest requests the Selftest Result command to be sent PEC requests the Product Engineering Code command to be sent Basic Manager Options
  • This command updates the programmable options supported by the IT's Basic manager.
  • This command allows direct read or write access to the devices (EEProm, microprocessor, etc . . . ) of the IT.
  • the SECURE CODE flag must be set through the Basic Manager Options (Secure Code) command.
  • the data bytes must not be present in the command.
  • This command allows specific EEprom data byte locations to be written by the NI. In order for this command to succeed, the secure code must be set through the Basic Manager Options (Secure Code) command. This command allows access to EEprom data bytes, without having to know the exact location of the data in the EEprom.
  • This command enables the NI to use UNIStim to encapsulate commands that belong to UNIStim or other protocols.
  • the NI could force the IT to send out a Key Event command by encapsulating it in the Encapsulate Command.
  • This command could also be used to directly access resources (such as a DSP, VGA screen etc) in the IT without using a UNIStim command.
  • Encapsulated Protocol Identifies protocol ID of ID encapsulated protocol Encapsulated Command Data corresponding to command in identified protocol IT to NI Basic Commands
  • This command is used in response of the Basic Manager Query (Attributes) command to inform the NI of both the EEPROM static and dynamic checksums. Both values are read directly from the EEPROM.
  • This command is sent after reception of the Basic Manager Query (Options) command. It sends the basic manager's options configuration to the NI.
  • the F/W version command contains the F/W version code of the IT's code.
  • F/W Version 7 character ASCII string representing the F/W Version IT Type
  • the IT Type command is sent in response to the Basic Manager Query (IT Type) command from the NI. It is used to inform the NI on the type of IT.
  • IT Type Basic Manager Query
  • This command is send after reception of the Basic Manager Query (Selftest) command from the NI.
  • Test ID An identifier for each test Test Result A pass/fail indication for each test identified General Read Response
  • This command is used in response to the General Read/Write command when a read operation is performed.
  • This command is sent in response to the Basic Manager Query (H/W ID) command. It provides the unique number that identifies the IT.
  • This command is sent in response to the Query Basic Manager (PEC) command from the NI. It provides the Product Engineering Code of the IT.
  • PEC Query Basic Manager
  • the Key/Indicator Manager is the manager responsible for managing parameters associated with keys and the indicators on the IT.
  • the LED Update command is used to update the state and cadence of LEDs on the IT.
  • cadence should be downloaded using Indicator Cadence Download before selecting Downloadable cadence as the LED State.
  • the Query Hookswitch command is used to query the state of hookswitch on the IT.
  • the IT must send back the Hookswitch State command in reply.
  • the User Activity Timer can be turned on and off using this command.
  • the time-out value of the timer is defined using the User Activity Timer Download command.
  • Start/Stop Starts or stops the timer Downloadable Free Form Icon Access
  • the Downloadable Free Form Icon Access command is used to enable or disable the download Icon RAM bit map. This command allows ‘overloading’ the existing Free Form Icon ROM bit maps.
  • the Query Key/Indicator manager command is used to request information about various states or information handled by the Key/Indicator manager.
  • This NI uses this command to set the Key/Indicator manager options.
  • the Logical Icon Mapping command is used to define the relationship between physical and logical icons in the IT.
  • the one-to-one mapping command is used to map the physical icon 0 with the logical icon 0, physical icon 1 with the logical icon 1 and so on.
  • the Key repeat Timer Download is used by the NI to specify the time (first timer) before sending the key repeat command when the key remains depressed and also for specifying the time (second timer) to wait before sending all subsequent key repeat commands if the same key remains depressed.
  • the Query LED State command is used by the NI to extract LED state information from the IT.
  • LED ID Specifies LED to be queried Query IT Icon State
  • the Query IT Icon State command is used by the NI to extract IT icon state information from the IT.
  • the Indicator Cadence Download command is used to specify a new custom cadence that can be used to flash the icons and LEDs when using the downloadable cadence option in the LED Update and IT Icon Update commands.
  • the User Activity User Download command is used to download the time-out value used by the User Activity timer. This time-out value will be used when the user Activity is started by the User Activity Timer command. Upon receipt of the command the IT will restart the timer with the new time-out value.
  • This command is used to download a free form icon representation that is not already hard coded in the IT ROM.
  • the command contains the ID of the downloadable icon, and the bitmap that represents the free form icon.
  • This command is used to change the current state and cadence of an IT icon.
  • the IT icon will be updated with the new state and cadence only if the physical icon IS NOT mapped to a logical icon.
  • Physical Icon ID specifies physical ID of icon to be updated
  • Icon State specifies desired state of icon Icon Cadence Off On Flash Flicker Wink Twinkle Blink Downloadable cadence IT to NI Key/Indicator Commands
  • This command is used to report an event related to the keys.
  • the event can be a key depression, key repeat or a key released.
  • This command is sent to the NI in response to the Query LED State. It informs the NI on the state and cadence of LEDs.
  • the On Hook command is sent to the NI when the IT detects an Off hook to On hook transition.
  • the Off Hook command is sent to the NI when the IT detects an On hook to Off hook transition.
  • This command is sent to the NI when the User Activity timer times out.
  • the actual time-out value for the User Activity Timer is specified by the User Activity Timer Download command.
  • This command is sent to the NI in response to the Query Key/Indicator Manager (Hookswitch) command.
  • This command is sent to the NI in response to the Query Key/Indicator Manager (Attributes) command and informs it of the attributes of the Key/Indicator manager.
  • the format of the command is as follows.
  • Programmable contains the number of programmable keys keys on the IT
  • Soft Keys contains the number of soft keys on the IT Headset Key indicates existence of a Headset Key on the IT
  • Mute Key indicates existence of a Mute Key on the IT
  • Quit indicates existence of a Quit Key on the IT Copy indicates existence of a Copy Key on the IT
  • Message indicates existence of a Message Waiting Waiting Indicator on the IT Indicator Navigation none keys two four Key/Indicator Manager Options Report
  • This command is sent to the NI in response to a Query Key/Indicator Manager (Options) command. It sends the Key/Indicator Manager's options configuration to the NI.
  • the options are set via the Key/Indicator Manager Options command.
  • This command is used in response of the Query Key/Indicator Manager (Icon State) command. It informs the NI of the state of icons.
  • Physical Icon specifies physical ID of icon to be queried ID
  • Icon State specifies state of icon Icon Cadence Off On Flash Flicker Wink Twinkle Blink Downloadable cadence Audio Manager
  • the Audio manager is the entity that manages every aspect of the audio configuration of the IT.
  • the main tasks of the manager are to configure the loss plan and tones, setup voice paths and establish end-to-end voice connections.
  • the Query Audio Manager command is used to request various status or information from the Audio manager.
  • Attributes requests the Attributes of the Audio manager Options request the option setting of the Audio manager Alerting requests the Alerting selection (warbler rate and cadence) Adjustable requests the IT to send the Adjustable Rx Rx Volume Volume Information command.
  • APB Default requests the IT to send the Default Rx Rx Volume Volume of the specified APB Handset requests the handset status Headset requests the headset status
  • APB number specifies the APB for the APB Default Rx Volume query Query Supervisor Headset Status
  • This command is used to query the connection status of the supervisor headset.
  • This command updates the programmable options supported by the Audio manager.
  • Volume Adjustment Remote volume adjusted by the NI Local: volume adjusted by IT Volume Adjustment Enable/Disable the transmission of Reports volume adjustment reports when volume keys are depressed Headset Rfeature Enable/Disable the transmission of Key Message Headset Rfeature Key message when key event is detected on headset interface. Mute/Unmute
  • This command is used to mute/unmute Rx and Tx streams.
  • This command is used to turn on one of the transducer based tone (alerter, paging or special tone).
  • the association between a transducer based tone and a transducer is done using the Alerter Tone Setup, Paging Tone Setup and Special Tone Setup commands of the audio manager. Some of these tones may be mutually exclusive.
  • This command is used disconnect a transducer based tone from its associated transducer.
  • This command is used to configure the various parameters that are associated with the Alerting tone. Through this command the alerter tone's volume range, warbler effect, cadence and transducer routing can be configured.
  • Warble Select Specifies the warble to use with the alerting tone Tone Volume Number of steps from the maximum tone Range volume value, which is set by hardware.
  • Transducer Handset Speaker Routing Headset Speaker Handsfree Speaker Cadence Select cadence 0 cadence 1 cadence 2 cadence 3 cadence 4 cadence 5 cadence 6 downloadable alerter tone cadence Special Tone Configuration
  • This command is used to configure the various parameters that are associated with the special tone. Through this command the special tone's volume range, cadence and transducer routing can be configured.
  • Tone Volume Number of steps from the maximum tone Range volume value which is set by hardware.
  • Handset speaker Headset speaker Handsfree speaker Cadence Select cadence 0 cadence 1 cadence 2 cadence 3 cadence 4 cadence 5 cadence 6 downloadable special tone
  • cadence Special Tone Selects the frequencies that make up the Content special tone Paging Tone Configuration
  • This command is used to configure the various parameters that are associated with the paging tone. Through this command the paging tone's volume range, cadence and transducer routing can be configured.
  • Handset speaker Headset speaker Handsfree speaker Cadence Select cadence 0 cadence 1 cadence 2 cadence 3 cadence 4 cadence 5 cadence 6 downloadable paging tone cadence Alerting Tone Cadence Download
  • the Alerting Cadence Download command is used by the NI to download an alerting cadence in the IT. This new Alerting Tone cadence will be used the next time the IT receives the Tone On (Alerting Tone) command if this tone is set to use the downloadable cadence (see Tone Cadence Select command).
  • the Special Tone Cadence Download command is used to download a Special Tone cadence in the IT. This new Special Tone cadence will be used the next time the IT receives the Tone On (Special Tone) command if this tone is set to use the downloadable cadence (see Tone Cadence Select command).
  • the Paging Tone Cadence Download command is used to download the configuration for the paging tone.
  • the command is used to specify the tone frequency and On/Off duration of all the tones that make up the paging tone.
  • This new Paging Tone cadence will be used the next time the IT receives the Tone On (Paging Tone) command if this tone is set to use the downloadable cadence (see Tone Cadence Select command).
  • Cycle 1 Paging Specifies the tone frequencies to be Tone Content used in the first cycle Cycle 1 On Time On duration for first cycle Cycle 1 Off Time Off duration for first cycle Cycle 2
  • Paging Specifies the tone frequencies to be Tone Content used in the second cycle Cycle 2 On Time On duration for second cycle Cycle 2 Off Time Off duration for second cycle Cycle 3
  • Paging Specifies the tone frequencies to be Tone Content used in the third cycle Cycle 3 On Time On duration for third cycle Cycle 3 Off Time Off duration for third cycle Notes:
  • the Transducer Based Tone Volume Level command is used to specify the volume level for different transducer based tones.
  • the volume is defined in steps from the lowest level of the volume range. If the volume level specified in the command is outside the volume range, the upper boundary of the range will be used as the new volume level.
  • the Alerting Tone Test command is used to start the alerting tone on the IT without changing the current selection of alerting. This command is usually used when the user selects the type of alerting. Only the warbler can be selected.
  • Warble Select Specifies the warble to use with the alerting tone Visual Transducer Based Tones Enable
  • This command is used to configure the IT with respect to providing visual tones feedback when it receives the Transducer Based Tone On command.
  • This command is used to inject a stream based tone into an audio stream.
  • the actual parameters that define the stream based tone specified in the command can be set using the Stream Based Tone Configuration command which is used to bind a cadence and a frequency component list with the tone.
  • Tone ID in audio stream Stream ID Identifies the stream in which to inject the stream based tone
  • Rx Tx Tone Level Volume level at which the tone should be played out in steps from minimum.
  • Tone ID in audio stream Stream ID Identifies the stream in which to inject the stream based tone should be stopped
  • This command is used to bind one of the 32 stream based tone cadences and one of the 32 frequency component lists with a stream based tone.
  • the actual cadences and frequency component lists can be modified through the Stream Based Tone Cadence Download and the Stream Based Tone Frequency Component List Download.
  • Stream based Tone ID Stream based tone to bind with cadence in frequency component list specified in the command.
  • Stream based Tone Cadence ID Cadence to use next time stream based tone specified in command is turned on.
  • Stream based Tone Frequency Frequency components to use next time Component List stream based tone specified in command is turned on.
  • This command is used to reconfigure one of the 32 frequency component lists available for stream based tones.
  • This command is used to reconfigure one of the 32 cadences available for stream based tones.
  • the command specifies up to four On/Off duration pairs.
  • This command is used to select the Rx volume that will be affected by the Change Adjustable Rx Volume command.
  • Adjustable Rx Volume none Audio Parameters Bank 1 Audio Parameters Bank 2 Audio Parameters Bank 3 Audio Parameters Bank 4 Audio Parameters Bank 5 Audio Parameters Bank 6 Audio Parameters Bank 7 Alerting Special Tones Paging Tones Set APB's Rx Volume Levels
  • the Set APB's Rx Volume Level command is used to specify the new Current Rx Volume for the specified APB.
  • the command can also force the Default Rx Volume to be changed to the specified Current Rx Volume by setting the Default flag.
  • the volume level is specified as an offset in number of steps from the system RLR for the path specified APB. This command will override volume control adjustments done by the user. This command is intended to be used by the system to convey volume control adjustments made by the user in list based option controls.
  • RLR Offset Indicates whether the offset is a positive or a Direction negative offset with respect to the APB's system RLR. Update Default Specifies whether the default volume for the APB should be updated Rx Volume Specifies the volume offset in steps to be Level Offset applied to the APB's system RLR. Change Adjustable Rx Volume
  • This command is used to increase or the decrease the receive volume selected through the Select Adjustable Rx Volume command by one step within the limits of its loss plan. This command is used when the volume adjustments are performed by the NI instead of locally in the IT.
  • This command is used to increase or decrease the Defalut Rx Volume value of the specified Audio Parameters Bank (APB) or transducer based tone by one step within the limits of its loss plan.
  • This command should be used when the user increases or decreases the default Rx volume from an option list. Also notice that this command will only change the default Rx volume and not the system default value which is the RLR (downloaded via the Receive Loudness Rating command) so the loss plan will not be changed with this command.
  • the Adjust APB's Tx and/or STMR command is sent by the NI to allow Tx and STMR volume adjustments for different transducer types. It is used to adjust the APB's Tx or STMR volume level, either increasing or decreasing it by one step.
  • the adjustment enable bits allow the NI to adjust both Tx and STMR volumes with a single command. Alternatively, either the STMR or Tx volumes can be adjusted individually. This command is intended to be used for multi-vendor headset configuration.
  • the Query APB's Tx and/or STMR command is sent by the NI to query the current STMR and/or Tx volume level settings. This command is intended to be used for multi-vendor headset configuration.
  • APB number none Audio Parameters Bank 1 Audio Parameters Bank 2 Audio Parameters Bank 3 Audio Parameters Bank 4 Audio Parameters Bank 5 Audio Parameters Bank 6 Audio Parameters Bank 7 STMR Volume Level requests STMR volume level Request information from audio manager Tx Volume Level Request requests Tx volume level information from audio manager ABP Download
  • This command is used to download all the audio parameters (such as loss plan) associated with a specific audio parameter bank. The new parameters will be used the next time a voice call involving the ABP is set up. This command uses flags to indicate the presence (or absence) of each audio parameter.
  • APB number Audio Parameters Bank 1 Audio Parameters Bank 2 Audio Parameters Bank 3 Audio Parameters Bank 4 Audio Parameters Bank 5 Audio Parameters Bank 6 Audio Parameters Bank 7 Switched Loss Amount of Switched Loss used by the Switching algorithm Step Size Minimum Volume Minimum Volume relative to the RLR Automatic Gain Specifies if AGC is implemented Control for this APB. Maximum Volume Maximum Volume Relative to the RLR Receive Loudness The RLR to use for this APB Rating Return to Default Specifies if the volume control for this APB is to operation in return to default mode Send Loudness Rating The SLR to use for this APB Side Tone Masking The STMR to use for this APB Rating Open Audio Stream
  • This command is used to set up full or half-duplex end-to-end RTP voice sessions between the IT and an IP connected far-end. This command is also used to specify RTCP ports and DTMF support for the specified voice session.
  • Rx Stream ID Tells the IT which stream it must use as the destination of voice data originating from the far end.
  • Tx Stream ID Tells the IT which stream it must use as the source of voice data destined to the far-end.
  • Rx Vocoder Type Specifies to type of vocoder to use to decode the Rx Stream.
  • Tx Vocoder Type Specifies to type of vocoder to use to encode the Tx Stream.
  • Tx DTMF This bit is used to indicate whether or not DTMF key pressed information will be transmitted as part of the voice session.
  • Rx DTMF This bit is used to indicate whether or not DTMF key pressed information will be received as part of the voice session.
  • IT RTP Port Local UDP port to use for transmitting and receiving voice data.
  • IT RTCP Port Local UDP port to use for transmitting and receiving RTCP control messages.
  • An RTCP port of “zero” means that the audio stream does not have an RTCP channel and that the Far-End RTCP port field is a “don't care”.
  • Far-End RTP Port Far-end UDP port to/from which the voice data should be sent/received.
  • Far-End IP Specifies the IP address of the end Address point that is at the other end of the RTP connection. Close Audio Stream
  • This command is used to kill audio voice sessions associated with the stream Ids specified in the payload of the command.
  • This command is used to cross-connect the transducers specified in the command with a quantity of streams in an unit-directional or bi-directional fashion.
  • the actual streams referred to in this command are created through the Open Audio Stream command.
  • This command can also be used to assign an Audio Parameters Bank (APB) to the transducer pair designated in the command.
  • APIB Audio Parameters Bank
  • Transducer Pair Handset ID Headset Handsfree Speaker/Microphone All Transducer Pairs Stream ID ID of the stream to connect to the transducer specified in the command.
  • Tx Enable Streams specified in the command are connected the microphone of the designated transducer pair.
  • Rx Enable Streams specified in the command are connected the speaker of the designated transducer pair.
  • APB Specifies if an APB is to be used in conjuction with the specified transducer pair
  • Sidetone Specifies if sidetone is enabled for transducer pair specified in command Destructive/ Specifies whether this command should Additive augment or replace transducers that were connected to the streams listed in the command prior to its reception.
  • APB number none Audio Parameters Bank 1 Audio Parameters Bank 2 Audio Parameters Bank 3 Audio Parameters Bank 4 Audio Parameters Bank 5 Audio Parameters Bank 6 Audio Parameters Bank 7 Frequency Response Specification
  • the Frequency Response Specification command specifies the filter building blocks to be used to implement the desired frequency response for a given transducer.
  • the command is used by the IT to fill in a frequency response specification table, specifying which filters need to be set up for a given transducer.
  • the Frequency Response Specification command contains a list of filter numbers which correspond to predefined filter building blocks in the IT. Each filter ID will program a predefined number of biquadratic sections (biquads).
  • the biquad ID field specifies the first biquad to be used for implementing the filter.
  • the Filter Gain Compensation is sent as part of the Frequency Response Specification.
  • the Filter Gain Compensation specifies a gain adjustment to compensate for any deviation from the Loudness Rating (LR) caused by the filter shape specified by the frequency response specification.
  • LR Loudness Rating
  • Transducer ID Handset Headset Handsfree Speaker/Microphone Rx Filter Count number of new filter in the Rx direction
  • Rx/Tx Filter ID Filter Id as specified in the functional description. Notes:
  • the Biquad Download command is used to adjust the IT frequency response by downloading new set of coefficients for a specific biquad. The next time the IT will program the biquads, it will use the new set of coefficients.
  • the downloaded biquad can be selected using the Frequency Response Specification command. Each biquad takes five coefficients, B0, B1, B2, A1 and A2.
  • This command is used to download the voice switching parameters associated with a specific transducer. These parameters will be used the next time the voice switching is enabled.
  • Transducer ID Handset Headset Handsfree Speaker/Microphone AGC Threshold Input threshold for application of AGC Rx Virtual Pad Tx blocking margin of the switching algorithm Dialtone Input threshold for considering a threshold dialtone Tx Virtual Pad Rx blocking margin of the switching algorithm Echo Mute Enable/Disable talker echo muting Enable Dynamic Side- Enable/Disable sidetone variation based tone Enable on noise floor Query RTCP Statistics
  • This command is used by the NI to request RTCP data gathered in the media session associated with the stream ID specified.
  • This command is used to configure parameters that are associated with the vocoder specified in the command.
  • the command contains a field that identifies the vocoder to modify followed by a list of new parameter settings. Note that not all vocoders support the entire list configurable parameters.
  • Vocoder Type Specifies the vocoder on which to apply the parameter settings
  • Direction Rx Tx Both Voice Activity Detection Enable/Disable Bad Frame Interpolation Algorithm
  • Enable/Disable Post Filter Enable/Disable High Pass Filter Enable/Disable Frame Size Specifies number of bytes per frame Jitter Buffer Configuration
  • This command is used to configure parameters that are associated with the jitter buffer of the specified stream.
  • the Handset Connected command is sent to the NI when a handset is detected in the handset port of the IT.
  • Handset Type Specifies the type of handset detected Handset Disconnected
  • the Handset Disconnected command is sent to the NI when the handset is disconnected from the handset port of the IT.
  • the Headset Connected command is sent to the NI when a headset is detected in the headset port of a so equipped IT
  • the Headset Disconnected command is sent to the NI when the headset is disconnected from the headset port.
  • the Supervisor Headset Connected command is sent to the NI when the supervisor headset is detected on the supervisor headset port of a so equipped IT.
  • the Supervisor Headset Disconnected command is sent to the NI when the supervisor headset is disconnected from the supervisor headset port.
  • the Headset Rfeature Key Pressed command is sent to the NI in response to the IT receiving the predefined headset based fearture key event on the headset port.
  • the transmission of this message is enabled by the Audio Manager Options (Headset Rfeature Key Message) command.
  • This command is used in response of the Query Attributes command to inform the NI of all the attributes that the Audio manager has.
  • This command is sent after reception of the Audio Manager Query (Options) command. It informs the NI of the Audio manager's option setup.
  • Volume Adjustment Remote volume adjusted by the NI Local: volume adjusted by IT Volume Adjustment Enable/Disable the transmission of Reports volume adjustment reports when volume keys are depressed Headset Rfeature Enable/Disable the transmission of Key Message Headset Rfeature Key message when key event is detected on headset interface. Adjustable Rx Volume Report
  • This command is sent to the NI after a volume key has been depressed and the “Volume Adjustment Reports” option has been enabled via the Audio Manager Options command.
  • the command shows which volume key has been depressed and if it caused the rx volume reach its “floor” or “ceiling”.
  • the NI could use this information to display a visual representation of the volume adjustment to the user.
  • Volume ID none Audio Parameters Bank 1 Audio Parameters Bank 2 Audio Parameters Bank 3 Audio Parameters Bank 4 Audio Parameters Bank 5 Audio Parameters Bank 6 Audio Parameters Bank 7 Alerting Special Tones Paging Tones Steam Based Tones
  • Vol. Down Indicates that the volume down key has been depressed.
  • Vol. Up Indicates that the volume up key has been depressed.
  • Floor Indicates that the volume setting of the specified .volume register has decreased to the “floor”
  • Ceiling Indicates that the volume setting of the specified .volume register has increased to the “ceiling” Adjustable Rx Volume Information
  • This command is used to inform the NI of the active Rx volume register in the IT. It contains the APB or transducer based tone number, its current Rx volume setting and volume range as well as the floor ceiling indications. This command is sent generally after reception of the Query Audio Manager (Adjustable Rx Volume) command
  • the Audio Parameters Bank Default Rx Volume Value command is used in response to the Query Audio Manager (APB Default Rx Volume) command. It gives the default Rx volume level of the specified APB. It contains the APB number, the default volume setting of the APB, the floor ceiling indicators.
  • APB Identifier none Audio Parameters Bank 1 Audio Parameters Bank 2 Audio Parameters Bank 3 Audio Parameters Bank 4 Audio Parameters Bank 5 Audio Parameters Bank 6 Audio Parameters Bank 7 Alerting Special Tones Paging Tones Stream Based Tones Floor Indicates that the volume setting of the specified .volume register is at its “floor”. Ceiling Indicates that the volume setting of the specified .volume register is at its “ceiling”. Default Volume Level Default volume of the specified volume register. Volume Range Range of the specified volume register. Alerting Tone Select
  • This command is used in response to the Query Audio Manager (Alerting) command.
  • the alerting information as well as the warble rate selection are sent as part of this command.
  • the format of the command as follows.
  • the Query APB's Tx and/or STMR response is sent by the IT in response to the corresponding query command.
  • the response sent by the IT indicates the current STMR and/or Tx volume level setting for the specified APB number.
  • APB number none Audio Parameters Bank 1 Audio Parameters Bank 2 Audio Parameters Bank 3 Audio Parameters Bank 4 Audio Parameters Bank 5 Audio Parameters Bank 6 Audio Parameters Bank 7 Tx Vol Level current Tx volume level for the specified APB STMR Vol. Level current STMR volume level for the specified APB RTCP Statistics Report
  • This command is sent in response to the Query RTCP Statistics command sent by the NI.
  • IT Packet Count Total number of packets sent by the IT in the session up to this point.
  • IT Octet Count Total number of octets sent by the IT in the session up to this point.
  • Interarrival Jitter Estimate of the statistical variance of the delay between each received media packet. Fraction Lost Fraction of media packets lost as reported in the last RTCP packet. Total Packet Lost Total number of lost packets since the beginning of the media session. Open Audio Stream Report
  • the IT automatically sends this command to the NI after it receives an Open Audio Stream command.
  • the command reports on the status of the stream created by the Open Audio Stream command.
  • the main task of the display manager is to present the information sent by the NI on the LCD.
  • the NI does not have to know the physical location of where the information is presented.
  • Another big task of the display manager is to maintain the configuration tables for the multi-language character tables.
  • This command is used to scroll up or down one page of display. This command assumes that the information of the page to scroll to is already downloaded in the IT.
  • This command is used to restore the character table configuration of the display to the one downloaded through the Set Default Character Table Configuration command.
  • the G1, G2 and G3 tables will contain the character sets specified by the default configuration and one of the G table will be lock-shifted (code A0 to FF hex).
  • This command is used to turn on and off the display backlight. This could be used in power saving mode when back lighting is supported by the IT.
  • This command turns on or off the dedicated arrow fields on the display.
  • This command is used to query the state of a specific icon in the status bar.
  • the IT will reply with the Status Bar Icon State command specifying the state of the queried icon.
  • Status Bar Icon ID Specifies the status bar icon to be queried Highlight On/Off
  • This command is used to turn on or off the highlight on the display.
  • the highlight is turned on, the field that is specified by the Highlighted Field Definition command will be highlighted.
  • This command is used to revert the effect of the Clear Time and Date and Caller Log Download commands by restoring the time and date in the time & date fields of the IT.
  • the time and date or the call duration information, whichever was the last one active prior to receipt of a Clear Time and Date command or the Caller Log Download command, will be shown in the time and date field.
  • This command clears the time and date fields and inhibits the update of the fields with the time and date information.
  • the time and date information is still kept in the IT in case it is restored with a Restore Time & Date command.
  • This command is used to configure the call duration timer. Through this command, the call duration timer can be started or stopped, reset, shown or hidden, with or without a delay.
  • the Query Display Manager command is sent by the NI to request various status information from the Display manager.
  • the format of the command is as follows.
  • Attributes requests the Attributes Info command to be sent.
  • TAD requests the Time and Date Format command to be sent.
  • Cursor requests the Cursor Location command to be sent.
  • Contrast requests the Contrast Level command to be sent.
  • Backlight requests the Backlight Status Info command to be sent.
  • Highlight requests the Highlight Status command to be sent.
  • Current Character Table requests the Current Character Table Configuration Status command to be sent.
  • Default Character Table requests the Default Character Table Configuration Status command to be sent. Download Call Duration Timer Delay
  • the Download Call Duration Timer Delay command is used to specify the delay to be used by the Call Duration Timer command when the Delay option is selected in the Call Duration Timer command.
  • Call Duration Timer Delay specifies the delay duration of call duration timer. Disable Display Field
  • the Disable Display Field command is used to enable and disable fields of the LCD. When a field is disabled it becomes blank until it is re-enabled. However, if the NI writes data to a disabled field, the data will be stored in the IT and will become visible on the LCD once it is re-enabled. All fields that have their corresponding bit set will be disabled and all others with their bit cleared will be enabled.
  • This command is used to erase fields of the LCD. Many portion of the display can be cleared at the same time. Once a field is cleared, the data it contain ed is lost and cannot be re-displayed on the field unless re-downloaded by the IT.
  • This command is used to activate, configure and move the cursor on the display.
  • Cursor Movement Set cursor at home (first character on the first text line) Set cursor at the specified position within the specified field Move the cursor by one to the left Move the cursor by one to the right Move the cursor a specified number of positions to the left Move the cursor a specified number of positions to the right Cursor State ON OFF Blink Field Numeric Line SoftKey Softkey ID
  • the Softkey ID when field specifies softkey Line Number Line number when field specifies line. Character Position Position of the cursor in the specified field (zero being the first position within the field) Position Delta Specifies number of positions left or right to move cursor Page Download
  • a portion can be any field that characterizes the display, i.e., line, softkey, etc.
  • Field Softkey Line Line Number Specifies line number when Line field is specified
  • Softkey ID Specifies softkey when Softkey field is specified
  • Character Position Specifies starting character position when Line field is specified Display Data Data to be written to specified field and position Display Scroll with Data
  • This command is used to download a new line of text and to scroll the others up or down. This command only affects the line fields of the display. This command cannot download more than one new line of text at the time.
  • This command is used to change to current state and cadence of a status bar icon.
  • Status Bar Icon ID specifies the status bar icon to be updated
  • Icon State specifies desired state of icon Icon Cadence Off On Flash Flicker Wink Twinkle Blink Downloadable cadence Month Labels Download
  • This command is used to download the label for the current and next months. These labels are used in the date field and enable the date to roll over to next month.
  • This command is used to download the call duration timer label which will be displayed on the IT's display when the call duration timer is activated.
  • Call Duration Timer Label Text string representing call duration timer label Time and Date Format
  • This command is used to specify the format that the Display manager will use to present the time and the date information to the user.
  • Time Format 12-hour clock e.g. 10:34pm
  • French clock e.g. 22h34
  • 24-hour clock e.g. 22:34
  • Date Format day first e.g. 16Sep
  • month first e.g. Sep16
  • numeric standard e.g. 09/16
  • numeric inverse e.g. 16/09
  • This command is used as a generic command for writing to the display. It is composed of four parts: the address, the control, the tag and the data. Three of these parts, the address, the control, and the tag, are optional.
  • the display data part is mandatory.
  • the address byte is used to specify where the text to write starts. If no address is specified, the data will start at the current cursor position.
  • the tag field is used to give a meaning to the attached text (directory, CLID, etc.).
  • the control field is used to control characteristics of the display. If the control field is not present, the default control setup will be used.
  • This command is used to specify the format of the Context Info bar field.
  • the supported formats are the ones specified in the functional description of the IT in question.
  • This command downloads the default character map configuration that the display manager must use. It specifies the mapping of the character table to the graphics tables and it also specifies which one of the graphics table is to be lock-shifted (code A0 to FF hex).
  • This command downloads the current character map configuration that the display manager must use. It specifies the mapping of the character table to the graphics tables and it also specifies which one of the graphics table is to be lock-shifted (code A0 to FF hex).
  • This command is used to download special characters that are not specified in the character ROM tables of the IT.
  • the special character address is specified as well as bitmap.
  • Character ID identifies character to be downloaded Bitmap Data data defining the character Highlighted Field Definition
  • This command is used to highlight a portion of the display.
  • This command sets the contrast level.
  • Contrast Specifies contrast level to be set Caller Log Download
  • This command is used to update the time and date fields with a downloaded time and text label instead of the usual time and date information.
  • Hour Specifies hour Minutes Specifies minutes Text Label Text data to be written to the Date field IT to NI Display Commands
  • This command is used in response to the Query Display Manager (Attributes) command.
  • Para- Line Width The width of the text area lines expressed meters: in characters Lines Number of lines in the text area Line Icon When set, it indicates that an icon is associated with each line in the text area of the display
  • Softkey Width The width of the softkeys expressed in characters.
  • Softkeys Number of softkeys Soft Labeled Key
  • the width of the Soft-Labeled key area Width expressed in characters.
  • Soft Labeled Keys Number of soft labeled keys
  • Context Field Width The width of the context field expressed in characters. Numeric Width Number of digit supported in the numeric index field. Time Width Number of Character supported in the time field. Date Width Number of Character supported in the date field. Character Download Number of downloadable characters. Free Form Icon Number of downloadable free form icons Download Character sets List of supported character sets Contrast Level Report
  • This command is used in response to the Query Display Manager (Contrast) command. It gives the current display contrast level. The level is set by the NI with the Contrast command.
  • This command is used in response to the Query Display Manager (Cursor) command. It gives the position of the cursor on the display.
  • Line SoftKey Softkey ID The Softkey ID when field specifies softkey Line Number Line number when field specifies line. Character Position of the cursor in the specified field Position (zero being the first position within the field) Highlight Status On
  • This command is used in response to the Query Display Manager (Highlight) command when the highlight feature is on.
  • the command defines the display area that is currently highlighted.
  • the Current Character Table Configuration Status command is used in response to the Query Display Manager (Current Config) command. It informs the NI about the current character table configuration of the display manager.
  • the Default Character Table Configuration Status command is used in response to the Query Display Manager (Default Config) command. It informs the NI about the default character table configuration of the display manager.
  • the Time and Date Format command is used in response to the Query Display Manager (TAD) command. It reports on the format that the IT uses to present the time and date information to the user.
  • TAD Query Display Manager
  • Time Format 12-hour clock e.g. 10:34 pm
  • French clock e.g. 22 h 34
  • 24-hour clock e.g. 22:34
  • Date Format day first e.g. 16 Sep
  • month first e.g. Sep 16
  • numeric standard e.g. 09/16
  • numeric inverse e.g. 16/09
  • This command is used in response to the Query Display Manager (Icon) command. It gives the current state and cadence of the selected status bar icon.
  • Status Bar Icon ID specifies the status bar icon to be updated
  • Icon State specifies desired state of icon Icon Cadence Off On Flash Flicker Wink Twinkle Blink Downloadable cadence Backlight Status
  • This command is used in response to the Query Display Manager (Backlight) command. It gives the current state of the backlight.
  • the backlight is controlled by the NI with the Display Backlight Control command.
  • This command is used to respond to the Query Display Manager (Highlight) command when the status of the highlight is off.

Abstract

A packetised data network includes IP telephones (ITs) and a network intelligence (NI). All of the keys of each IT are “soft” keys (i.e., they have no fixed function). The NI associates a configuration data structure with the IT which correlates the keys with functions, and, based on this, may control the display of the IT to indicate the current function of certain of the soft keys. Some of the functions are requests for data services at the telephone (e.g., video or programmed audio over the internet). When a user requests such a service with a key press, the NI sets up the service between the data source and the telephone. This may require associating a new configuration data structure with the keys of the IT. The IT user may activate multiple data services through the NI.

Description

This invention relates to the provision of telephony and corporate and public data network services at a telephone. The system has application to internet protocol (IP) based telephony.
Traditionally, a private branch exchange (PBX) has been used to provide telephone services to a network of local telephones. The PBX may exist in parallel with a local area network (LAN) which provides data services to a network of local computers. It has been contemplated to provision a LAN not only with computers but also with special telephones so that the network can provide telephony services in addition to data services thereby avoiding the need for parallel networks. In a known system, IP telephones connect to the LAN backbone as does a call manager (which is a server configured with call management software) and a gateway to the public switched telephone network (PSTN). The IP telephones include a vocoder so that audio signals may be converted between analog and IP packets. The call manager has a configuration file for each telephone on the LAN assigning call functions to certain of the buttons on the phone, which call functions will be handled by the call manager. Other call functions (e.g., “mute”) are handled by the telephone itself. When the call manager receives keypad digits from a calling phone on the LAN indicative of a called station, it sets up a call by instructing the calling phone to set up a Real-Time Protocol (RTP) audio stream to either the called telephone, if the called telephone is on the LAN, or to the gateway, if the called telephone is on the PSTN. Once the call is set up, the call manager is out of the loop unless the call manager receives a key press indication indicative of a call control function handled by the call manager, such as a call transfer, call hold, call forward, call park, multiple line appearance, or disconnect.
SUMMARY OF THE INVENTION
According to one aspect, the present invention provides an IP telephone (IT) where preferably all of the keys are “soft” keys (i.e., they have no fixed function). The network intelligence (NI) associates a configuration data structure with the IT which correlates the keys with functions, and, based on this, may control the display of the IT to indicate the current function of certain of the soft keys. Some of the functions may be requests for data services at the telephone (e.g., video or programmed audio over the internet). When a user requests such a service with a key press, the NI sets up the service between the data source and the telephone. This may require associating a new configuration data structure with the keys of the IT. The IT user may activate multiple data services through the NI. If none of the keys of the IT has a fixed function, the NI can more easily arrange for the provision of the services without conflicting with any telephony calls at the telephone.
According to the present invention, there is provided an NI for a data network, comprising a call service provider for, when connected to a plurality of data network telephones, facilitating provision of telephony services for said plurality of telephones. In one aspect, the NI includes at least one service proxy for, when connected to a plurality of data sources, setting up services between said plurality of data sources and said plurality of telephones. In another aspect, the NI includes a control messager for selectively sending a control message to enable a user input element of a given telephone of said plurality of telephones to locally control a function at said given telephone and a control message to disable a user input element of a given telephone of said plurality of telephones to locally control a function at said given telephone. In a further aspect, the call service provider includes a messager for sending messages with audio parameters over said data network to said plurality of telephones for controlling audio at said plurality of telephones, said audio parameters including transmission and reception filters.
According to another aspect of the invention, there is provided a telephony system, comprising: a plurality of telephones connected to a data network; a network intelligence connected to said network for facilitating provision of telephony services to said plurality of telephones and, where said network is also connected to a data source, for providing a data service between said plurality of telephones and said data source.
According to a further aspect of the invention, there is provided a telephone for a data network, comprising: an audio processor for converting between analog audio and packets of audio data according with a data protocol for said data network; and a plurality of user input elements, each of which, when used, generating an event for transmission on said data network and each of which having an assignable function and not having any dedicated function, and no user input elements other than those of said plurality of user input elements.
In another aspect, there is provided a telephone for a data network, comprising: a processor; a user input element associated with permanent function identifying indicia, said user input element operatively connected to said processor and free of any connection to any other operative elements of said telephone; said processor arranged for, when the telephone is connected to a data network and said user input element is operated, sending a user element operation message on the data network and taking no other action in response to operation of said user input element.
In another aspect, there is provided a telephone for a data network, comprising: a plurality of user input elements, each of which, when used, generating an event for transmission on said data network and each of which having an assignable function and not having any dedicated function. In one aspect, the telephone includes at least one timer arranged for timing when receiving an enabling message over said data network. In another aspect, the telephone includes a memory; and a receiver for receiving a labelling message over said data network and for storing labels from said labelling message in memory. In a further aspect, the telephone includes a window manager for receiving messages from a plurality of network intelligences over said data network and for passing messages associated with a master network intelligence; blocking messages other than alarm messages and data port reservation messages from any other network intelligence.
According to yet a further aspect of the invention, there is provided a method of remotely managing a telephone connected to a data network, comprising: receiving user input messages from said telephone over said data network, each user input message identifying a user input element actuated by a user; where one or more user input messages from said telephone indicate a called station, establishing a call between said telephone and said called station utilising a first service provider such that audio data may pass between said telephone and said called station, and updating a state of said telephone to a state of busy with a voice call; where, after establishment of said call, a further user input message is received and where a current function of a user input element identified in said further message indicates a service provided by a second service provider, if said state of said telephone is not incompatible with said function, sending a control message to said telephone to establish said service provided by said second service provider.
According to another aspect of the invention, there is provided a method of managing a telephone connected to a data network, comprising: based on user input messages from said telephone, establishing a voice call; based on one or more user input messages from said telephone received during pendency of said voice call, setting up at least one non-telephony data service between said telephone and at least one data source, at least where said at least one data service does not conflict with said voice call.
According to yet a further aspect of the invention, there is provided a method of remotely managing a telephone connected to a data network, comprising: based on a user input message received from said telephone over said data network, retrieving a first configuration data structure for said telephone which correlates user input elements of said telephone with functions; based on at least one further user input message received from said telephone over said data network, retrieving a second configuration data structure for said telephone which correlates at least some user input elements of said telephone with functions different from those of said first configuration data structure.
According to yet a further aspect of the present invention, there is provided a method of remotely managing a telephone over a data network, comprising: receiving indications from said telephone over said data network; based on said indications, activating a plurality of data services on said data network; determining an active one of said plurality of data services and sending control messages to said telephone over said data network so that said telephone can provide said active data services; and based on further indications received from said telephone over said data network, sending control messages to said telephone to establish a voice call.
In another aspect, the invention comprises a computer readable medium storing computer executable instructions which, when loaded by a computing device connected to a data network to which at least one telephone is also connected, adapts the computing device to undertake methods of this invention.
BRIEF DESCRIPTION OF THE DRAWINGS
In the figures which illustrate example embodiments of the invention,
FIG. 1 is a schematic diagram of a telephony system made in accordance with this invention,
FIG. 2 is a functional block diagram of the software architecture for an IT of FIG. 1,
FIG. 3 is a functional block diagram of a portion of the system of FIG. 1 detailing the software architecture for the NI,
FIG. 4 is a functional block diagram detailing a portion of FIG. 3,
FIG. 5 is a process flow diagram, and
FIG. 6 is another process flow diagram.
DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS
Referring to FIG. 1, a telephony system 10 comprises a private IP network 12 connected to an NI 14, ITs 16 a, 16 b, 16 c, a data service 11, a telephone service 13, a public switched telephone network (PSTN) gateway 18, and a public IP network 19. PSTN gateway 18 connects to a PSTN 20. The public IP network 19 may include an IT 16 d, a data service 21 and a telephony service 23. The private IP network could be in the nature of a local area network (LAN), such as an ethernet, or a wide area network (WAN). The public IP network could be an internet. The NI is software which executes on a processing entity 15 comprising a central processing unit, memory and a network interface. The processing entity may be a personal computer (PC), network server, or other general computer resource which may or may not be dedicated to running the NI. The processing entity may be loaded with the NI from any computer readable medium, such as disk 17, a tape, or a memory chip. Also, the NI may be down loaded from a remote source on the private or public IP network. Optionally, the processing entity 15 may be a dedicated processor, memory, and network interface into which the NI is embedded.
The IT reacts to events generated by a user (e.g., key presses, hook switch transitions) and reports these to the NI by sending IP messages over the private IP network in accordance with an elemental control protocol described hereinafter. The IP messages are transported using the IP protocol suite (specifically, messages are transported over a reliable user datagram protocol—UDP—layer). The NI, which implements the functional model of the IT, reacts to these events and controls the function of the terminal (user interface, visual/audio feedback, audio hardware control etc.) by sending elemental control messages to the IT. Using this approach, the IT software design can be static but the functional model of the IT may change, as new features and services become available, by simply changing the functional IT emulator software in the NI. This removes design complexity in the IT. Because the IT does not execute industry evolving functional protocol stacks locally (e.g. H.323), the IT does not become obsolete as new versions of the protocols evolve. All evolving protocol dependant software is maintained in the NI where software updates are handled easily. In this model, the NI acts as a proxy agent for the IT by converting messages received from the IT to appropriate standard protocol.
All of the keys of the IT are “soft keys”, that is, the keys can be assigned a function within the NI. This facilitates the provision of, along with telephony services, services not usually associated with a telephony device, such as access to live or archival audio programming available over the IP network (e.g., REAL AUDIO™), stock quotation updates, and web browsing.
The architecture for each IT is illustrated in FIG. 2. Turning to FIG. 2, the hardware of an IT 16 comprises a digital signal processor (DSP) 24, a text display 26, a set of keys (and a hookswitch) 28, and an ethernet controller 30 (which includes a port to the private IP network). These devices interface with a processor 33 which maintains, for each of the devices, a software driver 44, 46, 48, and 50, respectively. An event originating at any of these devices passes to a software event interface 64, 66, 68, and 70 for the respective devices. The processor 33 may also establish a connection between the ethernet controller 30 and any of the other devices through an IP protocol stack 75. An event queue 74 receives inputs from the event interfaces and from a window manager 76 and outputs to an event dispatcher 78. The event dispatcher 78 outputs to functional element managers 80 and any associated stream handlers 82 created by the functional element managers. The stream handlers of the functional element managers are interconnected with the IP protocol stack 75 and they, through their functional element managers 80, output to the device drivers. The functional element managers also output to the window manager 76. Communication with the device drivers is through a real time operating system (RTOS) 84. The RTOS maintains the IP protocol stack 75 as well as software sockets 86 in the stack.
The DSP 24 is connected to speaker 90 and microphone 92 of handset 94 through a codec 96 (which is an analog-to-digital (A/D) and digital-to-analog (D/A) converter) and to handsfree speaker 97 and handsfree microphone 98 through codec 99.
Each functional element manager 80 is designed to control a particular hardware device, group of hardware devices, or a specific set of book keeping tasks. These managers interact directly with the NI via elemental control messages to provide a control entry point to the IT. The managers provide two major capabilities:
    • 1. They are responsible for parsing incoming elemental command messages from the NI and translating the high level messages into low level commands directed to specific hardware devices within the IT. The managers 80 control each of the hardware devices, other than the ethernet controller 30, via its corresponding device driver.
    • 2. They are responsible for monitoring internally generated events (keypad presses, software timeouts) and reformatting these into elemental control messages, which are sent to the NI.
The specific functional element managers are as follows: a broadcast manager; network manager; basic manager; key/indicator manager; audio manager; and display manager. The broadcast manager is used to broadcast commands to all of the hardware devices of the IT. The network manager provides terminal initialisation, network maintenance and encryption. The basic manager provides an interface to query the status and operating parameters of the IT (e.g., the NI may query a hardware identifier). The key/indicator manager is responsible for managing all of the keys, indicators and associated commands within the IT. Key press events, hook switch events, key/indicator status, icon states and LED cadencing are all governed by this manager. The audio manager is responsible for all aspects of the audio including path setup, audio stream setup, and path maintenance. The display manager controls the display of the IT.
The elemental control messages sent by the NI to the functional element managers and from the functional element managers to the NI follow IP and are, therefore, packetised messages. The protocol for the messages contemplated for each of the functional element managers 80 is set out in Appendix A.
The managers sit on top of the RTOS 84, which provides the hardware abstraction layer. In particular, the RTOS provides priority based scheduling of system tasks; consistent application programming interfaces (APIs) for low level driver abstraction; inter-task communications primitives and data memory management control; and a tightly integrated transport control protocol/internet protocol (TCP/IP) stack, through which the ethernet driver 50 is controlled. While not preferred, optionally, the RTOS may be replaced by a simple task manager. In such case, the functional element managers would require greater sophistication in order to handle the different APIs of the various device drivers.
Below the RTOS sits the physical hardware drivers. If a piece of hardware changes, only the driver for that hardware and the respective event interface will need to change. Hardware can therefore be added or removed without impacting the rest of the software. The drivers are generally designed to be aware of two types of data—signalling events and media streams—and provide a separate API for each.
While all drivers except the ethernet driver 50 are controlled by the functional element managers, the ethernet driver 50 is controlled by the RTOS through the IP protocol stack 75. All functional element manager communication with the ethernet driver 50 is therefore done indirectly by opening a socket 86 at one of the IP protocol layers 75 (e.g., a simple IP socket or a datagram-based UDP socket). Data from the functional element managers thus passes through an opened socket, down the IP protocol stack to the ethernet driver; conversely, the ethernet driver 50 passes received data to the IP stack, up to the socket API layer such that the element manager that had opened the socket will receive the data.
There is only one event queue 74 and all internal and external events (elemental control messages) are placed in that event queue. This ensures that all events acted upon by the IT will be processed based on order of arrival. Media streams, on the other hand, bypass the event queue, as described hereinafter.
The window manager 76 intercepts all incoming elemental control messages. The purpose of the window manager is to allow the IT to be responsive to commands from more than one NI (and, as described hereinafter, in some instances to facilitate start-up). However, at any point in time, only one NI's commands are directed to the hardware resources. While a particular NI is controlling the IT resources, it has complete control of the IT (no resource sharing with other NIs). To gain access to a different NI, the user must activate that NI via the window manager. This forces the IT to switch the hardware resources to the newly activated NI providing a window to the IT.
As the user switches from NI ‘A’ to NI ‘B’, NI ‘A’ no longer has control of the IT resources and must be informed of this condition. The IT uses the “suspend Connection with Server” command from the elemental control message protocol for this purpose. Similarly, the IT uses “Resume Connection with Server” message to ‘start’ or ‘resume’ the session with NI′B′. NI′B′ uses this message as a signal to refresh the display and other IT hardware components as required.
As stated above, only one NI has access to the IT resources at a given time. There may be situations, however, when it is necessary for one of the “suspended” NIs to inform the IT of a special event. An example would be the reception of an incoming call on a suspended server. To allow the disconnected NI to inform the IT, and hence the user, of an important event, thereby allowing the user to decide how to handle the event, the elemental control message protocol provides the “Server Alarm” message. The “Server Alarm” message allows a disconnected NI to signal an event and a text string to the IT. The IT decodes the event, and informs the user of the pending event. The user may then decide to accept or reject the event. Upon reception of the event, the IT would suspend the current NI and switch to the new NI via “Suspend Connection with Server” and “Resume Connection with Server” messages as described above. If the user elects to reject the event, then the terminal sends a “Resume Connection with Server” message to the current NI to inform it that it needs to refresh the display.
One final capability of the elemental control message protocol, related to the handling of multiple NIs, is the ability to reserve a ‘block’ of UDP port numbers. In the IP domain, the media streams associated with voice and or video are typically transported using UDP. The setup of the media streaming with the far end device is performed by the NI on the IT's behalf. However, the IP stack is operated locally by the IT. As different NIs are added to the IT's list of supported NIs, there is no guarantee that a given UDP port number is available for a call setup session. To allow a given NI to guarantee that the negotiated UDP port is available on the IT, the NI must have previously reserved the UDP port via the “Reserve UDP Port Block” message. The IT responds with the “Reserve UDP Port Block Report” message. Once a successful message exchange has taken place, the IT will guarantee that the reserved port numbers are not given out to other NIs.
The architecture for the NI is illustrated in FIG. 3. Turning to FIG. 3, NI 14 comprises an elemental control message event router 102 which receives inputs from ITs 16 a, 16 b, 16 c over the private IP network 12 and outputs to terminal emulators 110 a, 110 b, 110 c. A terminal boot server 104 and an associated operations, administration, and maintenance (OA&M) manager 105 are connected for two-way communication with the private IP network 12 and with a terminal emulator manager 106. The terminal emulator manager manages the terminal emulators. The terminal emulators are connected for two-way communication with the private IP network 12 on lines 114 and also output to the network through elemental control message formatter 108. The NI also includes configuration data structures 112. Each configuration data structure correlates key codes with functions and, optionally, with text (or graphics) which explain the functions. Each configuration data structure also includes information sufficient to allow the launching of a service proxy for each of the functions.
A terminal emulator 110 is detailed in FIG. 4. Turning to FIG. 4, emulator 110 comprises a number of service proxies 112 a, 112 b, 112 n. Each service proxy comprises a service plug-in 116 which is connected for two-way communication with the private IP network on a line 114. The service proxies output to a context manager 120. The context manager is connected with an elemental control message driver 122. Elemental control message driver 122 receives inputs from the elemental control message router 102 and outputs to the elemental control message formatter 108.
The context manager includes a state memory 121 which stores current state data for the IT emulated by the terminal emulator. The “state” of the IT is the current status of elements of an IT, for example: “on hook”; “off hook”; “call on handset”; “call muted on handset”; “handsfree speaker connected”. The context manager also has a memory 123 for a current configuration data structure.
When an emulator 110 is first launched, it will have no service proxies. However, as further explained hereinafter, service proxies are launched as required based on information in the current configuration data structure in memory 123. The service proxies may be proxies for providing telephony or data services available at processing entity 15, over the private IP network 12 (such as services 11 and 13), or over the public IP network 19 (such as services 21 and 23). For example, service proxies may provide basic telephony call services, a call messaging service, a directory number locating service (such as an LDAP—light weight Directory Access Protocol—service, which is described in IETF publications 1777, 1778, and 1823), a direction finding service (such as MAPQUEST™), a stock market quotation service, an audio program service, and a personalized service.
Referencing FIGS. 1 to 4, when an IT 16 a is first plugged into the private IP network 12, the network manager of the IT (which is one of the functional element managers 80), using the dynamic host configuration protocol (DHCP) tries to find an NI. An appropriate message is therefore sent by IT 16 a to the NI. The terminal boot server 104 of the NI recognises this message and prompts the terminal emulator manager 106 to launch a terminal emulator 110 a for IT 16 a. When terminal emulator 110 a is launched, it looks to the configuration data structures 112 for an initial configuration data structure to associate with IT 16 a. The configuration data structure is copied to memory 123 of the context manager 120 for the terminal emulator and will correlate each of the keys of IT 16 a with a function and may also correlate keys with text (or a graphic) describing one of the functions. The NI then constructs elemental control reply messages to the IT 16 a which include commands to control elements of the IT. For example, the display of the IT 16 a could be written with text (or graphics) from the configuration data structure for the function of keys of the IT.
If the DHCP is not available then, when an IT is first plugged in, it defaults to a temporary user input state where the window manager 76 is responsive to input from the keypad 28. Thus, a user may, via keypad 28, input an IP address for the IT and an IP address for an NI (as will be appreciated by those skilled in the art, the user may also be required to input an IP address of a gateway and a sub-net mask). Once this has been keyed in, the IT sends a “new IT” message to the NI IP address which was keyed in. This prompts the addressed NI to launch a terminal emulator, retrieve an initial configuration data structure for the new IT, and construct a reply message. When the IT receives the reply message, the window manager switches out of its temporary user input state.
All hardware devices generate events. In operation, if, say, a key is pressed on the key pad 28 of IT 16 a, this key event is sensed by key pad driver 48. The key pad driver, recognising this as a signalling event, signals the key event interface 68. Only one event interface is supported per driver and the output of all of these processes is sent to the centralised event queue 74. Once the key event propagates through the event queue to the event dispatcher 78, the event dispatcher dispatches it to the key/indicator functional element manager 80. This functional element manager then formulates an elemental control message, opens a socket 86 on the IP protocol stack 75 and passes the elemental control message to the socket where it is passed down to the ethernet controller 30 for transmission to the NI.
Similarly, if an elemental control message is received from the NI by the ethernet controller, it is passed up to the event queue 74 where it propagates through to the event dispatcher 78. The event dispatcher then dispatches the elemental control message to the appropriate functional element manager 80 for action.
To ensure that the audio media streams incur the minimal amount of delay while propagating through the system, the driver APIs are designed to allow the media to bypass the event queue and event dispatcher and instead communicate directly with a stream handler 82 registered with the driver. The handling of a media stream begins with the NI sending appropriate elemental control messages to request processing of a new media stream. The audio functional element manager would then start a new process, a stream handler 82, to perform the stream processing task. If, for example, the elemental control message from the NI requested processing of an audio stream from a voice call, the functional element manager for the DSP 24 would open two stream handlers 82: one for receive stream processing and one for transmit stream processing. The receive stream handler would open a socket for the incoming stream of audio packets and the transmit stream handler would open a socket for an outgoing stream of audio packets. Both stream handlers would register the process identifier with the DSP driver. The audio stream arriving at the socket opened by the receive stream handler would pass directly to the receive stream handler where it would be sent on to the DSP driver 44 with the appropriate stream identifier. The driver would pass the audio stream to the DSP 24 which decompresses it; the stream is then converted to analog audio at codec 96 or 99 and passed to a speaker 90 or 97 of the IT. The DSP 24 also compresses audio received from a microphone 92 or 98 of the phone after the audio is digitised by codec 96 or 99. The DSP driver, upon reception of this audio data corresponding to a given stream identifier, signals the registered transmit stream handler matching the stream identifier; the transmit stream handler then reads the data from the DSP driver. Thus, more than one stream handler per driver can register for media streams.
When a media stream is originated from the IT to the outside world, the stream handler responsible for managing the media stream opens, maintains and closes the required socket and hence writes the media packets directly to the socket.
The flexibility of the system described is illustrated in the following examples.
Referencing FIG. 1, assume on power-up of IT 16 a, in response to the DHCP message from the IT, the NI 14 launched a terminal emulator 110 a for IT 16 a that retrieved an initial configuration data structure for the IT which, amongst other designations, designates (i) one key of IT 16 a as a mute key to mute a transmit path, as is standard in telephony for a mute button, (ii) another key to request specialised call services, (iii) a further key to request telephone directory information, (iv) another key to request (street) directions, (v) another key to request stock market quotations, (vi) a key to request a specific audio program (such as a radio station), (vii) a key as a “quit” key for use in quitting a service, and (viii) keys to designate digits. The mute button and digit keys are typically permanently so identified on IT 16 a. The “quit” key may also be permanently marked. For the other noted soft keys, the configuration data structure includes data which the NI uses to control the text display 26 of the IT 16 a to indicate the function of these keys.
Now referencing FIG. 5 along with FIGS. 1 through 4, if a user of IT 16 a wished to place a call to IT 16 c, she may first lift the handset of the IT 16 a. This results in the key/indicator manager of IT 16 a sending an “Off hook” elemental control message to the NI (S400). The elemental control message event router 102 of the NI receives this message then passes a request to the appropriate terminal emulator, here emulator 110 a. The request passes up through elemental control message driver 122 and context manager 120 of emulator 110 a to a service proxy, say 112 b, for handling basic call service (the proxy being launched, if necessary). The service proxy sends commands back down through the context manager and elemental control message driver so that the elemental control message formatter 108 is driven to generate a “Stream Based Tone On” message with appropriate parameters (S402) to cause the audio manager of the IT to turn on a dial tone. At this point, the NI considers the IT to be in an “off hook” state.
Next the user may press a digit key on the key pad. This results in a “key event” message to the NI which includes the key code for the key which was pressed (S404). The NI collects the digit, echoes the digit back to the IT 16 a for display in a “Display Data Write” message (S406) and sends a “Stream Based Tone Off” message to turn off the dial tone (S408). Next the user may dial a series of digits, resulting in a like series of “Key Event” messages to the NI (S410, S412) and a like series of “Display Data Write” messages from the NI (S411, S413) to cause the IT to display these digits. Once the basic call service proxy 112 b of the NI has collected a series of digits representing a called station on the private IP network, it obtains the IP address of the called station, here IT 16 c. The service proxy 112 b of the NI then queries the state memory 121 of emulator 110 c for IT 16 c to determine the state of IT 16 c. If IT 16 c is in an on hook state, the NI may then initiate the call with IT 16 c by sending a “Transducer Based Tone On” message to IT 16 c (S416) with appropriate parameters to cause the audio manager of IT 16 c to generate a ring cadence. The NI also sends such a message to IT 16 a (S418) causing IT 16 a to generate a ring back tone. If the user of IT 16 c takes the phone off-hook, then IT 16 c sends an “Off Hook” message to the NI (S420) causing the NI to send a “Stream Based Tone Off” message to IT 16 a (S422) so that the ringing tone at IT 16 a ceases and also sends a “Stream Based Tone Off” message to IT 16 c (S424) so that the ringing cadence at IT 16 c ceases. The NI then sends (i) a “Connect Transducer” message (S425, 427) and (ii) an “Open Audio Stream” message to each of IT 16 a and IT 16 c (S426, S428) so that (i) either the handset 94 or the handsfree speaker 97 and microphone 98 are connected at each IT and (ii) a voice session is set up between the phones. Thereafter each IT will send an “Open Audio Stream Report” message to the NI (S430,432) and IP media stream packets will flow directly between the two phones (S434).
Say, during the course of the call, the conversation turned to stock prices. The user of IT 16 a could press the key designated to provide stock market quotations. This would result in a “key event” message being sent to the NI (S440) which is routed by router 102 to terminal emulator 110 a. Emulator 110 a refers to the current configuration data structure in memory 123 to access a service proxy application corresponding with the key code in the received “key event” message, in the current example, this is a stock quote service proxy application. The emulator 110 a then launches this service proxy as, say, service proxy 112 a. Proxy 112 a then negotiates a connection with the server (i.e., the data source) providing this stock quote service, which server may be located on public data network 19. The remote server then addresses packets of characters to the NI 14. Emulator 110 a of the NI then sends a “Display Data Write” message to IT 16 a (S442) to pass the characters to the IT 16 a for display. Thus, while continuing the voice call with IT 16 c, the user of IT 16 a may receive stock quotation information (which may occupy a portion of the display of the phone).
When the user of IT 16 a requests connection to a stock quotation source, this could prompt the context manager 120 of emulator 10 a to look up a new configuration data structure for IT 16 a which would assign a different function to certain of the keys of the IT. For example, the star and pound keys on either side of the 0 key could be re-assigned to a “scroll up” and “scroll down” function, respectively. The NI could then send a “Display Data Write” message to the IT so that the phone display indicates this new function of these keys. Then, when the user pressed either of these keys, the NI, on receiving a “key event” message, would send an appropriate IP message to the remote server to request the next, or previous, page of information. In response, the remote server would send new packets of characters causing the NI to re-write the display of the IT 16 a with the new characters using a Display Data Write message.
To end the voice call, IT 16 a may be placed on hook. This results in an “On Hook” message being sent to the NI (S446). This prompts the NI to send a “Close Audio Stream” message to each of IT 16 a and 16 c (S448, S450). Thereafter, an “On Hook” message may be received from IT 16 c (S452). To end the stock market quotation service, the user may press the “quit key” resulting in a “Key Event” message to the NI (S454). The NI responds with a “Clear Field” message to IT 16 a (S456) to cause the portion of the display used for the stock quotation information to be cleared. Internally, emulator 10 a of the NI would either suspend or terminate the stock market quotation proxy 112 a.
Turning to FIG. 6 along with FIGS. 1 through 3, with IT 16 a idle, the user of IT 16 a may now decide she wishes to listen to the radio station indicated on the display as associated with a soft key. The user therefore presses this key resulting in a “Key Event” message being sent to the NI (S600). In response, the emulator 110 a of NI 14 launches an audio program service proxy, say 112 b, which negotiates a connection between a remote server which is the source for the appropriate audio program and IT 16 a. Meanwhile, the emulator 110 a sends a “Connect Transducer” message to IT 16 a (S602) indicating the new media stream should be directed to the handsfree speaker 97 and an “Open Audio Stream” message (S604) to launch a receive stream handler which opens a socket for the incoming audio program packets from the remote server and directs them to the DSP driver. Additionally, the pressing of the audio program key causes the emulator 110 a to retrieve a new configuration data structure for IT 16 a which re-assigns the function of the mute button on the IT so that its function is to mute the receive path of the handsfree audio transducers rather than the transmit path. Thus, if someone enters the office of the user of IT 16 a, the user may press the mute button to send a “Key Event” message to the NI (S606); the NI responds with a “Mute/Unmute” message with a parameter causing the IT to mute the receive path (S608). The user of the IT may then conduct a conversation with the visitor and, thereafter, again press the mute key, so that the NI send a “Mute/Unmute” message with appropriate parameters such that the receive path for the audio program is again unmuted (S610, S612).
When the user wishes to stop listening to the audio program, she may end the service by pressing the “quit” key on the IT resulting in an “Key Event” message to the NI (S614). The NI responds with a “Connect Transducer” message which disconnects the handsfree speaker of the phone (S616) and a “Close Audio Path” message to shut down the stream handler and associated socket for the audio program (S618). Thereafter, the NI retrieves the previous configuration data structure for IT 16 a so that the function of the mute button is internally re-assigned whereby it can be used to change the state of the IT to mute the transmit path.
If, while the user is listening to an audio program a call for IT 16 a reached the NI, the NI would send one or more Display Data Write messages to the IT 16 a to emulate a pop up window announcing the call (preferably with caller information) and asking the user to press a certain key to indicate that she wishes to take the call. This may be accompanied with a message which would result in a brief alerting tone at the IT. The NI retrieves a new configuration data structure for the IT which includes an assignment of one of the keys to an indication that the call is to be taken. If the user did not press this key, once the caller hung up, the NI would clear the pop up window and restore the previous display contents. If the user did press the key, then the NI may suspend or terminate the audio program session and connect through the call, as afore described. Optionally, a second key could indicate that the call was to be taken and the audio program continued. If the user pressed this key, the NI sets up the voice call on the handset 94, keeping the audio program on the handsfree speaker 97. By deciding upon whether to interrupt the user, the NI may provide for a prioritisation of services.
If, while the IT was busy with a voice call on, say, the handset 94, the user pressed the telephone key which is associated with a display message indicating an audio program (e.g., radio station), a “Key Event” message would be sent to the NI. Recognising the current state of the phone as busy with a voice call, the NI would recognise providing the new audio stream would potentially conflict with the voice call. Consequently, the NI sends a notification to the user. For example, the NI could highlight the usage conflict in a Display Data Write message. Also, the NI retrieves a new configuration data structure for the IT which re-assigns one key of the phone as a “warning override” key. The user could override the warning with the appropriate key press in which case the audio stream for the audio program is set up over the handsfree speaker 97, as described in conjunction with the example of FIG. 6. However, in this instance, the NI may assign a special key for the function of muting the handsfree speaker 97, leaving a mute key to mute the voice call in the standard fashion.
From the foregoing, it will be apparent that the IT may simultaneously deal with audio streams from different sources. Indeed, the user could even take two separate voice calls at the IT: one on the handset and one on the handsfree speaker and microphone. In such instance, should a key be pressed requesting an audio program, the NI could either ignore the key event message as there is no way to provide this service without conflicting with the existing voice calls or could display options to the user for dealing with the conflict.
As previously mentioned, another exemplary proxy which may be run on the terminal emulator is a directory number locator proxy which may be used to find telephone numbers over the public IP network. If a user of IT 16 a requested a search for a directory number (by pressing the appropriate key), the NI would launch a directory number locator proxy 112 a in terminal emulator 110 a. Possibly, this would also cause the NI to retrieve a new configuration data structure for the IT 16 a and send a “Display Data Write” message to the IT to display new functions for certain of the keys of the phone which would facilitate a user's use of the directory finding service. For example, the digit keys could be re-assigned to represent letters so that the user could key in a name. If the user entered a last name, the NI could respond with a list of “hits” through “Display Data Write” messages and retrieve another configuration data structure for the IT 16 a which assigns new functions to certain keys to allow handling of the list. One of these new functions could be a “copy” function which may be used to copy information from one data service to another. Thus, in this instance, a user could copy a name from the list of “hits” to, say, a personal address book in a call messaging service. Each configuration data structure tailored to a particular service will normally still provide keys by way of which the user could request other services. If the user pressed a key to request stock market quotations, this would cause the NI to launch a stock market quotation proxy 112 b in emulator 1110 a and, possibly, retrieve another new configuration data structure for the phone and overwrite portions of the display to indicate new key functions according to this new configuration data structure. In this way, the last function key which is pressed sets the current configuration data structure for the phone, and a user could “toggle” amongst services. Thus, a number of proxies may run on the terminal service emulator 110 a simultaneously but only the proxy most recently requested by a key press is the active proxy, the other proxies are in the background. From this it will be apparent that the NI provides an aggregation of services for the ITs, including many services not normally associated with a telephone.
The described text-based services were assumed to provide packets of characters to the NI. Some services, such as web pages on the world wide web, forward a file written in hypertext mark-up language (HTML) which file typically prompts down loading of further files to allow construction of a web page. To accommodate such services, the IT 16 may be provisioned with a graphics display along with an associated graphics driver and graphics event interface. Additionally, the ITs are provisioned with a graphics manager and the elemental message protocol is enhanced by the provision of graphics manager elemental control messages. This manager and the new messages will be very similar to the display manager and the display manager elemental control messages. Thus, the protocol will include a “Graphics Data Write” message similar to the “Display Data Write” message.
When a user requests a graphical service which uses the hypertext transfer protocol (HTTP), the NI will receive the HTML file and download necessary additional files to construct the web page. The NI will then encapsulate web page information in “Graphics Display Write” messages to cause the web page to be written to the graphical display of the IT. In so doing, the NI may also retrieve a new configuration data structure for the IT which will assign keys different functions, such as functions to navigate through the web page or request a hyperlink. If, for example, the NI receives “Key Event” messages indicating a hyperlink has been requested, the NI down loads information from the appropriate source(s) and updates the graphical display of the IT with new information received.
With a graphics capable display, if the IT also included a new functional element manager 80 for the display, namely, a video manager, then the NI could control the display in the same manner as it controls the audio transducers, provided the elemental control protocol were enhanced with suitable additional commands. More particularly, the configuration data structure for an IT 16 b could assign one key to a request for a video program (such as a close captioned news program). Were this key on IT 16 b pressed, the NI would launch an appropriate proxy in emulator 110 b which would negotiate a connection between a remote server providing this video service and IT 16 b. The NI would also send an appropriate elemental control message to IT 16 b which results in the video manager of IT 16 b opening a receive stream handler, registering it with the display driver and opening a socket 86 on the IP stack 75. Thereafter, when the video stream reaches the ethernet controller 30 and is passed up to the socket, it is received by the receive video stream handler and passed down to the display driver. It will therefore be apparent that the user of IT 16 b could, while continuing with a voice call, view, for example, a close captioned news service.
The various proxies which may be launched in the terminal service emulator are written so as to be compatible with the protocol of the service provided on the remote server. These different protocols are therefore transparent to the ITs.
Since all of the keys of the IT are soft keys, the IT may display text in association with each of its keys which includes function information provided by the NI. Alternatively, certain keys found on the IT, such as hold, mute, handsfree, volume control, screen navigation, and headset on/off keys, may be permanently labelled as such. Notwithstanding, these permanently labelled keys are soft keys since their function is assigned at the NI. Thus, their function may be re-assigned where necessary (such as described in conjunction with the foregoing example in respect of the mute key). The ability to control all of the keys on the telephone ensures that the NI may provision the ITs with a variety of services, without conflicts amongst the services and without conflicting with voice calls.
While it is preferred that all of the keys of each IT are soft keys, the system of this invention could function even if some keys of an IT were “hard wired”. For example, the mute key of an IT could be hard wired to mute the transmit path of the phone. In such instance, were a user to request an audio program service, the NI could still allow muting of the receive path through assigning this function to a soft key on the phone.
While the user input elements of the telephone have been described as keys (and the hook switch), it will be appreciated that the telephone could equally have other user input elements, such as a touch screen (i.e., a screen where x and y co-ordinates are obtained from a touch sensitive matrix) and proximity or motion detectors. If so, appropriate protocol messages would log signalling “events” from these devices. Also, while the functions have been described as associated with single keys, it could be that the NI requires a series of key presses on the part of a user to request a function.
The DSP in each IT provides data compression. If the bandwidth of the network is sufficiently great, or if compression is accomplished in some other manner (such as with a network transcoder), the DSPs may be omitted.
The configuration data structures 112 (FIG. 3) may be different for each IT. Thus, the configuration data structures may be based on user profiles. In this way, different phones on the private IP network may request services from a different set of services.
The NI may also provide the functional emulation for IT 16 d on public IP network 19. Also, the NI could be directly connected to the public IP network 19 instead of to a private IP network and may provide the functional emulation for any ITs connected directly or indirectly to the public IP network.
While the multi-service telephony system has been described in the context of an IP data network, the system could be adapted to function in the context of data networks following other data protocols. For example, rather than sending packetised data, the data network could employ a synchronous transfer mode for data.
In the described system, the intelligence for the operation of the IT is located in the NI. The functional model for the IT resides in the NI and the user interface is projected onto the IT using the elemental control protocol. This model results in a slight delay at the IT whenever a key is pressed as a key event message must pass up to the NI and a response message must return from the NI to the IT before the IT takes action consequent on the key press. In most instances, this slight delay is entirely acceptable. In the case of receive volume adjustments, this delay is not preferred. Consequently, the elemental control message protocol allows the NI server to configure the terminal for local, receive volume control. This is accomplished using several messages.
A two-mode operation scheme allows the NI to specify whether the terminal has direct control over active-path volume adjustment or if the NI will assume control over the adjustments. The two modes are defined as follows:
    • “Remote Mode”: The NI controls all volume adjustments. The terminal forwards volume key events to NI to be interpreted, then the NI instructs the terminal to adjust the active volume register accordingly.
    • “Local Mode”: The Terminal controls all volume adjustments directly. The terminal still forwards volume key events (if enabled), but the terminal interprets the volume key events and increments or decrements the active volume register directly.
The NI can instruct the terminal to operate in either mode, by setting the “Adjust Volume” and “Automatic Adjustable Rx Volume Report” options of the “Audio Manager Options” elemental control message. If the “Adjustable Rx Volume Report” option of the “Audio Manager Options” message is enabled, the terminal will send an “Adjustable Rx Volume Report” message each time after a volume key is pressed by the user. This report informs the NI that the volume has been adjusted and indicates whether one of the rails (min./max. volume) has been reached. This provides a clean interface for NI visual feedback of user volume adjustments when the IT handles the volume control locally.
The NI uses the “Change Adjustable Rx Volume” message to adjust an active path receive volume when local volume control handling has been disabled. The NI uses the “Adjust Default Rx Volume” message to change the default receive volume levels when a user is adjusting default volume levels from, for example, an options list. As will be noted from the protocol, the NI may set audio parameters for the handset or handsfree transducers (headset, where extant) in an audio parameter bank (APB) download message. The “Select Adjustable Rx Volume” message can be used by the NI to set or change the active APB volume register. This is useful when multi-path calls are configured and the user wishes to adjust the volume of a specific register (i.e. receive volume register associated with a specific APB).
There is also a situation where maintaining the functional model for the IT solely in the NI would be unnecessarily burdensome, namely, in implementing timers. There are many user interface features that require a time-out function to expire if no user activity is detected for a certain period of time. An example of such a feature is the viewing of a caller's list. When the user enters the list, as each new item is viewed, a timer is started. If the timer expires before the next list item is viewed, or the list is exited (signalled by a ‘Quit’ key press), the system will automatically exit the list and revert back to the ‘Idle’ display screen. The concept of a ‘time-out if no key press’ feature is very simple. This, along with the undesirability of maintaining possibly thousands of timers in the NI, one per each terminal, lead to a elegant solution: Perform the timer feature in the terminal and send back time-out notifications to the NI to ensure that the NI is in-sync and in control of the user interface.
The “User Activity Timer” message is used to turn on or to turn off a timer, which reloads when any key is pressed. If the timer expires, meaning no keys were pressed, then the terminal sends the “User Activity Timer Expired” message. The “User Activity Timer Download” command allows the NI to specify the time-out value.
Another timer which may be present in the IT is a local call duration timer. Also, an IT may have a local time and date display (set by the NI) and will locally manage the current NI to which it responds (through the window manager). There are text strings displayed in conjunction with each of these functions. In order to maintain language independence with this local functionality, the NI downloads text strings in the appropriate language, as follows.
The Call Duration Timer uses the time & date fields to display its information. The date field is used for displaying the Call Duration Timer label (i.e., a text string) that can be defined by the NI using the “Call Timer Label Download” command. By allowing the NI to download a separate label for this feature, the locally implemented feature remains language independent as the downloaded label may be implemented in any language.
The IT is configured to track the month field digitally, i.e. 1=January, 2=February, etc. However, to allow a text label to be used, while at the same time ensuring language independence, the terminal allows two month labels to be downloaded via the NI. These labels are applied to “this” month and “next” month. The terminal tracks the number of days per month and automatically switches to the next month at the appropriate time. The NI downloads the month labels via the “Month Labels Download” message.
The elemental control message protocol provides a message which allows the NI to download a text string (or optionally an icon/bit map etc. as graphical display capabilities are deployed) to be used as the server identification tag in the local user interface. The NI uses the “Server Identification Tag” message for this purpose.
An advantage of the elemental control message protocol is the control it provides the NI over the characteristics of audio at an IT. As discussed previously, the NI may control an IT to connect audio streams to a selected transducer pair (e.g., handset, headset or handsfree microphones and speakers). In addition, the NI may control parameters of an audio stream by assigning an Audio Parameter Bank (APB). The APB is a grouping of parameters that describes the characteristics of the audio stream. The IT provides several APBs. Each APB can be configured by the NI. When setting up an audio stream, the NI controls where the audio stream terminates (i.e. which transducer pair to use), and which APB to associate with the audio stream. An APB contains the following parameters:
    • RLR—Receive Loudness Rating.
    • SLR—Send Loudness Rating.
    • STMR—SideTone Masking Rating.
    • Transmit/Receive Filters.
    • Transmit/Receive Filter Gain Compensation (FGC).
    • Receive volume range (minimum/maximum volume).
    • Receive volume step size.
    • Default and current receive volume level as well as Return To Default (R2D) enable/disable switch.
    • AGC—Automatic Gain Control.
    • SWL—Switched Loss.
The NI configures these APB parameters using the following elemental control message commands:
  • “APB Download”, “Set APB's Rx Volume Levels”, “Adjust APB's Tx and/or STMR Volume Level”, “Frequency Response Specification”, “Voice Switching Parameter Download”, “Change Adjustable Rx Volume” and “Adjust Default Rx Volume.”
The elemental control message protocol allows the IT to implement handset detection algorithms and report the findings back to the NI via the “Handset Connected” and “Handset Disconnected” messages. This flexibility allows the terminal to detect specially designed handsets, for example extended frequency response handsets, and report this to the NI. The NI, upon receiving this message, could activate enhanced audio capabilities within the terminal to exploit the capabilities of the special handset. These enhanced audio capabilities could be used as a product differentiater in the market.
The elemental control message protocol allows the IT to be configured to switch to a new control protocol. Upon receipt of the “Protocol Switch” message from the NI, the terminal could be directed to start communicating using the newly specified protocol instead of the elemental control message protocol of Appendix A. This would allow one terminal to be built that could be compatible with several distinct control protocols.
The elemental control message protocol allows the NI to query the IT for a ‘copyright’ identification string. The NI queries the IT using the “Copyright” option of the “Query Network Manager” command. The IT responds with the “Copyright Report” message.
The amount of information to be presented to a user may exceed the visible area of the display for the IT. This may typically occur when viewing e-mail, directories, or incoming callers logs. To accommodate such situations, the elemental control message protocol provides for page scrolling. The NI may send a “page” of information via a “Page Download” message. The IT saves this “page” of information locally and presents the first portion of the page on the display. If a user uses a page scrolling key (such as a key on a navigation cluster, or another key assigned to this purpose by the NI), on receiving the resulting “Key Event” message, the NI responds with a “Page Scroll” message, causing the IT to scroll to another portion of the “page”.
The elemental control message protocol allows the NI the disable specific portions of the display via the “Disable Display Field” message. Once disabled, all writes to this portion of the display are saved in an off-screen buffer but are not visible on the screen. To enable the field, the NI sends a second the “Disable Display Field” message with the associated field bit enabled. Once enabled, the previously ‘hidden’ information is displayed on the screen.
Other modifications will be apparent to those skilled in the art.
APPENDIX A
Broadcast Manager
NI to IT Broadcast Commands
    • Logical Icon Update
    • Time and Date download
    • Set Default Character Table Configuration
      Logical Icon Update
The Logical Icon Update command is used for updating the state of a logical icon. The IT keeps a map of the association between logical and physical icons. When the state or cadence of a logical icon changes, the NI sends this command to update the corresponding physical icon with the new state and cadence.
Parameters: Logical Icon specifies logical ID of icon to be updated
ID
Icon State specifies desired state of icon
Icon Cadence Off
On
Flash
Flicker
Wink
Twinkle
Blink
Downloadable cadence

Time and Date Download
The Time and Date Download command is used to set the IT's time and date. This new time and date will overwrite the current time and date data stored in the IT. The command contains the year, month, day, hours, minutes and seconds. All numbers are expressed in hexadecimal.
Parameters:
    • Year
    • Month
    • Day
    • Hour
    • Minute
    • Second
      Set Default Character Table Configuration
This command downloads the default character table configuration that the display manager uses. It specifies the mapping of the character tables to graphics tables and it also specifies which one of the graphics table is to be lock-shifted (code A0 to FF hex).
IT to NI Broadcast Commands
    • None
      Network Manager
The Network Manager is responsible for configuring and maintaining the network connections between the NI and the IT.
NI to IT Network Manager Commands
    • Soft Reset
    • Hard Reset
    • Query Network Manager
    • Network Manager Options
    • Control Channel QoS Configuration
    • Reserve UDP Port Block
    • Server Identification Tag
    • Set RTCP Source Description Items
    • Protocol Switch
    • Download Backup Server Information
    • Server Switch
    • Server Alarm
      Soft Reset
The Soft Reset command is sent by the NI to reset the IT as well as the accessory ports. This command is intended to reset the IT data structures to their default states.
Hard Reset
The Hard Reset command is sent when the NI wants to fully re-initialize the IT to its power-up default state.
Query Network Manager
The Query command is used to request the status or information from the Network Manager.
Parameters: Diagnostic requests the diagnostic info command to be
sent to the NI.
Managers requests the Manager's ID command to be
sent to the NI.
Attributes requests the Attributes Info command to be
sent to the NI.
RTCP requests the RTCP stats to be sent to the NI.
Options requests the Options status command to be sent
to the NI.
Copyright requests the Copyright report containing a
copyright string.
Sanity requests the IT to reply with a Sanity OK
response. This insures that the IT is alive and
well.

Network Manager Options
This command updates the programmable options supported at the IT by the Network Manager.
Parameters: Diagnostics Enables or disables automatic
diagnostic data transmission
Reliable UDP Enables or disables reliable UDP layer
for control channel

Control Channel QoS Configuration
This command is used tell the IT which QoS features to make use of when communicating with the NI.
Parameters: Type Of Service Enable Enables ToS field of command
ToS Minimize delay
Maximize throughput
Maximize reliability
Minimize monetary cost
Normal service
Precedence Routine
Priority
Immediate
Flash
Flash override
Critical
Internetwork control
Network control

Reserve UDP Port Block
The NI uses this command to force the IT to reserve a continuous block UDP ports. Once the ports are successfully reserved the NI can make use of them without fear of interfering with other servers controlling the IT. The command contains the number of ports to reserve and a starting port number. The IT will reply to this command with the Reserved UDP Ports Report stating how many ports were successfully reserved and the starting port number. The NI could use those reserved port numbers to open audio streams for example.
Parameters: Number of UDP Number between 1 and 255 which
ports to reserve indicates the number of UDP ports that
the NI wants to reserve.
Starting UDP Indicates the number of the first UDP
port number port of the block of ports to reserve.
When set to 0×00, the IT chooses the
starting UDP port.

Server Identification Tag
This command is used by the NI to download a character string oriented tag which identifies the server. The IT could place this information on the display to identify the active server for the user.
Set RTCP Source Description Items
This command is used by the NI to configure the different source description items that are part of the SDES report of the RTCP protocol.
Parameters: Source Description Name used to descibe the IT e.g.
“Homer Doe's IT”
E-mail address associated with the IT
Phone number of the IT
Geographic location of the IT
IT software version
Notice/Status information

Protocol Switch
The NI sends this command to an IT that supports multiple protocols to force it to change control protocols. The other protocols that the IT supports could have a similar command to enable a switch-back to UNIStim.
Parameters: Protocol ID An identifier for different protocols

Download Backup Server Information
This command is used by the NI to download network-related information regarding backup servers into the IT. Note this command supports the download of info for several backup servers.
Parameters: Server ID Server identifier, used to reference a specific
backup server per the following parameters.
Server Port Port number an identified server uses for
Number UNIStim channel.
Server IP IP address of the identified server.
Address

Server Switch
The NI sends this command to force the IT to stop accepting UNIStim commands from the current server and start listening to the server specified in the command. This command assumes that the IT has been made aware of the new server's network address in the configuration process or through the Download Backup Server Information.
Parameters: Server ID Server identifier, used to reference a specific,
previously identified server

IT to NI Network Manager Commands
    • Soft Reset Ack
    • Sanity OK
    • Network Manager Attributes info
    • Network Manager Diagnostic Info
    • Manager IDs
    • Network Manager Options Report
    • Resume Connection With Server
    • Suspend Connection With Server
    • Reserved UDP Ports Report
    • Copyright Text
      Soft Reset Ack
The Soft Reset Ack command is sent to the NI after the IT has been reset via the reception of the Soft Reset command. The command will be transmitted only after a successful reset has been performed.
Sanity OK
The Sanity OK command is used in response to a Query Sanity command. It indicates that the IT can still receive and transmit from/to the NI.
Network Manager Attributes Info
This command is used in response to the Query Network Manager (Attributes) command generated from the NI. The IT replies by sending the Network Manager Attributes.
Parameters: Supported List of protocols supported, by protocol
Protocols identifier

Network Manager Diagnostic Info
The Diagnostic Info command is sent after it has been requested by the Query Network Manager (Diagnostic) command or when an error occurs and the Diagnostic Command transmission has been enabled via the Network Manager Options command.
Parameters: RXBUFOVF Rx Buffer Overflow
TXBUFOVF Tx Buffer Overflow
RXBEMPTY Rx Buffer Empty
INVALMSG Invalid Command Received

Manager IDs
This command is sent from the IT after reception of the Query Network Manager (managers) command from the NI. The IT replies with a list of all managers contained in the IT with the exception of the Network Manager and the Broadcast Manager. A flag, for each manager, indicates if the manager is active or inactive. The format of the command is as follows.
Parameters: Managers List of managers supported by the IT
Active Active/Inactive indication for each manager

Network Manager Options Report
This command is sent after reception of the Query Network Manager (Options) command. It sends the setup of the options to the NI.
Parameters: Diagnostics Automatic diagnostic data transmission
enabled or disabled
Reliable UDP Reliable UDP layer for control channel
enabled or disabled

Copyright Report
This command is used to respond to the Query Network Manager (Copyright) request from the NI. It provides the copyright information as an ASCII string.
Resume Connection With Server
The IT sends this unsolicited command to inform the NI that it is ready to accept commands from NI. The transmission of this command can either be triggered by a power-up or by a user choosing to connect to a new NI after power-up.
Suspend Connection With Server
The IT sends this unsolicited command to inform the NI that it will disconnect itself from the NI. The transmission of this command is normally triggered by a user choosing to connect to a different NI. Typically, this is the last command that the NI will receive from the IT until the user chooses to switch back to the NI.
Reserved UDP Ports Report
This command is sent to inform the NI of the UDP ports that have been reserved as a result of the Reserve UDP Port Block command. The command payload reports the number of UDP ports reserved as well as the number of the first UDP port of the reserved block.
Parameters: Number reserved Number between 1 and 255 which
UDP ports indicates the number of UDP ports that
are reserved by the IT. A ‘0’ in this
field means that the command failed.
First UDP Port Indicates the number of the first UDP
of block port of the reserved block.

Basic Manager
The Basic manager handles the IT maintenance functions.
NI to IT Basic Commands
    • Start Selftest
    • Query Basic Manager
    • Basic Manager Options
    • General Read/Write
    • EEprom Write
    • Encapsulate Command
      Start Selftest
The start selftest command is used for running a selftest in the IT. The self tests are device specific. This message requires that the secure code of the IT be set using the Basic Managers Options (Secure Code) command.
Query Basic Manager
The Query command is sent by the NI. It is used to request the status or information from the Basic manager.
Parameters: Attributes requests the Attributes Info command to be
sent
Options requests the Options Status command to be
sent
F/W version requests the F/W version command to be
sent
H/W ID requests the IT H/W ID command to be sent
(serial number, color and the release number)
IT Type requests the IT Type command to be sent
Selftest requests the Selftest Result command to be
sent
PEC requests the Product Engineering Code
command to be sent

Basic Manager Options
This command updates the programmable options supported by the IT's Basic manager.
Parameters: Secure Code Enables or disables the secure code for
critical messages

General Read/Write
This command allows direct read or write access to the devices (EEProm, microprocessor, etc . . . ) of the IT. For the write operation, the SECURE CODE flag must be set through the Basic Manager Options (Secure Code) command. For a read operation, the data bytes must not be present in the command.
Parameters: Operation Read or Write
Device Hardware device identifier
Address address within the requested device
Data Data to be written in the case of a Write
operation

EEprom Write
This command allows specific EEprom data byte locations to be written by the NI. In order for this command to succeed, the secure code must be set through the Basic Manager Options (Secure Code) command. This command allows access to EEprom data bytes, without having to know the exact location of the data in the EEprom.
Parameters: Element ID Dynamic EE Chksm
Static EE Chksm
PEC Index
Release Number
Color
Serial Number
Data Data bytes to be written to Element ID

Encapsulate Command
This command enables the NI to use UNIStim to encapsulate commands that belong to UNIStim or other protocols. For example, the NI could force the IT to send out a Key Event command by encapsulating it in the Encapsulate Command. This command could also be used to directly access resources (such as a DSP, VGA screen etc) in the IT without using a UNIStim command.
Parameters: Encapsulated Protocol Identifies protocol ID of
ID encapsulated protocol
Encapsulated Command Data corresponding to command
in identified protocol

IT to NI Basic Commands
    • Basic Manager Attributes Info
    • Basic Manager Options Report
    • F/W version
    • IT Type
    • Selftest result
    • General Read Response
    • Hardware ID
    • Product Engineering Code
      Basic Manager Attributes Info
This command is used in response of the Basic Manager Query (Attributes) command to inform the NI of both the EEPROM static and dynamic checksums. Both values are read directly from the EEPROM.
Parameters: Static Checksum Static Checksum of EEPROM
Dynamic Checksum Dynamic Checksum of EEPROM

Basic Manager Options Report
This command is sent after reception of the Basic Manager Query (Options) command. It sends the basic manager's options configuration to the NI.
Parameters: Secure Code Status Enabled or Disabled

F/W Version
This command is used in response to the Basic Manager Query (F/W version) command. The F/W version command contains the F/W version code of the IT's code.
Parameters: F/W Version 7 character ASCII string representing the
F/W Version

IT Type
The IT Type command is sent in response to the Basic Manager Query (IT Type) command from the NI. It is used to inform the NI on the type of IT.
Parameters: IT Type IT type identifier

Selftest Result
The result of each test performed during a selftest is given by this command. This command is send after reception of the Basic Manager Query (Selftest) command from the NI.
Parameters: Test ID An identifier for each test
Test Result A pass/fail indication for each test identified

General Read Response
This command is used in response to the General Read/Write command when a read operation is performed.
Parameters: Device Hardware device identifier
Address address within the requested device
Data Data read from the device.

Hardware ID
This command is sent in response to the Basic Manager Query (H/W ID) command. It provides the unique number that identifies the IT.
Parameters: Serial Number Unique serial number of the IT
Release Number HW release number of the IT
Colour Colour code of the IT

Product Engineering Code
This command is sent in response to the Query Basic Manager (PEC) command from the NI. It provides the Product Engineering Code of the IT.
Parameters: PEC Product Engineering Code for the IT

Key/Indicator Manager
The Key/Indicator Manager is the manager responsible for managing parameters associated with keys and the indicators on the IT.
NI to IT Key/Indicator Commands
    • LED Update
    • Query Hookswitch
    • User Activity Timer
    • Downloadable Free Form Icon Access
    • Query Key/Indicator Manager
    • Key/Indicator Manager Options
    • Logical Icon Mapping
    • Key Repeat Timer Download
    • Query LED State
    • Query IT Icon State
    • Indicator Cadence Download
    • User Activity Timer Download
    • Free Form Icon Download
    • IT Icon Update
      LED Update
The LED Update command is used to update the state and cadence of LEDs on the IT.
Parameters LED ID LED identifier
LED State Off
On
Flash
Flicker
Wink
Twinkle
Blink
Downloadable cadence
Note that cadence should be downloaded using Indicator Cadence Download before selecting Downloadable cadence as the LED State.
Query Hookswitch
The Query Hookswitch command is used to query the state of hookswitch on the IT. The IT must send back the Hookswitch State command in reply.
User Activity Timer
The User Activity Timer can be turned on and off using this command. The time-out value of the timer is defined using the User Activity Timer Download command. When the User Activity timer starts, if no key event happens (depression, repeat or release) in the IT before the timer times-out, the IT will send the User Activity Timer Expired command back to the NI. If at least one key event happens then the timer will reset and start the count down again until the User Activity timer is stopped.
Parameters: Start/Stop Starts or stops the timer

Downloadable Free Form Icon Access
The Downloadable Free Form Icon Access command is used to enable or disable the download Icon RAM bit map. This command allows ‘overloading’ the existing Free Form Icon ROM bit maps.
Parameters: Free Form Hard coded Free Form ROM bit map or
Icon Source downloaded Free Form RAM bit map

Query Key/Indicator Manager
The Query Key/Indicator manager command is used to request information about various states or information handled by the Key/Indicator manager.
Parameters: Options Requests the status of the option setting
Attributes Requests the information of the Key/Indicator
manager's Attributes.

Key/Indicator Manager Options
This NI uses this command to set the Key/Indicator manager options.
Parameters: Key Release Message Enable/Disable the transmission
of Key Event message with Key
Release flag set when a valid
key release occurs
Volume Key Message Enable/Disable the transmission
of Volume Key Event messages
Local Dial Pad Feedback No Feedback
Key Click
DTMF

Logical Icon Mapping
The Logical Icon Mapping command is used to define the relationship between physical and logical icons in the IT.
Parameters: Command Global NIL mapping
One-to-one mapping
Single mapping
Physical Icon ID Same as defined in the IT Icon Update
command
Logical Icon ID Logical ID to be assigned to the
specified Physical Icon

Notes:
    • 1) The Global NIL mapping command removes all the mapping between the logical icons and the physical icons.
2) The one-to-one mapping command is used to map the physical icon 0 with the logical icon 0, physical icon 1 with the logical icon 1 and so on.
    • 3) The single mapping command maps a single physical icon to a logical icon ID.
    • 4) The Physical and Logical Icon ID fields are not required when the Administration command is the Global NIL mapping or the one-to-one mapping.
      Key Repeat Timer Download
The Key repeat Timer Download is used by the NI to specify the time (first timer) before sending the key repeat command when the key remains depressed and also for specifying the time (second timer) to wait before sending all subsequent key repeat commands if the same key remains depressed.
Parameters: Key Repeat Initial Time Duration key must be pressed
prior to sending key repeat
command
Key Auto Repeat Interval Time interval between
successive key repeat commands
while key remains depressed

Notes:
    • 1) The key repeat function may not be supported on all keys
      Query LED State
The Query LED State command is used by the NI to extract LED state information from the IT.
Parameters: LED ID Specifies LED to be queried

Query IT Icon State
The Query IT Icon State command is used by the NI to extract IT icon state information from the IT.
Parameters: Physical Icon ID Specifies the physical icon to be queried

Indicator Cadence Download
The Indicator Cadence Download command is used to specify a new custom cadence that can be used to flash the icons and LEDs when using the downloadable cadence option in the LED Update and IT Icon Update commands.
Parameters: Cycle 1 On Time On duration for first cycle
Cycle
1 Off Time Off duration for first cycle
Cycle
2 On Time On duration for second cycle
Cycle
2 Off Time Off duration for second cycle
Cycle 3 On Time On duration for third cycle
Cycle 3 Off Time Off duration for third cycle
Cycle 4 On Time On duration for fourth cycle
Cycle 4 Off Time Off duration for fourth cycle
Notes:
    • 1) A maximum of four on-off cycles can be specified.
    • 2) Not all four cycles have to be used.
      User Activity Timer Download
The User Activity User Download command is used to download the time-out value used by the User Activity timer. This time-out value will be used when the user Activity is started by the User Activity Timer command. Upon receipt of the command the IT will restart the timer with the new time-out value.
Parameters: User Activity Duration of user activity timeout.
Timeout Value

Free Form Icon Download
This command is used to download a free form icon representation that is not already hard coded in the IT ROM. The command contains the ID of the downloadable icon, and the bitmap that represents the free form icon.
Parameters: Free Form Icon ID Identifier of downloaded icon
Icon Bitmap Data Bitmap data of icon representation

IT Icon Update
This command is used to change the current state and cadence of an IT icon. The IT icon will be updated with the new state and cadence only if the physical icon IS NOT mapped to a logical icon.
Parameters: Physical Icon ID specifies physical ID of icon to be
updated
Icon State specifies desired state of icon
Icon Cadence Off
On
Flash
Flicker
Wink
Twinkle
Blink
Downloadable cadence

IT to NI Key/Indicator Commands
    • Key Event
    • LED Status Report
    • On hook
    • Off hook
    • User Activity Timer Expired
    • Hookswitch State
    • Key/Indicator Manager Attributes info
    • Key/Indicator Manager Options Report
    • IT Icon Status Report
      Key Event
This command is used to report an event related to the keys. The event can be a key depression, key repeat or a key released.
Parameters: Key ID dial pad 0
dial pad 1
dial pad 2
dial pad 3
dial pad 4
dial pad 5
dial pad 6
dial pad 7
dial pad 8
dial pad 9
dial pad *
dial pad #
Navigation Up
Navigation Down
Navigation Right
Navigation Left
Quit
Copy
Volume Up
Volume Down
Hold
Release
Mute
Headset
Handsfree
Programmable Key 1 to N
Key Event Key released
Key depressed
Key Repeated

Notes:
    • 1) A number (N) of non specific “programmable” keys are supported
      LED Status Report
This command is sent to the NI in response to the Query LED State. It informs the NI on the state and cadence of LEDs.
Parameters LED ID LED identifier
LED State Off
On
Flash
Flicker
Wink
Twinkle
Blink
Downloadable cadence

On Hook
The On Hook command is sent to the NI when the IT detects an Off hook to On hook transition.
Off Hook
The Off Hook command is sent to the NI when the IT detects an On hook to Off hook transition.
User Activity Timer Expired
This command is sent to the NI when the User Activity timer times out. The actual time-out value for the User Activity Timer is specified by the User Activity Timer Download command.
Hookswitch State
This command is sent to the NI in response to the Query Key/Indicator Manager (Hookswitch) command.
Parameters: Hookswitch State On hook
Off hook

Key/Indicator Manager Attributes Info
This command is sent to the NI in response to the Query Key/Indicator Manager (Attributes) command and informs it of the attributes of the Key/Indicator manager. The format of the command is as follows.
Parameters: Programmable contains the number of programmable
keys keys on the IT
Soft Keys contains the number of soft keys on the IT
Headset Key indicates existence of a Headset Key on
the IT
Mute Key indicates existence of a Mute Key on the
IT
Quit indicates existence of a Quit Key on the IT
Copy indicates existence of a Copy Key on the
IT
Message indicates existence of a Message Waiting
Waiting Indicator on the IT
Indicator
Navigation none
keys two
four

Key/Indicator Manager Options Report
This command is sent to the NI in response to a Query Key/Indicator Manager (Options) command. It sends the Key/Indicator Manager's options configuration to the NI.
Parameters: Key Release Message Enabled/Disabled
Volume Key Message Enabled/Disabled
Local Dial Pad Feedback No Feedback
Key Click
DTMF
The options are set via the Key/Indicator Manager Options command.
IT Icon Status Report
This command is used in response of the Query Key/Indicator Manager (Icon State) command. It informs the NI of the state of icons.
Parameters: Physical Icon specifies physical ID of icon to be queried
ID
Icon State specifies state of icon
Icon Cadence Off
On
Flash
Flicker
Wink
Twinkle
Blink
Downloadable cadence

Audio Manager
The Audio manager is the entity that manages every aspect of the audio configuration of the IT. The main tasks of the manager are to configure the loss plan and tones, setup voice paths and establish end-to-end voice connections.
NI to IT Audio Commands
    • Query Audio Manager
    • Query Supervisor Headset Status
    • Audio Manager Options
    • Mute/unmute
    • Transducer Based Tone On
    • Transducer Based Tone Off
    • Alerting Tone Configuration
    • Special Tone Configuration
    • Paging Tone Configuration
    • Alerting Tone Cadence Download
    • Special Tone Cadence Download
    • Paging Tone Cadence Download
    • Transducer Based Tone Volume Level
    • Alerting Tone Test
    • Visual Transducer Based Tones Enable
    • Stream Based Tone On
    • Stream Based Tone Off
    • Stream Based Tone Configuration
    • Stream Based Tone Frequency Component List Download
    • Stream Based Tone Cadence Download
    • Select Adjustable Rx Volume
    • Set APB's Rx Volume Levels
    • Change Adjustable Rx Volume
    • Adjust Default Rx Volume
    • Adjust APB's Tx and/or STMR Volume Level
    • Query APB's Tx and/or STMR Volume Level
    • ABP Download
    • Open Audio Stream
    • Close Audio Stream
    • Connect Transducer
    • Frequency Response Specification
    • Biquad Download
    • Voice Switching Configuration
    • Query RTCP Statistics
    • Vocoder Configuration
    • Jitter Buffer Configuration
      Query Audio Manager
The Query Audio Manager command is used to request various status or information from the Audio manager.
Parameters: Attributes requests the Attributes of the Audio manager
Options request the option setting of the Audio
manager
Alerting requests the Alerting selection (warbler rate
and cadence)
Adjustable requests the IT to send the Adjustable Rx
Rx Volume Volume Information command.
APB Default requests the IT to send the Default Rx
Rx Volume Volume of the specified APB
Handset requests the handset status
Headset requests the headset status
APB number specifies the APB for the APB Default Rx
Volume query

Query Supervisor Headset Status
This command is used to query the connection status of the supervisor headset.
Audio Manager Options
This command updates the programmable options supported by the Audio manager.
Parameters: Volume Adjustment Remote: volume adjusted by the NI
Local: volume adjusted by IT
Volume Adjustment Enable/Disable the transmission of
Reports volume adjustment reports when
volume keys are depressed
Headset Rfeature Enable/Disable the transmission of
Key Message Headset Rfeature Key message when
key event is detected on headset
interface.

Mute/Unmute
This command is used to mute/unmute Rx and Tx streams.
Parameters Stream ID Identifies stream to mute/unmute
Direction Rx
Tx
Mute Function Mute
Unmute

Notes:
    • 1) A single command can be used to change the mute setting of many streams at once by replicating the parameters of the command as many times as required.
      Transducer Based Tone On
This command is used to turn on one of the transducer based tone (alerter, paging or special tone). The association between a transducer based tone and a transducer is done using the Alerter Tone Setup, Paging Tone Setup and Special Tone Setup commands of the audio manager. Some of these tones may be mutually exclusive.
Parameters: Transducer based Tone Alerting
ID Special Tones
Paging Tones
Attenuation Downloaded tone volume level
Downloaded tone volume level-2

Transducer Based Tone Off
This command is used disconnect a transducer based tone from its associated transducer.
Parameters: Transducer Based Tone ID Alerting
Special Tones
Paging Tones

Alerting Tone Configuration
This command is used to configure the various parameters that are associated with the Alerting tone. Through this command the alerter tone's volume range, warbler effect, cadence and transducer routing can be configured.
Parameters: Warble Select Specifies the warble to use with the
alerting tone
Tone Volume Number of steps from the maximum tone
Range volume value, which is set by hardware.
Transducer Handset Speaker
Routing Headset Speaker
Handsfree Speaker
Cadence Select cadence 0
cadence 1
cadence 2
cadence 3
cadence 4
cadence 5
cadence 6
downloadable alerter tone cadence

Special Tone Configuration
This command is used to configure the various parameters that are associated with the special tone. Through this command the special tone's volume range, cadence and transducer routing can be configured.
Parameters: Tone Volume Number of steps from the maximum tone
Range volume value, which is set by hardware.
Transducer Transducer to which the special tone will
Routing be routed when turned on.
Handset speaker
Headset speaker
Handsfree speaker
Cadence Select cadence 0
cadence 1
cadence 2
cadence 3
cadence 4
cadence 5
cadence 6
downloadable special tone cadence
Special Tone Selects the frequencies that make up the
Content special tone

Paging Tone Configuration
This command is used to configure the various parameters that are associated with the paging tone. Through this command the paging tone's volume range, cadence and transducer routing can be configured.
Parameters: Tone Volume Number of steps from the maximum tone
Range volume value, which is set by hardware.
Transducer Transducer to which the special tone will
Routing be routed when turned on.
Handset speaker
Headset speaker
Handsfree speaker
Cadence Select cadence 0
cadence 1
cadence 2
cadence 3
cadence 4
cadence 5
cadence 6
downloadable paging tone cadence

Alerting Tone Cadence Download
The Alerting Cadence Download command is used by the NI to download an alerting cadence in the IT. This new Alerting Tone cadence will be used the next time the IT receives the Tone On (Alerting Tone) command if this tone is set to use the downloadable cadence (see Tone Cadence Select command).
Parameters: Cycle 1 On Time On duration for first cycle
Cycle
1 Off Time Off duration for first cycle
Cycle
2 On Time On duration for second cycle
Cycle
2 Off Time Off duration for second cycle
Cycle 3 On Time On duration for third cycle
Cycle 3 Off Time Off duration for third cycle
Cycle 4 On Time On duration for fourth cycle
Cycle 4 Off Time Off duration for fourth cycle

Notes:
    • 1) A maximum of four on-off cycles can be specified.
    • 2) Not all four cycles have to be used.
      Special Tone Cadence Download
The Special Tone Cadence Download command is used to download a Special Tone cadence in the IT. This new Special Tone cadence will be used the next time the IT receives the Tone On (Special Tone) command if this tone is set to use the downloadable cadence (see Tone Cadence Select command).
Parameters: Cycle 1 On Time On duration for first cycle
Cycle
1 Off Time Off duration for first cycle
Cycle
2 On Time On duration for second cycle
Cycle
2 Off Time Off duration for second cycle

Notes:
    • 1) A maximum of two on-off cycles can be specified.
    • 2) Not all two cycles have to be used.
      Paging Tone Cadence Download
The Paging Tone Cadence Download command is used to download the configuration for the paging tone. The command is used to specify the tone frequency and On/Off duration of all the tones that make up the paging tone. This new Paging Tone cadence will be used the next time the IT receives the Tone On (Paging Tone) command if this tone is set to use the downloadable cadence (see Tone Cadence Select command).
Parameters: Cycle 1 Paging Specifies the tone frequencies to be
Tone Content used in the first cycle
Cycle
1 On Time On duration for first cycle
Cycle
1 Off Time Off duration for first cycle
Cycle
2 Paging Specifies the tone frequencies to be
Tone Content used in the second cycle
Cycle
2 On Time On duration for second cycle
Cycle
2 Off Time Off duration for second cycle
Cycle 3 Paging Specifies the tone frequencies to be
Tone Content used in the third cycle
Cycle 3 On Time On duration for third cycle
Cycle 3 Off Time Off duration for third cycle

Notes:
    • 1) A maximum of three paging tone cycles can be specified.
    • 2) Not all three cycles have to be used.
    • 3) The paging tone frequency content is specified for each cycle
      Transducer Based Tone Volume Level
The Transducer Based Tone Volume Level command is used to specify the volume level for different transducer based tones. The volume is defined in steps from the lowest level of the volume range. If the volume level specified in the command is outside the volume range, the upper boundary of the range will be used as the new volume level.
Para- Transducer Based Tone ID Alerting
meters: Special Tones
Paging Tones
Tone Volume Specifies tone volume from lowest
level of volume range

Alerting Tone Test
The Alerting Tone Test command is used to start the alerting tone on the IT without changing the current selection of alerting. This command is usually used when the user selects the type of alerting. Only the warbler can be selected.
Parameters: Warble Select Specifies the warble to use with the
alerting tone

Visual Transducer Based Tones Enable
This command is used to configure the IT with respect to providing visual tones feedback when it receives the Transducer Based Tone On command.
Parameters: Visual Tones Enable/Disable Visual Tones

Stream Based Tone On
This command is used to inject a stream based tone into an audio stream. The actual parameters that define the stream based tone specified in the command can be set using the Stream Based Tone Configuration command which is used to bind a cadence and a frequency component list with the tone.
Para- Stream Based Identifies the stream based tone to be injected
meters: Tone ID in audio stream
Stream ID Identifies the stream in which to inject the
stream based tone
Direction Rx
Tx
Tone Level Volume level at which the tone should be
played out, in steps from minimum.

Stream Based Tone Off
This command to stop the injection of the specified stream based tone in the specified audio stream.
Para- Stream Based Identifies the stream based tone to be stopped
meters: Tone ID in audio stream
Stream ID Identifies the stream in which to inject the
stream based tone should be stopped
Direction Rx
Tx

Stream Based Tone Configuration
This command is used to bind one of the 32 stream based tone cadences and one of the 32 frequency component lists with a stream based tone. The next time the stream based tone referred to in the command is turned on through the Stream Based Tone On command, it will use the cadence and frequency component list specified in this command. The actual cadences and frequency component lists can be modified through the Stream Based Tone Cadence Download and the Stream Based Tone Frequency Component List Download.
Parameters:
Stream based Tone ID Stream based tone to bind with cadence
in frequency component list specified
in the command.
Stream based Tone Cadence ID Cadence to use next time stream based
tone specified in command is turned on.
Stream based Tone Frequency Frequency components to use next time
Component List stream based tone specified in
command is turned on.

Stream Base Tone Frequency Component List Download
This command is used to reconfigure one of the 32 frequency component lists available for stream based tones.
Para- Frequency Specifies the frequency of the first component
meters: Component 1
Frequency Specifies the frequency of the second
Component
2 component
Frequency Specifies the frequency of the third component
Component 3
Frequency Specifies the frequency of the fourth
Component 4 component

Notes:
  • 1) A maximum of four frequency components can be specified.
  • 2) Not all four components have to be used.
    Stream Based Tone Cadence Download
This command is used to reconfigure one of the 32 cadences available for stream based tones. The command specifies up to four On/Off duration pairs.
Parameters: Stream based Cadence to use next time stream based
Tone Cadence tone specified in command is turned on.
ID
Cycle
1 On Time On duration for first cycle
Cycle
1 Off Time Off duration for first cycle
Cycle
2 On Time On duration for second cycle
Cycle
2 Off Time Off duration for second cycle
Cycle 3 On Time On duration for third cycle
Cycle 3 Off Time Off duration for third cycle
Cycle 4 On Time On duration for fourth cycle
Cycle 4 Off Time Off duration for fourth cycle

Notes:
  • 1) A maximum of four cycles can be specified.
  • 2) Not all four components have to be used.
  • 3) If the off time of cycle 1 is not specified, the stream based tone will be played until it is turne off through the Stream Based Tone Off command.
    Select Adjustable Rx Volume
This command is used to select the Rx volume that will be affected by the Change Adjustable Rx Volume command.
Parameters: Adjustable Rx Volume none
Audio Parameters Bank 1
Audio Parameters Bank 2
Audio Parameters Bank 3
Audio Parameters Bank 4
Audio Parameters Bank 5
Audio Parameters Bank 6
Audio Parameters Bank 7
Alerting
Special Tones
Paging Tones

Set APB's Rx Volume Levels
The Set APB's Rx Volume Level command is used to specify the new Current Rx Volume for the specified APB. The command can also force the Default Rx Volume to be changed to the specified Current Rx Volume by setting the Default flag. The volume level is specified as an offset in number of steps from the system RLR for the path specified APB. This command will override volume control adjustments done by the user. This command is intended to be used by the system to convey volume control adjustments made by the user in list based option controls.
Para- APB number none
meters: Audio Parameters Bank 1
Audio Parameters Bank 2
Audio Parameters Bank 3
Audio Parameters Bank 4
Audio Parameters Bank 5
Audio Parameters Bank 6
Audio Parameters Bank 7
RLR Offset Indicates whether the offset is a positive or a
Direction negative offset with respect to the APB's
system RLR.
Update Default Specifies whether the default volume for the
APB should be updated
Rx Volume Specifies the volume offset in steps to be
Level Offset applied to the APB's system RLR.

Change Adjustable Rx Volume
This command is used to increase or the decrease the receive volume selected through the Select Adjustable Rx Volume command by one step within the limits of its loss plan. This command is used when the volume adjustments are performed by the NI instead of locally in the IT.
Parameters: Down One step quieter
Up One step louder

Adjust Default Rx Volume
This command is used to increase or decrease the Defalut Rx Volume value of the specified Audio Parameters Bank (APB) or transducer based tone by one step within the limits of its loss plan. This command should be used when the user increases or decreases the default Rx volume from an option list. Also notice that this command will only change the default Rx volume and not the system default value which is the RLR (downloaded via the Receive Loudness Rating command) so the loss plan will not be changed with this command.
Where Down One step quieter
Up One step louder
Default Rx Volume to Change none
Audio Parameters Bank 1
Audio Parameters Bank 2
Audio Parameters Bank 3
Audio Parameters Bank 4
Audio Parameters Bank 5
Audio Parameters Bank 6
Audio Parameters Bank 7
Alerting
Special Tones
Paging Tones

Adjust APB's Tx and/or STMR Volume Level
The Adjust APB's Tx and/or STMR command is sent by the NI to allow Tx and STMR volume adjustments for different transducer types. It is used to adjust the APB's Tx or STMR volume level, either increasing or decreasing it by one step. The adjustment enable bits allow the NI to adjust both Tx and STMR volumes with a single command. Alternatively, either the STMR or Tx volumes can be adjusted individually. This command is intended to be used for multi-vendor headset configuration.
Para- APB number none
meter Audio Parameters Bank 1
Audio Parameters Bank 2
Audio Parameters Bank 3
Audio Parameters Bank 4
Audio Parameters Bank 5
Audio Parameters Bank 6
Audio Parameters Bank 7
STMR Volume STMR volume increase/decrease by
Increment Direction one increment
STMR Volume Adjust Enables/Disables volume adjustments
Enable to be made to the STMR path
Tx Volume Increment Tx volume increase/decrease by one
Direction increment
Tx Volume Adjust. Enables/Disables adjustments to be
Enable made to the Tx path

Query APB's Tx and/or STMR Volume Level
The Query APB's Tx and/or STMR command is sent by the NI to query the current STMR and/or Tx volume level settings. This command is intended to be used for multi-vendor headset configuration.
Parameters: APB number none
Audio Parameters Bank 1
Audio Parameters Bank 2
Audio Parameters Bank 3
Audio Parameters Bank 4
Audio Parameters Bank 5
Audio Parameters Bank 6
Audio Parameters Bank 7
STMR Volume Level requests STMR volume level
Request information from
audio manager
Tx Volume Level Request requests Tx volume level
information
from audio manager

ABP Download
This command is used to download all the audio parameters (such as loss plan) associated with a specific audio parameter bank. The new parameters will be used the next time a voice call involving the ABP is set up. This command uses flags to indicate the presence (or absence) of each audio parameter.
Parameters: APB number Audio Parameters Bank 1
Audio Parameters Bank 2
Audio Parameters Bank 3
Audio Parameters Bank 4
Audio Parameters Bank 5
Audio Parameters Bank 6
Audio Parameters Bank 7
Switched Loss Amount of Switched Loss used
by the Switching algorithm
Step Size The volume step size
Minimum Volume Minimum Volume relative to
the RLR
Automatic Gain Specifies if AGC is implemented
Control for this APB.
Maximum Volume Maximum Volume Relative to
the RLR
Receive Loudness The RLR to use for this APB
Rating
Return to Default Specifies if the volume control for
this APB is to operation in return
to default mode
Send Loudness Rating The SLR to use for this APB
Side Tone Masking The STMR to use for this APB
Rating

Open Audio Stream
This command is used to set up full or half-duplex end-to-end RTP voice sessions between the IT and an IP connected far-end. This command is also used to specify RTCP ports and DTMF support for the specified voice session.
Parameters: Rx Stream ID Tells the IT which stream it must use as
the destination of voice data originating
from the far end.
Tx Stream ID Tells the IT which stream it must use as
the source of voice data destined to the
far-end.
Rx Vocoder Type Specifies to type of vocoder to use to
decode the Rx Stream.
Tx Vocoder Type Specifies to type of vocoder to use to
encode the Tx Stream.
Frames per Specifies how many audio frames are
Packet contained in a single UDP packet
ToS Minimize delay
Maximize throughput
Maximize reliability
Minimize monetary cost
Normal service
Precedence Routine
Priority
Immediate
Flash
Flash override
Critical
Internetwork control
Network control
Tx DTMF This bit is used to indicate whether or
not DTMF key pressed information will
be transmitted as part of the voice
session.
Rx DTMF This bit is used to indicate whether or
not DTMF key pressed information will
be received as part of the voice session.
IT RTP Port Local UDP port to use for transmitting
and receiving voice data.
IT RTCP Port Local UDP port to use for transmitting
and receiving RTCP control messages.
An RTCP port of “zero” means that the
audio stream does not have an RTCP
channel and that the Far-End RTCP
port field is a “don't care”.
Far-End RTP Port Far-end UDP port to/from which the
voice data should be sent/received.
Far-End RTCP Far-end UDP port to/from which the
Port RTCP control messages should be
sent/received.
Far-End IP Specifies the IP address of the end
Address point that is at the other end of the RTP
connection.

Close Audio Stream
This command is used to kill audio voice sessions associated with the stream Ids specified in the payload of the command.
Parameters: Rx Stream ID Tells the IT which Rx stream it must
terminate
Tx Stream ID Tells the IT which Tx stream it must
terminate

Connect Transducer
This command is used to cross-connect the transducers specified in the command with a quantity of streams in an unit-directional or bi-directional fashion. The actual streams referred to in this command are created through the Open Audio Stream command. This command can also be used to assign an Audio Parameters Bank (APB) to the transducer pair designated in the command.
Parameters Transducer Pair Handset
ID Headset
Handsfree Speaker/Microphone
All Transducer Pairs
Stream ID ID of the stream to connect to the
transducer specified in the command.
Tx Enable Streams specified in the command are
connected the microphone of the
designated transducer pair.
Rx Enable Streams specified in the command are
connected the speaker of the
designated transducer pair.
APB Specifies if an APB is to be used in
conjuction with the specified
transducer pair
Sidetone Specifies if sidetone is enabled for
transducer pair specified in command
Destructive/ Specifies whether this command should
Additive augment or replace transducers that
were connected to the streams listed in
the command prior to its reception.
APB number none
Audio Parameters Bank 1
Audio Parameters Bank 2
Audio Parameters Bank 3
Audio Parameters Bank 4
Audio Parameters Bank 5
Audio Parameters Bank 6
Audio Parameters Bank 7

Frequency Response Specification
The Frequency Response Specification command specifies the filter building blocks to be used to implement the desired frequency response for a given transducer. The command is used by the IT to fill in a frequency response specification table, specifying which filters need to be set up for a given transducer. The Frequency Response Specification command contains a list of filter numbers which correspond to predefined filter building blocks in the IT. Each filter ID will program a predefined number of biquadratic sections (biquads). The biquad ID field specifies the first biquad to be used for implementing the filter.
The Filter Gain Compensation is sent as part of the Frequency Response Specification. The Filter Gain Compensation specifies a gain adjustment to compensate for any deviation from the Loudness Rating (LR) caused by the filter shape specified by the frequency response specification. Both the Rx and Tx FGC values must be provided each and every time this command is sent.
Parameters: Transducer ID Handset
Headset
Handsfree Speaker/Microphone
Rx Filter Count number of new filter in the Rx direction
Tx Filter Count number of new filter in the Tx
Starting BQ ID ID of the first biquad to use for
implementing the filter.
Rx/Tx Filter ID Filter Id as specified in the functional
description.

Notes:
    • 1) The number of Rx and Tx Filter ID bytes must match the filter count provided in the first data byte.
    • 2) Each filter occupies a certain number of biquads. The NI should know exactly the number of biquads each filter occupies in order to fill up the biquads in the IT correctly.
      Biquad Download
The Biquad Download command is used to adjust the IT frequency response by downloading new set of coefficients for a specific biquad. The next time the IT will program the biquads, it will use the new set of coefficients. The downloaded biquad can be selected using the Frequency Response Specification command. Each biquad takes five coefficients, B0, B1, B2, A1 and A2.
Parameters: Biquad ID Biquad Identifier
B0 Coefficient B0
B1 Coefficient B1
B2 Coefficient B2
A1 Coefficient A1
A2 Coefficient A2

Voice Switching Configuration
This command is used to download the voice switching parameters associated with a specific transducer. These parameters will be used the next time the voice switching is enabled.
Note that unlike the Connect Transducer command, there is no need for the Transducer Direction bit since the command specifies frequency responses for both the receive and transmit transducers. For each receive transducer specified in the Transducer ID field, the command will also be used to configure its transmit-side counterpart.
Parameters: Transducer ID Handset
Headset
Handsfree Speaker/Microphone
AGC Threshold Input threshold for application of AGC
Rx Virtual Pad Tx blocking margin of the switching
algorithm
Dialtone Input threshold for considering a
threshold dialtone
Tx Virtual Pad Rx blocking margin of the switching
algorithm
Echo Mute Enable/Disable talker echo muting
Enable
Dynamic Side- Enable/Disable sidetone variation based
tone Enable on noise floor

Query RTCP Statistics
This command is used by the NI to request RTCP data gathered in the media session associated with the stream ID specified.
Parameters: Stream ID ID of the stream to be queried
Stream Direction Rx
Tx
IT Packet Count Requests the total number of packets
sent by the IT in the session up to this
point
IT Octet Count Requests the total number of octets sent
by the IT in the session up to this point
Interarrival Jitter Requests an estimate of the statistical
variance of the delay between each
received media packets
Fraction Lost Requests the fraction of media packets
lost as reported in the last RTCP packet
Total Packet Loss Requests the total number of lost
packets since the beginning of the
media session

Vocoder Configuration
This command is used to configure parameters that are associated with the vocoder specified in the command. The command contains a field that identifies the vocoder to modify followed by a list of new parameter settings. Note that not all vocoders support the entire list configurable parameters.
Parameters: Vocoder Type Specifies the vocoder
on which to apply
the parameter settings
Direction Rx
Tx
Both
Voice Activity Detection Enable/Disable
Bad Frame Interpolation Algorithm Enable/Disable
Post Filter Enable/Disable
High Pass Filter Enable/Disable
Frame Size Specifies number of
bytes per frame

Jitter Buffer Configuration
This command is used to configure parameters that are associated with the jitter buffer of the specified stream.
Parameters: Stream ID ID of the stream to associated with the
jitter buffer to be configured.
Jitter Buffer Maximum number of frames in jitter
Maximum Size buffer beyond which uncontrolled
frame loss will occur.
Desired Jitter Desired number of frames in jitter
buffer. When controlled frame deletion
occurs, enough frames will be deleted
to reach this number.
High Water Mark Threshold number of frames in jitter
buffer at which point controlled frame
deletion will occur.

IT to NI Audio Commands
    • Handset connected
    • Handset disconnected
    • Headset connected
    • Headset disconnected
    • Supervisor Headset connected
    • Supervisor Headset disconnected
    • Headset Rfeature Key Pressed
    • Audio Manager Attributes info
    • Audio Manager Options Report
    • Adjustable Rx Volume Report
    • Adjustable Rx Volume Information
    • APB's Default Rx Volume Value
    • Alerting Tone Select
    • APB's Tx and/or STMR Response
    • RTCP Statistics Report
    • Open Audio Stream Report
      Handset Connected
The Handset Connected command is sent to the NI when a handset is detected in the handset port of the IT.
Parameters: Handset Type Specifies the type of handset detected

Handset Disconnected
The Handset Disconnected command is sent to the NI when the handset is disconnected from the handset port of the IT.
Headset Connected
The Headset Connected command is sent to the NI when a headset is detected in the headset port of a so equipped IT
Headset Disconnected
The Headset Disconnected command is sent to the NI when the headset is disconnected from the headset port.
Supervisor Headset Connected
The Supervisor Headset Connected command is sent to the NI when the supervisor headset is detected on the supervisor headset port of a so equipped IT.
Supervisor Headset Disconnected
The Supervisor Headset Disconnected command is sent to the NI when the supervisor headset is disconnected from the supervisor headset port.
Headset Rfeature Key Pressed
The Headset Rfeature Key Pressed command is sent to the NI in response to the IT receiving the predefined headset based fearture key event on the headset port. The transmission of this message is enabled by the Audio Manager Options (Headset Rfeature Key Message) command.
Audio Manager Attributes Info
This command is used in response of the Query Attributes command to inform the NI of all the attributes that the Audio manager has.
Parameters: Handsfree Handsfree supported
Supported Vocoders List of all vocoders supported by the
IT.

Audio Manager Options Report
This command is sent after reception of the Audio Manager Query (Options) command. It informs the NI of the Audio manager's option setup.
Parameters: Volume Adjustment Remote: volume adjusted by the NI
Local: volume adjusted by IT
Volume Adjustment Enable/Disable the transmission of
Reports volume adjustment reports when
volume keys are depressed
Headset Rfeature Enable/Disable the transmission of
Key Message Headset Rfeature Key message when
key event is detected on headset
interface.

Adjustable Rx Volume Report
This command is sent to the NI after a volume key has been depressed and the “Volume Adjustment Reports” option has been enabled via the Audio Manager Options command. The command shows which volume key has been depressed and if it caused the rx volume reach its “floor” or “ceiling”. The NI could use this information to display a visual representation of the volume adjustment to the user.
Parameters: Volume ID none
Audio Parameters Bank 1
Audio Parameters Bank 2
Audio Parameters Bank 3
Audio Parameters Bank 4
Audio Parameters Bank 5
Audio Parameters Bank 6
Audio Parameters Bank 7
Alerting
Special Tones
Paging Tones
Steam Based Tones
Vol. Down Indicates that the volume down key has
been depressed.
Vol. Up Indicates that the volume up key has
been depressed.
Floor Indicates that the volume setting of the
specified .volume register has
decreased to the “floor”
Ceiling Indicates that the volume setting of the
specified .volume register has increased
to the “ceiling”

Adjustable Rx Volume Information
This command is used to inform the NI of the active Rx volume register in the IT. It contains the APB or transducer based tone number, its current Rx volume setting and volume range as well as the floor ceiling indications. This command is sent generally after reception of the Query Audio Manager (Adjustable Rx Volume) command
Parameters: Active Volume ID none
Audio Parameters Bank 1
Audio Parameters Bank 2
Audio Parameters Bank 3
Audio Parameters Bank 4
Audio Parameters Bank 5
Audio Parameters Bank 6
Audio Parameters Bank 7
Alerting
Special Tones
Paging Tones
Stream Based Tones
Floor Indicates that the volume setting of
the specified .volume register is at its
“floor”.
Ceiling Indicates that the volume setting of
the specified .volume register is at its
“ceiling”.
Rx Volume Level Current setting of the specified
volume register.
Rx Volume Range Range of the specified volume
register.

APB Default Rx Volume Value
The Audio Parameters Bank Default Rx Volume Value command is used in response to the Query Audio Manager (APB Default Rx Volume) command. It gives the default Rx volume level of the specified APB. It contains the APB number, the default volume setting of the APB, the floor ceiling indicators.
Parameters: APB Identifier none
Audio Parameters Bank 1
Audio Parameters Bank 2
Audio Parameters Bank 3
Audio Parameters Bank 4
Audio Parameters Bank 5
Audio Parameters Bank 6
Audio Parameters Bank 7
Alerting
Special Tones
Paging Tones
Stream Based Tones
Floor Indicates that the volume setting of
the specified .volume register is at
its “floor”.
Ceiling Indicates that the volume setting of
the specified .volume register is at
its “ceiling”.
Default Volume Level Default volume of the specified
volume register.
Volume Range Range of the specified volume
register.

Alerting Tone Select
This command is used in response to the Query Audio Manager (Alerting) command. The alerting information as well as the warble rate selection are sent as part of this command. The format of the command as follows.
Parameters: Alerting Cadence Selection cadence 0
cadence 1
cadence 2
cadence 3
cadence 4
cadence 5
cadence 6
downloadable cadence
Warbler Select Specifies warble selected

APB's Tx and/or STMR Response
The Query APB's Tx and/or STMR response is sent by the IT in response to the corresponding query command. The response sent by the IT indicates the current STMR and/or Tx volume level setting for the specified APB number.
Parameters: APB number none
Audio Parameters Bank 1
Audio Parameters Bank 2
Audio Parameters Bank 3
Audio Parameters Bank 4
Audio Parameters Bank 5
Audio Parameters Bank 6
Audio Parameters Bank 7
Tx Vol Level current Tx volume level for the
specified APB
STMR Vol. Level current STMR volume level for the
specified APB

RTCP Statistics Report
This command is sent in response to the Query RTCP Statistics command sent by the NI.
Parameters: IT Packet Count Total number of packets sent by the IT
in the session up to this point.
IT Octet Count Total number of octets sent by the IT in
the session up to this point.
Interarrival Jitter Estimate of the statistical variance of
the delay between each received media
packet.
Fraction Lost Fraction of media packets lost as
reported in the last RTCP packet.
Total Packet Lost Total number of lost packets since the
beginning of the media session.

Open Audio Stream Report
The IT automatically sends this command to the NI after it receives an Open Audio Stream command. The command reports on the status of the stream created by the Open Audio Stream command.
Parameters: Status Code Stream opened successfully
Operation failed - RTP port not available
Operation failed - RTCP port not available

Display Manager
The main task of the display manager is to present the information sent by the NI on the LCD. The NI does not have to know the physical location of where the information is presented. Another big task of the display manager is to maintain the configuration tables for the multi-language character tables.
NI to IT Display Commands
    • Page Scroll
    • Restore Default Character Table Configuration
    • Display Backlight Control
    • Arrow
    • Query Status Bar Icon
    • Highlight On/Off
    • Restore Time and Date
    • Clear Time and Date
    • Call Duration Timer
    • Query Display Manager
    • Download Call Duration Timer Delay
    • Disable Display Field
    • Clear Field
    • Cursor Control
    • Page Download
    • Display Scroll with Data
    • Status Bar Icon Update
    • Month Label Download
    • Call Timer Label Download
    • Time and Date Format
    • Display Data Write
    • Context Info Bar Format
    • Set Default Character Table Configuration
    • Set Current Character Table Configuration
    • Special Character Download
    • Highlighted Field Definition
    • Contrast
    • Caller Log Download
      Page Scroll
This command is used to scroll up or down one page of display. This command assumes that the information of the page to scroll to is already downloaded in the IT.
Restore Default Character Table Configuration
This command is used to restore the character table configuration of the display to the one downloaded through the Set Default Character Table Configuration command. The G1, G2 and G3 tables will contain the character sets specified by the default configuration and one of the G table will be lock-shifted (code A0 to FF hex).
Display Backlight Control
This command is used to turn on and off the display backlight. This could be used in power saving mode when back lighting is supported by the IT.
Parameters: Backlight Turn Backlight on or off

Arrow
This command turns on or off the dedicated arrow fields on the display.
Parameters: Left Turn Left arrow on or off
Right Turn Right arrow on or off
Up Turn Up arrow on or off
Down Turn Down arrow on or off

Query Status Bar Icon
This command is used to query the state of a specific icon in the status bar. The IT will reply with the Status Bar Icon State command specifying the state of the queried icon.
Parameters: Status Bar Icon ID Specifies the status bar icon to be
queried

Highlight On/Off
This command is used to turn on or off the highlight on the display. When the highlight is turned on, the field that is specified by the Highlighted Field Definition command will be highlighted.
Parameters: Highlight Turn Highlight on or off

Restore Time and Date
This command is used to revert the effect of the Clear Time and Date and Caller Log Download commands by restoring the time and date in the time & date fields of the IT. The time and date or the call duration information, whichever was the last one active prior to receipt of a Clear Time and Date command or the Caller Log Download command, will be shown in the time and date field.
Clear Time and Date
This command clears the time and date fields and inhibits the update of the fields with the time and date information. The time and date information is still kept in the IT in case it is restored with a Restore Time & Date command.
Call Duration Timer
This command is used to configure the call duration timer. Through this command, the call duration timer can be started or stopped, reset, shown or hidden, with or without a delay.
Parameters: Function Start
Stop
Reset Resets the Timer
Display Show
Hide
Delay None
Action specified by Display bit
executed after Call Duration Timer
Delay

Query Display Manager
The Query Display Manager command is sent by the NI to request various status information from the Display manager. The format of the command is as follows.
Parameters: Attributes requests the Attributes Info
command to be sent.
TAD requests the Time and Date
Format command to be sent.
Cursor requests the Cursor Location
command to be sent.
Contrast requests the Contrast Level
command to be sent.
Backlight requests the Backlight Status
Info command to be sent.
Highlight requests the Highlight Status
command to be sent.
Current Character Table requests the Current Character
Table Configuration Status
command to be sent.
Default Character Table requests the Default Character
Table Configuration Status
command to be sent.

Download Call Duration Timer Delay
The Download Call Duration Timer Delay command is used to specify the delay to be used by the Call Duration Timer command when the Delay option is selected in the Call Duration Timer command.
Parameters: Call Duration Timer Delay specifies the delay duration of
call duration timer.

Disable Display Field
The Disable Display Field command is used to enable and disable fields of the LCD. When a field is disabled it becomes blank until it is re-enabled. However, if the NI writes data to a disabled field, the data will be stored in the IT and will become visible on the LCD once it is re-enabled. All fields that have their corresponding bit set will be disabled and all others with their bit cleared will be enabled.
Parameters: Numeric Enable/Disable Numeric Index Field in the Info
Bar
Context Enable/Disable Context Field in the Info Bar
Date Enable/Disable Date Field
Time Enable/Disable Time Field
Line X Enable/Disable Line X
Softkey Y Enable/Disable Softkey Y
All Enable/Disable all fields

Clear Field
This command is used to erase fields of the LCD. Many portion of the display can be cleared at the same time. Once a field is cleared, the data it contain ed is lost and cannot be re-displayed on the field unless re-downloaded by the IT.
Parameters: Numeric Clear Numeric Index Field in the Info Bar
Context Clear Context Field in the Info Bar
Date Clear Date Field
Time Clear Time Field
Line X Clear Line X
Softkey Y Clear Softkey Y
All Clear all fields

Cursor Control
This command is used to activate, configure and move the cursor on the display.
Parameters: Cursor Movement Set cursor at home (first character on
the first text line)
Set cursor at the specified position
within the specified field
Move the cursor by one to the left
Move the cursor by one to the right
Move the cursor a specified number
of positions to the left
Move the cursor a specified number
of positions to the right
Cursor State ON
OFF
Blink
Field Numeric
Line
SoftKey
Softkey ID The Softkey ID when field specifies
softkey
Line Number Line number when field specifies
line.
Character Position Position of the cursor in the specified
field (zero being the first position
within the field)
Position Delta Specifies number of positions left or
right to move cursor

Page Download
This command downloads portions of next up or next down page in the IT. A portion can be any field that characterizes the display, i.e., line, softkey, etc.
Parameters: Field Softkey
Line
Line Number Specifies line number when Line
field is specified
Softkey ID Specifies softkey when Softkey field
is specified
Character Position Specifies starting character position
when Line field is specified
Display Data Data to be written to specified field
and position

Display Scroll with Data
This command is used to download a new line of text and to scroll the others up or down. This command only affects the line fields of the display. This command cannot download more than one new line of text at the time.
Parameters: Scroll Direction Down: Place text data on first line and
scroll others down
Up: Place text data on last line scroll
others up
Display Data Data to be written

Status Bar Icon Update
This command is used to change to current state and cadence of a status bar icon.
Parameters: Status Bar Icon ID specifies the status bar icon to be
updated
Icon State specifies desired state of icon
Icon Cadence Off
On
Flash
Flicker
Wink
Twinkle
Blink
Downloadable cadence

Month Labels Download
This command is used to download the label for the current and next months. These labels are used in the date field and enable the date to roll over to next month.
Parameters: Current Month Label Text string representing current
month
Next Month Label Text string representing next
month

Call Duration Timer Label Download
This command is used to download the call duration timer label which will be displayed on the IT's display when the call duration timer is activated.
Parameters: Call Duration Timer Label Text string representing call
duration timer label

Time and Date Format
This command is used to specify the format that the Display manager will use to present the time and the date information to the user.
Parameters: Time Format 12-hour clock (e.g. 10:34pm)
French clock (e.g. 22h34)
24-hour clock (e.g. 22:34)
Date Format day first (e.g. 16Sep)
month first (e.g. Sep16)
numeric standard (e.g. 09/16)
numeric inverse (e.g. 16/09)

Notes:
    • 1) For the day-first and for the month-first formats, the month label has to be downloaded, via the Month Label Download command.
      Display Data Write
This command is used as a generic command for writing to the display. It is composed of four parts: the address, the control, the tag and the data. Three of these parts, the address, the control, and the tag, are optional. The display data part is mandatory. The address byte is used to specify where the text to write starts. If no address is specified, the data will start at the current cursor position. The tag field is used to give a meaning to the attached text (directory, CLID, etc.). The control field is used to control characteristics of the display. If the control field is not present, the default control setup will be used.
Parameters:
Address Field Numeric
Context
Line
SoftLabelKey
Softkey
Line Number Specifies line number when Line field
is specified
SoftLabelKey ID Specifies soft labelled key when Soft
Labeled Key field is specified
Softkey ID Specifies softkey when Softkey field is
specified
Character Position Specifies starting character position
when Line field is specified
Control Cursor Movement None
Cursor moves to end of new text
Clear Left Clears the text at the left of the active
position before writing the new text.
Clear Right Clears the text at the right of the active
position before writing the new text.
Shift Left Shifts text at the specified position to
the left when writing new text.
Shift Right Shifts text at the specified position to
the right when writing new text.
Highlight Highlights new text
Extended Height Displays new text in extended height
format
Tag Tag Data Non displayed data indicating purpose
of data
Data Display Data Data to be displayed per command

Context Info Bar Format
This command is used to specify the format of the Context Info bar field. The supported formats are the ones specified in the functional description of the IT in question.
Parameters: Format none
Underline
Overline
Marquee
Border
Reverse-video
Reverse-video with border
Field Numeric
Context
Date
Time

Set Default Character Table Configuration
This command downloads the default character map configuration that the display manager must use. It specifies the mapping of the character table to the graphics tables and it also specifies which one of the graphics table is to be lock-shifted (code A0 to FF hex).
Parameters: Default Character Table Data representing Default
Configuration character table configuration

Set Current Character Table Configuration
This command downloads the current character map configuration that the display manager must use. It specifies the mapping of the character table to the graphics tables and it also specifies which one of the graphics table is to be lock-shifted (code A0 to FF hex).
Parameters: Default Character Table Data representing Default
Configuration character table configuration

Special Character Download
This command is used to download special characters that are not specified in the character ROM tables of the IT. In the command, the special character address is specified as well as bitmap.
Parameters: Character ID identifies character to be downloaded
Bitmap Data data defining the character

Highlighted Field Definition
This command is used to highlight a portion of the display.
Parameters: Field Numeric
Context
Line
SoftKey
Line Number Line number when field specifies line.
Softkey ID The Softkey ID when field specifies
softkey
Starting Position Starting character position of the
highlighted portion.
Ending Position Ending character position of the
highlighted portion.

Contrast
This command sets the contrast level.
Parameters: Contrast Specifies contrast level to be set

Caller Log Download
This command is used to update the time and date fields with a downloaded time and text label instead of the usual time and date information.
Parameters: Hour Specifies hour
Minutes Specifies minutes
Text Label Text data to be written to the Date field

IT to NI Display Commands
    • Display Manager Attributes Info
    • Contrast Level Report
    • Cursor Location Report
    • Highlight Status On
    • Current Character Table Configuration Status
    • Default Character Table Configuration Status
    • Time and Date Format Report
    • Status Bar Icon State Report
    • Backlight Status
    • Highlight Status Off
      Display Manager Attributes Info
This command is used in response to the Query Display Manager (Attributes) command.
Para- Line Width The width of the text area lines expressed
meters: in characters
Lines Number of lines in the text area
Line Icon When set, it indicates that an icon is
associated with each line in the text area
of the display
Softkey Width The width of the softkeys expressed
in characters.
Softkeys Number of softkeys
Soft Labeled Key The width of the Soft-Labeled key area
Width expressed in characters.
Soft Labeled Keys Number of soft labeled keys
Context Field Width The width of the context field expressed in
characters.
Numeric Width Number of digit supported in the numeric
index field.
Time Width Number of Character supported in the time
field.
Date Width Number of Character supported in the date
field.
Character Download Number of downloadable characters.
Free Form Icon Number of downloadable free form icons
Download
Character sets List of supported character sets

Contrast Level Report
This command is used in response to the Query Display Manager (Contrast) command. It gives the current display contrast level. The level is set by the NI with the Contrast command.
Parameters: Contrast Level Current setting of display contrast

Cursor Location Report
This command is used in response to the Query Display Manager (Cursor) command. It gives the position of the cursor on the display.
Para- Field Numeric
meters: Line
SoftKey
Softkey ID The Softkey ID when field specifies softkey
Line Number Line number when field specifies line.
Character Position of the cursor in the specified field
Position (zero being the first position within the field)

Highlight Status On
This command is used in response to the Query Display Manager (Highlight) command when the highlight feature is on. The command defines the display area that is currently highlighted.
Para- Field Numeric
meters: Context
Line
SoftKey
Line Number Line number when field specifies line.
Softkey ID The Softkey ID when field specifies softkey
Starting Position Starting character position of the highlighted
portion.
Ending Position Ending character position of the highlighted
portion.

Current Character Table Configuration Status
The Current Character Table Configuration Status command is used in response to the Query Display Manager (Current Config) command. It informs the NI about the current character table configuration of the display manager.
Parameters: Contrast Level Current contrast setting
Current Character Table Data representing current
Confuration character table configuration

Default Character Table Configuration Status
The Default Character Table Configuration Status command is used in response to the Query Display Manager (Default Config) command. It informs the NI about the default character table configuration of the display manager.
Parameters: Contrast Level Current contrast setting
Default Character Table Data representing default
Confuration character table configuration

Time and Date Format Report
The Time and Date Format command is used in response to the Query Display Manager (TAD) command. It reports on the format that the IT uses to present the time and date information to the user.
Parameters: Time Format 12-hour clock (e.g. 10:34 pm)
French clock (e.g. 22 h 34)
24-hour clock (e.g. 22:34)
Date Format day first (e.g. 16 Sep)
month first (e.g. Sep 16)
numeric standard (e.g. 09/16)
numeric inverse (e.g. 16/09)

Status Bar Icon State Report
This command is used in response to the Query Display Manager (Icon) command. It gives the current state and cadence of the selected status bar icon.
Parameters: Status Bar Icon ID specifies the status bar icon to be
updated
Icon State specifies desired state of icon
Icon Cadence Off
On
Flash
Flicker
Wink
Twinkle
Blink
Downloadable cadence

Backlight Status
This command is used in response to the Query Display Manager (Backlight) command. It gives the current state of the backlight. The backlight is controlled by the NI with the Display Backlight Control command.
Parameters: Backlight Status On
Off

Highlight Status Off
This command is used to respond to the Query Display Manager (Highlight) command when the status of the highlight is off.
TABLE 1
Broadcast Manager Commands
NI to IT IT to NI
Logical Icon Update
Time and Data Download
Set Default Character Table Configuration
TABLE 2
Network Manager Commands
NI to IT IT to NI
Soft Reset Soft Reset Ack
Hard Reset Sanity OK
Query Network Manager Network Manager Attributes
info
Network Manager Options Network Manager Diagnostic
Info
Control Channel QoS Configuration Manager Ids
Reserve UDP Port Block Network Manager Options
Report
Server Identification Tag Resume Connection With Server
Set RTCP Source Description Items Suspend Connection With
Server
Protocol Switch Reserved UDP Ports Report
Download Backup Server Information Copyright Text
Server Switch
Server Alarm
TABLE 3
Basic Manager Commands
NI to IT IT to NI
Start Selftest Basic Manager Attributes Info
Query Basic Manager Basic Manager Options Report
Basic Manager Options F/W version
General Read/Write IT Type
Eeprom Write Selftest result
Encapsulate Command General Read Response
Hardware ID
Product Engineering Code
TABLE 4
Key/Indicator Manager Commands
NI to IT IT to NI
LED Update Key Event
Query Hookswitch LED Status Report
User Activity Timer On hook
Downloadable Free Form Icon Off hook
Access
Query Key/Indicator Manager User Activity Timer Expired
Key/Indicator Manager Options Hookswitch State
Logical Icon Mapping Key/Indicator Manager Attributes info
Key Repeat Timer Download Key/Indicator Manager Options Report
Query LED State IT Icon Status Report
Query IT Icon State
Indicator Cadence Download
User Activity Timer Download
Free Form Icon Download
IT Icon Update
TABLE 5
Audio Manager Commands
NI to IT IT to NI
Query Audio Manager Handset connected
Query Supervisor Headset Status Handset disconnected
Audio Manager Options Headset connected
Mute/unmute Headset disconnected
Transducer Based Tone On Supervisor Headset connected
Transducer Based Tone Off Supervisor Headset disconnected
Alerting Tone Configuration Headset Feature Key Pressed
Special Tone Configuration Audio Manager Attributes info
Paging Tone Configuration Audio Manager Options Report
Alerting Tone Cadence Download Adjustable Rx Volume Report
Special Tone Cadence Download Adjustable Rx Volume Informa-
tion
Paging Tone Cadence Download APB's Default Rx Volume
Value
Transducer Based Tone Volume Level Alerting Tone Select
Alerting Tone Test APB's Tx and/or STMR
Response
Visual Transducer Based Tones Enable RTCP Statistics Report
Stream Based Tone On Open Audio Stream Report
Stream Based Tone Off
Stream Based Tone Configuration
Stream Based Tone Frequency Com-
ponent List Download
Stream Based Tone Cadence Download
Select Adjustable Rx Volume
Set APB's Rx Volume Levels
Change Adjustable Rx Volume
Adjust Default Rx Volume
Adjust APB's Tx and/or STMR Volume
Level
Query APB's Tx and/or STMR Volume
Level
ABP Download
Open Audio Stream
Close Audio Stream
Connect Transducer
Frequency Response Specification
Biquad Download
Voice Switching Configuration
Query RTCP Statistics
Vocoder Configuration
Jitter Buffer Configuration
TABLE 6
Display Manager Commands
NI to IT IT to NI
Page Scroll Display Manager Attributes Info
Restore Default Character Table Contrast Level Report
Configuration
Display Backlight Control Cursor Location Report
Arrow Highlight Status On
Query Status Bar Icon Current Character Table Con-
figuration Status
Highlight On/Off Default Character Table Con-
figuration Status
Restore Time and Date Time and Date Format Report
Clear Time and Date Status Bar Icon State Report
Call Duration Timer Backlight Status
Query Display Manager Highlight Status Off
Download Call Duration Timer Delay
Disable Display Field
Clear Field
Cursor Control
Page Download
Display Scroll with Data
Status Bar Icon Update
Month Label Download
Call Timer Label Download
Time and Date Format
Display Data Write
Context Info Bar Format
Set Default Character Table
Configuration
Set Current Character Table
Configuration
Special Character Download
Highlighted Field Definition
Contrast
Caller Log Download

Claims (8)

1. An apparatus for facilitating provision of services in an IP data network for a data network telephone, the apparatus comprising:
a network intelligence for communicating IP messages to said data network telephone over the IP data network and facilitating provision of services for said data network telephone; and
wherein said network intelligence comprises, at least one terminal emulator operable for emulating said data network telephone, a configuration data structure, and a first service proxy launched in response to a first input received at the data network telephone based upon information in said configuration data structure, and a second service proxy launched in response to a second input received at the data network telephone, said first service proxy operable for setting up a first service between a first data source and said data network telephone, and said second service proxy operable for setting up a second service between a second data source and said data network telephone.
2. The apparatus of claim 1 wherein said configuration data structure correlates user input elements from said data network telephone with functions.
3. The apparatus of claim 1 further comprising a plurality of terminal emulators each having a configuration data structure for each of said plurality of data network telephones, each configuration data structure correlating user input elements of said respective data network telephone with functions.
4. The apparatus of claim 3 wherein said user input elements comprise key press indications.
5. A computer readable medium, which when loaded into a processor connected to a data network to which at least one telephone is also connected, controls said processor to:
receive user input messages from said telephone over said data network, each user input message identifying a user input element actuated by a user;
where one or more user input messages from said telephone indicate a called station, establish a call between said telephone and said called station utilising a first service provider such that audio data may pass between said telephone and said called station, and update a state of said telephone to a state of busy with a voice call;
where, after establishment of said call, a further user input message is received and where a current function of a user input element identified in said further message indicates a service provided by a second service provider, if said state of said telephone is not incompatible with said function, send a control message to said telephone to establish said service provided by said second service provider.
6. A computer readable medium, which when loaded into a processor connected to an IP data network to which at least one telephone is also connected, controls said processor to:
based on one or more first user input messages from said telephone, launch a first service proxy in response to said one or more first user input messages received from said telephone to establish a voice call between said telephone and a first source, said one or more first user input messages from said telephone including IP messages received over the IP data network;
based on one or more second user input messages from said telephone received during pendency of said voice call, launch a second service proxy in response to said one or more second input messages received from said telephone based upon information in a configuration data structure to set up at least one non-telephony data service between said telephone and at least one data source, at least where said at least one non-telephony data service does not conflict with said voice call.
7. An apparatus for facilitating provision of services in an IP data network for a data network telephone, the apparatus comprising:
a network intelligence for communicating IP messages to said data network telephone over said IP data network and facilitating provision of a service for said data network telephone, said network intelligence including a messager for sending messages with audio parameters over said data network to said data network telephone for controlling audio at said data network telephone, said audio parameters including transmission and reception filters, receive loudness rating, send loudness rating, side tone masking rating, transmission and reception filter gain compensation, automatic gain control, and switched loss.
8. The apparatus of claim 7 wherein said audio parameters further comprise receive volume range, receive volume step size, and default volume level.
US09/307,356 1999-05-05 1999-05-07 Telephony and data network services at a telephone Expired - Lifetime US7068641B1 (en)

Priority Applications (8)

Application Number Priority Date Filing Date Title
CA 2273657 CA2273657C (en) 1999-05-05 1999-06-07 Telephony and data network services at a telephone
JP2000617632A JP2002544718A (en) 1999-05-05 2000-05-03 Telephone telephony and data network services
PCT/CA2000/000510 WO2000069155A2 (en) 1999-05-05 2000-05-03 Telephony and data network services at a telephone
DE60032356T DE60032356T2 (en) 1999-05-05 2000-05-03 TELEPHONE AND DATA NETWORK SERVICES FOR TELEPHONE
EP00929151A EP1180296B1 (en) 1999-05-05 2000-05-03 Telephony and data network services at a telephone
AU47364/00A AU4736400A (en) 1999-05-05 2000-05-03 Telephony and data network services at a telephone
US11/300,997 US7660295B2 (en) 1999-05-05 2005-12-15 Telephony and data network services at a telephone
US12/646,404 US8964727B2 (en) 1999-05-05 2009-12-23 Telephony and data network services at a telephone

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CA2271180 1999-05-05

Related Child Applications (1)

Application Number Title Priority Date Filing Date
US56456100A Continuation-In-Part 1999-05-05 2000-05-04

Publications (1)

Publication Number Publication Date
US7068641B1 true US7068641B1 (en) 2006-06-27

Family

ID=36600534

Family Applications (1)

Application Number Title Priority Date Filing Date
US09/307,356 Expired - Lifetime US7068641B1 (en) 1999-05-05 1999-05-07 Telephony and data network services at a telephone

Country Status (1)

Country Link
US (1) US7068641B1 (en)

Cited By (37)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20040001482A1 (en) * 2002-06-28 2004-01-01 Eung-Moon Yeom Method for sending dual-tone multi-frequency signal using voice over internet protocol
US20040170155A1 (en) * 2001-07-12 2004-09-02 Omar Salim H. System and method for providing remote data access for a mobile communication device
US20040225502A1 (en) * 2003-05-05 2004-11-11 Bear Eric Gould Record button on a computer system
US20050254637A1 (en) * 2004-05-12 2005-11-17 Megumi Hosoe Call request control device
US20060007940A1 (en) * 2000-03-13 2006-01-12 Sollee Patrick N Controlling voice communications over a data network
US20060159029A1 (en) * 2005-01-20 2006-07-20 Samuels Allen R Automatic LAN/WAN port detection
US20060176271A1 (en) * 2005-02-07 2006-08-10 Microsoft Corporation Interface for consistent program interaction with auxiliary computing devices
US20060242590A1 (en) * 2005-04-21 2006-10-26 Microsoft Corporation Simple content format for auxiliary display devices
US20060284787A1 (en) * 2003-05-05 2006-12-21 Microsoft Corporation Method and system for auxiliary display of information for a computing device
US20070071257A1 (en) * 2003-09-30 2007-03-29 Microsoft Corporation Method and system for unified audio control on a personal computer
US20070121801A1 (en) * 2005-10-05 2007-05-31 Alex Montoya System and method for maintaining a translations database to effect call control at a remote terminal
US20090003551A1 (en) * 2007-06-28 2009-01-01 Mitel Networks Corporation Method And Apparatus For Managing A Call
WO2008059533A3 (en) * 2006-11-16 2009-04-09 Onmobile Global Ltd Method to stream compressed digital audio over circuit switched, voice networks
US20090187620A1 (en) * 2008-01-21 2009-07-23 Alcatel-Lucent Via The Electronic Patent Assignment Systems (Epas) Converged information systems
US20090305695A1 (en) * 2003-05-05 2009-12-10 Microsoft Corporation Real-time communications architecture and methods for use with a personal computer system
US8069205B1 (en) * 2000-06-16 2011-11-29 8X8, Inc. Communications controller and method therefor
US8233392B2 (en) 2003-07-29 2012-07-31 Citrix Systems, Inc. Transaction boundary detection for reduction in timeout penalties
US8238241B2 (en) 2003-07-29 2012-08-07 Citrix Systems, Inc. Automatic detection and window virtualization for flow control
US8259729B2 (en) 2002-10-30 2012-09-04 Citrix Systems, Inc. Wavefront detection and disambiguation of acknowledgements
US8270423B2 (en) 2003-07-29 2012-09-18 Citrix Systems, Inc. Systems and methods of using packet boundaries for reduction in timeout prevention
US8411560B2 (en) 2002-10-30 2013-04-02 Citrix Systems, Inc. TCP selection acknowledgements for communicating delivered and missing data packets
US8432800B2 (en) 2003-07-29 2013-04-30 Citrix Systems, Inc. Systems and methods for stochastic-based quality of service
US8437284B2 (en) 2003-07-29 2013-05-07 Citrix Systems, Inc. Systems and methods for additional retransmissions of dropped packets
US8595478B2 (en) 2000-07-10 2013-11-26 AlterWAN Inc. Wide area network with high quality of service
US8635554B2 (en) 2003-05-20 2014-01-21 Microsoft Corporation Enhanced telephony computer user interface allowing user interaction and control of a telephone using a personal computer
US20150296226A1 (en) * 2010-03-04 2015-10-15 Dolby Laboratories Licensing Corporation Techniques For Client Device Dependent Filtering Of Metadata
US20160006853A1 (en) * 1999-08-12 2016-01-07 Hewlett-Packard Development Company, L.P. Method and apparatus for accessing a contacts database and telephone services
US9432516B1 (en) 2009-03-03 2016-08-30 Alpine Audio Now, LLC System and method for communicating streaming audio to a telephone device
USD835060S1 (en) * 2017-01-19 2018-12-04 Li Peng Telephone
USD835599S1 (en) * 2017-01-19 2018-12-11 Li Peng Telephone
USD848391S1 (en) * 2017-07-26 2019-05-14 Peng Li Telephone
US10404698B1 (en) 2016-01-15 2019-09-03 F5 Networks, Inc. Methods for adaptive organization of web application access points in webtops and devices thereof
US10834065B1 (en) 2015-03-31 2020-11-10 F5 Networks, Inc. Methods for SSL protected NTLM re-authentication and devices thereof
US11216742B2 (en) 2019-03-04 2022-01-04 Iocurrents, Inc. Data compression and communication using machine learning
US11526859B1 (en) 2019-11-12 2022-12-13 Bottomline Technologies, Sarl Cash flow forecasting using a bottoms-up machine learning approach
US11532040B2 (en) 2019-11-12 2022-12-20 Bottomline Technologies Sarl International cash management software using machine learning
US11704671B2 (en) 2020-04-02 2023-07-18 Bottomline Technologies Limited Financial messaging transformation-as-a-service

Citations (27)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4893310A (en) 1987-11-30 1990-01-09 Northern Telecom Limited Digital key telephone system
US5485370A (en) * 1988-05-05 1996-01-16 Transaction Technology, Inc. Home services delivery system with intelligent terminal emulator
US5541917A (en) * 1994-09-12 1996-07-30 Bell Atlantic Video and TELCO network control functionality
US5583920A (en) * 1992-04-17 1996-12-10 Bell Atlantic Intelligent peripheral in video dial tone network
US5610910A (en) * 1995-08-17 1997-03-11 Northern Telecom Limited Access to telecommunications networks in multi-service environment
US5625678A (en) * 1995-05-24 1997-04-29 Microsoft Corporation Method and system for allowing switched voice and data communication among multiple application programs
EP0781016A2 (en) 1995-12-18 1997-06-25 Sony Corporation Telephone apparatus used for computer network telephone system
WO1997031492A1 (en) 1996-02-21 1997-08-28 International Business Machines Corporation Distributed architecture for services in a telephony system
WO1998021872A1 (en) 1996-11-14 1998-05-22 Vois Corporation System and method for providing and using universally accessible voice and speech data files
US5771279A (en) * 1995-07-31 1998-06-23 Bell Atlantic Network Services, Inc. Advanced intelligent network interacting with customer premises equipment
US5790671A (en) * 1996-04-04 1998-08-04 Ericsson Inc. Method for automatically adjusting audio response for improved intelligibility
US5881103A (en) * 1995-08-03 1999-03-09 Motorola, Inc. Electronic device with equalized audio accessory and method for same
US5991292A (en) * 1997-03-06 1999-11-23 Nortel Networks Corporation Network access in multi-service environment
US6044264A (en) * 1994-11-01 2000-03-28 Nokia Telecommunications Oy Method for activating intelligent network services in a mobile communication system, and a mobile communication system
US6131095A (en) * 1996-12-11 2000-10-10 Hewlett-Packard Company Method of accessing a target entity over a communications network
US6161134A (en) * 1998-10-30 2000-12-12 3Com Corporation Method, apparatus and communications system for companion information and network appliances
US6161008A (en) * 1998-11-23 2000-12-12 Nortel Networks Limited Personal mobility and communication termination for users operating in a plurality of heterogeneous networks
US6229810B1 (en) * 1997-12-31 2001-05-08 At&T Corp Network server platform for a hybrid fiber twisted pair local loop network service architecture
US6282281B1 (en) * 1995-12-11 2001-08-28 Hewlett-Packard Company Method of providing telecommunications services
US6385646B1 (en) * 1996-08-23 2002-05-07 At&T Corp. Method and system for establishing voice communications in an internet environment
US6393481B1 (en) * 1997-10-06 2002-05-21 Worldcom, Inc. Method and apparatus for providing real-time call processing services in an intelligent network
US6446127B1 (en) * 1998-10-30 2002-09-03 3Com Corporation System and method for providing user mobility services on a telephony network
US6445695B1 (en) 1998-12-31 2002-09-03 Nortel Networks Limited System and method for supporting communications services on behalf of a communications device which cannot provide those services itself
US6564261B1 (en) 1999-05-10 2003-05-13 Telefonaktiebolaget Lm Ericsson (Publ) Distributed system to intelligently establish sessions between anonymous users over various networks
US6584490B1 (en) * 1998-10-30 2003-06-24 3Com Corporation System and method for providing call-handling services on a data network telephone system
US6711157B1 (en) 1999-08-24 2004-03-23 Telefonaktiebolaget L M Ericsson (Publ) System and method of creating subscriber services in an IP-based telecommunications network
US6831915B1 (en) * 1997-02-20 2004-12-14 Hewlett-Packard Development Company, L.P. Service node for providing telecommunication services

Patent Citations (28)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4893310A (en) 1987-11-30 1990-01-09 Northern Telecom Limited Digital key telephone system
US5485370A (en) * 1988-05-05 1996-01-16 Transaction Technology, Inc. Home services delivery system with intelligent terminal emulator
US5583920A (en) * 1992-04-17 1996-12-10 Bell Atlantic Intelligent peripheral in video dial tone network
US5541917A (en) * 1994-09-12 1996-07-30 Bell Atlantic Video and TELCO network control functionality
US6044264A (en) * 1994-11-01 2000-03-28 Nokia Telecommunications Oy Method for activating intelligent network services in a mobile communication system, and a mobile communication system
US5625678A (en) * 1995-05-24 1997-04-29 Microsoft Corporation Method and system for allowing switched voice and data communication among multiple application programs
US5771279A (en) * 1995-07-31 1998-06-23 Bell Atlantic Network Services, Inc. Advanced intelligent network interacting with customer premises equipment
US5881103A (en) * 1995-08-03 1999-03-09 Motorola, Inc. Electronic device with equalized audio accessory and method for same
US5610910A (en) * 1995-08-17 1997-03-11 Northern Telecom Limited Access to telecommunications networks in multi-service environment
US5828666A (en) * 1995-08-17 1998-10-27 Northern Telecom Limited Access to telecommunications networks in multi-service environment
US6282281B1 (en) * 1995-12-11 2001-08-28 Hewlett-Packard Company Method of providing telecommunications services
EP0781016A2 (en) 1995-12-18 1997-06-25 Sony Corporation Telephone apparatus used for computer network telephone system
WO1997031492A1 (en) 1996-02-21 1997-08-28 International Business Machines Corporation Distributed architecture for services in a telephony system
US5790671A (en) * 1996-04-04 1998-08-04 Ericsson Inc. Method for automatically adjusting audio response for improved intelligibility
US6385646B1 (en) * 1996-08-23 2002-05-07 At&T Corp. Method and system for establishing voice communications in an internet environment
WO1998021872A1 (en) 1996-11-14 1998-05-22 Vois Corporation System and method for providing and using universally accessible voice and speech data files
US6131095A (en) * 1996-12-11 2000-10-10 Hewlett-Packard Company Method of accessing a target entity over a communications network
US6831915B1 (en) * 1997-02-20 2004-12-14 Hewlett-Packard Development Company, L.P. Service node for providing telecommunication services
US5991292A (en) * 1997-03-06 1999-11-23 Nortel Networks Corporation Network access in multi-service environment
US6393481B1 (en) * 1997-10-06 2002-05-21 Worldcom, Inc. Method and apparatus for providing real-time call processing services in an intelligent network
US6229810B1 (en) * 1997-12-31 2001-05-08 At&T Corp Network server platform for a hybrid fiber twisted pair local loop network service architecture
US6161134A (en) * 1998-10-30 2000-12-12 3Com Corporation Method, apparatus and communications system for companion information and network appliances
US6446127B1 (en) * 1998-10-30 2002-09-03 3Com Corporation System and method for providing user mobility services on a telephony network
US6584490B1 (en) * 1998-10-30 2003-06-24 3Com Corporation System and method for providing call-handling services on a data network telephone system
US6161008A (en) * 1998-11-23 2000-12-12 Nortel Networks Limited Personal mobility and communication termination for users operating in a plurality of heterogeneous networks
US6445695B1 (en) 1998-12-31 2002-09-03 Nortel Networks Limited System and method for supporting communications services on behalf of a communications device which cannot provide those services itself
US6564261B1 (en) 1999-05-10 2003-05-13 Telefonaktiebolaget Lm Ericsson (Publ) Distributed system to intelligently establish sessions between anonymous users over various networks
US6711157B1 (en) 1999-08-24 2004-03-23 Telefonaktiebolaget L M Ericsson (Publ) System and method of creating subscriber services in an IP-based telecommunications network

Non-Patent Citations (6)

* Cited by examiner, † Cited by third party
Title
A. Catchpole, Voice-Data Convergence and the Corporate Voice-over-IP Trial, British Telecommunications Engineering, vol. 17, Jan. 1999, p. 218-224.
Hansson, A. et al., "Phone Doubler-A Step Towards Integrated Internet and Telephone Communities", Ericsson Review No. 4, 1997, pp. 142-151.
R. DeMillo, The Internet as a Telephone Network, Educom Review, 1998, p. 12-16.
Richard Platt, ISP Centrex "A White paper discussing ISP Centrex value and functionality", Feb. 20, 1998 Version 2.0.
Selsuis Systems Inc., A Fundamental Shift in Telephony Networks, Mar. 1, 1998.
Zellweger, P. T. et al., "An Overview of The Etherphone System And Its Applications", IEEE, 1988, pp. 160-168.

Cited By (72)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9860363B2 (en) * 1999-08-12 2018-01-02 Hewlett-Packard Development Company, L.P. Method and apparatus for accessing a contacts database and telephone services
US20160006853A1 (en) * 1999-08-12 2016-01-07 Hewlett-Packard Development Company, L.P. Method and apparatus for accessing a contacts database and telephone services
US20060007940A1 (en) * 2000-03-13 2006-01-12 Sollee Patrick N Controlling voice communications over a data network
US7995589B2 (en) 2000-03-13 2011-08-09 Genband Us Llc Controlling voice communications over a data network
US8069205B1 (en) * 2000-06-16 2011-11-29 8X8, Inc. Communications controller and method therefor
US8595478B2 (en) 2000-07-10 2013-11-26 AlterWAN Inc. Wide area network with high quality of service
US9985800B2 (en) 2000-07-10 2018-05-29 Alterwan, Inc. VPN usage to create wide area network backbone over the internet
US9667534B2 (en) 2000-07-10 2017-05-30 Alterwan, Inc. VPN usage to create wide area network backbone over the internet
US9525620B2 (en) 2000-07-10 2016-12-20 Alterwan, Inc. Private tunnel usage to create wide area network backbone over the internet
US9015471B2 (en) 2000-07-10 2015-04-21 Alterwan, Inc. Inter-autonomous networking involving multiple service providers
US7526572B2 (en) * 2001-07-12 2009-04-28 Research In Motion Limited System and method for providing remote data access for a mobile communication device
US8578057B2 (en) 2001-07-12 2013-11-05 Blackberry Limited System and method for providing remote data access for a mobile communication device
US20090210936A1 (en) * 2001-07-12 2009-08-20 Omar Salim H System and method for providing remote data access for a mobile communication device
US20040170155A1 (en) * 2001-07-12 2004-09-02 Omar Salim H. System and method for providing remote data access for a mobile communication device
US7230945B2 (en) * 2002-06-28 2007-06-12 Samsung Electronics Co., Ltd. Method for sending dual-tone multi-frequency signal using voice over internet protocol
US20040001482A1 (en) * 2002-06-28 2004-01-01 Eung-Moon Yeom Method for sending dual-tone multi-frequency signal using voice over internet protocol
US9008100B2 (en) 2002-10-30 2015-04-14 Citrix Systems, Inc. Wavefront detection and disambiguation of acknowledgments
US8553699B2 (en) 2002-10-30 2013-10-08 Citrix Systems, Inc. Wavefront detection and disambiguation of acknowledgements
US9496991B2 (en) 2002-10-30 2016-11-15 Citrix Systems, Inc. Systems and methods of using packet boundaries for reduction in timeout prevention
US8411560B2 (en) 2002-10-30 2013-04-02 Citrix Systems, Inc. TCP selection acknowledgements for communicating delivered and missing data packets
US8259729B2 (en) 2002-10-30 2012-09-04 Citrix Systems, Inc. Wavefront detection and disambiguation of acknowledgements
US20090305695A1 (en) * 2003-05-05 2009-12-10 Microsoft Corporation Real-time communications architecture and methods for use with a personal computer system
US20060284787A1 (en) * 2003-05-05 2006-12-21 Microsoft Corporation Method and system for auxiliary display of information for a computing device
US7827232B2 (en) 2003-05-05 2010-11-02 Microsoft Corporation Record button on a computer system
US7913182B2 (en) 2003-05-05 2011-03-22 Microsoft Corporation Method and system for auxiliary display of information for a computing device
US20040225502A1 (en) * 2003-05-05 2004-11-11 Bear Eric Gould Record button on a computer system
US20070195007A1 (en) * 2003-05-05 2007-08-23 Microsoft Corporation Method and system for auxiliary display of information for a computing device
US9392043B2 (en) 2003-05-20 2016-07-12 Microsoft Technology Licensing, Llc Enhanced telephony computer user interface allowing user interaction and control of a telephone using a personal computer
US8694915B2 (en) 2003-05-20 2014-04-08 Microsoft Corporation Enhanced telephony computer user interface allowing user interaction and control of a telephone using a personal computer
US8635554B2 (en) 2003-05-20 2014-01-21 Microsoft Corporation Enhanced telephony computer user interface allowing user interaction and control of a telephone using a personal computer
US9071543B2 (en) 2003-07-29 2015-06-30 Citrix Systems, Inc. Systems and methods for additional retransmissions of dropped packets
US8824490B2 (en) 2003-07-29 2014-09-02 Citrix Systems, Inc. Automatic detection and window virtualization for flow control
US8233392B2 (en) 2003-07-29 2012-07-31 Citrix Systems, Inc. Transaction boundary detection for reduction in timeout penalties
US8238241B2 (en) 2003-07-29 2012-08-07 Citrix Systems, Inc. Automatic detection and window virtualization for flow control
US8432800B2 (en) 2003-07-29 2013-04-30 Citrix Systems, Inc. Systems and methods for stochastic-based quality of service
US8462630B2 (en) 2003-07-29 2013-06-11 Citrix Systems, Inc. Early generation of acknowledgements for flow control
US8270423B2 (en) 2003-07-29 2012-09-18 Citrix Systems, Inc. Systems and methods of using packet boundaries for reduction in timeout prevention
US8437284B2 (en) 2003-07-29 2013-05-07 Citrix Systems, Inc. Systems and methods for additional retransmissions of dropped packets
US8245027B2 (en) 2003-09-30 2012-08-14 Microsoft Corporation Method and system for unified audio control on a personal computer
US8644481B2 (en) 2003-09-30 2014-02-04 Microsoft Corporation Method and system for unified audio control on a personal computer
US8443179B2 (en) 2003-09-30 2013-05-14 Microsoft Corporation Method and system for unified audio control on a personal computer
US20090259327A1 (en) * 2003-09-30 2009-10-15 Microsoft Corporation Method and system for unified audio control on a personal computer
US20070071257A1 (en) * 2003-09-30 2007-03-29 Microsoft Corporation Method and system for unified audio control on a personal computer
US20100010653A1 (en) * 2003-09-30 2010-01-14 Microsoft Corporation Method and system for unified audio control on a personal computer
US8127125B2 (en) 2003-09-30 2012-02-28 Microsoft Corporation Method and system for unified audio control on a personal computer
US8166287B2 (en) 2003-09-30 2012-04-24 Microsoft Corporation Method and system for unified audio control on a personal computer
US20050254637A1 (en) * 2004-05-12 2005-11-17 Megumi Hosoe Call request control device
US20060159029A1 (en) * 2005-01-20 2006-07-20 Samuels Allen R Automatic LAN/WAN port detection
US8077632B2 (en) 2005-01-20 2011-12-13 Citrix Systems, Inc. Automatic LAN/WAN port detection
US20060176271A1 (en) * 2005-02-07 2006-08-10 Microsoft Corporation Interface for consistent program interaction with auxiliary computing devices
US7784065B2 (en) 2005-02-07 2010-08-24 Microsoft Corporation Interface for consistent program interaction with auxiliary computing devices
US20060242590A1 (en) * 2005-04-21 2006-10-26 Microsoft Corporation Simple content format for auxiliary display devices
US8009808B2 (en) * 2005-10-05 2011-08-30 Intrado Inc. System and method for maintaining a translations database to effect call control at a remote terminal
US20070121801A1 (en) * 2005-10-05 2007-05-31 Alex Montoya System and method for maintaining a translations database to effect call control at a remote terminal
US20100067672A1 (en) * 2006-11-16 2010-03-18 Harish Babu Method to stream compressed digital audio over circuit switched, voice networks
WO2008059533A3 (en) * 2006-11-16 2009-04-09 Onmobile Global Ltd Method to stream compressed digital audio over circuit switched, voice networks
US8971515B2 (en) 2006-11-16 2015-03-03 Onmobile Global Limited Method to stream compressed digital audio over circuit switched, voice networks
US8180026B2 (en) * 2007-06-28 2012-05-15 Mitel Networks Corporation Method and apparatus for managing a call
US20090003551A1 (en) * 2007-06-28 2009-01-01 Mitel Networks Corporation Method And Apparatus For Managing A Call
US20090187620A1 (en) * 2008-01-21 2009-07-23 Alcatel-Lucent Via The Electronic Patent Assignment Systems (Epas) Converged information systems
US9432516B1 (en) 2009-03-03 2016-08-30 Alpine Audio Now, LLC System and method for communicating streaming audio to a telephone device
US20150296226A1 (en) * 2010-03-04 2015-10-15 Dolby Laboratories Licensing Corporation Techniques For Client Device Dependent Filtering Of Metadata
US10834065B1 (en) 2015-03-31 2020-11-10 F5 Networks, Inc. Methods for SSL protected NTLM re-authentication and devices thereof
US10404698B1 (en) 2016-01-15 2019-09-03 F5 Networks, Inc. Methods for adaptive organization of web application access points in webtops and devices thereof
USD835599S1 (en) * 2017-01-19 2018-12-11 Li Peng Telephone
USD835060S1 (en) * 2017-01-19 2018-12-04 Li Peng Telephone
USD848391S1 (en) * 2017-07-26 2019-05-14 Peng Li Telephone
US11216742B2 (en) 2019-03-04 2022-01-04 Iocurrents, Inc. Data compression and communication using machine learning
US11468355B2 (en) 2019-03-04 2022-10-11 Iocurrents, Inc. Data compression and communication using machine learning
US11526859B1 (en) 2019-11-12 2022-12-13 Bottomline Technologies, Sarl Cash flow forecasting using a bottoms-up machine learning approach
US11532040B2 (en) 2019-11-12 2022-12-20 Bottomline Technologies Sarl International cash management software using machine learning
US11704671B2 (en) 2020-04-02 2023-07-18 Bottomline Technologies Limited Financial messaging transformation-as-a-service

Similar Documents

Publication Publication Date Title
US7068641B1 (en) Telephony and data network services at a telephone
US7660295B2 (en) Telephony and data network services at a telephone
JP4548242B2 (en) Voice IP telephone method and apparatus.
JP4999244B2 (en) Network telephone apparatus and system for internet telephones
US6169734B1 (en) Internet phone set
US6853713B1 (en) Client-server network for managing internet protocol voice packets
KR100306167B1 (en) System and method of delivering a multimedia alarm call massage
AU777728B2 (en) Distributed communications network including one or more telephony communication devices having programmable functionality
JP2008505408A (en) METHOD AND APPARATUS FOR CORDLESS TELEPHONE AND OTHER TELECOMMUNICATION SERVICES (Related Application) This application enjoys the benefit of US Provisional Patent Application No. 60 / 585,375, whose name and inventor are the same, This document is incorporated by reference into this document.
US20040057417A1 (en) Apparatus and method for providing call status information
US6819665B1 (en) Private branch exchange implemented using H.323 gatekeeper
JP2004511936A (en) Network telephone communication equipment and system supporting wireless Internet telephone communication
US6757704B1 (en) Linked call forwarding
KR20010092273A (en) Internet protocol standards-based multi-media messaging
US7480376B2 (en) Apparatus and method for providing call status information
CA2590263C (en) Incoming caller information on self labeling telephone keys
US20090220061A1 (en) Telephone Device
AU2004205302A1 (en) Distributed communications network including one or more telephony communication devices having programmable functionality
JP3626446B2 (en) Gatekeeper, gatekeeper control method, service providing system, control program, and recording medium
JP2004512774A (en) User control of telephone exchange via HTTP client application
JP2002077363A (en) Cti system
JPH05300205A (en) Digital telephone set

Legal Events

Date Code Title Description
AS Assignment

Owner name: NORTEL NETWORKS CORPORATION, CANADA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:ALLAN, WILLIAM;MORLEY, ROBERT S.;KRAMER, KRIS W.;AND OTHERS;REEL/FRAME:010126/0102;SIGNING DATES FROM 19990625 TO 19990707

AS Assignment

Owner name: NORTEL NETWORKS LIMITED, CANADA

Free format text: CHANGE OF NAME;ASSIGNOR:NORTEL NETWORKS CORPORATION;REEL/FRAME:011195/0706

Effective date: 20000830

Owner name: NORTEL NETWORKS LIMITED,CANADA

Free format text: CHANGE OF NAME;ASSIGNOR:NORTEL NETWORKS CORPORATION;REEL/FRAME:011195/0706

Effective date: 20000830

FEPP Fee payment procedure

Free format text: PAYOR NUMBER ASSIGNED (ORIGINAL EVENT CODE: ASPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

STCF Information on status: patent grant

Free format text: PATENTED CASE

CC Certificate of correction
FPAY Fee payment

Year of fee payment: 4

AS Assignment

Owner name: ROCKSTAR BIDCO, LP, NEW YORK

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:NORTEL NETWORKS LIMITED;REEL/FRAME:027164/0356

Effective date: 20110729

FPAY Fee payment

Year of fee payment: 8

AS Assignment

Owner name: ROCKSTAR CONSORTIUM US LP, TEXAS

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:ROCKSTAR BIDCO, LP;REEL/FRAME:032389/0263

Effective date: 20120509

AS Assignment

Owner name: RPX CLEARINGHOUSE LLC, CALIFORNIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:ROCKSTAR CONSORTIUM US LP;ROCKSTAR CONSORTIUM LLC;BOCKSTAR TECHNOLOGIES LLC;AND OTHERS;REEL/FRAME:034924/0779

Effective date: 20150128

AS Assignment

Owner name: JPMORGAN CHASE BANK, N.A., AS COLLATERAL AGENT, IL

Free format text: SECURITY AGREEMENT;ASSIGNORS:RPX CORPORATION;RPX CLEARINGHOUSE LLC;REEL/FRAME:038041/0001

Effective date: 20160226

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 12TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1553)

Year of fee payment: 12

AS Assignment

Owner name: RPX CLEARINGHOUSE LLC, CALIFORNIA

Free format text: RELEASE (REEL 038041 / FRAME 0001);ASSIGNOR:JPMORGAN CHASE BANK, N.A.;REEL/FRAME:044970/0030

Effective date: 20171222

Owner name: RPX CORPORATION, CALIFORNIA

Free format text: RELEASE (REEL 038041 / FRAME 0001);ASSIGNOR:JPMORGAN CHASE BANK, N.A.;REEL/FRAME:044970/0030

Effective date: 20171222

AS Assignment

Owner name: JEFFERIES FINANCE LLC, NEW YORK

Free format text: SECURITY INTEREST;ASSIGNOR:RPX CLEARINGHOUSE LLC;REEL/FRAME:046485/0644

Effective date: 20180619

AS Assignment

Owner name: RPX CLEARINGHOUSE LLC, CALIFORNIA

Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:JEFFERIES FINANCE LLC;REEL/FRAME:054305/0505

Effective date: 20201023