KR100209360B1 - B-isdn interfacing apparatus providing intelligent device driver - Google Patents

B-isdn interfacing apparatus providing intelligent device driver Download PDF

Info

Publication number
KR100209360B1
KR100209360B1 KR1019960060344A KR19960060344A KR100209360B1 KR 100209360 B1 KR100209360 B1 KR 100209360B1 KR 1019960060344 A KR1019960060344 A KR 1019960060344A KR 19960060344 A KR19960060344 A KR 19960060344A KR 100209360 B1 KR100209360 B1 KR 100209360B1
Authority
KR
South Korea
Prior art keywords
aim
data
call
device driver
connection
Prior art date
Application number
KR1019960060344A
Other languages
Korean (ko)
Other versions
KR19980041075A (en
Inventor
이해영
설근석
정상현
이필종
정학진
Original Assignee
이계철
한국전기통신공사
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 이계철, 한국전기통신공사 filed Critical 이계철
Priority to KR1019960060344A priority Critical patent/KR100209360B1/en
Publication of KR19980041075A publication Critical patent/KR19980041075A/en
Application granted granted Critical
Publication of KR100209360B1 publication Critical patent/KR100209360B1/en

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/28Data switching networks characterised by path configuration, e.g. LAN [Local Area Networks] or WAN [Wide Area Networks]

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)

Abstract

본 발명은 지능형 디바이스 드라이버를 제공하는 광대역 종합정보통신망 정합장치에 관한 것으로, 보다 상세하게는 호스트 프로세서와 로컬 프로세서로 이루어지며 호스트 프로세서의 부담을 줄일 수 있도록 시그널링, 계층 관리, 평면관리 모듈을 로컬프로세서가 수용하며 호스트 프로세서에서 수용하는 디바이스 드라이버는 인터넷 접속 서비스를 지원하기 위하여 서비스 필터링 기능을 갖는 지능형 디바이스 드라이버를 제공하는 광대역 종합정보통신망 정합장치에 관한 것이다.The present invention relates to a broadband integrated information network matching device for providing an intelligent device driver, and more particularly, comprising a host processor and a local processor. The device driver accommodated by the host processor is related to a broadband integrated information network matching device that provides an intelligent device driver having a service filtering function to support an internet access service.

채널에 따라 로컬 프로세서와 호스트 프로세서로 라우팅이 가능한 Bt8230을 사용하여 운용유지보수관리(OAM) 및 시그널링 처리를 로컬 프로세서에 맡김으로써 호스트 프로세서의 부담을 줄일 수 있는 ATM 통신망 정합보드를 개발하였으며 이를 이용하여 호스트 프로세서가 사용자 데이타 처리를 전담하도록 하는 지능형 디바이스 드라이버를 제공하는 광대역 종합정보통신망 정합장치를 제공한다.By using Bt8230 which can be routed to local processor and host processor according to channel, we developed ATM network matching board to reduce the burden of host processor by delegating OAM and signaling processing to local processor. It provides a broadband integrated information network matching device that provides an intelligent device driver that allows a host processor to handle user data processing.

Description

지능형 디바이스 드라이버를 제공하는 광대역 종합정보통신망 정합장치Broadband Telecommunication Network Matching Device Providing Intelligent Device Driver

본 발명은 지능현 디바이스 드라이버를 제공하는 광대역 종합정보통신망 정합장치에 관한 것으로, 보다 상세하게는 호스트 프로세서와 로컬 프로세서로 이루어지며 호스트 프로세서의 부담을 줄일 수 있도록 시그널링, 계층 관리, 평면관리 모듈을 로컬 프로세서가 수용하며 호스트 프로세서에서 수용하는 디바이스 드라이버는 인터넷 접속 서비스를 지원하기 위하여 서비스 필터링 기능을 갖는 지능형 디바이스 드라이버를 제공하는 광대역 종합정보통신망 정합장치에 관한 것이다.The present invention relates to a broadband integrated information network matching device for providing a smart device driver, and more particularly, comprising a host processor and a local processor, and localized signaling, layer management, and plane management module to reduce the burden on the host processor. A device driver accommodated by a processor and accommodated by a host processor relates to a broadband integrated information network matching device that provides an intelligent device driver having a service filtering function to support an internet access service.

최근부터 멀티미디어 서비스에 대한 모든 산업부분 특히 통신부문 및 가전부문에서의 열의는 대단하다. 이 멀티미디어는 인터넷을 통하여 주로 이루어지고 있는데 현재의 인터넷은 어드레스의 한계가 있기 때문에 이를 모든 가입자에게 할당하기 힘들고 공중망과의 연동이 용이하지 않은 단점을 가지고 있기 때문에 일반인이 쉽게 접근하기 어렵다. 더구나 동영상과 같은 멀티미디어 서비스는 대용량 및 초고속과 같은 능력을 요구하고 있기 때문에 이들을 초고속 통신망 특히 광대역 종합정보통신망(Broadband Integration Services Digital Network : B-ISDN) 망과의 연동을 통하여 서비스 하고자 하는 추세가 전문가 그룹(ITU-T 그리고 ATM 포럼)들을 통하여 이루어지고 있다. B-ISDN망은 다음과 같은 서비스에 대처할 능력을 가지고 있다.In recent years, enthusiasm for multimedia services in all industries, particularly in the telecommunications and consumer electronics sectors, has been tremendous. This multimedia is mainly done through the Internet. Because the current Internet has a limitation of address, it is difficult to assign it to all subscribers and it is difficult to access to the general public because it has a disadvantage that it is not easy to connect with the public network. Moreover, since multimedia services such as video demand high-capacity and high-speed capabilities, there is a tendency to service them through interworking with high-speed networks, in particular, Broadband Integration Services Digital Network (B-ISDN). (ITU-T and ATM Forums). The B-ISDN network has the ability to cope with the following services.

대화형 서비스: 영상전화, 영상회의, 데이타 전송 그리고 문서통신 등등Interactive services: video telephony, video conferencing, data transmission and telecommunications etc.

메시지 서비스: 동영상 메일, 음성 메일 그리고 전자우편 등등Message service: video mail, voice mail and email

검색 서비스: 비디오텍스, 데이타베이스 그리고 멀티미디어 DB 등등Search services: Videotex, Database and Multimedia DB etc.

분배성 서비스: 주문형 비디오(Video-On-Demand), 전자 신문 그리고 전자출판 등등.Distributive Services: Video-On-Demand, electronic newspapers and electronic publishing.

위에서 언급한 서비스를 제공할 호스트의 플랫폼으로 가정에서 가장 대중적으로 사용하리라 여겨지는 윈도우즈 NT(Windows NT)를 운용하는 PC가 B-ISDN망에 접속하여 멀티미디어 서비스를 제공받을 수 있도록 망정합장치가 필요하다.A network matching device is required so that a PC running Windows NT, which is considered to be the most popular in the home, as the platform of the host to provide the above-mentioned services, can access the B-ISDN network and receive multimedia services. Do.

그러나, 현재까지 나와 있는 B-ISDN망 정합 장치로서는 주로 워크스테이션 상에서 B-ISDN 통신 정합(B-ISDN DSS2)을 소프트웨어로 처리함으로써 호스트 프로세서의 부담을 가중시키는 문제점이 있었다.However, as the B-ISDN network matching device described up to now, the B-ISDN communication matching (B-ISDN DSS2) is mainly processed on the workstation by software, which adds to the burden on the host processor.

본 발명은 상기와 같은 호스트 프로세서의 부담을 덜고 로컬 프로세서를 사용하므로써 전체시스템의 안정을 가져올 수 있도록 하는 지능형 디바이스 드라이버를 제공하는 광대역 종합정보통신망 정합장치를 제공하고자 한다.The present invention is to provide a broadband integrated information network matching device that provides an intelligent device driver to reduce the burden of the host processor as described above and to bring stability to the entire system by using a local processor.

상기와 같은 목적을 달성하기 위하여 본 발명은 채널에 따라 로컬 프로세서(B-ISDN망의 정합장치 내의 프로세서를 의미하며 이하, 로컬 프로세서라 한다)와 호스트 프로세서(플랫폼으로 사용되는 스테이션의 프로세서를 의미하며 이하, 호스트 프로세서라 한다)로 라우팅이 가능한 Bt8230을 사용하여 운용유지보수관리(Opreation And Management ; OAM) 및 시그널링 처리를 로컬 프로세서에 맡김으로써 호스트 프로세서의 부담을 줄일 수 있는 ATM 통신망 정합보드(ATM Interface Module: 이하, AIM라 한다)를 개발하였으며 이를 이용하여 호스트 프로세서가 사용자 데이타 처리를 전담하도록 하는 지능형 디바이스 드라이버를 제공하는 광대역 종합정보통신망 정합장치를 제공한다.In order to achieve the above object, the present invention refers to a local processor (a processor in a matching device of a B-ISDN network, hereinafter referred to as a local processor) and a host processor (a processor of a station used as a platform) according to a channel. ATM Network Interface Board (ATM Interface), which can reduce the burden on the host processor by using the Bt8230, which can be routed to the host processor, to entrust the Operation And Management (OAM) and signaling processing to the local processor. Module (hereinafter referred to as AIM) is used to provide a broadband integrated information network matching device that provides an intelligent device driver for the host processor to handle user data.

제1도는 본 발명에 따른 호스트 프로세서의 구성도.1 is a block diagram of a host processor according to the present invention.

제2도는 본 발명에 따른 로컬 프로세서의 구성도.2 is a block diagram of a local processor according to the present invention.

제3도는 전체 프로세서간의 통신을 위한 프리미티브 헤더의 구성도.3 is a block diagram of a primitive header for communication between all processors.

제4도는 본 발명에 따른 응용 프로그램의 AIM API 상세도.4 is a detailed view of an AIM API of an application program according to the present invention.

제5도는 로컬 프로세서를 위한 ATM 통신망 정합 보드의 메모리 구성도.5 is a memory diagram of an ATM network matching board for a local processor.

제6도는 로컬 프로세서 신호 모듈의 SSCOP의 처리 흐름도.6 is a process flow diagram of the SSCOP of the local processor signal module.

제7도는 Bt8230의 세그먼테이션 처리 흐름도.7 is a flowchart of segmentation processing of Bt8230.

제8도는 Bt8230의 리어셈블리 처리 흐름도이다.8 is a flowchart of a reassembly process of Bt8230.

* 도면의 주요부분에 대한 부호의 설명* Explanation of symbols for main parts of the drawings

100 : 호/연결 데이타 분배장치 101 : AIM API 동적 링크 라이브러리100: call / connection data distribution device 101: AIM API dynamic link library

102 : AIM 상위 디바이스 드라이버102: AIM parent device driver

103 : AIM 네트워크 디바이스 인터페이스 디바이스 드라이버103: AIM Network Device Interface Device Driver

104 : LAN 에뮬레이션 수단 105 : AIM 하위 디바이스 드라이버104: LAN emulation means 105: AIM lower device driver

200 : 호스트 접속 데이타 분배 장치200: host connection data distribution device

201 : 망 접속 데이타 분배 장치 202 : 계층 관리 모듈201: network access data distribution device 202: layer management module

203 : 평면 관리 모듈 204 : 타이머203: plane management module 204: timer

210 : 신호 모듈210: signal module

본 발명은 호스트 프로세서와 로컬 프로세서로 구성되며, 상기 호스트 프로세서는 ATM 인터페이스 모듈의 응용 프로그램 인터페이스(AIM API)를 제공하기 위한 AIM API 동적 링크 라이브러리(AIM API DLL)와, 상기 동적 링크 라이브러리와 동적 데이타 교환을 통하여 호/연결 접속 정보와 사용자 데이타를 주고 받기 위한 호/연결 데이타 분배장치(CDDM)와, 상기 호/연결 데이타 분배장치가 AIM 디바이스에 접근할 수 있도록 하기 위한 AIM 상위 디바이스 드라이버와, ATM 네트워크를 통하여 네트워크 디바이스에게 데이타 링크 레이어 서비스를 제공하기 위한 AIM 네트워크 디바이스 인터페이스 디바이스 드라이버, 및 AIM 상위 디바이스는 드라이버가 AIM 디바이스 드라이버 인터페이스를 이용하여 호/연결 접속에 대한 제어정보, 사용자 데이타, 다중화/역다중화에 필요한 제어정보를 AIM 디바이스와 교환하기 위한 AIM 하위 디바이스 드라이버를 포함하며, 상기 로컬 프로세서는 상기 호스트 프로세서로부터 입력되는 제어 프리미티브를 공통메모리중의 로컬 메일박스 영역에 저장한 후 전달받거나, 제어 프리미티브를 공통메모리중의 호스트 메일박스에 저장한 후 호스트 프로세서로 전달하기 위한 호스트 접속 데이타 분배 장치와, 망으로부터 입력되는 메시지 프레임을 리어셈블리 버퍼에 저장한 후 하위 프리미티브 구조를 갖는 제어 프리미티브로 전환하여 입력큐로 전달하거나, 입력된 제어 프리미티브의 헤더를 제외한 메시지 프레임을 분할 버퍼에 저장한 후 Bt8230에 의해 분할한 후 망으로 전송하기 위한 망 접속 데이타 분배 장치와, 일대일 호/연결 제어, 일대다 호/연결 제어, 객체관리자를 통한 객체관리의 수행 및 신호와 프리미티브들을 매핑하고 순차적인 신호의 전달을 위한 신호 모듈, 및 ITU-T/I.610에 따른 F5 단대단 유지보수운용 관리를 위한 계층관리모듈과, 각 모듈들의 오류, 시스템 리소스들을 관리하고 오류 상태, 시스템 리소스 상태에 관한 정보를 제공하기 위한 평면관리모듈과, 타이머를 포함하는 것을 특징으로 하는 지능형 디바이스 드라이버를 제공하는 광대역 종합정보통신망 정합장치이다.The present invention comprises a host processor and a local processor, wherein the host processor includes an AIM API dynamic link library (AIM API DLL) for providing an application program interface (AIM API) of an ATM interface module, the dynamic link library and dynamic data. A call / connection data distribution device (CDDM) for exchanging call / connection connection information and user data through an exchange, an AIM high-level device driver for allowing the call / connection data distribution device to access an AIM device, and an ATM The AIM network device interface device driver for providing data link layer services to network devices over a network, and the AIM host device, the driver uses the AIM device driver interface to provide control information, user data, and multiplexing / deactivation for call / connection connections. Required for multiplexing An AIM subordinate device driver for exchanging control information with an AIM device, wherein the local processor receives and stores control primitives input from the host processor in a local mailbox area of common memory, or receives control primitives from a common memory. A host access data distribution device for storing in a host mailbox in the middle and transmitting it to a host processor, and a message frame input from a network is stored in a reassembly buffer, and then converted to a control primitive having a lower primitive structure and transferred to an input queue. Network access data distribution device for one-to-one call / connection control, one-to-many call / connection control, for storing message frames excluding the header of input control primitives in a partition buffer, segmenting by Bt8230, and then transmitting them to the network. Perform object management through object manager And a signal module for mapping signals and primitives and for sequential signal transmission, and a layer management module for F5 end-to-end maintenance operation management according to ITU-T / I.610, and managing errors and system resources of each module. And a planar management module for providing information on an error state and a system resource state, and a timer, and a device for providing an intelligent device driver.

상술한 목적, 특징, 및 장점들은 첨부된 도면과 관련한 다음의 상세한 설명을 통하여 보다 분명해 질 것이다. 이하 첨부된 도면을 참조하여 본 발명의 실시예를 상세히 설명하기로 한다.The above objects, features, and advantages will become more apparent from the following detailed description taken in conjunction with the accompanying drawings. Hereinafter, embodiments of the present invention will be described in detail with reference to the accompanying drawings.

상기와 같이 본 발명은 호스트 프로세서의 부담을 줄이고 통신 효율을 높이기 위하여 로컬 소프트웨어(또는 ATM 통신망 정합보드내의 소프트웨어라고도 하며 이하, 로컬 소프트웨어라 한다)를 이용하는 로컬 프로세서와 호스트 소프트웨어(PC 혹은 워크스테이션에서 운용되는 소프트웨어를 의미하며 이하, 호스트 소프트웨어라 한다)를 이용하는 호스트 프로세서로 구성된다. 즉, 호스트 프로세서는 디바이스 드라이버, 응용 프로그램과 호를 연결하는 모듈 그리고 응용 프로그램의 편리한 인터페이스를 위하여 응용 프로그램 인터페이스(Application Program Interface ; API)를 제공하며, 특히 디바이스 드라이버는 B-ISDN 전용 서비스 및 LAN 에뮬레이션(Emulation)을 이용하여 기존의 인터넷 망의 인터넷 접속 장치를 접속할 수 있는 서비스를 지원하기 위하여 서비스 필터링 기능을 제공하는 지능형 디바이스 드라이버로 구성된다.As described above, the present invention uses a local processor (or software in an ATM network matching board, hereinafter referred to as local software) and a host software (operating in a PC or a workstation) to reduce the burden on the host processor and increase communication efficiency. It refers to the software that is referred to as, and hereinafter referred to as the host software). In other words, the host processor provides an application program interface (API) for device drivers, modules for connecting applications and calls, and for convenient interface of applications. Especially, the device driver provides B-ISDN dedicated service and LAN emulation. It is composed of intelligent device driver that provides service filtering function to support service that can access internet access device of existing internet network by using (Emulation).

그리고, 로컬 프로세서는 호스트 프로세서의 부담을 줄일 수 있도록 시그널링, 계층 관리 그리고 평면관리 모듈을 수용함으로써 호스트 프로세서가 이들을 관리하지 않고 시스팀 리소스들을 충분히 사용할 수 있도록 배려한다. 이들 로컬 프로세서와 호스트 프로세서의 구조는 제1도와 제2도에서 나타내었다.In addition, the local processor accommodates signaling, layer management, and plane management modules to reduce the burden on the host processor so that the host processor can fully utilize the system resources without managing them. The structures of these local and host processors are shown in FIG. 1 and FIG.

이 때 호스트 프로세서와 로컬 프로세서 혹은 로컬 프로세서간의 통신은 제3도에서 나타낸 프리미티브 구조를 가지고 전달된다. 그리고 ATM 정합 보드의 PCI 버스 콘트롤과 AAL기능을 가진 Bt8230과 로컬 프로세서가 동시에 공유하는 메모리를 가지고 있다.At this time, communication between the host processor and the local processor or the local processor is carried with the primitive structure shown in FIG. It also has memory shared between the local processor and the Bt8230 with ATM bus PCI bus control and AAL.

본 발명에 따른 호스트 프로세서는 AIM API 제공용 동적 라이브러리(AIM API DLL), 호/연결 데이타 분배장치(CDDM: Call/connection Data Distributor Module), AIM 상위 디바이스 드라이버(AIM Upper Device Driver), AIM NDIS 디바이스 드라이버(AIM Network Device Interface Specification Device Driver) LAN 에뮬레이션 수단, 및 AIM 하위 디바이스 드라이버(AIM Lower Device Driver)를 포함한다.The host processor according to the present invention is a dynamic library for providing AIM API (AIM API DLL), call / connection data distributor (CDDM), AIM Upper Device Driver (AIM Upper Device Driver), AIM NDIS device Driver (AIM Network Device Interface Specification Device Driver) LAN emulation means, and AIM Lower Device Driver.

제1도에서 윈도우즈 NT에 구현된 호스트 프로세서의 각 모듈들의 기능 및 구성은 다음과 같다.In FIG. 1, the functions and configurations of the respective modules of the host processor implemented in Windows NT are as follows.

AIM API 제공용 동적 링크 라이브러리(AIM API DLL)(101)는 AIM API를 통하여 AIM 서비스를 직접 접근할 수 있게 한다. AIM API는 기존의 소켓(socket) 인터페이스와 거의 유사한 형태를 취하도록 설계하였으며, 또한 점대 다중점 연결을 지원할 수 있도록 하였고 제4도는 API를 사용하는 응용 프로그램의 상태도를 나타내었다. 제4도의 API에 대한 개략적인 기술이다.The dynamic link library (AIM API DLL) 101 for providing AIM APIs enables direct access to AIM services through the AIM API. The AIM API is designed to take almost the same shape as the existing socket interface, and also supports point-to-multipoint connection, and FIG. 4 shows a state diagram of an application using the API. A schematic description of the API of FIG.

aim_open: 호/연결 기술자를 얻는다.aim_open: get call / connect descriptor

aim_connect: 호/연결 접속을 시도한다.aim_connect: Attempt to call / connect

aim_bind: 호/연결 기술자에 응용의 서비스 접속점(Service Access Point ; SAP)를 지정한다.aim_bind: Specifies the service access point (SAP) of the application in the call / connection descriptor.

aim_listen: 호/연결 접속을 기다린다.aim_listen: wait for a call / connection

aim_accept: 호/연결 접속을 허락한다.aim_accept: Allow call / connection connection.

aim_reject: 호/연결 접속을 거절한다.aim_reject: Rejects a call / connection.

aim_write: 접속된 호/연결을 통하여 데이타를 보낸다.aim_write: Send data through connected call / connection.

aim-read: 접속된 호/연결을 통하여 데이타를 받는다.aim-read: Receive data through a connected call / connection.

aim_disconnect: 호/연결 접속을 해제한다.aim_disconnect: Disconnect a call / connect.

aim_add_party: 점대 다중점 호/연결에 대하여 파티를 추가한다.aim_add_party: Add a party for point-to-multipoint call / connection.

aim_drop_party: 점대 다중점 호/연결에 대하여 파티를 제거한다.aim_drop_party: Drop a party for point-to-multipoint call / connection.

aim_ctrl: 호/연결에 대한 제어를 요청한다.aim_ctrl: Request control of a call / connection.

aim_close: 호/연결 기술자를 돌려준다.aim_close: Returns the call / connection descriptor.

aim_get_last_error: 호/연결에 대한 최종 에러를 돌려준다.aim_get_last_error: Returns the last error for the call / connection.

aim_set_last_error: 호/연결에 대한 최종 에러를 세팅한다.aim_set_last_error: Set the last error for call / connection.

호/연결 데이타 분배 장치(CDDM : Call/connection Data Distributor Module )(100)는 제1도에서 보는 바와 같이 AIM 동적 데이타 교환 쓰레드(AIM Dynamic Data Exchange(DDE) Thread)(106), 트랜잭션 쓰레드(Transaction Thread)(107 ), AAL5 서비스 쓰레드(108), 그리고 제어 쓰레드(Control Thread)(109) 등의 멀티 쓰레드로 구성되어 멀티프로그래밍 환경에서 AIM 서비스를 제공하는 기능을 갖는다. AIM DDE 쓰레드(106)는 응용 프로그램들의 AIM API들로부터 데이타를 동적 데이타 교환을 통하여 입력받아 트랜잭션 쓰레드(107)로 전달하며 하위 계층에서 처리된 결과를 응용 프로그램이 가져갈 수 있도록 큐에 저장한다.The Call / Connection Data Distributor Module (CDDM) 100 is an AIM Dynamic Data Exchange Thread (DDE) 106, a transaction thread, as shown in FIG. A thread (107), an AAL5 service thread (108), and a control thread (Control Thread) (109) is composed of a multi-threaded AIM service in a multi-programming environment. The AIM DDE thread 106 receives data from the AIM APIs of the applications through dynamic data exchange and transfers the data to the transaction thread 107 and queues the result processed in the lower layer so that the application can take it.

트랜잭션 쓰레드(107)는 응용 프로그램으로부터의 프리미티브를 App_Xact_ Handler를 통하여 처리하고, AAL5 데이타를 Aal_Xact_Handler를 통하여 처리하며 통신을 위한 제어용 프리미티브는 Net_Xact_Handler를 통하여 처리한 후 처리결과를 AIM DDE 쓰레드(106)로 전달한다. AAL5 서비스 쓰레드(108)는 AIM API를 통하여 요청된 각 응용의 데이타 서비스를 ATM 정합보드를 통하여 다중화하고 역으로 ATM 정합보드를 통하여 요청된 서비스를 적절히 해당응용으로 역다중화한다.The transaction thread 107 processes the primitive from the application program through the App_Xact_ Handler, processes the AAL5 data through the Aal_Xact_Handler, and the control primitive for communication processes the Net_Xact_Handler and passes the processing result to the AIM DDE thread 106. do. The AAL5 service thread 108 multiplexes the data service of each application requested through the AIM API through the ATM matching board, and conversely demultiplexes the service requested through the ATM matching board to the appropriate application.

마지막으로 제어 쓰레드(109)는 B-ISDN 통신 제어 프리미티브를 트랜잭션 쓰레드로 전달하여 이를 처리하도록 한다. 호/연결 서비스의 경우 점대점(Q.2931), 점대 다중점(Q.2971) 호/연결 접속 서비스를 지원한다.Finally, the control thread 109 passes the B-ISDN communication control primitive to the transaction thread for processing. For call / connection service, point-to-point (Q.2931) and point-to-multipoint (Q.2971) call / connection connection services are supported.

AIM API DLL(101)과 호/연결 데이타 분배장치(CDDM)(100)는 동적 데이타 교환을 통하여 호/연결 접속 정보와 사용자 데이타를 주고 받으며, 그 인터페이스는 특정 AIM API와 무관하게 설계되었다. 따라서 CDDM(100)을 이용하여 새로운 API를 쉽게 설계하고 구현할 수 있도록 하였다.The AIM API DLL 101 and the call / connection data distribution device (CDDM) 100 exchange call / connection connection information and user data through dynamic data exchange, and an interface thereof is designed regardless of a specific AIM API. Therefore, it was possible to easily design and implement a new API using the CDDM (100).

AIM 상위 디바이스 드라이버(102)는 사용자 프로그램(예를들면 CDDM)이 AIM 디바이스를 접근할 수 있도록 한다. 사용자 프로그램은 시스템 콜을 통하여 호/연결, 데이타에 대한 서비스를 요청한다. AIM 상위 디바이스 드라이버(102)는 요청된 서비스를 즉시 AIM 하위 디바이스 드라이버(105)에게 투명하게 전달하며, AIM 하위 디바이스 드라이버(105)는 이를 처리한다.The AIM host device driver 102 allows a user program (eg CDDM) to access the AIM device. User program requests service for call / connection and data through system call. The AIM higher device driver 102 transparently delivers the requested service to the AIM lower device driver 105 immediately, which the AIM lower device driver 105 processes.

AIM 디바이스 드라이버(102, 105)를 상위와 하위 디바이스 드라이버로 분리한 이유는 여타의 윈도우즈(Windows) NT 상위레벨 디바이스 드라이버(예를 들면 LAN 에뮬레이션(Emulation) NDIS 드라이버(103))들 또한 ATM 디바이스를 접근할 수 있도록 하기 위한 것이다.The reason for separating the AIM device drivers 102 and 105 into upper and lower device drivers is that other Windows NT higher level device drivers (eg, LAN emulation NDIS driver 103) may also use ATM devices. This is to make it accessible.

AIM NDIS 디바이스 드라이버(103)는 ATM 네트웍을 통하여 네트웍 디바이스 드라이버(NetBEUI 또는 TCP/IP 프로토콜)에게 데이타 링크 레이어(Data Link Layer) 서비스를 제공한다. 이 때 AIM NDIS 디바이스 드라이버(103)는 AIM 하위 디바이스 드라이버(105)가 AIM 디바이스 드라이버 인터페이스(AIM DDI)를 통하여 제공하는 서비스를 이용하여 AIM 디바이스를 접근하고 LAN 에뮬레이션 수단은 AIM NDIS 디바이스 드라이버(103) 내부에 위치하여 어드레스 분석(Resolution) 서비스를 제공한다. AIM NDIS 디바이스 드라이버(103) 및 LAN 에뮬레이션 수단(104)은 제1도에서 보는 바와 같이 위치한다. LAN 에뮬레이션 기능을 갖추어 LAN 에뮬레이션 서버와 함께 사용되었을 경우, 기존의 TCP/IP 서비스 프로그램, 네트워크 기본 입출력 시스템(NetBIOS) 프로그램 등을 수정없이 ATM 네트워크 환경에서 사용될 수 있도록 한다.The AIM NDIS device driver 103 provides a data link layer service to a network device driver (NetBEUI or TCP / IP protocol) through an ATM network. At this time, the AIM NDIS device driver 103 accesses the AIM device using a service provided by the AIM subordinate device driver 105 through the AIM device driver interface (AIM DDI), and the LAN emulation means is the AIM NDIS device driver 103. It is located inside to provide address resolution service. The AIM NDIS device driver 103 and the LAN emulation means 104 are located as shown in FIG. With LAN emulation function, when used with LAN emulation server, existing TCP / IP service program and network basic input / output system (NetBIOS) program can be used in ATM network environment without modification.

AIM 하위 디바이스 드라이버(105)는 윈도우즈 NT 상위레벨 디바이스 드라이버들이 AIM 디바이스에 접근할 수 있도록 한다. 이를 위하여 AIM 디바이스 드라이버 인터페이스(AIM DDI)를 정의하였는데, 이 인터페이스를 통하여 호/연결 접속에 대한 제어 정보, 사용자 데이타, 다중화/역다중화에 필요한 제어 정보들을 주고 받는다. 호/연결 접속에 대한 제어 정보의 경우 메일박스와 인터럽트를 통하여 AIM 보드내의 호스트 접속 데이타 분배장치(100)에게 전달하며, 사용자 데이타의 경우는 AIM 보드에서 지원하는 AAL5 정합 데이타 유니트(Information Data Unit ; IDU)(ALL5_CPCS_SDU로 일대일 매핑하도록 구현되어 있다.)를 통하여 네트웍으로 전달한다. 다중화/역다중화에 필요한 제어정보는 자체 처리된다. AIM 디바이스 드라이버 인터페이스는 크게 두가지로 나뉜다. 첫째는 호/연결 제어 정보와 사용자 데이타의 다중화/역다중화에 필요한 인터페이스이며, 둘째는 호/연결 제어 정보와 사용자 데이타를 주고받는데 필요한 인터페이스이다.The AIM lower device driver 105 allows Windows NT higher level device drivers to access the AIM device. For this purpose, AIM device driver interface (AIM DDI) has been defined. Through this interface, control information for call / connection connection, user data, and control information for multiplexing / demultiplexing are exchanged. In the case of control information on the call / connection connection, the control information is transmitted to the host connection data distribution apparatus 100 in the AIM board through a mailbox and an interrupt, and in the case of user data, an AAL5 information data unit supported by the AIM board; It is delivered to the network through IDU) (implemented for one-to-one mapping to ALL5_CPCS_SDU). Control information necessary for multiplexing / demultiplexing is processed by itself. The AIM device driver interface is divided into two main categories. The first is an interface for multiplexing / demultiplexing call / connection control information and user data, and the second is an interface for exchanging call / connection control information and user data.

첫째의 경우에 필요한 인터페이스는 다음과 같다.In the first case, the interface needed is:

IOCTL_AIMDD_REGISTER_MSG_FILTER: 호/연결 제어 정보는 일단 메시지 필터링을 통해 역다중화된다. 이를 위한 제어 정보를 등록한다.IOCTL_AIMDD_REGISTER_MSG_FILTER: Call / connection control information is demultiplexed once through message filtering. Register control information for this.

IOCTL_AIMDD_UNREGISTER_MSG_FILTER: 메시지 필터링 역다중화에 대한 정보를 없앤다.IOCTL_AIMDD_UNREGISTER_MSG_FILTER: Removes information about message filtering demultiplexing.

IOCTL_AIMDD_ACTIVATE_ALL_SAP: 호/연결 접속이 완료된 후, 해당 호/연결 접속을 통하여 사용자 데이타를 주거나 받고자 하는 경우에 해당 호/연결 접속의 AAL 링크를 활성화한다.IOCTL_AIMDD_ACTIVATE_ALL_SAP: Activates the AAL link of the call / connection connection after the call / connection connection is completed, when the user data is to be transmitted or received through the call / connection connection.

IOCTL_AIMDD_DEACTIVATE_AAL_SAP: 호/연결 접속이 해제되어 더 이상 해당 ALL 링크를 사용할 수 없음을 알린다.IOCTL_AIMDD_DEACTIVATE_AAL_SAP: Signals that the call / connection has been disconnected and that the ALL link is no longer available.

사용자 데이타의 다중화/역다중화는 해당 AAL 링크를 활성화하고 비활성화 함으로써 쉽게 달성된다. 그러나, 호/연결 제어 정보(이하 메시지)는 메시지 필터링 방법을 통하여 다중화/역다중화한다. 구체적 방법은 입력된 메시지에서 원하는 특정 스트링(필터링 데이타)이 나타나면 그 메시지를, IOCTL_AIMDD_REGISTER_MSG_FILT ER를 통하여 해당 필터를 등록한 윈드우즈 NT 상위레벨 디바이스에게 전달하는 방식이다. 메시지 필터링 정보의 구조는 다음과 같다.Multiplexing / demultiplexing of user data is easily accomplished by activating and deactivating the corresponding AAL link. However, call / connection control information (hereinafter referred to as message) is multiplexed / demultiplexed through a message filtering method. Specifically, when a specific string (filtering data) desired in the input message appears, the message is transmitted to the Windows NT high-level device that registered the filter through IOCTL_AIMDD_REGISTER_MSG_FILTER. The structure of the message filtering information is as follows.

오프셋은 4 바이트 크기이고, 메시지의 어디에서부터 필터링 데이타를 검색할 것인가를 표시한다. 0xFFFFFFFF은 필터링 데이타가 메시지의 모든 부분에서 시작될 수 있음을 나타낸다. 사이즈는 4 바이트 크기이고, 매스크와 필터링 데이타의 크기를 표시한다. 매스크의 크기는 사이즈에서 지정한 크기이며, 필터링 데이타의 어느 비트가 유효한 비트인지를 나타낸다. 즉 매스크 비트 1은 유효 비트를, 0는 돈캐어(don't care) 비트를 나타낸다. 필터링 데이타는 사이즈에서 지정한 크기이며, 원하는 특정 스트링을 나타낸다. 이러한 필터링은 필터링 정보가 등록된 순서대로 수행된다.The offset is 4 bytes in size and indicates where to retrieve the filtering data from the message. 0xFFFFFFFF indicates that the filtering data can begin at any part of the message. The size is 4 bytes in size and indicates the size of the mask and filtering data. The size of the mask is the size specified by the size, and indicates which bits of the filtering data are valid bits. In other words, mask bit 1 represents a valid bit and 0 represents a don't care bit. The filtering data is the size specified in the size, and represents the desired specific string. This filtering is performed in the order in which the filtering information is registered.

둘째의 경우에 필요한 인터페이스는 다음과 같다.The interface required in the second case is as follows.

IOCTL_AIMDD_CTRL_DATA_WIRTE: 호/연결 접속에 대한 제어정보를 AIM 보드내의 소프트웨어로 보낸다.IOCTL_AIMDD_CTRL_DATA_WIRTE: Send control information about call / connection connection to software in AIM board.

IOCTL_AIMDD_CTRL_DATA_READ: AIM 보드내의 소프트웨어가 보낸 호/연결 접속에 대한 제어정보를 읽는다.IOCTL_AIMDD_CTRL_DATA_READ: To read the control information about the call / connection connection sent by the software in the AIM board.

IOCTL_AIMDD_CPCS_UNITDATA_WRITE: 사용자 데이타를 AAL5-IDU(AAL5 CPCS SDU)에 실어 네트웍으로 보낸다.IOCTL_AIMDD_CPCS_UNITDATA_WRITE: User data is loaded on the AAL5-IDU (AAL5 CPCS SDU) and sent over the network.

IOCTL_AIMDD_CPCS_UNITDATA_READ: 네트웍을 통하여 도착한 AAL5-IDU(AAL 5 CPCS SDU)를 읽는다.IOCTL_AIMDD_CPCS_UNITDATA_READ: Reads AAL5-IDU (AAL 5 CPCS SDU) that arrives over the network.

위에 정의된 AIM DDI는 AIM 보드의 하드웨어가 바뀌더라도 불변하므로 새로운 상위레벨 디바이스 드라이버나, CDDM(100)과 같이 AIM 서비스를 지원하는 새로운 사용자 프로그램 수준의 서버를 쉽게 설계하고 구현할 수 있다.Since the AIM DDI defined above is invariant even if the hardware of the AIM board is changed, it is easy to design and implement a new high-level device driver or a new user program level server supporting the AIM service such as the CDDM 100.

제2도는 본 발명에 의한 로컬 프로세서의 구성을 나타낸다. 본 발명에 따른 로컬 프로세서는 호스트 접속 데이타 분배 장치(Call/Connection Data Distributor for HOST : CDDH)(200), 망 접속 데이타 분배 장치(Call/Connection Data Distributor for Network: CDDN)(201), 일대일 호/연결 제어장치(Q2931 유니트)(211)와 일대다 호/연결 제어장치(Q2971 유니트)(212) 및 ATM 신호 적응 계층 유니트(Signaling AAL: SAAL Unit)(215, 216)을 포함하는 신호모듈(Signaling Module)(210), 계층 관리 모듈(OAMM: OAM Module)(202), 평면 관리 모듈(AIMM: ATM Interface Management Module)(203), 타이머 모듈(TIMER)(204)로 구성된다. 제5도에서는 이들 로컬 프로세서를 위한 ATM 통신망 정합보드 메모리의 구성을 나타낸다. 이중 공통메모리(Common Shared Memory)는 로컬 프로세서, 호스트 프로세서 및 Bt8230의 어드레스에 매핑되어 있어 세 개의 프로세서들 모두 사용가능하게 되며 이 메모리에 관한 제어권은 Bt8230이 수행한다. 이하, 로컬 프로세서를 구성하는 각 장치에 대해 기술한다.2 shows a configuration of a local processor according to the present invention. According to the present invention, a local processor includes a Call / Connection Data Distributor for HOST (CDDH) 200, a Call / Connection Data Distributor for Network (CDDN) 201, one-to-one call / Signaling module including connection control unit (Q2931 unit) 211, one-to-many call / connection control unit (Q2971 unit) 212 and ATM Signaling AAL (SAAL Unit) (215, 216) Module 210, a layer management module (OAMM) 202, an ATM interface management module (AIMM) 203, and a timer module (TIMER) 204. 5 shows the configuration of ATM network registration board memory for these local processors. The common shared memory is mapped to the address of the local processor, the host processor and the Bt8230 so that all three processors can be used, and control of the memory is performed by the Bt8230. Hereinafter, each device constituting the local processor will be described.

호스트 접속 데이타 분배 장치(CDDH: Call/Connection Data Distributor for HOST)(200)는 제2도에서 보는 바와 같이 ATM 정합 보드 내부에 위치하고 있다. 이 장치는 2가지의 주요기능을 갖으며 첫 번째 기능은 제5도에서 보는 바와 같이 호스트로부터 입력된 제어 프리미티브를 공통 메모리(Common Shared Memory)중의 로컬 메일 박스 영역에 저장한 후 Bt8230칩의 로컬 메일 박스 레지스터를 통하여 호스트 접속 데이타 분배 장치로 전달되며 이 제어 프리미티브를 처리할 수 있는 소프트웨어로 분배하는 기능을 가지고 있다. 그리고, 두 번째 기능은 로컬 소트웨어들이 호스트로 제어 프리미티브를 전달하기 위하혀 호스트 접속 데이타 분배 장치의 입력큐에 저장하여 두면 호스트 접속 데이타 분재 장치(200)는 이 입력큐로부터 제어 프리미티브를 입력받아 공통 메모리중의 호스트 메일 박스 영역에 저장한 후 Bt8230칩의 호스트 메일 박스 레지스터를 통하여 호스트로 전달하게 된다.The Call / Connection Data Distributor for Host (CDDH) 200 is located inside an ATM matching board as shown in FIG. The device has two main functions. The first function is to store the control primitives input from the host in the local mailbox area of the common shared memory, as shown in Figure 5. It is passed through the box register to the host access data distribution device and has the ability to distribute this control primitive to software that can handle it. The second function is that the local software stores the control primitives in the input queue of the host connection data distribution device so that the host connection data distribution device 200 receives the control primitives from the input queue. It is stored in the host mailbox area in memory and transferred to the host through the host mailbox register of the Bt8230 chip.

망 접속 데이타 분배 장치(CDDN: Call/Connection Data Distributor for Network)(201)는 제2도에서 보는 바와 같이 ATM 정합 보드 내부에 위치하고 있다. 그리고 망으로부터 입력되는 메시지 프레임이 Bt8230에 의하여 공통 메모리중의 리어셈블리 버퍼에 저장된 후 인터럽트에 의하여 망 접속 데이타 분배 장치(201)에게 알리면 로컬 상태 큐로부터 메시지 프레임이 저장된 버퍼의 포인터 및 리어셈블리 된 상태를 알 수 있게 된다. 이를 제8도에 나타내었으며, 이렇게 하여 얻어진 메시지 프레임은 제3도의 하위프리미티브 구조를 가지는 제어 프리미티브로 전환하여 이를 처리할 수 있는 로컬 소프트웨어의 입력큐로 전달한 후 이 메시지 프레임이 저장되었던 리어셈블리 버퍼를 해제하여 Bt8230에 의하여 재사용할 수 있도록 프리버퍼큐에 입력시킨다. 그리고, 로컬 소프트웨어들로부터 제어 프리미티브를 전달받아 공통메모리중의 분할 버퍼(Segmentation buffer)에 제어 프리미티브의 프리미티브 헤더를 제외한 메시지 프레임을 저장하여 그 버퍼의 포인트와 세그먼테이션 제어 플래그 그리고 분할 가상 채널 테이블의 인덱스를 로컬 전송 링 버퍼에 저장하고 마지막으로 Bt8230의 레지스터에 저장된 데이타 프레임의 개수를 기록하면 Bt8230에 의하여 세그먼테이션되어 망으로 전송된다. 이를 제7도에 도식적으로 나타내었다. 그리고, Bt8230은 그 결과를 분할 상태 큐에 저장하고 인터럽트에 의하여 망 접속 데이타 분배 장치(201)에 알리면 망 접속 데이타 분배 장치(201)가 사용된 분할 버퍼를 해제시키는 기능을 가지고 있다.A Call / Connection Data Distributor for Network (CDDN) 201 is located inside an ATM matching board as shown in FIG. When the message frame inputted from the network is stored in the reassembly buffer in the common memory by Bt8230, and notified to the network access data distribution device 201 by an interrupt, the pointer and the reassembled state of the buffer in which the message frame is stored from the local state queue are interrupted. You will know. This is illustrated in FIG. 8, and the message frame thus obtained is converted to the control primitive having the subprimitive structure of FIG. Release it and enter it into the prebuffer queue for reuse by Bt8230. The control primitive is received from local software, and the message frame excluding the primitive header of the control primitive is stored in a segmentation buffer in the common memory, and the point, segmentation control flag, and index of the segmentation virtual channel table are stored. The number of data frames stored in the local transmission ring buffer and finally stored in the registers of the Bt8230 is segmented by the Bt8230 and transmitted to the network. This is shown schematically in FIG. The Bt8230 has a function of releasing the partition buffer used by the network connection data distribution device 201 when the result is stored in the partition status queue and notified to the network connection data distribution device 201 by an interrupt.

신호모듈(210)은 일대일 호/연결 제어장치(211)와 일대다 호/연결 제어장치(212) 및 SAAL 유니트(215, 216)로 구성된다.The signal module 210 includes a one-to-one call / connection controller 211, a one-to-many call / connection controller 212 and SAAL units 215 and 216.

일대일 호/연결 제어장치(211)는 B-ISDN 망의 일대일 접속을 위한 사용자 망 인터페이스(UNI) 계층 3 규격(Q.2931)을 만족하도록 구현되어 있다. 규격과 동일하게 CD 유니트(217), Q2931 유니트(211), RS 유니트(213) 그리고 RR 유니트(214)로 구성되어 있으며 규격에 준하여 수행되도록 각각 타스크(task)로서 존재한다. CD 유니트(217)는 하나의 입력큐를 가지며 호스트 접속 데이타 분배장치(200), SAAL 모듈(215, 216) 그리고 Q2931 유니트(211)로 입력된 제어 프리미티브를 라우팅할 수 있다. 하나의 입력큐를 가지고 있는 Q2931 유니트(211)는 제2도에서 보는 바와 같이 프리미티브 헨들러(Prim Handler)와 메시지 헨들러(Msg Handler)를 통하여 B-ISDN 통신 제어를 할 수 있으며 Q2971 유니트(212)와 제어 프리미티브를 주고 받을 수 있다. 더불어 가상 패스 연결(Virtual Path Connection; VPC)에 대한 관리를 VPC 객체관리자(VPC Entity Manager)를 통하여, 각 호/연결에 대한 객체 관리를 호 객체관리자(Call Entity Manager)를 통하여 할 수 있다. 이들 객체들은 서로 링키드 리스트방식으로 구현되어 있어 호/연결 설정 또는 해제시 능동적으로 관리가 가능하며 로컬 메모리를 실시간 처리에 적절하게 관리하도록 설계하였다. 그리고 RS 유니트와 RR 유니트는 재시동시 글로벌 호로서 호들을 재시동할 수 있도록 기능한다.The one-to-one call / connection controller 211 is implemented to satisfy the User Network Interface (UNI) Layer 3 standard (Q.2931) for one-to-one access of the B-ISDN network. Similarly to the standard, it is composed of the CD unit 217, the Q2931 unit 211, the RS unit 213, and the RR unit 214, and each exists as a task to be performed in accordance with the standard. The CD unit 217 has one input queue and can route the control primitives input to the host connection data distribution apparatus 200, the SAAL modules 215 and 216, and the Q2931 unit 211. As shown in FIG. 2, the Q2931 unit 211 having one input queue can control B-ISDN communication through a primitive handler and a message handler. Can send and receive control primitives. In addition, the virtual path connection (VPC) can be managed through the VPC Entity Manager, and the object management for each call / connection can be performed through the Call Entity Manager. These objects are linked to each other in a linked list, so they can be actively managed when a call / connection is established or released, and designed to properly manage local memory for real-time processing. The RS unit and the RR unit function to restart calls as global calls upon restart.

일대다 호/연결 제어장치(212)는 B-ISDN 망의 일대다 접속을 위한 UNI 계층 3 규격(Q.2971)을 만족하도록 구현되어 있다. 규격과 동일한 방법으로 하나의 입력큐를 가지는 Q2971 유니트(212)는 Q2931 유니트(211)로부터 전달된 제어 프리미티브를 제2도에서 보는 바와 같이 프리미티브 헨들러(Prim Handler)와 메시지 헨들러(Msg Handler)를 통하여 처리하며 처리에 의한 결과를 파티 객체관리자(Party Entity Manager)를 통하여 상태관리한다. 각 파티에 대한 객체 관리가 링키드 리스트 방식으로 구현되어 있으며 파티추가 및 제거에 따라 능동적으로 관리되며 호/연결에 대한 객체에 종속되어 파티에 대한 객체 관리를 하고 있다. 그리고 이 처리 결과에 의한 메시지나 제어 프리미티브는 Q2931(211)의 입력큐로 전달된다.The one-to-many call / connection controller 212 is implemented to satisfy the UNI Layer 3 specification (Q.2971) for one-to-many connection of a B-ISDN network. Q2971 unit 212 having one input queue in the same manner as the standard, through the primitive handler and message handler (Msg Handler) as shown in Figure 2 the control primitive transmitted from the Q2931 unit 211 Process and manage the result through the Party Entity Manager. Object management for each party is implemented by linked list method, and actively managed according to adding and removing party, and object management for party depends on object for call / connection. The message and control primitive resulting from this processing result are delivered to the input queue of Q2931 (211).

ATM 신호 적응계층 유니트는(SAAL 유니트)(215, 216) 두가지의 부계층으로 나누어진다. 즉, 동등 계층 사이의 신뢰성 있는 정보의 교환을 위한 SSCOP부 계층(Q.2110)(216)과 사용자 망 접면의 계층3 프로토콜과 SSCOP(216)의 프리미티브들을 서로 매핑하는 기능을 하는 SSCF부계층(Q.2130)(215)이 있다. 규격과 동일하게 하위로는 CPCS와 상위로는 계층 3과 연동하며 작용하도록 구현되어 있다.The ATM signal adaptation layer unit (SAAL unit) (215, 216) is divided into two sublayers. That is, the SSCF sublayer (Q.2110) 216 for exchanging reliable information between the peer layers and the SSCF sublayer function of mapping the layer 3 protocol of the user network interface and the primitives of the SSCOP 216 with each other ( Q.2130) 215. Similar to the standard, it is implemented to work in conjunction with CPCS as a lower layer and Layer 3 as a higher layer.

SSCF부계층(215)은 단지 신호와 프리미티브들을 매핑해주는 계층이므로 상태와 입력 신호, 프리미티브에 대한 함수 테이블을 이용하여 구현하였다.Since the SSCF sublayer 215 is a layer that only maps signals and primitives, it is implemented using a function table for states, input signals, and primitives.

SSCOP부계층(216)은 순차데이타의 순차적인 전달이 주목적이다. 이를 위하여 데이타 전송의 오류가 발생할 경우를 고려하여야 한다. 이러한 오류는 크게 두가지로 나누어 볼수가 있다. 첫째는 데이타를 전송받을 계층에서 오류나 자원의 부족으로 인하여 데이타 전달이 불가능할 경우이고, 둘째는 데이타의 유실로 인하여 동등으로 순차적인 데이타가 전달되지 않을 경우이다. 이러한 경우의 오류를 보정하기 위하여 SSCOP(216)는 두 가지의 자원을 사용하고 있다. 첫 번째의 오류를 보정하기 위하여 전송 큐를, 두 번째의 오류를 보정하기 위하여는 전송 백업 어레이를 사용하고 있다.The SSCOP sublayer 216 is primarily designed for the sequential transfer of sequential data. For this purpose, the case of error in data transmission should be considered. These errors can be divided into two broad categories. The first case is when data transmission is impossible due to an error or lack of resources in the layer to receive data, and the second case is when data is not sequentially transmitted due to loss of data. In order to correct errors in this case, the SSCOP 216 uses two resources. The transmission queue is used to correct the first error and the transmission backup array is used to correct the second error.

SSCOP부계층(216)의 입력 큐에 메시지가 입력되면, 이 메시지의 종류를 먼저 판단한다. 메시지가 시그널링 신호거나 PDU일 경우에는 적절한 함수를 호출하여 프로토콜의 정의에 의하여 수행하여 준다. 메시지가 AA_DATA.req일 경우에는 SSCOP는 데이타를 전송 큐에 저장을 하고, SSCOP(216)자신에게 SD_QUEUED 신호를 발생시켜 준다. 그리고 SD_QUEUED가 전송되면, 먼저 전송받을 계층의 상태를 살펴 전송받을 수 있는 상태가 되어 있으면, 이를 전송함과 동시에 이 데이타를 출력 버퍼에 저장하고, 만일 전송받을 계층이 자원의 부족등으로 전송받을 수 없는 상태에 있으면, 다시 SD_QUEUED신호를 자신에게 발생하여 준다. 이러한 방식을 사용함으로써 계층간의 무리한 전송으로 인한 오동작을 없앨 수 있고, 동류(Peer)로부터 유실된 데이타의 요구가 있을 경우에는 출력버퍼에 저장되어 있는 데이타를 전송하여 주면 된다. 이에 관한 사항은 제6도를 참조한다.When a message is input to the input queue of the SSCOP sublayer 216, the type of the message is first determined. If the message is a signaling signal or a PDU, the appropriate function is called and executed according to the protocol definition. If the message is AA_DATA.req, the SSCOP stores the data in the transmission queue and generates an SD_QUEUED signal to the SSCOP 216 itself. If SD_QUEUED is transmitted, first check the state of the layer to be transmitted, and if it is ready to be transmitted, the data is stored in the output buffer at the same time, and the layer to be transmitted may be transmitted due to lack of resources. If it is not present, it generates SD_QUEUED signal to itself again. By using this method, malfunctions due to excessive transmission between layers can be eliminated, and when there is a request for data lost from peers, data stored in the output buffer can be transmitted. See Figure 6 for details.

계층 관리 모듈(OAMM: OAM Module)(202)은 ITU-T/I.610에 따른 계층관리로서 광대역통신단말은 Sb점에 접속되기 때문에 F5 단대단 OAM만 관리하면 된다. 그러나, 재싱기 구간과 다중기 구간 등의 물리 계층의 상태와 F4 단대단 OAM을 모니터링하는 능력을 가질 수 있도록 하기 위하여 Bt8222에 의하여 인터럽트로 제공되는 물리 계층의 상태중 신호손실(Loss of Signal ; LOS)와 프레임 손실(Out of Frame)를 입력받거나 F4 레벨의 오류발생OAM셀을 입력받으면 VPC 객체관리자와 호/연결 객체관리자에 의하여 계층 관리 상태를 관리하며 타이머에 등록함으로써 1초 주기마다 F5 레벨의 OAM 오류관리를 한다. 이 때 F4, F5 OAM 셀은 Bt8230에 의하여 재결합 버퍼로 저장된 후 역시 인터럽트에 의하여 계층관리 모듈로 알려준다. 계층 관리 모듈은 F5 레벨에 대한 오류 관리만 구현되어 있으며 F4 레벨에 대한 오류 관리는 하지 않는다. OAMM(202)은 경보 표시 신호(Alarm Indication Signal ; AIS) 상태와 원격수신고장(Remote Defect Indication ; RDI) 상태 그리고 정상 상태가 있다.The layer management module (OAMM) 202 is a layer management according to ITU-T / I.610. Since the broadband communication terminal is connected to the Sb point, only the F5 end-to-end OAM needs to be managed. However, in order to have the ability to monitor the state of the physical layer such as the restoring section and the multiplexer section and the F4 end-to-end OAM, the loss of signal (LOSs) of the physical layer provided as an interrupt by the Bt8222. ), Frame loss (Out of Frame) or F4 level error OAM cell is input, the layer management status is managed by VPC object manager and call / connection object manager and registered in timer. OAM error management. At this time, the F4 and F5 OAM cells are stored in the recombination buffer by the Bt8230 and inform the layer management module by interrupts. The layer management module implements only error management for the F5 level. It does not manage error for the F4 level. The OAMM 202 has an Alarm Indication Signal (AIS) state, a Remote Defect Indication (RDI) state, and a normal state.

평면 관리 모듈(AIMM: ATM Interface Management Module)(203)은 각 모듈들의 오류들 및 시스팀 리소스들을 관리하고 있으며 사용자 요구시 오류 상태, 시스팀 리소스 상태 등에 관한 정보를 제공한다. 그 외에도 사용자 요구에 의하여 영구 가상 채널을 할당하고 관리하는 기능을 가지고 있다.The ATM Interface Management Module (AIMM) 203 manages errors and system resources of each module and provides information on error status, system resource status, and the like upon user request. In addition, it has the function of assigning and managing permanent virtual channels according to user's request.

타이머 모듈(TIMER)(204)은 VRTX 스펙트라(spectra)에서 제공하는 10msec 소프트 타이머를 사용하여 구동되며 하나의 타이머큐를 가지고 있어 로컬 소프트웨어들의 타이머 등록시 타이머 종류, 등록한 소프트웨어 모듈 식별자 그리고 타이머가 종료된 후에 재실행되기 위하여 필요한 정보가 저장된 버퍼 등을 가지고 등록하며 각 타이머가 등록될 때에는 타이머큐가 팝(pop)될 시간순서에 따라 동적으로 구성되고 등록된 타이머가 reset될때에는 해당 타이머를 삭제 함으로써 이루어진다. 지정된 타이머 간격동안 아무런 입력이 없을 경우에는 타이머큐의 루트에 저장되어 있는 시각과 현재의 시각을 비교하여 현재의 시각보다 빠른시각이면 팝(pop)하여 해당 모듈로 메시지를 보내고 큐를 재구성한다.The timer module (TIMER) 204 is driven using a 10msec soft timer provided by the VRTX spectra and has a single timer queue so that the timer type, the registered software module identifier, and after the timer expires when the local software registers the timer. It registers with a buffer, etc. necessary information to be re-executed. When each timer is registered, it is dynamically configured according to the time sequence in which the timer queue is popped, and is deleted by deleting the timer when the registered timer is reset. If there is no input during the specified timer interval, it compares the time stored at the root of the timer queue with the current time, and if it is earlier than the current time, it pops a message to the module and reconfigures the queue.

이상에서 상세히 설명한 바와 같이 본 발명에 따른 로컬 프로세서는 VRTX 스펙트라(spectra)를 통하여 구현되었으며, AAL5 계층의 CPCS 및 셀분할 조립 부계층(SAR)은 Bt8230을 통하여 구현되어 있으며, ATM 계층은 Bt8222를 통하여 구현되어 있기 때문에 이들 디바이스들을 제어하는 코드들을 함수화하여 라이브러리로 구성하였다. 그리고 시그널링, 계층관리, 평면관리에 관한 기능 역시 라이브러리화 함으로써 향후의 업그레이드를 용이하도록 하였다. 그리고 B-ISDN 시그널링, 계층관리 및 평면관리를 ATM 통신망 정합보드내에서 처리함으로서 호스트(예: PC, workstation) 프로세서의 부하를 줄임으로써 응용 프로그램에게 더 많은 리소스를 제공하며 시스팀 퍼포먼스를 개선할 수 있다. 호스트 프로세서는 PCI 버스를 제어하며 역시 Bt8230을 통하여 통신 데이타를 전달할 수 있도록 이들 하드웨어에 관한 제어기능들을 라이브러리화 하고 B-ISDN 서비스 및 인터넷 서비스를 장애없이 지원할 수 있도록 디바이스 드라이버를 제공함으로써 기존의 인터넷 서비스를 제공받을 수 있는 유연한 아키텍쳐를 제공하게 되었다.As described in detail above, the local processor according to the present invention is implemented through the VRTX spectra, the CPCS of the AAL5 layer and the cell division sublayer (SAR) are implemented through the Bt8230, and the ATM layer is implemented through the Bt8222. Since it is implemented, the code that controls these devices is functionalized to form a library. In addition, functions related to signaling, hierarchical management, and plan management have also been libraryed to facilitate future upgrades. In addition, B-ISDN signaling, layer management, and plane management can be handled within ATM network registration boards, thereby reducing the load on host (eg, PC, workstation) processors, providing more resources to applications and improving system performance. . The host processor controls the PCI bus and library of control functions for these hardware to transfer communication data through Bt8230, and provides device driver to support B-ISDN service and Internet service without any problem. It provides a flexible architecture that can be provided.

아울러 본 발명의 바람직한 실시예는 예시의 목적을 위해 개시된 것이며, 당업자라면 본 발명의 사상과 범위안에서 다양한 수정, 변경, 부가 등이 가능할 것이며, 이러한 수정 변경 등은 이하의 특허 청구의 범위에 속하는 것으로 보아야 할 것이다.In addition, a preferred embodiment of the present invention is disclosed for the purpose of illustration, those skilled in the art will be able to make various modifications, changes, additions, etc. within the spirit and scope of the present invention, such modifications and modifications belong to the following claims You will have to look.

Claims (7)

호스트 프로세서와 로컬 프로세서로 구성되며, 상기 호스트 프로세서는 ATM 인터페이스 모듈의 응용 프로그램 인터페이스(AIM API)를 제공하기 위한 AIM API 동적 링크 라이브러리(AIM API DLL)와, 상기 동적 링크 라이브러리와 동적 데이타 교환을 통하여 호/연결 접속 정보와 사용자 데이타를 주고 받기 위한 호/연결 데이타 분배장치(CDDM)와, 상기 호/연결 데이타 분배장치가 AIM 디바이스에 접근할 수 있도록 하기 위한 AIM 상위 디바이스 드라이버, ATM 네트워크를 통하여 네트워크 디바이스에게 데이타 링크 레이어 서비스를 제공하기 위한 AIM 네트워크 디바이스 인터페이스 디바이스 드라이버, 및 AIM 상위 디바이스는 드라이버가 AIM 디바이스 드라이버 인터페이스를 이용하여 호/연결 접속에 대한 제어정보, 사용자 데이타, 다중화/역다중화에 필요한 제어정보를 AIM 디바이스와 교환하기 위한 AIM 하위 디바이스 드라이버를 포함하며, 상기 로컬 프로세서는 상기 호스트 프로세서로부터 입력되는 제어 프리미티브를 공통메모리중의 로컬 메일박스 영역에 저장한 후 전달받거나, 제어 프리미티브를 공통메모리중의 호스트 메일박스에 저장한 후 호스트 프로세서로 전달하기 위한 호스트 접속 데이타 분배 장치와, 망으로부터 입력되는 메시지 프레임을 리어셈블리 버퍼에 저장한 후 하위 프리미티브 구조를 갖는 제어 프리미티브로 전환하여 입력큐로 전달하거나, 입력된 제어 프리미티브의 헤더를 제외한 메시지 프레임을 분할 버퍼에 저장한 후 Bt8230에 의해 분할한 후 망으로 전송하기 위한 망 접속 데이타 분배 장치와, 일대일 호/연결 제어, 일대다 호/연결 제어, 객체관리자를 통한 객체관리의 수행 및 신호와 프리미티브들을 매핑하고 순차적인 신호의 전달을 위한 신호 모듈, 및 ITU-T/I.610에 따른 F5 단대단 유지보수운용 관리를 위한 계층관리모듈과, 각 모듈들의 오류, 시스템 리소스들을 관리하고 오류 상태, 시스템 리소스 상태에 관한 정보를 제공하기 위한 평면관리모듈과, 타이머를 포함하는 것을 특징으로 하는 지능형 디바이스 드라이버를 제공하는 광대역 종합정보통신망 정합장치.Comprising a host processor and a local processor, the host processor is an AIM API dynamic link library (AIM API DLL) for providing an application program interface (AIM API) of the ATM interface module, and through the dynamic data exchange with the dynamic link library A call / connection data distribution device (CDDM) for exchanging call / connection connection information and user data, and an AIM host device driver for allowing the call / connection data distribution device to access an AIM device, through an ATM network The AIM network device interface device driver for providing data link layer services to the device, and the AIM host device, the driver uses the AIM device driver interface to control the call information, user data, and control necessary for multiplexing / demultiplexing. Information An AIM sub-device driver for exchanging with an AIM device, wherein the local processor receives and stores control primitives input from the host processor in a local mailbox area of common memory, or receives control primitives from a host in common memory. Host connection data distribution device for storing in the mailbox and forwarding to the host processor, and message frames inputted from the network are stored in the reassembly buffer, and then converted to control primitives having a lower primitive structure and transmitted to the input queue, or input. A network access data distribution device for storing message frames excluding the headers of control primitives in a partition buffer, segmenting by Bt8230, and then transmitting them to the network, one-to-one call / connection control, one-to-many call / connection control, Object management and signal and program through Signal module for mapping limits and transmitting sequential signals, and hierarchical management module for F5 end-to-end maintenance operation management according to ITU-T / I.610, managing errors and system resources of each module. Broadband integrated information network matching device for providing an intelligent device driver, characterized in that it comprises a plane management module for providing information on the status, system resource status, and a timer. 제1항에 있어서, 상기 호스트 프로세서의 호/연결 데이타 분배장치는 응용 프로그램들의 AIM API들로부터 데이타를 동적교환을 통하여 입력받아 트랜잭션으로 전달하며 하위 계층에서 처리된 결과를 응용 프로그램이 가져갈 수 있도록 큐에 저장하는 AIM 동적 교환 쓰레드와, 응용 프로그램으로부터의 프리미티브를 App_Xact_Handler를 통하여 처리하고, ALL5 데이타를 Aal_Xact_Handler를 통하여 처리하고 통신을 위한 제어용 프리미티브는 Net_Xact_Handler를 통하여 처리한 후 처리결과를 AIM 동적 데이타 교환 쓰레드로 전달하기 위한 트랜잭션 쓰레드와, AIM API를 통하여 요청된 각 응용의 데이타 서비스를 ATM 정합보드를 통하여 다중화하고 역으로 ATM 정합 보드를 통하여 요청된 데이타 서비스를 적절히 해당 응용으로 역다중화하는 AAL5 서비스 쓰레드와, B-ISDN 통신 제어 프리미티브를 트랜잭션 쓰레드로 전달하여 이를 처리하도록 하기 위한 제어 쓰레드로 구성됨을 특징으로 하는 지능형 디바이스 드라이버를 제공하는 광대역 종합정보통신망 정합장치.The call / connection data distribution device of the host processor receives the data from the AIM APIs of the applications through dynamic exchange and transfers the data to the transaction, and queues the application to take the result processed in the lower layer. The AIM dynamic exchange thread stored in the program and the primitive from the application are processed through App_Xact_Handler, the ALL5 data is processed through Aal_Xact_Handler, and the control primitive for communication is processed through Net_Xact_Handler, and the processing result is transferred to the AIM dynamic data exchange thread. AAL5 service thread that multiplexes the data service of each application requested through the AIM API through the ATM matching board and conversely demultiplexes the data service requested through the ATM matching board to the corresponding application. B-ISDN Communication Control Broadband Telecommunications network matching device providing an intelligent device driver, characterized in that the control thread for passing the primitive to the transaction thread to process it. 제1항에 있어서, 상기 호스트 프로세서의 AIM 네트워크 디바이스 인터페이스 디바이스 드라이버는 어드레스 분석(resolution) 서비스를 위한 LAN 에뮬레이션 수단을 내부에 포함하는 것을 특징으로 하는 지능형 디바이스 드라이버를 제공하는 광대역 종합정보 통신망 정합장치.2. The apparatus of claim 1, wherein the AIM network device interface device driver of the host processor includes LAN emulation means for address resolution service therein. 제1항에 있어서, 상기 호스트 프로세서의 AIM 하위 디바이스 드라이버의 AIM 디바이스 드라이버 인터페이스는 호/연결 제어정보와 사용자 데이타의 다중화/역다중화를 위한 인터페이스와, 호/연결 제어정보와 사용자 데이타를 주고 받기 위한 인터페이스로 구성됨을 특징으로 하는 지능형 디바이스 드라이버를 제공하는 광대역 종합정보통신망 정합장치.The AIM device driver interface of the AIM lower device driver of the host processor is an interface for multiplexing / demultiplexing call / connection control information and user data, and transmits and receives call / connection control information and user data. Broadband integrated information network matching device providing an intelligent device driver characterized in that the interface is configured. 제4항에 있어서, 상기 호/연결 제어정보와 사용자 데이타의 다중화/역다중화를 위한 인터페이스의 호/연결 제어정보의 다중화/역다중화는 메시지 필터링 정보를 사용하여 입력된 메시지 중의 원하는 특정 스트링(필터링 데이타)에 나타난 메시지를 소정의 필터에 등록한 후 해당 필터를 등록한 AIM 상위 디바이스 드라이버에 전달하는 것에 의해 행해지며, 사용자 데이타의 다중화/역다중화는 해당 AAL 링크의 활성화 비활성화에 의해 행해지는 것을 특징으로 하는 지능형 디바이스 드라이버를 제공하는 광대역 종합정보통신망 정합장치.5. The method of claim 4, wherein the multiplexing / demultiplexing of call / connection control information of an interface for multiplexing / demultiplexing of the call / connection control information and user data is performed by using a message filtering information. Data) by registering the message in a predetermined filter and then passing the filter to the registered AIM high-level device driver, wherein the multiplexing / demultiplexing of user data is performed by activating and deactivating the corresponding AAL link. Broadband Telecommunication Network Network Device that provides intelligent device driver. 제5항에 있어서, 상기 메시지 필터링 정보는 메시지의 어느 부분부터 필터링 데이타를 검색할지를 표시하는 오프셋부분과, 매스크와 필터링 데이타의 크기를 표시하는 사이즈부분과, 필터링 데이타의 유효 비트를 나타내는 매스크부분 및 원하는 특정 스트링인 필터링 데이타부분으로 구성됨을 특징으로 하는 지능형 디바이스 드라이버를 제공하는 광대역 종합정보통신망 정합장치.6. The method of claim 5, wherein the message filtering information comprises: an offset portion indicating from which part of the message to retrieve filtering data, a size portion indicating a size of the mask and filtering data, a mask portion indicating an effective bit of the filtering data, and Broadband Telecommunication Network Interface Device providing intelligent device driver characterized in that it consists of filtering data part which is a specific desired string. 제1항에 있어서, 상기 로컬 프로세서의 신호 모듈은 하나의 입력큐를 갖고 호스트 접속 데이타 분배장치, SAAL 모듈, Q2931 유니트로 입력된 제어 프리미티브를 라우팅하는 CD 유니트와, 프리미티브 핸들러와 메시지 핸들러를 통하여 B-ISDN 통신제어를 하고 Q2971 유니트와 제어 프리미티브를 교환하기 위한 Q2931 유니트와, 재시동시 글로벌 호로서 호들을 재시동하기 위한 RS 및 RR 유니트, 동등계층 사이의 신뢰성 있는 정보의 교환을 위한 SSCOP 부계층과 사용자 망 접면의 계층 3 프로토콜과 SSCOP의 프리미티브들을 서로 매핑하는 기능을 하는 SSCF 부계층으로 구성된 SAAL 모듈을 포함하는 것을 특징으로 하는 지능형 디바이스 드라이버를 제공하는 광대역 종합정보통신망 정합장치.The signal module of claim 1, wherein the signal module of the local processor has a single input queue, a CD unit for routing control primitives input to a host connection data distribution device, a SAAL module, and a Q2931 unit, and a B through a primitive handler and a message handler. -Q2931 unit for controlling ISDN communication and exchanging control primitives with Q2971 unit, RS and RR unit for restarting calls as global calls on restart, SSCOP sublayer and user for reliable exchange of information between peers Broadband Telecommunications network matching device providing an intelligent device driver comprising a SAAL module consisting of SSCF sublayer that functions to map the layer 3 protocol of the network interface and the primitives of the SSCOP to each other.
KR1019960060344A 1996-11-30 1996-11-30 B-isdn interfacing apparatus providing intelligent device driver KR100209360B1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
KR1019960060344A KR100209360B1 (en) 1996-11-30 1996-11-30 B-isdn interfacing apparatus providing intelligent device driver

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1019960060344A KR100209360B1 (en) 1996-11-30 1996-11-30 B-isdn interfacing apparatus providing intelligent device driver

Publications (2)

Publication Number Publication Date
KR19980041075A KR19980041075A (en) 1998-08-17
KR100209360B1 true KR100209360B1 (en) 1999-07-15

Family

ID=19485005

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1019960060344A KR100209360B1 (en) 1996-11-30 1996-11-30 B-isdn interfacing apparatus providing intelligent device driver

Country Status (1)

Country Link
KR (1) KR100209360B1 (en)

Families Citing this family (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8578439B1 (en) * 2000-01-28 2013-11-05 Koninklijke Philips N.V. Method and apparatus for presentation of intelligent, adaptive alarms, icons and other information
KR100464349B1 (en) * 2002-08-08 2005-01-03 삼성전자주식회사 Common control implement method for device driver

Also Published As

Publication number Publication date
KR19980041075A (en) 1998-08-17

Similar Documents

Publication Publication Date Title
US6708210B2 (en) Application programming interfaces and methods enabling a host to interface with a network processor
US6735773B1 (en) Method and apparatus for issuing commands to a network processor configured to provide a plurality of APIs
JP2950366B2 (en) Multimedia communication platform and multimedia communication device
US5274768A (en) High-performance host interface for ATM networks
US7411968B2 (en) Two-dimensional queuing/de-queuing methods and systems for implementing the same
US6160811A (en) Data packet router
US6373846B1 (en) Single chip networking device with enhanced memory access co-processor
Black et al. Experiences of building an ATM switch for the Local Area
JPH08111693A (en) Data transfer method
US6535512B1 (en) ATM communication system interconnect/termination unit
JPH11513545A (en) Service provision in telecommunications networks
US5930525A (en) Method and apparatus for network interface fetching initial and data burst blocks and segmenting blocks and scheduling blocks compatible for transmission over multiple virtual circuits
US5956344A (en) Interprocessor communications in an ATM environment
KR100209360B1 (en) B-isdn interfacing apparatus providing intelligent device driver
EP0690599A2 (en) Application programming interface for distributed processing in networks
JP3676917B2 (en) Multiprocessor switch and communication method thereof
JPH11346219A (en) Control or asynchronous transfer mode(atm) switching network
Orphanos et al. Compensating for moderate effective throughput at the desktop
US7039057B1 (en) Arrangement for converting ATM cells to infiniband packets
US6072799A (en) Scalable ATM signaling message processing based on per session dispatch
Hidell Supporting the Internet Protocols in a High Performance Real-Time Network
Stassinopoulos et al. Performance evaluation of adaptation functions in the ATM environment
KR100314582B1 (en) Method of managing control messages for extending the number of subscriber boards of digital subscriber line access multiplexor
KR100442688B1 (en) Interprocess communication method and apparatus
Guillaud et al. An ATM-based multimedia integrated manufacturing system

Legal Events

Date Code Title Description
A201 Request for examination
E701 Decision to grant or registration of patent right
GRNT Written decision to grant
FPAY Annual fee payment

Payment date: 20130403

Year of fee payment: 15

FPAY Annual fee payment

Payment date: 20140404

Year of fee payment: 16

LAPS Lapse due to unpaid annual fee