NZ242529A - Allocating/deallocating b channels in a computer interface to isdn - Google Patents
Allocating/deallocating b channels in a computer interface to isdnInfo
- Publication number
- NZ242529A NZ242529A NZ242529A NZ24252992A NZ242529A NZ 242529 A NZ242529 A NZ 242529A NZ 242529 A NZ242529 A NZ 242529A NZ 24252992 A NZ24252992 A NZ 24252992A NZ 242529 A NZ242529 A NZ 242529A
- Authority
- NZ
- New Zealand
- Prior art keywords
- channel
- virtual
- isdn
- channels
- computer
- Prior art date
Links
- 238000004891 communication Methods 0.000 claims abstract description 24
- 230000005540 biological transmission Effects 0.000 claims abstract description 20
- 230000004044 response Effects 0.000 claims abstract description 15
- 238000000034 method Methods 0.000 claims description 105
- 230000008569 process Effects 0.000 claims description 80
- 230000001052 transient effect Effects 0.000 claims description 17
- 238000012544 monitoring process Methods 0.000 claims description 9
- 238000012217 deletion Methods 0.000 claims description 2
- 230000037430 deletion Effects 0.000 claims description 2
- 238000003780 insertion Methods 0.000 claims description 2
- 230000037431 insertion Effects 0.000 claims description 2
- 238000011084 recovery Methods 0.000 claims description 2
- 230000003213 activating effect Effects 0.000 claims 6
- 230000010354 integration Effects 0.000 claims 3
- 238000013467 fragmentation Methods 0.000 claims 1
- 238000006062 fragmentation reaction Methods 0.000 claims 1
- 108091006146 Channels Proteins 0.000 description 137
- 230000011664 signaling Effects 0.000 description 10
- 230000009471 action Effects 0.000 description 6
- 238000010586 diagram Methods 0.000 description 6
- 238000012545 processing Methods 0.000 description 5
- 238000006243 chemical reaction Methods 0.000 description 4
- 230000006870 function Effects 0.000 description 4
- 238000007726 management method Methods 0.000 description 4
- ZPUCINDJVBIVPJ-LJISPDSOSA-N cocaine Chemical compound O([C@H]1C[C@@H]2CC[C@@H](N2C)[C@H]1C(=O)OC)C(=O)C1=CC=CC=C1 ZPUCINDJVBIVPJ-LJISPDSOSA-N 0.000 description 3
- 238000001514 detection method Methods 0.000 description 3
- 238000009432 framing Methods 0.000 description 3
- 238000012546 transfer Methods 0.000 description 3
- 230000001960 triggered effect Effects 0.000 description 3
- 208000003035 Pierre Robin syndrome Diseases 0.000 description 2
- 244000105017 Vicia sativa Species 0.000 description 2
- 238000004590 computer program Methods 0.000 description 2
- 230000007246 mechanism Effects 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 241000272808 Anser Species 0.000 description 1
- 230000004913 activation Effects 0.000 description 1
- 230000002730 additional effect Effects 0.000 description 1
- 230000008901 benefit Effects 0.000 description 1
- 230000000903 blocking effect Effects 0.000 description 1
- 230000003139 buffering effect Effects 0.000 description 1
- 230000007423 decrease Effects 0.000 description 1
- 238000010348 incorporation Methods 0.000 description 1
- 235000015250 liver sausages Nutrition 0.000 description 1
- 230000000873 masking effect Effects 0.000 description 1
- 230000006855 networking Effects 0.000 description 1
- 230000011218 segmentation Effects 0.000 description 1
- 238000012163 sequencing technique Methods 0.000 description 1
- 230000007704 transition Effects 0.000 description 1
- 230000002747 voluntary effect Effects 0.000 description 1
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04J—MULTIPLEX COMMUNICATION
- H04J3/00—Time-division multiplex systems
- H04J3/16—Time-division multiplex systems in which the time allocation to individual channels within a transmission cycle is variable, e.g. to accommodate varying complexity of signals, to vary number of channels transmitted
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04Q—SELECTING
- H04Q11/00—Selecting arrangements for multiplex systems
- H04Q11/04—Selecting arrangements for multiplex systems for time-division multiplexing
- H04Q11/0428—Integrated services digital network, i.e. systems for transmission of different types of digitised signals, e.g. speech, data, telecentral, television signals
- H04Q11/0435—Details
- H04Q11/0471—Terminal access circuits
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L69/00—Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
- H04L69/14—Multichannel or multilink protocols
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L69/00—Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
- H04L69/30—Definitions, standards or architectural aspects of layered protocol stacks
- H04L69/32—Architecture of open systems interconnection [OSI] 7-layer type protocol stacks, e.g. the interfaces between the data link level and the physical level
- H04L69/322—Intralayer communication protocols among peer entities or protocol data unit [PDU] definitions
- H04L69/324—Intralayer communication protocols among peer entities or protocol data unit [PDU] definitions in the data link layer [OSI layer 2], e.g. HDLC
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04Q—SELECTING
- H04Q2213/00—Indexing scheme relating to selecting arrangements in general and for multiplex systems
- H04Q2213/093—Personal computer
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04Q—SELECTING
- H04Q2213/00—Indexing scheme relating to selecting arrangements in general and for multiplex systems
- H04Q2213/13003—Constructional details of switching devices
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04Q—SELECTING
- H04Q2213/00—Indexing scheme relating to selecting arrangements in general and for multiplex systems
- H04Q2213/1305—Software aspects
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04Q—SELECTING
- H04Q2213/00—Indexing scheme relating to selecting arrangements in general and for multiplex systems
- H04Q2213/13093—Personal computer, PC
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04Q—SELECTING
- H04Q2213/00—Indexing scheme relating to selecting arrangements in general and for multiplex systems
- H04Q2213/13107—Control equipment for a part of the connection, distributed control, co-processing
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04Q—SELECTING
- H04Q2213/00—Indexing scheme relating to selecting arrangements in general and for multiplex systems
- H04Q2213/13166—Fault prevention
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04Q—SELECTING
- H04Q2213/00—Indexing scheme relating to selecting arrangements in general and for multiplex systems
- H04Q2213/13204—Protocols
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04Q—SELECTING
- H04Q2213/00—Indexing scheme relating to selecting arrangements in general and for multiplex systems
- H04Q2213/13209—ISDN
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04Q—SELECTING
- H04Q2213/00—Indexing scheme relating to selecting arrangements in general and for multiplex systems
- H04Q2213/1325—Priority service
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04Q—SELECTING
- H04Q2213/00—Indexing scheme relating to selecting arrangements in general and for multiplex systems
- H04Q2213/13271—Forced release
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04Q—SELECTING
- H04Q2213/00—Indexing scheme relating to selecting arrangements in general and for multiplex systems
- H04Q2213/13332—Broadband, CATV, dynamic bandwidth allocation
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04Q—SELECTING
- H04Q2213/00—Indexing scheme relating to selecting arrangements in general and for multiplex systems
- H04Q2213/13399—Virtual channel/circuits
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04Q—SELECTING
- H04Q2213/00—Indexing scheme relating to selecting arrangements in general and for multiplex systems
- H04Q2213/164—Traffic registration; Adaptation of traffic possibilities
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04Q—SELECTING
- H04Q2213/00—Indexing scheme relating to selecting arrangements in general and for multiplex systems
- H04Q2213/204—ISDN protocol; ISO 7
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04Q—SELECTING
- H04Q2213/00—Indexing scheme relating to selecting arrangements in general and for multiplex systems
- H04Q2213/25—Preferential service
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04Q—SELECTING
- H04Q2213/00—Indexing scheme relating to selecting arrangements in general and for multiplex systems
- H04Q2213/271—Forced release
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04Q—SELECTING
- H04Q2213/00—Indexing scheme relating to selecting arrangements in general and for multiplex systems
- H04Q2213/392—Channel allocation - special rules
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Communication Control (AREA)
Abstract
Dynamic channel allocation in an ISDN line is implemented above a Level II link layer protocol (LAP-D). The preferred embodiment comprises programming operating on a computing platform system including a communication coprocessor system. The programming includes a channel management module (CMM) (302) and a virtual channel module (VCM) (304) to implement dynamic channel allocation. The modules cooperate to control bandwidth between communication partners by selective allocation and deallocation of virtual B channels between them in response to preassigned priorities and real time events. Channel deallocation also takes place in response to high error rates in message transmission. The coprocessor system preferably is circuit board mounted and installed in an available slot of a personal computer.
Description
. *.
242529
Priority Pate(s);... .a34a|."ai.
"S-'Xi'ivll'.icn
C-; - i:-).HGH*..»3/©S>i Wolt'T3/i?,Srt-,,
2 fi JUL Q35
Patents Form No. 5 Number
PATENTS ACT 1953 Dated
COMPLETE SPECIFICATION
* '» .
✓
c o ^/JW
DYNAMIC CHANNEL ALLOCATION METHOD AND SYSTEM ^ FOR INTEGRATED SERVICES DIGITAL NETWORK 'vr°
We, BELL ATLANTIC NETWORK SERVICES, INC. of 1310 North Court House Road, Arlington, Virginia, United States of America^ a corporation of Delaware do hereby declare the invention for which we pray that a Patent may be granted to us, and the method by which it is to be performed, to be particularly described in and by the following statement:
1A
Technical Field
This invention relates generally to Integrated Services Digital Network (ISDN), and more particularly to controlling dynamic channel allocation in ISDN and to creating a virtual channel out of underlying network channels.
Background Art
A digital telecommunication network can be characterized by two general features, the existence of well defined digital interfaces to Customer Premise Equipment (CPE) which are the end nodes of the network, and an interconnected switching backbone network which is capable, upon demand, of creating point-to-point connections between any two end nodes. An example of such a network architecture can be found in the ISDN specifications which have been developed by the International Telegraph and Telephone Consultative Committee (CCITT). Although aspects of the invention may be relevant to other types of digital telecommunication networks, in the paragraphs below, the general features of a digital telecommunication network upon which this invention depends will be described using examples drawn from ISDN.
A complete description of the architecture of ISDN is beyond the scope of this specification. For details, and for an extensive bibliography of references of ISDN, see Stallings, ISDN, An Introduction, MacMillan Publishing Company, 1989. In general, all ISDN interfaces to customer premises
4
242529
t channel to each user of the interface. In the event of contention for a channel between different users, high priority channel users should be able to preempt channels from low priority channel users. The present 5 invention addresses these limitations and provides a method to overcome them.
Dynamic channel (bandwidth) allocation per se is not new to ISDN. U.S. Pat. No. 4,763,321 and U.S. Pat. No. 4,805,167 describe techniques to accomplish channel 10 synchronization at the physical level (bit level synchronization) by manipulating the ISDN interface frame structures (TDM frames) to create a high data rate virtual channel. However, it is disadvantageous to carry out operations at the physical level (Level 1 15 of OSI) which require manipulation of hardware. The present invention does not operate at the physical level and makes no attempt to manipulate the ISDN physical interface.
Disclosure of Invention
Accordingly, a broad object of the invention is to improve bandwidth utilization of ISDN.
Another object is to dynamically allocate B channels between ISDN communication partners in 25 response to preassigned priorities and real time events.
Another object of the invention is to enable computer networking on ISDN while retaining support of traditional telephone services.
An additional object is to carry out automatic
ISDN channel allocation in a manner that is transparent to a user.
Still another object of the invention i6 to carry cui-t—improved—protocol——implementing—dynamic
242529
bandwidth allocatiun in ISDN. ■—
A further object of the_^D3CBBt±otT~i8to carry out the aforementlpaed—Qg^ectawithout manipulation of data afc—Cfiephyeioal layog» —
In broad terms the invention comprises a computer program implementation that enables a CPE device to dynamically manage the ISDN resources available to it in such a manner as to overcome the above mentioned limitations of ISDN. The invention enables ISDN to accommodate a computer network while retaining the ability to also support traditional telephony services.
One aspect of the invention carries out dynamic channel allocation in an ISDN line by monitoring events supplied to the line which indicate requests to use or release a B channel, evaluating channel usage priorities associated with users generating events monitored, and, based upon channel usage priorities, automatically setting up or tearing down B channels associated with the line. Processing takes place, in present implementation, above LAP-D protocol.
In accordance with a preferred embodiment of the invention, upon a hardware platform are provided first and second program modules, a channel management module (CMM) and a virtual channel module (VCM), to implement dynamic channel allocation. The program modules cooperate to control bandwidth between communication partners by selective allocation and deallocation of virtual B channels between them in response to preassigned priorities and real time events.
The first program module, CMM, monitors requests to connect and disconnect B channels by potential end users and the second module (VCM). The CMM is capable of signalling the VCM to force deallocation of a B
6
242529
channel from a virtual channel based on a request for channel connection by a higher priority end user. The CMM signals the VCM to indicate the existence of available B channels when end users disconnect the channel.
The second module, VCM, provides a block oriented transport service to various computer processes which can operate over one or more B channels. This service operates above the data link layer and manages the multiplexing of messages across one or more data link connections which operate on a B channel so as to ensure properly ordered delivery of message blocks. Channels are added or deleted on a dynamic basis, without interrupting the flow of data. The service supports the allocation and deallocation of channels based on signals from the CMM. Channel deallocation also takes place in response to high error rates in message transmission.
The program modules implemented in accordance with this invention provide control logic for a CPE device to allocate and deallocate ISDN channels to a plurality of end users, i.e., the local analog telephone equipment, the various processes running on the local computer system, and similar entities located remotely on the ISDN network. Implementation is based both on user specified priorities and the real time requirements of each user. The modules also support the virtualization of B channel resources so as to overcome the bandwidth limitations of a single B channel.
Still other objects and advantages of the present invention will become readily apparent to those skilled in this art from the following detailed description, wherein only the preferred embodiment of the invention
7
242529
is shown and described, simply by way of illustration of the best mode contemplated of carrying out the invention. As will be realized, the invention is capable of other and different embodiments, and its several details are capable of modifications in various obvious respects, all without departing from the invention. Accordingly, the drawing and description are to be regarded as illustrative in nature, and not as restrictive.
Brief Description of the Drawings
FIGURE 1 is a circuit diagram of the hardware platform upon which programming in accordance with the invention is implemented.
FIGURE 2 is a system software module diagram of a communication coprocessor system known in the prior art and forming part of the hardware platform shown in FIGURE 1 for implementation of the present invention.
FIGURE 3 is a software module diagram corresponding to FIGURE 1 including additional software modules comprising an aspect of the invention.
FIGURE 4 is a message interface diagram for the additional modules shown in Figure 3.
FIGURES 5(a) and 5(b) are diagrams of B channel state tables and priority levels maintained by the CMM.
FIGURE 6 is a flow chart of programming carrying out an aspect of the invention.
FIGURE 7 is a representative view of a circuit board carrying the hardware shown schematically in FIGURE 1.
FIGURE 8 is a flow chart of programming for removing B-channels from the -virtual channel in response to an excessive error rate in accordance with another aspect of the invention.
8
242529
FIGURE 9 is a flow chart of a routine for sending to a remote resource.
FIGURE 10 is a flow chart of a routine for receiving from a remote resource.
Detailed Description of the Invention
1. Overview
The preferred embodiment of the invention provides a computer-to-ISDN interface residing at customer premise equipment (CPE) and operating above LAP-D protocol to perform dynamic channel allocation and deallocation in response to processes occurring on the ISDN and in accordance with user priorities. In the preferred embodiment, the CPE comprises a computer communication coprocessor board which contains an RJ-45 BRI interface (either at the ISDN T reference point or at the U reference point), an RJ-11 interface, a shared memory interface to an AT bus, and a UART interface to an AT bus. The interface is implemented by programming executed by a processor that, in the preferred embodiment, is mounted on a commercially available Teleos B101 ISDN communications coprocessor board. The programming alternatively can be executed by other systems having the characteristics described below.
2. System Requirements
The system includes a real time operating system kernel capable of supporting multiple processes which execute as threads in a common address space. A message passing and signalling system permits various processes on the ISDN to communicate with each other. The kernel supports voluntary blocking of a process until the occurrence of an event in the system and process rescheduling based on the occurrence of the
242 52 Q
event have taken place. (As used herein, an "event" is a hardware interrupt or the arrival of a message sent by another process in the system.) This type of system support is common to many real time operating system kernels such as PSOS, VRTX, or RTU.
Furthermore, it is assumed that the system has an initial start-up process which supports the loading of additional processes and their initialization, as well as initialization of various hardware devices in the system. The preferred embodiment of the invention is based on the PSOS kernel together with a capability for initialization and downloading other processes.
The system furthermore includes hardware interrupt routines which support plural hardware interfaces in the system and which use real time kernel message passing to cause a process to be executed to further service the event. The following hardware interrupt routines preferably are present in the system:
1. At least one interrupt routine to support HOLC frame operations on the two B channels and the D channel, such as flag detection and generation, zero bit insertion and deletion, CRC checking and generation, and address masking. Such a routine may operate with a DMA controller.
2. An interrupt routine to support a shared memory interface to a computer system bus, such as an ISA bus (AT bus). This routine, which may be in the form of a co-routine on the computer processor, must be able to route messages to all the processes in the system.
3. An interrupt routine to support a UART interface to the ISA bus or other -computer system bus.
4. The system furthermore should include a software module which implements the user side of the
242 52 9
ISDN D channel signalling protocol. This includes the data link layer, that is, LAP-D, as specified in ISDN specification Q.921, and the network layer as specified in Q.931.
. The system must be able to support an analog telephone, manage the conversion of analog to digital signals according to the ISDN standard, and interface to the program interrupt routines to support connection/disconnection of a voice call.
6. The system additionally must implement a data link layer protocol which can support a separate data link connection over each of the B channels. It is assumed that the partner for this data link connection is a similar process running on a similar ISDN communication coprocessor system. The data link process will have an implementation which supports full duplex operation by separate transmit and receive queues and interrupt driven thread dispatching based on the event of a message arriving to the system or a message being queued for transmission. In other words, the transmit and receive threads are non-biocking from a dispatch point of view.
7. The system of the preferred embodiment further should include a software module which implements a translator to map the AT command set into ISDN commands to connect and disconnect B channels. This module will also implement a PAD function to interface a byte oriented UART to a block oriented HDLC controller.
3. Platform Hardware
The hardware platform in the preferred embodiment is implemented by the commercially available Teleos B101 ISDN Communication Coprocessor System board. The capabilities identified as 4 and 5 in the preceding
XI
24 2 52
system requirements are carried out by Signalling Interface Process (SIP) software accompanying the Teleos BlOl. The function identified as 7 is implemented by its AT/PAD process. Further details of the Teleos BlOl communication coprocessor are given in the BIOIPC Hardware Reference Manual (REV A), 1990, available through Teleos Communications, Incorporated.
The present invention is implemented at customer premise equipment, preferably by incorporation on at least one printed circuit board 700 as shown in FIGURE 7, adapted to be mounted in an available slot of a personal computer PC. A conventional analog telephone T is connected to the board 700 at RJ-11 plug 702. The hardware platform upon which the invention is implemented, and as depicted schematically in FIGURE 1, includes an internal bus 100 supporting a microprocessor 102, preferably a 68000 type, such as a 68HC00CP-12). A direct memory access (DMA) controller 104, such as an NEC uPD 71071 Controller, on the bus, handles memory to memory and serial I/O to memory transfers. An HDLC controller 106, such as an NEC uPD 72001 is connected to the RAM 114. The DMA and HDLC controllers 104, 106 together operate at HDLC framing protocol, carrying out conversion of data in parallel bit format to serial bit format for supply to ACFA 110 and I PAT 112. The ACFA 110 and IPAT 112, which are commercially available ISDN chips, provide physical interfacing with the ISDN, performing framing, electrical signal conversion, and D channel collision detection functions. Using the RJ-11 plug shown in Figure 7 at the rear of the coprocessor board, the ACFA 110 is interfaced to an analog telephone 126 through a CODEC 132
The HDLC 106 controller has four channels, with
242 5
one line incoming and another outgoing for each channel for full duplex operation. Logic implemented in the HDLC controller 106 identifies start and stop bits of each incoming block.
Upon receipt of a block as determined by the start and stop bit framing patterns, and following error detection using a checksum protocol indicating the block contains no errors, the HDLC controller 106 instructs the DMA controller 104 to pass the block to a selected location in a random access memory (RAM) 114 on the bus. If there is an error in the block, an error routine is executed.
Upon transmission of data, start and stop flags are applied to define a block, bit stuffing is carried out as necessary, and the block is discharged on the two B-channels comprising the BRI. Another HDLC controller 118, operating with a DMA controller 120, carries out similar functions for the D-channel of the ISDN line. Communication between the DMA controller 120 and the RAM 114 in the preferred embodiment is implemented using the SIP protocol of the commercially available Teleos BlOl ISDN communication coprocessor board.
Also residing on bus 100 is a UART 122 forming a COM port that interfaces data bidirectionally, one block at a time, between bus 100 and a bus 124, that preferably is an ISA (AT compatible) bus, upon which resides the user's personal computer.
Another interface to user bus 124 is a memory 128 that is shared by both busses 100 and 124. The shared memory 128 is controlled by a shared memory controller 130 divided into two blocks-, one for control information and the other for utilities such as debugging. The shared memory 128 receives data at
13
242529
separate read/write ports in a known manner to provide service to both of the busses 100 and 124.
Each program module, described below, will support message passing interfaces to and from other processes in the system and is an event driven, dispatchable thread being run under the real time kernel.
4. Platform Software
Figure 2, depicting symbolically the software architecture for implementing the computing platform, provided in the preferred embodiment by the Teleos communication coprocessor system, provides the principal program modules and their interfaces resident in the system. An off-board PC Comm Package 210 together with UART 212 on the user bus 124 is coupled to the communication coprocessor circuit shown in the FIGURE at board resident UART 214. User side ISDN D channel signalling protocol is carried out at the data link layer (LAP-D as specified in Q.921) and at the network layer (Q.931) by software module 218. In the Teleos BlOl coprocesesor board, module 218 is implemented by a protocol termed "SIP", as mentioned earlier.
AT/PAD 216 interfaces with one of the two B-channels forming the BRI by accessing either the LAPD 1 or LAPD 2, module 220 or 222 with corresponding HDLC modules 224 or 226. These modules enable a separate data link connection over each of the B-channels in the system. The data link process implements full duplex operation using separate transmit and receive queues and interrupt driven thread dispatching based on the event of a message arriving to the system or a message being queued from transmission. These processes are implemented in the Teleos coprocessor board as the
.14
242 52
V.120*/LAPDl and V.120**/LAPD2 processes.
Shared memory manager module 230 directs flow of data between the shared memory 232 and the three BRI channels through interface 218 and HDLC 228 (D-channel) and LAPD, HDLC modules 220-226 (Bl- and B2-channels).
The architecture further supports an analog telephone, managing conversion of analog to digital signals according to the ISDN standard including D channel signalling (SIP) protocol.
. Dynamic Channel Allocation
Referring to FIGURE 3, the preferred embodiment of the invention is provided as two new program modules 302 and 304 to provide channel allocation management and virtual channels of greater bandwidth than a single B channel. For convenience, the description of these modules is provided with respect to the Teleos BlOl ISDN Communication Coprocessor System, but the concept can be applied to any system supporting these new program modules. Program modules other than the new modules 302, 304 in Figure 3 correspond to like modules in FIGURE 2.
Module 302, the Channel management module (CMM), monitors B channel usage and preempts the use of a B channel by a lower priority user when the channel is needed by a higher priority user. To accomplish this function, CMM 302 maintains a state table 502, shown symbolically in FIGURE 5(a), which indicates the state of each B channel including whether the channel is a "preemptable channel", that is, whether the channel is connected or disconnected and if connected, whether it is being used by a process that could release the channel in the event of preemption by a higher priority device. This process is carried out in the invention
242 52
by Virtual Channel Process, described in more detail hereinafter, when more than one channel as part of a virtual channel is requested. The state table also records if a channel is in use as a result of preemption.
As shown in Figures 3 and 4, information necessary to maintain the table comes from messages sent by the signalling interface module 216 (SIP processes in the Teleos communication coprocessor) to the CMM; messages are sent each time module 218 receives a request for channel connection or disconnection. Local requests originate from a user process running on the computer via shared memory interrupt manager 230, the Virtual Channel Process via internal message passing, AT/PAD processes via UART 214, or the Teleos voice process via Analog Phone Support 221. Remote requests arrive over the D channel. Upon receipt of such a message, the CMM 302 updates the state table 502 to record the new state of a B channel.
The CMM 302 also includes a table 504, shown symbolically in FIGURE 5(b), which maintains priority levels P(n) for all the end users n in the system. In the event that the CMM detects contention for a B channel, i.e., there is a request to connect a new channel but all the channels are in use, the following additional action takes place.
Referring to the flowchart of FIGURE 6, and the message interface diagram of FIGURE 4, the CMM 302 first determines if a request for channel connection is received (step 600). When a request arrives, the module 302 determines whether the request is from an end user with greater priority than the users that are currently occupying the channels (step 602). If the request is from a user of equal or lower priority, the
.16
242529
CMM takes no action and tells the signalling interface process 218 to deny the request (step 604). In the event that the request is from a higher priority user, the CMM 302 determines if a preemptable channel exists (step 606). If such a channel exists, the CMM will signal the virtual channel process using the channel to logically free the channel from use (step 608), and when CMM 302 receives a signal indicating that the channel is no longer in use, step 610, the CMM will send a message to the signalling interface which will cause the channel to be disconnected (step 612). In this manner a channel will be made available to the higher priority end user. An example of this occurs when the Virtual Channel Process is using both B channels and the end user requesting a new channel is the analog telephone.
In the event that the CMM 302 receives a message indicating that a channel has been disconnected, in step 614, the CMM determines if the channel was a preempted channel (step 616). In this case the CMM will signal the process which had the channel preempted to reconnect the channel (step 618).
The virtual channel module (VCM) 304 provides the capability to dynamically combine multiple, circuit-switched B channels into a single virtual channel which is capable of carrying a properly ordered sequence of data blocks. The VCM 304 comprises a block multiplexer/demultiplexer with buffering support to overcome the lack of synchronization across B channels inherent in the ISDN network. As shown in Figure 3, VCM 304 operates in conjunction with the CMM 302 to allocate and deallocate B channels based on events monitored by the CMM 302. The VCM 304 has a block oriented interface to the computer processes which use
17
24 2 5
block send and block receive commands via the shared memory interface 128 of the communication coprocessor circuit shown in FIGURE 1. The PC computer process views the virtual channel as an ordered stream of blocks and has no knowledge of on which B channel the block is actually sent or received. The only indication to the computer process that the virtual channel is in use is the speed (bandwidth) available for transmission; as more channels are added or deleted, the bandwidth increases or decreases correspondingly.
The VCM 304 implements a protocol which operates as an upper sublayer of the data link layer, similar in purpose to but different in implementation from the ISO Multiple Link Procedure. This aspect of the invention is significant, as no processing at the physical layer, together with disadvantages associated therewith, takes place.
6. Virtual Channel Protocol
6.1 B-Channel State Transitions
Component channels allocated for a virtual B-channel have three defined states, viz., activated, deactivated, and transient states. In the deactivated state, data transfer is forbidden although control protocol exchange is not. Component channels that have been allocated but not joined to the virtual channel are initially in the deactivated state. A channel is deactivated for a sender immediately after the deactive b command, described later, has been queued for transmission. For a receiver, a channel is deactivated immediately after the command is received. Only a bi-directionally deactivated channel can be removed and physically disconnected from the virtual channel of
242529
which it was a member.
In the activated state, both data and control protocol transfer are permitted. A channel is activated to a sender only after acknowledgement of the active b command has been received. For a receiver, a channel is activated immediately following receipt of the active b command.
The transient state is defined by guarding periods before acknowledgements are received from the far-end. No user data can be sent over a channel in the transient state.
A virtual channel can be in either of two states, transient and steady. A virtual channel is transient when any component channels are transient. If no component channel is in the transient state, the Virtual Channel is in the steady state.
6.2 Virtual Channel Multiplexing
In a virtual channel, data received for transmission is sequentially distributed, one packet at a time, in a round-robin fashion over the channels in active state. The remote virtual channel process receives and recovers data in the same round-robin sequence.
To add and delete channels, protocol messages are exchanged by the sender and receiver which cause the virtual channel to enter the transient state. An active b command is sent to add a channel; a deactive b command is sent to delete one. When a virtual channel is in the transient state, the round-robin send and receive mechanism continues but the additional features are added. On the receive side, -a trace-back timer is used to ensure that error conditions on a transient line will not block the virtual channel for a long
.19
242529
period of time. On the transmit side, if no user data is available, SYNC vB protocol messages optionally are sent on active lines to ensure that the receiver will initiate the trace back timer.
The traceback timer, which is implementation by programming within the program module VCM, is based upon an "optimistic algorithm" that assumes that a transmission sent ultimately will be received by the transmission partner. It is started at the probable logical end of transmission for recovery of time-inverted propogation of physical events. In the preferred embodiment, the traceback timer is initiated upon transmission of a block. If the communication partner does not respond within a predetermined amount of time, determined by the timer, the transmission is deemed to be invalid, and the channels are torn down and reinitiated. The operation of the traceback timer within the present system, depicted in the flow chart of Figure 10, is described in detail later.
Rather than global sequence numbers, a packet generation number preferably is used and has meaning only in terms of round-robin line scanning. Thus if two channels are in use, the first two packets will be sent with a generation number of 1, the second two packets with a generation number of 2, etc. The sending and receiving processes both keep track of generation numbers and both use the same round-robin ordering so as to provide correct sequencing of packets.
6.3 Protocol Fields and Commands
The protocol commands, together with detailed format and bit definitions used for controlling and multiplexing over the virtual channel, are as follows.
242529
* DATA
0s8nnnnn: one byte as header of client's data for transmit.
* RQST Bs lOlnnnnn: one byte header of one or multiple control bytes. The first control byte can further specify explicitly whether the data is global. If the header does not specify, whether the data is global depends on the address bytes which follow. No address byte for in-band operation is required, and multiple address bytes imply that the in-band line is not explicitly included. The explicit global commands have the leftmost bit on, followed by explicitly specified address bytes. If the leftmost two bits are both on, the data is a broadcast and no address bytes follow. Multiple bytes are useful for off-band control. Preferably, only one byte of in-band control is employed. The leftmost third bit is reserved, and the fourth bit is for system control point specification. These are external or internal indicated by E and I respectively as follows. The last four bits define the commands of this category. At present, these are: DEACTIV Bs group: uwxlz, w bit is reserved and u defines two system points.
DEL Bs - (0X00 J 0), an external delete command DEX Bs - (DEL Bs j 1), an DEL Bs, followed by external setup
DIL Bs - (DEL Bs | 0X10), internally initiated delete command
DIX Bs - (DEX Bs | 0X10), DIL Bs, followed by internal setup
24252
ACTIV Bs group: uwxOz, w bit is reserved, u the same as defined above.
ADD Bs - (0X00 | 5 AID Bs - (ADD Bs initiated ADD Bs
2), an external add command. ! 0X10), an internally
* SYNC vB
llOnnnnn: one byte only, used for time-fill and 10 synchronization.
* RA Bs lllnnnnn: one byte header, followed by no or multiple optional bytes. This is an acceptance acknowledgment 15 in reply to a RQST Bs, and in-band is implied if no other bytes follow. Similar to the case in RQST Bs, the first byte which follows can further specify whether it is global. The left-most two bits have exactly the same meanings, which describe the scope of 20 the possible additional address bytes. The leftmost third bit, if on, turns the whole meaning of the response into a negative acknowledgement. The last five bits are the same as for RQST Bs.
* MODE vB
1000000m: for virtual channel operation and format specification. This has two members, MODE rst with m = 0 and MODE lbc with m = 1; MODE rst defines the nnnnn five bit generation number. The mode negotiation can 30 proceed only when all component channels are in deactivated states, or UNA will be received. If the optional attributes are not accepted, UNA will also be received. A REJ will be received if the remote end does not support or will not accept this request. In
242520
addition to this role of mode negotiations, MODE vB resets the generation number or the global sequence number for transmitter and the corresponding variable back to 0 to restart and resets the transmitter and 5 receiver (loop) pointers back to the first component position.
* RR
10000010: Informs the far-end receiver that this end 10 is ready.
* RNR
10000011: Informs the far-end receiver that this end 15 is not ready.
* ATTRB vB
100000100: The parameters in APPENDIX I follow this for far-end negotiation.
* UA
100100 00: This unnumbered positive response means acceptance in the mode negotiation. The same MODE vB packet will be sent back as bi-directional 25 initialization, following the UA. The UA is also used for acknowledgement to flow control commands RR and RNR. It is used for acceptance acknowledgement to ATTRB vB as well as unnumbered commands.
* UNA
10010100: a negative response for refusing, used similarly to UA.
242 52 9
* REJ
10011100: as explained in the MODE vB description.
All those unnumbered are in-band, although MODE vB 5 is for global. The "nnnnn" is a module 32 correlation generation number assigned to each round of transmissions. The "sb" in the DATA command, which has four values 11, 10, 01 and 11, is for frame segmentation.
6.4 Protocol Processing
Programming described with reference to Figures 9 and 10 is provided for the two key routines in the Virtual Channel, Send_To_Remote and 15 Receive_From_Remote. Both routines are initiated when a message is received from another process in the system, as shown in FIGURE 4.
Process: Send_To_Remote
Entry Condition:
This task executes when either a message arrives from another process requesting that a block of data be sent on the virtual channel (VC), or when the process itself 25 must transmit messages due to virtual channel protocol processing, shown in FIGURE 4.
Data Structures Assumed:
1. Circular List of Transmission Lines maintained in 30 the round-robin order of transmission.
2. Current Line Ptr.
3. VC Header block with current generation number.
24
242529
Figure 9 is a flow chart describing the send_to remote routine in accordance with an aspect of this invention. Assume initially that a message is received to activate a channel deactivated in a virtual channel, represented by step 900. A decision is made on whether the virtual channel currently is in a steady state, i.e., none of its members is in transient state (step 902). Assuming that the channel is in steady state, step 904 queries whether a data block is ready to send, i.e., a block of data has been assembled. Only when a data block is ready, step 906 adds a virtual channel header to the data block, sends the block to a current line LAPD process, and then updates the current line to the next line in round-robin fashion. When a complete round of lines has been completed (step 908), the current generation number of the virtual channel header is updated in step 910.
If step 902 determines that the virtual channel is not in a steady state condition, step 912 of the program determines whether the current line is active. If the current line is not active and activation is requested, step 918 sends virtual channel protocol message to turn it into an active channel. If the current line is active, step 914 determines whether a data block is ready for sending. When a data block is ready, steps 920, 924 and 426 carry out block assembly by adding a virtual channel header to the block to be sent, then sending the block to the current line LAPD process, updating the line in round-robin fashion and finally updating the virtual channel header generation sequence number as in steps 906-910.
When step 914 determines that a data block is not ready to send, step 916 queries whether the transient line has any protocol to send. If there is nothing to
242529
send, it exists. If protocol is available for sending, in transient line step 922 prepares the current line for transmission by carrying out a synchronization protocol, i.e., sending fill-blocks with the virtual 5 channel header, and then updates the current line to next line in round-robin fashion.
Pseudo code corresponding to the above routine is shown in Appendix II.
Process: Receive_From_Remote Entry Condition:
This task executes when either a message arrives from the data link layer indicating that a new block has 15 arrived from the Remote VC partner, or when the local Send_To_PC indicates that it is ready to receive another block.
Data Structures Assumed:
1. Circular List of Message Queues kept in the round-robin order of transmission.
2. Current Queue Ptr.
3. VC Header block with current generation number.
Protocol for receiving channel data from a remote source, in accordance with an aspect of this invention, can be better understood with reference to Figure 10. Assume initially that a message is received from a remote source (step 1000). Step 1002 determines 30 whether the virtual channel is in steady state. Assuming that the virtual channel currently is in steady state, the message to be sent is placed in queue for the appropriate channel (step 1004). In step 1006, the queue is interrogated in a round-robin sequence to
26
212 52
determine whether it is empty. When the queue is not empty, step 1008 processes the queue in round-robin order and sends the message to the appropriate party. This sequence of steps is repeated until a complete round of lines has been finished, determined by step 1010, and then the virtual channel header generation sequence number is updated (step 1012).
If the virtual channel is determined in step 1002 not to be in steady state, the traceback timer, noted previously, and which preferably is software implemented, is queried to determine whether it is triggered (step 1014). Assuming that the timer has not yet been triggered, step 1016 detects whether the current line is empty. Only if the current line is empty, and assuming also that a non-empty line currently exists, and the generation number of messages on this line is current or future, determined by step 1018, the timing by the traceback timer is initiated. The program exits to step 1000 when either a message on the transient line arrives, or the traceback timer expires (step 1020).
If step 1014 determines that the traceback timer is not triggered, step 1022 places a new message for the appropriate channel in the queue. If there is a message on the transient line, and the traceback timer is set, step 1024, the traceback timer is disabled (step 1026). If there is no message, the queue is queried on a round-robin basis to determine whether it is empty (step 1028). Assuming that the queue is not empty, the line is processed in round-robin order, step 1030, and the generation number of the message is read at step 1032 to determine whether -it is current. If it is current, the message is delivered to the appropriate party (step 1034), if not, the message is discarded in
27
24 2 52
step 1036.
On the other hand, if the queue on a round-robin basis is not empty, the virtual channel header generation sequence number is updated (step 1038). Pseudo code corresponding to the above routine is given in Appendix III.
6.5 Dynamic Channel Control
The computer program which is using the virtual channel controls the number of B channels which can participate in the virtual channel by sending commands to the CMM module 302 to indicate that a channel should be added to or deleted from the virtual channel.
Channel allocation/deallocation can also occur based on actions by CMM 302 as described earlier. In the event that a channel is deallocated and then disconnected by the partner who was the calling party (i.e. the partner who did not originate the call), it is advantageous to provide a mechanism to indicate that the original party called should reestablish the channel when so requested. The virtual channel protocol supports this by using control messages to indicate to the communication partner that the preempted channel is available again.
Using the routine shown in FIGURE 8, the VCM 304 deletes a B-channel if a high line error rate is detected. A predefined threshold rate of errors in a given period of time is provided to the VCM in step 802. If the data link layer for a given B-channel reports an error rate above this threshold, determined by step 804, the VCM 304 logically removes the B-channel from the virtual channel (step 806) and requests the CMM 302 to have the channel disconnected (step 808).
28
24 2 52
The invention described herein accordingly carries out dynamic channel allocation in an ISDN line by monitoring events supplied to the line which indicate requests to use or release a B channel, evaluating channel usage priorities associated with users generating events monitored, and, based upon channel usage priorities, automatically setting up or tearing down B channels associated with the line. Processing takes place above LAP-D protocol. Upon a communication coprocessor platform are provided first and second program modules, a channel management module (CMM) and a virtual channel module (VCM), to implement dynamic channel allocation. The program modules cooperate to control bandwidth between communication partners by selective allocation and deallocation of virtual B channels between them in response to preassigned priorities and real time events. The CMM monitors requests to connect and disconnect B channels by potential end users and the VCM. The CMM is capable of signalling the VCM to force deallocation of a B channel from a virtual channel based on a request for channel connection by a higher priority end user. The CMM signals the VCM to indicate the existence of available B channels when end users disconnect the channel. The VCM provides a block oriented transport service to various computer processes which can operate over one or more B channels. This service operates above the data link layer and manages the multiplexing of messages across one or more data link connections which operate on a B channel so as to ensure properly ordered delivery of message blocks. Channels are added or deleted on a dynamic basis, without interrupting the flow of data. Channel deallocation also takes place in response to high error rates in message transmission.
I
. 29
24 2 5 ?
In this disclosure, there is shown and described only the preferred embodiment of the invention, but, as aforementioned, it is to be understood that the invention is capable of use in various other combinations and environments and is capable of changes or modifications within the scope of the inventive concept as expressed herein.
242 52
9
Virtual 5 Channel Attributes (C lanaunc»M
rypede; struct :
* iong err_tare»ftolci ;
sncrt err~aemon_tr.res :
sncrt err'actiorrperzit :
sncrt nax^aanci viitr.;
sr.cn nign^util tr.res ;
sncrt r.ign~ausy~ut:.i_tr.res:
sr.cr*: Cign2astior._ir.res :
sncrt aign^pction^pe^r-- •'
sncrr ain_eand_wieitr. :
sncrt low~utii~tnres:
snort low~Dusy_utii_tnres;
sncrt low2actior._tnres :
sncrt low~acrion jpersit r snort set~u?_retry tr.res ;
snort no action tares: • V2 THRESHOLD;
one out of err_tar«afioli fraaes • ■ act on conrig err acticr. tr.res »' allow aeactivation el errarec cnanne. nax allowed oanavidtr. v man effective \ oand wiitr. tr.resr.=i one aigr. util cut ci ftisrr._ausy_utij. * act on conng sign ousy util tares » allow oandvidtr. increment actions * smibub allowed oandwidtr. » ' low effective * oandwidtr. tnresr.clz one low util cut a t low ausy_-til * act on contig iow-flusy_util_tnres * allow oandwidtA decrement actions * aax contig retry oefore civmc up • no action taresnald tine •/
Table I - Virtual 5 Cnannel Attributes (in Z language representaticr.
242529
APPENDIX II
SEND TO REMOTE ROUTINE
If (VC in Steady State) {
if (Data-Block Ready to Send) {
Add VC Header to DataBlock;
Send Block to Curr-Line LAPD Process; Update Curr-Line to Next-Line in RR Fashion;
if (Finish Complete Round of Line) {
Update VC Header Gen-Seq-Number;
}
>
Exit;
> else if (Curr_Line Active) {
if (Date-Block Ready to Send) {
Add VC Header to Data-Block;
Send Block to Curr-Line LAPD Process; Update Curr-Line to Next-Line in RR Fashion;
goto RL_CF;
}
else if (Anything to send in Transient-Line ) {
Send Fill Block with VC Header;
Send Block to Process for
Synchronization;
Update Curr-Line Next-Line in RR Fashion;
goto RL_CF;
>
> else {
Send VC Protocol Message to Create Active Channel;
Send Block to Curr-Line LAPD Process; Update Curr-Line Next-Line in RR Fashion;
goto RL_CF;
>
32
AfPEWiX »:
RECEIVE FROM REMOTE RQCTINE
r vr. SS: if f'~ is in Staasy Si.«L*»,
RHQ_E: if (Round-Robin Queue is Empty, {
~ Update Virtual Cnannel Receiving-
expected Generation Sequence Number;
}
1C Exit; /• no data to tend */
► {
Process a Queue in Round-Robin Ordar; Deliver Message to Appropriate Party;
goto VC SS;
}
> else {
if (Current Line is Active) 20 goto RRQ-E;
else {
TB_0 S: if (Trace-Back Timer and Operation is
~ Start) {
if (Current-Line is Non-empty OR
Trace-Back Timer is Expired) if (Round-Robin Queue is Update to The First Non-empty Departure) { Exit;
}
else {
Process a Line in Round-Robin
Order;
if (Massag-Gen-No is update) { 35 Deliver Message to
Appropriate Party for Active Line;
OR Process Protocal and Prepare Anser If any For Transient Line;
goto TB_0_S;
40 else {
if (Gen-No of Message is
Past.) {
Discard Messages;
Exit;
45 >
else Exit;
>
}
else Exit;
50 }else {
if (Cur-line is Empty){
24252
if (Non-empty Line ti Gen-Messge >■ Current) {
Start traceback Timer; .
Wait for Message on Curent Line OR
Timer to Exprie;
}
> else {
Process Protocl and Prepare Answer if Any
Queue for Transmition;
>
Exit:
242529
33
Claims (38)
1. A method of automatically allocating/deallocating B-channels in a computer interface to ISDN, said method comprising the steps, above the LAP-D protocol, of: (a) monitoring events supplied to the ISDN which indicated requests to use or release a B-channel; (b) evaluating channel usage priorities associated with users generating events monitored in step (a); and (c) based upon said channel usage priorities, automatically setting up or tearing down B-channels associated with said ISDN.
2. The method of claim 1, wherein said events include setup and teardown messages arriving to the ISDN over the D-channel of said ISDN.
3. The method of claim 1, wherein said events further include generation of local messages by said computer or other devices locally attached to said interface.
4. The method of claim 1, wherein said ISDN is a Basic Rate Interface (BRI).
5. The method of claim 1, including the steps of activating a virtual B-channel between two compatible computer processes using a B-channel set up in step (c), and wherein step (c) includes the steps of logically adding or deleting channels to or from said virtual B-channel, and tearing down said virtual B-channel based upon a condition predetermined by said computer processes. (r - 'v> [fj — •£■*. Oj, V 30 SEP 1994 242 5 34
6. The method of claim 1, wherein said events include local events generated by an analog telephone 5 interfaced by said computer interfaced to the ISDN.
7. The method of claim 1, wherein said computer interface includes at least one of a shared memory component or UART component, and wherein step (a) 10 includes monitoring events generated by a computer process communicating with said shared memory or UART component of said interface.
8. The method of claim 1, wherein step (b) 15 includes assigning properties to said events, and step (c) includes allocating or deallocating B-channels based upon bandwidth requirements of events having particular properties. 20
9. The method of claim 8, including activating a virtual B-channel between two compatible computer processes using a B-channel set up in step (c), and wherein said step of assigning is carried out during said step of activating. 25
10. The method of claim 1, wherein step (c) includes further allocating or deallocating B-channels complementarily. 30
11. A method of forming a virtual B-channel in a computer interface to ISDN, for communication between two compatible computer processes, out of a pool of B-channels from said ISDN, comprising the steps of: (a) setting up a virtual B-channel with a 35 circuit switched B-channel from said ISDN; '' -in SEP 1994 24252 35 {b} logically adding or deleting circuit-switched B-channels into or from said ISDN into or from 5 said virtual B-channel activated in step (a); (c) dynamically allocating or deallocating B-channels to or from said virtual B-channel based upon usage by said computer processes; and (d) tearing down said virtual B-channel based 10 upon a condition predetermined by said computer processes.
12. The method of claim 11, wherein step (c) includes a step of implementing a protocol between said 15 computer processes for using all B-channels of said virtual B-channel while dynamically allocating or deallocating circuit-switched B-channels to or from said virtual B-channel based upon channel usage by said computer processes. 20
13. The method of claim 11, wherein said method comprises a full duplex mode made of communication, and the step of adding or deleting multiple circuit-switched B-channels into or from said 25 ISDN into or from said virtual B-channel is carried out as a parallel process.
14. The method of claim 11, including the additional steps of: 30 (a) monitoring on said ISDN events that are local or remote with respect to one of said computer processes; and (b) in response to step (a), evaluating channel requirements of said remote or local events; 35 wherein step (b) includes the step of automatically setting up or tearing down a circuit-switched B-channel based upon said channel requirements. \ SO SEP 1994"i 2425*9
15. The method of claim 12, wherein the step of implementing includes exchanging between said 5 processes information sufficient to indicate that an incoming call set up request is directed to said virtual B-channel, and allocating a circuit-switched B-channel thereto. 10
16. The method of claim 11, wherein step (b) is initiated by either one of said compatible computer processes.
17. The method of claim 11, wherein steps (b), 15 (c) and (d) are initiated by the computer processes or user applications.
18. Apparatus for interfacing a personal computer to ISDN, comprising: 20 a processor; and program means executable by said processor and operating above the LAPD Layer of the Open Systems Integration (OSI) model for monitoring events supplied to the ISDN which indicate requests to use or release a 25 B-channel; evaluating channel usage priorities associated with users generating events; and based upon said channel usage priorities, automatically setting up or tearing down B-channels associated with said ISDN. 30
19. The apparatus of claim 18, wherein said program means includes means for activating a virtual B-channel between two compatible computer processes using a B-channel that has been set by said program means, and logically adding or deleting channels to or from said 35 virtual B-channel, and tearing down said virtual B-channel based upon a condition predetermined by said - -t t f , computer processes. ^ </ ^ « ... ^ f * 30 SEP 1994 194 "J t?/ t 242 5?
20. The apparatus of claim 18, wherein said program means includes means for assigning properties to said event1 and allocating or deallocating B-channels based upon bandwidth requirements of events having particular properties.
21. The apparatus of claim 18, including at least one of a shared memory component and UART component, and wherein said program means includes means for monitoring events generated by a computer process communicating with said shared memory or UART component.
22. Apparatus for interfacing a personal computer to ISDN, comprising: a processor; and program means executable by said processor and operating above the LAPD Layer of the Open Systems Integration (OSI) model for activating a virtual B-channel with a B-channel from said ISDN; logically adding or deleting a B-channel into or from said ISDN into an activated virtual B-channel; dynamically allocating or deallocating B-channels to or from said virtual B-channel based upon usage by said computer processes; and tearing down said virtual B-channel based upon a condition predetermined by said computer processes.
23. The apparatus of claim 22, wherein said program means includes means for implementing a protocol between said computer processes for using all B-channels of said virtual B-channel while dyncimically allocating or deallocating B-channels to or from said \ *M S 242 52 virtual B-channel based upon channel usage by said computer processes.
24. The apparatus of claim 22, wherein said 5 program means includes monitoring remote events on the D-channel of said ISDN and local events to the ISDN, and, in response, evaluating channel requirements of said remote or local events including automatically setting up or tearing down a B-channel based upon said 10 channel requirements.
25. The apparatus of claim 22, including at least one of a shared memory component and UART component, and wherein said program means includes 15 means for monitoring events generated by a computer process communicating with said shared memory or UART component.
26. Apparatus for interfacing a personal 20 computer to ISDN, comprising: a processor; and program means executable by said processor and operating above the LAPD Layer of the Open Systems Integration (OSI) model for activating a virtual B-25 channel with a B-channel from said ISDN, logically adding or deleting a B-channel into or from said ISDN into an activated virtual B-channel, dynamically allocating or deallocating B-channels to or from said virtual B-channel based upon usage by said computer 30 processes, and tearing down said virtual B-channel based upon a condition predetermined by said computer processes; said program means comprising (a) a channel management module (CMM) for • V ^ 39 'LVL b inonitorinq requests to connect or disconnect B-channels by users; and (b) a virtual channel module (VCM) responsive to information from said CMM and providing a block 5 oriented transport service to computer processes capable of operating over one or more B-channels for allocating or deallocating B-channels to or from a virtual B-channel without interrupting flow of data in said virtual B-channel. 10
27. The apparatus of claim 26, wherein said CMM further supplies to said VCM information on availability of a B-channel when a user disconnects it. 15 28. The apparatus of claim 26, wherein said
CMM further supplies to said VCM information instructing deallocation of a B-channel from said virtual B-channel upon a request for channel connection by a user having a priority greater than the priority 20 of a current user.
29. The apparatus of claim 26, wherein said VCM includes means for detecting in a line a message transmission containing an error rate greater than a 25 predetermined acceptable error rate, and in response, requesting deallocation of said line.
30. The apparatus of claim 26, wherein said program means further includes traceback timer means 30 initiated at the probable logical end of a receiving for recovery of time inverted propagation of events on the ISDN.
31. The apparatus of claim 26, wherein said 2 42 5 > 40 program means further includes means for operating a channel vely in deactivated, activated and transient states. 5
32. The apparatus of claim 26, wherein said program means further includes means for synchronization of channels in steady state and parallel insertion and deletion of component channels into or from a virtual 10 channel.
33. The apparatus of claim 32, wherein said synchronization means includes means for performing simultaneous longitudinal and transverse data flow 15 regulation in said channels.
34. The apparatus of claim 33, wherein said longitudinal data regulation comprises regulation by generation number. 20
35. The apparatus of claim 33, wherein said transverse data regulation comprises regulation by a round-robin protocol. 25
36. The apparatus of claim 35, wherein said round-robin protocol comprises regulation by a traceback timer and data fragmentation.
37. A method of automatically 30 allocating/deallocating B-channels, substantially as described herein with reference to Figs 2 to 10 of the accompanying drawings.
38. Apparatus for interfacing a personal 35 computer to ISDN substantially as described herein with reference to Figs 2 to 10 of the accompanying drawings. N 7 (J, WESTrWALKER McCME ^ per: m.l J i i - ..... v -rn aq£\A. ; ATTORNEYS FOR THE APPLICANT * 50 Stf* ii
Applications Claiming Priority (1)
| Application Number | Priority Date | Filing Date | Title |
|---|---|---|---|
| PCT/US1991/003448 WO1992021187A1 (en) | 1991-05-23 | 1991-05-23 | Dynamic channel allocation method and system for integrated services digital network |
Publications (1)
| Publication Number | Publication Date |
|---|---|
| NZ242529A true NZ242529A (en) | 1995-07-26 |
Family
ID=22225536
Family Applications (1)
| Application Number | Title | Priority Date | Filing Date |
|---|---|---|---|
| NZ242529A NZ242529A (en) | 1991-05-23 | 1992-04-28 | Allocating/deallocating b channels in a computer interface to isdn |
Country Status (3)
| Country | Link |
|---|---|
| CA (1) | CA2109836C (en) |
| NZ (1) | NZ242529A (en) |
| WO (1) | WO1992021187A1 (en) |
Families Citing this family (8)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| CA2107047C (en) * | 1992-12-29 | 1998-04-28 | Alan M. Bentley | Switched circuit connection management over public data networks for wide area networks |
| GB2295520A (en) * | 1994-10-15 | 1996-05-29 | Knx Limited | Communications device having priority control |
| US6005847A (en) * | 1997-07-07 | 1999-12-21 | Siemens Information And Communications Network, Inc. | Method and apparatus for facilitating communication between multiple platforms via single, multi-channel communication conduit |
| JP4054477B2 (en) * | 1998-04-08 | 2008-02-27 | キヤノン株式会社 | COMMUNICATION DEVICE CAPABLE OF COMMUNICATION USING MULTIPLE COMMUNICATION CHANNELS TO THE SAME PARTY AND ITS CONTROL METHOD |
| FR2870417B1 (en) * | 2004-05-17 | 2006-09-01 | France Telecom | TELECOMMUNICATION TERMINAL FOR ISDN INTEGRATION NETWORK |
| FR2870419B1 (en) * | 2004-05-17 | 2006-09-01 | France Telecom | METHOD FOR ESTABLISHING COMMUNICATION OVER ISDN NETWORK AND CORRESPONDING TELECOMMUNICATION INSTALLATION |
| CN101540872B (en) * | 2009-02-23 | 2012-07-04 | 华为终端有限公司 | Control method of multichannel cascade connection of media control server, device and system thereof |
| CN106850045B (en) * | 2017-01-17 | 2020-04-24 | 北京邮电大学 | Self-adaptive over-subscription LEO satellite system channel allocation method |
Family Cites Families (5)
| Publication number | Priority date | Publication date | Assignee | Title |
|---|---|---|---|---|
| DE3316492A1 (en) * | 1983-05-05 | 1984-11-08 | Siemens AG, 1000 Berlin und 8000 München | CIRCUIT ARRANGEMENT FOR THE SUBSCRIBER CONNECTION IN A SERVICE-INTEGRATING DIGITAL NETWORK (ISDN) |
| JPS63214043A (en) * | 1987-03-02 | 1988-09-06 | Fujitsu Ltd | Packet communication service system |
| US4958153A (en) * | 1987-04-08 | 1990-09-18 | Nec Corporation | Method and apparatus for priority control of incoming calls at ISDN terminals |
| US4958343A (en) * | 1988-11-30 | 1990-09-18 | At&T Bell Laboratories | Communication channel reservation |
| US4896350A (en) * | 1989-03-29 | 1990-01-23 | American Telephone And Telegraph Company | Arrangement for providing a call-connection service |
-
1991
- 1991-05-23 CA CA002109836A patent/CA2109836C/en not_active Expired - Lifetime
- 1991-05-23 WO PCT/US1991/003448 patent/WO1992021187A1/en not_active Ceased
-
1992
- 1992-04-28 NZ NZ242529A patent/NZ242529A/en not_active IP Right Cessation
Also Published As
| Publication number | Publication date |
|---|---|
| WO1992021187A1 (en) | 1992-11-26 |
| CA2109836C (en) | 2000-10-17 |
Similar Documents
| Publication | Publication Date | Title |
|---|---|---|
| US5463629A (en) | Dynamic channel allocation method and system for integrated services digital network | |
| US5912888A (en) | Digital network access server | |
| US5442630A (en) | ISDN interfacing of local area networks | |
| US5528595A (en) | Modem input/output signal processing techniques | |
| US4996685A (en) | Technique for dynamically changing an ISDN connection during a host session | |
| EP0605349B1 (en) | Switched circuit connection management over public data networks for wide area networks | |
| EP0965204B1 (en) | Access to telecommunications networks in a multiservice environment | |
| US5051982A (en) | Methods and apparatus for implementing switched virtual connections (SVCs) in a digital communications switching system | |
| EP1850601A1 (en) | Device and method for distributed network control | |
| US6430162B1 (en) | Automatic echo cancellation for an integrated services digital network interface | |
| KR19980041666A (en) | ISDN D-Channel Signaling Discriminator | |
| Shepherd et al. | Protocol support for distributed multimedia applications | |
| CA2109836C (en) | Dynamic channel allocation method and system for integrated services digital network | |
| US5680589A (en) | Ring communication system using ISDN | |
| US5329523A (en) | Extension agent system of ISDN electronic exchange | |
| JPH0879309A (en) | LAN connection device and LAN connection system | |
| US6674722B1 (en) | Processes in a distributed multiprocessor system | |
| Hertweck et al. | X25 based process—process communication | |
| WO1992021188A1 (en) | Channel utilization method and system for isdn | |
| JP2731007B2 (en) | Circuit switching system | |
| JP2761880B2 (en) | Transmission control system for private branch exchange | |
| JP2812767B2 (en) | Packet terminal device and communication system | |
| JP2831687B2 (en) | Terminal address management method | |
| NZ242530A (en) | Gateway between lan and isdn | |
| CN1247685A (en) | Subscriber network terminal of access line network and method for operating network connecting unit |
Legal Events
| Date | Code | Title | Description |
|---|---|---|---|
| RENW | Renewal (renewal fees accepted) | ||
| RENW | Renewal (renewal fees accepted) | ||
| EXPY | Patent expired |