KR100273103B1 - 대기 용장화 시스템 - Google Patents

대기 용장화 시스템 Download PDF

Info

Publication number
KR100273103B1
KR100273103B1 KR1019970040384A KR19970040384A KR100273103B1 KR 100273103 B1 KR100273103 B1 KR 100273103B1 KR 1019970040384 A KR1019970040384 A KR 1019970040384A KR 19970040384 A KR19970040384 A KR 19970040384A KR 100273103 B1 KR100273103 B1 KR 100273103B1
Authority
KR
South Korea
Prior art keywords
cpu unit
command
system cpu
control system
standby
Prior art date
Application number
KR1019970040384A
Other languages
English (en)
Other versions
KR19980069899A (ko
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 다니구찌 이찌로오
Publication of KR19980069899A publication Critical patent/KR19980069899A/ko
Application granted granted Critical
Publication of KR100273103B1 publication Critical patent/KR100273103B1/ko

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • GPHYSICS
    • G05CONTROLLING; REGULATING
    • G05BCONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
    • G05B19/00Programme-control systems
    • G05B19/02Programme-control systems electric
    • G05B19/04Programme control other than numerical control, i.e. in sequence controllers or logic controllers
    • G05B19/042Programme control other than numerical control, i.e. in sequence controllers or logic controllers using digital processors
    • G05B19/0421Multiprocessor system

Landscapes

  • Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Automation & Control Theory (AREA)
  • Theoretical Computer Science (AREA)
  • Quality & Reliability (AREA)
  • General Engineering & Computer Science (AREA)
  • Hardware Redundancy (AREA)
  • Multi Processors (AREA)
  • Safety Devices In Control Systems (AREA)

Abstract

대기(待機)용장화(冗長化)시스템에서 데이터 동일성 유지를 위해 작업성을 향상시킨다.
제어대상기기를 제어하는 제어계 CPU 유닛과 상기 제어대상기기를 상기 제어계 유닛대신에 제어가능한 대기계 CPU 유닛을 구비한 대기용장화 시스템에 있어서, 주변기기로부터 입력되는 명령문 및 데이터로 구성되는 코멘트를 일시 보관하고, 그 코멘드에서의 명령문에 따른 상기 데이터의 처리를 하는 동시에 일시 보관하고 있던 상기 코멘드를 타계의 CPU 유닛에 대해서 전송하는 트래킹 수단을 구비하였다.

Description

대기 용장화 시스템
제1도는 본 발명의 실시의 형태에서의 대기용장화 시스템의 PC의 구성을 표시하는 블록도.
제2도는 마이크로 프로그램 ROM 내부의 상세를 표시하는 상세구성도.
제3도는 실시의 형태 1에서의 통신 서비스요구 트래킹수단의 동작을 표시하는 플로차트.
제4도는 실시의 형태 1에서의 양계 동시에 파일일괄기록을 실행하는 동작을 표시하는 플로차트.
제5도는 실시의 형태 2에서의 양계동시에 디바이스 일괄기록을 실행하는 동작을 표시하는 플로차트.
제6도는 실시의 형태 3에서의 RUN 중 일괄파일 전송을 양계동시에 실행하는 동작을 표시하는 플로차트.
제7도는 실시의 형태 4에서의 메모리내의 파일내용의 자동전송수단의 동작을 표시하는 플로차트.
제8도는 실시의 형태 5에서의 시스템정보의 자동 전송수단의 동작을 표시하는 플로차트.
제9도는 실시의 형태 6에서의 운전상태의 자동운전상태 추종수단의 동작을 표시하는 플로차트.
제10도는 종래의 대기용장화 시스템의 구성을 표시하는 구성도.
제11도는 종래의 대기용장화 시스템에서의 데이터 트래킹의 동작을 표시하는 플로차트.
제12도는 종래의 통신 서비스 요구기능의 동작을 표시하는 플로차트.
제13도는 종래의 통신 서비스 요구기능을 대기 용장화 시스템에 대해서 실행할때의 순서.
* 도면의 주요부분에 대한 간단한 설명
1 : 제어계 CPU 유닛 100 : 대기계 CPU 유닛
2,200 : 외부메모리 3,300 : 주변기기
4,400 : 운전상태 전환스위치 11,101 : CPU
12,102 : 마이크로프록램 ROM 13,103 : 디바이스메모리
14,104 : 시스템메모리 15,105 : 프로그램 메모리
16,106 : 트래킹메모리 17,107 : 트래킹 인터페이스
18,108 : 외부메모리인터페이스 10,109 : 주변인터페이스
[발명의 목적]
본 발명의 목적은 대기용장화 시스템에서의 데이터 동일성 보존을 위한 작업성을 향상시키는데 있다.
[발명이 속하는 기술분야 및 그분야의 종래기술]
본 발명은, 한쪽은 실제로 제어 대상기기의 제어를 하는 제어계 CPU 유닛과 다른쪽은 CPU유닛이 어떤이유로 다운되었을 때, 계속해서 제어대상기기를 제어하는 대기계 CPU 유닛으로 구성되고, 산업기기등으로 사용되는 프로그래머블 콘트롤러의 대기용장화시스템에서, 제어계 CPU 유닛과 대기계 CPU 유닛의 파일이나 제어정보나 운전상태의 동일성을 실현할 수 있도록 한 대기용장화 시스템에 관한 것이다.
제10도는 예를 들면 일본국 특개평2-81101호 공보에 표시된 종래의 대기용장화 시스템의 구성을 표시하는 구성도이다.
도면에서 10은 온라인 되어 제어대상기기를 제어실행하고 있는 제어계 CPU 유닛, 110은 제어계 CPU 유닛(10)이 고장이 났을때에 그 대신 제어를 실행하는 대기계 CPU 유닛, 5는 이들의 입출력과 제어대상기기를 연결하는 라인을 전환하기 위한 전환장치, 6은 백업에 필요한 정보를 전송하기 위한 전송라인이다.
그리고 이들 2대의 CPU 유닛의 입출력은, 전환장치(5)를 통해서, 제어대상기기에 접속되어 있다.
대기계 CPU 유닛(110)은, 실제의 제어는 실행하지 않으나, 제어계 CPU 유닛(10)의 백업기능을 달성할 필요에서 제어계 CPU 유닛(10)과 같은 H/W 구성을 하고 있으며, 내부의 프로그램을 포함한 데이터도 같게 되어있다.
이 때문에, 대기계 CPU 유닛(110)은, 전송라인(6)을 통해서 트래킹정보를 제어계 CPU 유닛(1)로부터 항상받고 있다.
여기서, 트래킹되어 있는 정보에는 제어대상기기의 상태를 표시하는 입력정보, 제어출력정보, 표준프로그램, 어플리케이션프로그램에서 실행한 제어알고리즘의 계산의 도중결과와 결과의 데이터, 어플리케이션프로그램 그 자체, 제어연산 등에서 사용하는 파라미터등이 있다.
다음에 일반적인 트래킹 수법에 대해 제11도의 플로차트를 사용해서 설명한다.
우선 스텝 S1100에서, 제어계 CPU 유닛의 시스템정보와 미리 RUN 전에 사용자의해 범위 설정한 제어계 CPU 유닛의 디바이스정보를 추출하고 스텝 S1101로 이행한다.
스텝 S1101에서는 제어계 CPU 유닛으로 추출한 정보를 대기계 CPU 유닛내의 트래킹메모리에 전송한다.
그리고, 스텝 S1102에 의해, 대기계 CPU 유닛내의 트래킹메모리에 전송된 정보를, 각 대상 메모리인 디바이스메모리, 시스템메모리의 어느것인가에 반영함으로써 시행된다.
그러나 일본국 특개평 2-81101호 공보에 기재된 트래킹이라는 것은, 일단 시스템이 작동된 후, 즉 가동중의 제어계 CPU 유닛과 대기계 CPU 유닛간에 있어서 변경이 있었던 데이터의 동일성을 보존하기 위한 기술일뿐이다.
이 때문에 시스템의 작동시에 필요하게 되는 프로그램, 데이터등은 트래킹을 실행할 수가 없고, 제어계 CPU 유닛 및 대기계 CPU 유닛간에서 동일성을 보존할 수가 없다.
또 일반적으로 트래킹하는 트래킹데이터는 사용자에 의한 파리미터설정에 의해 메모리영역이 미리 설정된 범위내의 데이터를 대상으로 하고 있기 때문에, 트래킹데이터의 대상이 되는 메모리영역과는 다른 영역에 저장되는 데이터는 트래킹데이터로서 트래킹되지 않고, 마찬가지로 제어계 CPU 유닛 및 대기계 CPU 유닛간에서 동일성을 보존할 수가 없다.
이 때문에, 트래킹에 관한 신뢰성의 관점에서 아래에 표시하는 것과 같은 방법을 사용해서, 제어계 CPU 유닛 및 대기계 CPU 유닛간의 프로그램, 데이터 설정을 하고 있었다.
아래에 대기용장화 시스템에서, 제어계 CPU 유닛 및 대기계 CPU 유닛에 대해서 파일일괄 기록수단이나 디바이스일괄 기록수단과 같은 통신서비스기능을 실행할때의 프로그램, 데이터등의 설정방법에 대해 제12도의 플로차트 및 제13도의 순서를 표시한 도면을 사용해서 설명한다.
상술한 바와 같이 대기용장화 시스템에서는 양계의 CPU 유닛에 대해 각각 같은 프로그램, 데이터로 할 필요가 있다.
이 때문에, STOP 모드에서, 대상으로 하는 CPU 유닛에 통신회신을 통해서, 주변장치를 접속하고, 주변장치로부터의 프로그램, 데이터 등의 일괄기록요구에 따라, CPU 유닛 내부의 파일일괄 기록수단, 디바이스 일괄기록수단이 주변장치로부터 전송된 파일내용이나 디바이스정보를 대상메모리 즉, 디바이스메모리, 프로그램메모리의 어느 하나에 기록한다.
이 기록에 있어서, CPU 유닛은 기록되는 프로그램, 데이터등의 제어대상 에리어등을 체크하고 있다.(스텝 S1200, S1201)
그리고 주변장치로부터의 일괄기록의 코멘드실행이 정상적으로 완료되면, 응답데이터를 작성(스텝 S1202)하고, 이를 주변장치에 대해 완료를 알리는 응답을 보낸다(스텝 S1203), (제13(a)도 참조)
그 후 주변장치를 대기계 CPU 유닛으로 접속선을 변경하고(제13(b)도 참조), 대기계 CPU 유닛에 대해서도 제10도에 따라 동일한 기록처리를 실행하고 있었다(제13(c)도 참조). 다음에, 제어계 CPU 유닛의 프로그램메모리, 디바이스메모리, 외부메모리내의 각 파일내용을, 대기계 CPU 유닛의 대응하는 각 메모리(프로그램메모리, 디바이스메모리, 외부메모리)에 전송하는 경우에 대해 설명한다.
우선 주변장치로부터 제어계 CPU 유닛에 대해서 파일일괄 판독수단이나 디바이스일괄 판독수단을 제12도에 따라 실행하고(제13(a)도 참고), 제어계 CPU 유닛내의 판독데이터를 일단 주변장치에 받아들인다.
그 후 상기 주변장치를 제어계 CPU 유닛으로 접속선을 변경하고(제13(b)도 참조), 대기계 CPU 유닛에 대해 제어계 CPU 유닛에서 판독한 정보를 통신 서비스기능의 파일 일괄기록수단이나 디바이스일괄기록수단에 의해 대기계 CPU 유닛의 대상메모리에 대해 기록되어야 한다. (제13(c)도 참조).
또, 주변장치로부터 프로그램파일을 일괄해서 대상 CPU 유닛의 프로그램 메모리에 기록할때는, CPU 유닛의 운전상태가 RUN이면 STOP로 전환해서 실행할 필요가 있다.
이 RUN으로부터 STOP에 또는 STOP로부터 RUN으로의 운전상태의 전환은, 대기용장화시스템에서, 대기계 CPU 유닛의 운전상태를 제어계 CPU 유닛의 운전상태와 동일하게 하기 위해, 제어계 CPU 유닛의 운전상태의 변화에 맞추어 대기계 CPU 유닛의 운전상태 전환스위치를 수동으로 전환함으로써 실현하고 있었다.
[발명의 이루고자하는 기술적과제]
상술한 바와같이, 트래킹할 수 없는 데이터의 제어계 CPU 유닛 및 대기계 CPU 유닛간의 동일성 확보를 위해서는, 주변장치를 양계의 CPU 유닛에 각각 접속해서 동일성을 보존할 필요가 있었고, 데이터의 동일성을 확보하기 위한 작업이 대단히 번잡하였었다.
또 일반적으로 프로그램을 일부변경할때에는, RUN 모드에서의 END 처리시에 주변기기로부터 변경하는 프로그램을 기록 대응하고 있다.
그러나, END 처리의 한정된 시간내에서는, 통신회선을 통한 주변기기로부터 기록할 수 있는 프로그램의 용량이 제한되어 버린다.
또 최근의 프로그램의 경향으로서, 각 프로그램이 모듈화되고, 각각의 프로그램이 밀접하게 결합되어서 일련의 프로그램을 형성하는 것에서는, 모듈화 한 1블록의 프로그램내부를 일부 변경하는 것보다, 그 한 블록의 프로그램 내부 전체를 변경하는 쪽이 작업효율, 프로그램의 신뢰성의 관점에서 유용할때가 많다.
또 RUN 모드에서의 END 처리시에는 RUN 모드로부터 STOP로 변경하고, 이 STOP 모드에서 일괄해서 주변기기로부터 프로그램을 기록하고 있었으므로, 일단 제어 대상기기를 STOP 시켜야 하며, 작업효율이 저하한다는 과제가 있었다.
또, 트래킹은 설정된 범위내의 데이터전부를 트래킹데이터로 인식하기 때문에, 변경이 없는 데이터도 트래킹데이터로 인식하고, 트래킹에 요하는 시간도 길어져버린다.
본 발명은 이런 문제점을 해결하기 위해 된 것으로, 제1의 목적은 대기용장화 시스템에서의 데이터 동일성 보존을 위한 작업성을 향상시키는 것이다.
또 제2의 목적은, 데이터동일성의 신뢰성을 보다 향상시키는 것이다.
또 제3의 목적은, 대기용장화시스템에서, RUN 중에도 일괄해서 프로그램의 변경을 가능케하고, 작업효율을 향상시키는 것이다.
또 제4의 목적은, RUN 중에서 일괄해서 기록하는 프로그램의 신로성을 향상시키는 것이다.
또 제5의 목적은, RUN 중에서 일괄해서 기록하는 프로그램의 동기를 확실하게 취하는 것이다.
또, 제6의 목적은, 대기용장화 시스템에서의 트래킹작업을 효율화하는 것이다.
또, 제7의 목적은 대기용장화 시스템에서의 운전상황의 변화에 빨리 대응하고, 효율적으로 운전전환을 하는 것이다.
[발명의 구성 및 작용]
본 발명에 관한 대기용장화시스템에서는, 제어대상기기를 제어하는 제어계 CPU 유닛과, 상기 제어대상기기를 상기 제어계 CPU 대신에 제어가능한 대기계 CPU 유닛을 구비한 대기용장화 시스템에서, 주변기기로부터 입력되는 명령문 및 데이터로 구성되는 코멘드를 일시 보관하고, 그 코멘드에서의 명령문에 따른 상기 데이터의 처리를 하는 동시에, 일시보관하고 있던 상기 코멘드를 다른계통의 CPU 유닛에 대해 전송하는 트래킹수단을 구비한 것이다.
또, 주변기기로부터 입력되는 명령문 및 프로그램으로 구성되는 코멘트를, 일시보관하고, 그 코멘드에서의 상기 명령문에 따라 상기 프로그램을 내부 접속된 제1의 외부메모리의 에러 체크를 하면서 저장하는 동시에, 일시보관하고 있던 상기 코멘드를 제2의 CPU 유닛에 대해 전송하는 제1의 CPU 유닛과, 전송된 코멘드의 상기 명령문에 따라, 상기 프로그램을 내부 접속된 제2의 외부메모리의 에러체크를 하면서 저장하는 동시에, 상기 체크결과를 상기 제1의 CPU 유닛에 송신하는 제2의 CPU 유닛을 구비하고, 각각 제1 및 제2의 외부메모리에 저장되어 있는 상기 프로그램을, 시퀸스프로그램에 따른 RUN 중에 각각 대응하는 메모리에 기록하도록 한 것이다.
또, 제어대상기기를 제어하는 제어계 CPU 유닛과, 상기 제어대상기기를 상기 제어계 CPU 유닛 대신에 제어가능한 대기계 CPU 유닛을 구비한 대기용 장화시스템에서, 제어계 CPU 유닛의 운전상태를 스켄마다에 기억하고, 스켄종료마다에 현재의 운전상황 및 스켄전의 운전상황을 비교해서, 운전상황의 변화가 검출되면, 대기계 CPU 유닛에 대해 운전 상황을 변경시키기 위한 코멘드를 발행하도록 한 것이다.
[발명의 실시의 형태]
[실시의 형태 1]
본 발명의 실시의 형태 1을 도면을 사용해서 설명한다.
제1도는 대기용장화 시스템의 PC의 전체의 구성을 표시하는 블록도이다.
도면에서, 1은 실제로 제어 대상기기의 제어를 하는 제어계 CPU 유닛, 100은 제어계 CPU 유닛이 어떤원인으로 다운되었을때에, 계속해서 제어 대사기기의 제어를 하는 대기계 CPU 유닛이다.
2,200은 CPU 유닛에 내부버스 등에 의해 접속되는 파일레지스터나 프로그램 파일을 저장하는 외부메모리, 3,300은 CPU 유닛에 통신회선에 의해 접속되는 사용자가 프로그램을 작성하거나 PC에 프로그램을 저장하기 위한 주변장치, 4,400은 운전상태를 STOP으로부터 RUN, 또는 RUN으로부터 STOP에 수동으로 전환하는 운전상태 전환스위치이다.
11은 프로그램을 실행하는 CPU, 12는 CPU(11)를 제어하는 OS 로서의 마이크로 프로그램을 저장하는 마이크로 프로그램 ROM, 13은 디바이스정보를 저장하는 디바이스메모리, 14는 CPU(11)를 제어하기 위한 시스템정보를 저장하는 시스템메모리, 15는 시퀸스프로그램이 저장되는 프로그램 메모리, 16은 대기용장화 시스템에서 제어계 CPU 유닛(1)과 대기계 CPU 유닛(100)사이에서 트래킹하는 트래킹데이터를 저장하는 트래킹메모리, 17은 대기용장화 시스템에서, 타계의 CPU 유닛과 트래킹데이터의 주고받기를 하는 트래킹인터페이스, 18은 외부메모리(2)와 데이터의 주고받기를 하는 외부메모리인터페이스, 19는 주변장치(3)와 데이터의 주고받기를 하는 주변인터페이스이다.
또 제어계 CPU 유닛(1)과 대기계 CPU 유닛(100)은 같은 내부구성을 갖고 있다.
즉, 제어계 CPU 유닛(1)과 대기계 CPU 유닛(100)은 같은 내부구성을 갖고 있다.
즉 제어계 CPU 유닛(1)에서의 CPU(11), 마이크로프로그램 ROM(12), 디바이스메모리(13), 시스템메모리(14), 프로그램메모리(15), 트래킹메모리(16), 트래킹인터페이스(17), 외부메모리인터페이스(18), 주변인터페이스(19)에 대응해서, 대기계 CPU 유닛(100)의 CPU(101), 마이크로프로그램 ROM(102), 디바이스메모리(103), 시스템메모리(104), 프로그램메모리(105), 트래킹메모리(106), 트래킹인터페이스(107), 외부메모리인터페이스(108), 주변인터페이스(109)가 구성되어 있다.
제2도는 본 실시의 형태 1에 관한 마이크로프로그램 ROM(12), (102)의 내부기능의 상세를 표시한 메모리 구성도이다.
본 실시의 형태에서는 마이크로프로그램 ROM(12), (102)의 주기능으로서, 주변장치(3)와 CPU 유닛(1), (100) 사이에서의 데이터의 주고받기나, 주변장치(3)로부터 CPU 유닛(1), (100)로의 동작지령을 제어하는 통신서비스에 관한 통신서비스기능(20) 및 제어계 CPU 유닛(1)과 대기계 CPU 유닛(100)간에서의 정보 및 상태의 변화를 검출하는 메인기능(30) 및 대기용장화 시스템에서의 제어계 CPU 유닛(1)과 대기계 CPU 유닛(100)간에서 데이터의 주고받기를 제어하는 트래킹기능(40)을 들 수 있다.
여기서, 통신서비스기능(20)은, 그 상세한 수단으로서, 주변장치(3)으로부터의 지령에 따라, 지정하는 운전상태로 변경하는 운전상태변경수단(21), 주변장치(3)로부터 파일을 지정하는 프로그램 메모리(15) 또는 외부메모리(2)에 대해 일괄기록을 하는 파일일괄기록수단(22), 주변장치(3)로부터 디바이스치를 디바이스메모리(13)에 대해 일괄 기록을 하는 디바이스 일괄기록수단(23), CPU 유닛(1)이 지정하는 프로그램메모리(15) 또는 외부메모리(2)내의 지정하는 파일을 주변장치(3)에 대해 일괄판독을 하는 파일일괄판독수단(24), CPU 유닛(1)의 디바이스메모리(13)내의 지정 디바이스치를 주변장치(3)에 대해 일괄 판독을 하는 디바이스 일괄판독수단(25), 외부메모리(2)내에 미리 존재하는 파일을, RUN 중(일련의 스캔종료후의 엔드처리시)에 프로그램메모리에 전송하는 RUN 중 일괄파일전송수단(26)을 갖고 있다.
또, 메인기능(30)은 그 상세한 수단으로서, 자동적으로 시스템정보의 변화를 검출하고, 변화가 있었던 시스템저옵를 타계통의 CPU 유닛에 송신하는 시스템정보검출수단(31), 대상 CPU 유닛의 운전상태의 변화를 검출하고, 운전상태의 변경을 타계통의 CPU 유닛에 송신하는 운전상태검출수단(32)를 갖고 있다.
또 트래킹기능(40)은 그 상세한 수단으로서, 제어계 CPU 유닛(1)의 시스템정보 및 사용자로부터 지정된 범위의 디바이스정보를 대기계 CPU 유닛(100)에 대해 전송하는 데이터트래킹수단(41), 주변장치(3)로부터 대기용장화 시스템의 제어계 CPU 유닛(1)에 대해 통신서비스요구가 걸리면, 트래킹유닛을 통해서 대기계 CPU 유닛(100)에 대해서도 같은 통신 서비스요구를 거는 통신서비스요구 트래킹수단(42), 제어계 CPU 유닛(1)의 프로그램메모리(15)나 외부메모리(2)내의 파일내용을 대기계 CPU 유닛(100)의 해당하는 프로그램메모리(105)나 외부메모리(200)에 대해 전송하는 파일내용 트래킹수단(43)을 갖고 있다.
제3도는 통신서비스요구 트래킹수단(41)의 동작의 상세를 표시하는 플로차트.
대상으로하는 CPU 유닛에 접속된 주변장치(3)으로부터 제어계 CPU 유닛(1)에 대해 통신서비스기능(20)의 코멘드가 발생되고, 스텝 S300에서, 그 코멘드를 제어계 CPU 유닛(1)이 수신하면, 스텝 S301에서 송신되어온 코멘드내용에 따른 마이크로프로그램 ROM(12)내의 통신서비스기능(20)이 실행된다.
즉, 송신되어온 코멘트의 선두부분의 명령을 CPU(1)가 해석하고 그 명령에 대응하는 마이크로프로그램 ROM(12)내의 어느 한 프로그램이 기동되며, CPU(1)에 의해 그 프로그램에 따라, 명령이후의 데이터 처리를 실행한다.
이때, 제어계 CPU 유닛(1)은 코멘드에 따른 처리가 실제로, CPU(1) 자신이 프로그램, 데이터등의 제어대상에리어등을 체크해서, 이 프로그램, 데이터등이 실제로 유효한지 아닌지를 체크하고 있다.
또, CPU(1)는 주변기기(3)로부터 송신되어온 코멘드 전체를, 시스템 메모리(14)에 그대로 저장해둔다.
스텝 S301에서 송신된 코멘드에 따른 처리가 완료되면, 스텝 S202로 이행하고, 주변장치(3)에대한 정상완료 혹은 이상완료를 표시하는 응답데이터를 작성한다.
그후, 스텝 S303에서 스텝 S301의 실행이 정상완료되었는지의 여부를 검출한다.
여기서, 이상완료이면 스텝 S304로 이행하고, 스텝 S302에서 작성한 응답을 주변장치(3)로 돌려보내고 처리를 종료한다.
스텝 S303에서, 정상완료이면, 상기 스텝302에서 작성한 응답을 버리고, 통신서비스요구 트래킹수단(41)에 의해 대기계 CPU 유닛(100)의 트래킹메모리(16)에 대해, 상기 스텝 S300에서 제어계 CPU 유닛(1)이 받은 통신서비스기능(20)의 코멘드와 같은 코멘드를 발행한다.
구체적으로는, 시스템메모리(14)에 저장되어있던 받은 코멘드를 트래킹인터페이스(17)를 통해서 대기계 CPU 유닛(100)에 대해 발행한다.
스텝 S305에서, 대기계 CPU 유닛(100)이 제어계 CPU 유닛(1)으로부터 트래킹인터페이스(107)를 통해서 트래킹메모리(106)에 일단 저장된 주변장치(3)로부터 발행된 코멘드와 완전 동일한 코멘드를 수신하면, 스텝 S306에서 송신되어 온 코멘드 내용에 따른 통신서비스 기능내의 각 수단이 처리를 실행한다.
이 코멘드에 대한 실행도, 송신되어온 코멘드의 선두분의 명령을 CPU(101)가 해석하고, 그 명령에 대응하는 마이크로 프로그램 ROM(102)내의 어느하나의 프로그램이 기동되며, CPU(101)에 의해 그 프로그램에 따라, 명령이후의 데이터 처리를 실행한다.
이때에도 대기계 CPU 유닛(100)은 코멘드에 따른 처리가 실제로 제어가능한지의 여부를 체크하고 있다.
스텝 S306에서 송신된 코멘드에 따른 처리가 완료되면 스텝 S307로 이행하고, 제어계 CPU 유닛(1)에 대한 정상완료 혹은 이상완료를 표시하는 응답 데이터를 작성하며, 스텝 S308에서 제어계 CPU 유닛(1)의 트래킹메모리(16)에 대해 전송된다.
제어계 CPU 유닛(1)은, 대기계 CPU 유닛(100)으로부터의 정상완료 혹은 이상완료를 표시하는 응답데이터를 수신하면 스텝 S309에서 받은 응답데이터를, 제어계 CPU 유닛(1)에 스텝 S300에서 통신서비스기능(20)의 코멘드를 발행하는 주변장치(3)에 대해 돌려주고, 일련의 처리를 종료한다.
주변장치(3)는, 제어계 CPU 유닛(1)으로부터의 응답에 의해 자신이 이송한 코멘드에 따른 처리가 제어계 CPU 유닛(1) 혹은 대기계 CPU 유닛(100)에서 정상적으로 시행되었는지 여부를 확인할 수가 있다.
다음 제4도의 프로차트를 사용해서 파일 일괄기록처리에 대해 설명한다.
제어계 CPU 유닛(1)에 접속해 있는 주변기기(3)으로부터 통신서비스기능(20)으 파일일괄기록수단(22)을 기동하기 위한 명령과, 그 기록하는 파일이 첨부된 코멘드를 발행함으로써 제4도에서 표시되는 플로차트가 기동된다.
스텝 S400에서 제어계 CPU 유닛(1)의 CPU(11)가 주변장치(3)으로부터 코멘드를 주변인터페이스(19)를 통해서 수신함으로써 스텝(401)로 이행한다.
스텝 S401에서 CPU(11)은 송신된 코멘드의 선두부분에 존재하는 명령문을 해석하고, 마이크로프로그램 ROM(12)내의 파일일괄기록수단(22)의 프로그램을 판독해서 실행한다.
파일일괄기록수단(22)에 따른 프로그램은, 명령문에 첨부되어 있는 파일을, 명령문에 규정되어 있는 파일메모리(2) 혹은 프로그램메모리(15)의 소정영역에 기록하는 처리를 실행한다.
이 파일일괄기록수단(22)에 의해 파일을 외부메모리(2) 혹은 프로그램메모리(15)의 소정영역에 기록할 때, 송신되어온 파일내부의 프로그램의 명령코드호출 부속정보가 소정범위내인지 아닌지를 파일일괄기록수단(21) 에 따른 CPU(1)의 기능에 의해 체크하고 있다.
그리고, 스텝 S402에서, 코멘드에 대한 정상완료 혹은 이상완료를 표시하는 응답데이터를 작성하고, 스텝 S403으로 이행한다.
스텝 S403에서는, 코멘드에 대한 처리가 정상완료되었는지의 여부를 검출하고, 이상완료이면 스텝 S404로 이행하며, 제어계 CPU 유닛(1)에 대한 코멘드가 실패한 것을 통지하고 처리를 종료한다.
정상완료이면, 스텝 S402에서 작성한 응답을 버리고 주변기기(3)로부터 송신된 코멘드와 같은 코멘드를 대기계 CPU 유닛(100)에 전송하기 위한 통신서비스요구트래킹수단(41)을 마이크로 프로그램 ROM(12)으로부터 기동한다.
통신서비스 요구 트래킹수단(41)에 의해, CPU(11)는 주변기기(3)로부터 송신된 코멘드를 저장하고 있던 시스템 메모리(14)로부터 인출하고 대기계 CPU 유닛(100)의 트래킹메모리(106)에 대해 트래킹인터페이스를 통해서 발행한다.
대기계 CPU 유닛(100)에서는, 스텝 S405에서, 트래킹메모리(106)에 전송된 코멘드를 수신하면 스텝 S406으로 이행한다.
스텝 S406에서, CPU(101)는 트래킹메모리(106)에 의해 수신한 코멘드의 명령문을 해석하고, 이 코멘드는 제어계 CPU 유닛(1)로부터의 파일일괄기록인 것을 인식한다.
그리고, CPU(101)는 마이크로 프로그램 ROM(12)의 파일일괄기록수단의 프로그램을 판독실행하고, 명령문에 규정되어 있는 외부메모리(200) 혹은 프로그램메모리(105)의 소정영역에 첨부파일의 기록처리를 실행한다.
이 대기계CPU유닛(100)에서의 기록처리때에도, 제어계 CPU 유닛(1)이 시행한 파일일괄기록수단에 따른 CPU(101)의 기능에 의한 체크를 하고 있다.
그리고, 스텝 S407에서, 코멘드에 대한 정상완료 혹은 이상완료를 표시하는 응답데이터를 작성하고, 스텝 S408에서 제어계 CPU 유닛(1)의 트래킹메모리(16)에 대해, 트래킹 인터페이스를 통해 전송된다.
스텝 409에서는, 제어계 CPU 유닛 1은, 대기계 CPU 유닛(100)으로부터의 정상완료 혹은 이상완료를 표시하는 응답데이터를 수신하면, 수신한 응답데이터를 주변장치(3)에 대해 반송하고, 일련의 처리를 종료한다.
본 실시의 형태에 의하면, 종래 주변기기(3)를 제어계 CPU 유닛(1) 및 대기계 CPU 유닛(100) 각각에 접속하고, 파일을 기록하던 처리를, CPU의 기능으로서 통시서비스요구 트래킹수단을 설치함으로써, 주변기기로부터 한번의 코멘드 발신에 의해 제어계 CPU 유닛(1)이 같은 코멘드를 대기계 CPU 유닛(100) 측에도 송신하고, 파일을 일괄해서 제어계 CPU 유닛(1) 및 대기계 CPU 유닛(100) 각각에 기록할 수가 있다.
이 때문에, 시스템의 기동시의 프로그램의 변경에 대한 사용자의 작업효율을 향상시킬수가 있다.
또 일괄해서, 파일을 기록할때도, 대기계 CPU 유닛(100)으로부터의 응답을, 주변기기에 송신하고, 확실하게 파일이 기록되었는지 여부를 주변기기에서 체크할 수 있으며, 프로그램을 통신회선을 통해서 송신하는 경우에 문제가 되는 신뢰성도 고려할 수 있다.
이 때문에 용장화 시스템의 특징인, 제어계 CPU 유닛(1)의 다운시에 대기계 CPU 유닛(100)이 계속해서 동일 프로그램으로 제어를 할 수가 있다.
또, 종래의 트래킹과는 달리, 트래킹하는 메모리의 지정영역에 구애되지 않고 파일기록을 실행할 수가 있다.
[실시의 형태 2]
본 실시의 형태 2에서는, 양계 동시에 디바이스 일괄기록을 실행하는 처리에 대해 제5도를 사용해서 설명한다.
제어계 CPU 유닛(1)에 접속해 있는 주변장치(3)로부터, 통신서비스기능(20)의 디바이스일괄기록수단(23)을 기동하기 위한 명령과, 그 기록파일이 첨부된 코멘드를 발행함으로써 제5도에 표시되는 플로차트가 기동된다.
스텝 S500에서 제어계 CPU 유닛(1)의 CPU(11)가 주변장치(3)로부터 코멘드를 주변인터페이스(19)를 통해서 수신함으로써 스텝 S501로 이행한다.
스텝 S501에서, CPU(1)는 송신되어온 코멘드의 선두부분에 존재하는 명령문을 해석하고, 마이크로프로그램 ROM(12)내의 디바이스일괄기록수단(23)의 프로그램을 판독해서 실행한다.
디바이스일괄기록수단(23)에 따른 프로그램은, 명령문에 첨부되어 있는 기록을 위한 디바이스정보를, 명령문에 규정되어 있는 디바이스메모리(13)의 소정영역에 기록하는 처리를 실행한다.
이 디바이스일괄기록수단(23)에 의해, 디바이스 정보를 디바이스메모리(13)의 소정영역에 기록할 때, 기록을 하는 선두 디바이스 및 그 선두 디바이스와 점수로부터 구해지는 최종 디바이스가 파라미터로 설정되어 있는 디바이스범위내인지의 여부를 디바이스 일괄기록수단(23)에 따른 CPU(1)의 기능에 의해 체크하고 있다.
그리고, 스텝 S502에서, 코멘드에 대한 정상완료 혹은 이상완료를 표시하는 응답데이터를 작성하고, 스텝 S504로 이행한다.
스텝 S503에서는, 코멘드에 대한 처리가 정상완료하였는지 여부를 검출하고, 이상완료이면, 스텝 S504로 이행하며, 제어계 CPU 유닛(1)에 대한 코멘드가 실패한 것을 통지하고, 처리를 종료한다.
정상완료이면, 스텝 S502에 작성한 응답을 버리고, 주변기기(3)로부터 송신되어온 코멘드와 동일한 코멘드를 대기계 CPU 유닛(100)에 전송하기 위한 통신서비스요구 트래킹수단(41)을, 마이크로프로그램 ROM(12)으로부터 기동한다.
통신서비스요구 트래킹수단(41)에 의해, CPU(11)는 주변기기(3)으로부터 송신된 코멘드를 저장하고 있던 시스템메모리(14)로부터 코멘드를 인출하고, 대기계 CPU 유닛(100)의 트래킹메모리(106)에 대해 트래킹 인터페이스를 통해 발행한다.
대기계 CPU 유닛(100)에서는, 스텝 S505에서, 트래킹메모리(106)에 전송된 코멘드를 수신하면, 스텝 S506로 이행한다.
스텝 S506에서 CPU(101)는 트래킹메모리(106)에 의해, 수신한 코멘드의 명령문을 해석하고, 이 코멘드는 제어계 CPU 유닛(1)으로부터의 디바이스일괄기록인 것을 인식한다.
그리고 CPU(101)는, 마이크로 프로그램 ROM(102)내의 디바이스 일괄기록수단의 프로그램을 판독 실행하고, 명령문에 규정되어 있는 디바이스메모리(103)는 소정영역에 첨부파일의 기록처리를 실행한다.
이 대기계 CPU 유닛(100)에서의 기록처리때도, 제어계 CPU 유닛(1)이 시행한 디바이스일괄기록수단에 따른 CPU(101)의 기능에 의한 체크를 하고 있다.
그리고 스텝 S507에서, 코멘드에 대한 정상완료 혹은 이상완료를 표시하는 응답데이터를 작성하고, 스텝 S508에서 제어계 CPU 유닛(1)의 트래킹메모리(16)에 대해 트래킹인터페이스를 통해서 전송한다.
스텝 S509에서는, 제어계 CPU 유닛(1)은, 대기계 CPU 유닛(100)으로부터의 정상완료 혹은 이상완료를 표시하는 응답데이터를 수시하면, 수신된 응답데이터를 제어계 CPU 유닛(1)에 통신서비스기능(20)의 코멘드를 발행한 주변장치(3)에 대해 반송하고 일련의 처리를 종료한다.
또 실시의 형태에 의하면, 종래 주변기기(3)를 제어계 CPU 유닛(1) 및 대기계 CPU 유닛(100) 직각에 접속하고, 파일을 기록하던 처리를, CPU의 기능으로서, 통신서비스 요구 트래킹수단을 설치함으로서, 한번의 코멘드 발신에 의해 제어계 CPU 유닛(1)이 같은 코멘드를 대기계 CPU 유닛(100) 측에도 송신하고, 디바이스치 즉 디바이스정보를 일괄해서 제어계 CPU 유닛(1) 및 대기계 CPU 유닛(100) 각각에 기록할 수가 있고, 시스템의 기동시의 프로그램의 변경에 대한 사용자의 작업효율을 향상시킬수가 있다.
또 일괄해서 파일을 기록할때도, 대기계 CPU 유닛(100)으로부터의 응답을 주변기기에 송신하고, 확실하게 정확한 정보가 기록되었는지 여부를 주변기기에서 체크할 수 있으며 통신회선을 통해서 송신하는 경우에 문제가 되는 신뢰도 고려할 수 있다.
또, 종래의 트래킹과는 달리, 디바이스 데이터가 저장되는 메모리에서의 트래킹지정영역에 구애되지 않고, 디바이스기록을 실행할수 있다.
즉, 트래킹하는 디바이스데이터가 여러개의 트래킹지정영역에 걸칠때에도 일괄해서 디바이스 데이터를 기록할 수가 있고, 디바이스 정보의 동일성을 유지하며, 용장화 시스템의 특징인, 제어계 CPU 유닛(1)의 다운시에 대기계 CPU 유닛(100)이 계속해서 제어를 할 수가 있다.
[실시의 형태 3]
본 실시의 형태 3에서는, 양계 동시에 RUN 중 일괄파일전송을 실행하는 처리에 대해 제6도를 사용해서 설명한다.
본 실시의 형태 3에서는, 상술한 실시의 형태 1에 표시되는 처리에 의해 주변기기(3)로부터의 제어계 CPU 유닛(1) 및 대기계 CPU 유닛(100)에 대한 파일일괄기록을 일단의 외부메모리(2), (200)에서 시행한 후, 프로그램의 RUN 중, 즉 RUN 중의 END 처리시에 기록된 파일을 내부버스를 통해서 프로그램메모리(15), (105)에 일괄해서 기록하는 처리를 표시하고 있다.
제6도를 사용해서, 구체적으로 처리순서에 대해 설명한다.
우선, 스텝 S600에서 통신서비스기능(20)의 파일일괄기록수단(22)을 기동하기위한 명령과, 그 기록파일이 첨부된 코멘드를 발행함으로써, 제4도에 표시되는 플로차트가 기동되고, 상술한 실시의 형태 1과 같이, 프로그램의 실행에 영향이 없는 양계의 외부메모리(2), (200)에 대해, 파일일괄기록수단(22)의 실행에 의해, RUN 중에 변경하고 싶은 프로그램파일을 기록한다(스텝 S601).
그리고 스텝 S602에서, 제어계 CPU 유닛(1) 및 대기계 CPU 유닛(100)에 대한 프로그램파일기록이 정상적으로 완료하였는지의 여부를 제어계 CPU 유닛(1) 혹은 대기계 CPU 유닛(100)으로부터의 응답데이터에 의해 판단한다.
여기서 응답데이터에 의해 이상완료된 경우는 처리를 종료한다.
주변기기(3)는 제어계 CPU 유닛(1)을 통해서 송신되는 응답데이터에 의해, 제어계 CPU 유닛(1) 및 대기계 CPU 유닛(100)의 외부메모리(2), (200)에 대한 파일일괄기록이 정상완료된 것을 검출하면, 대기용장화시스템의 제어계 CPU 유닛(1)에 대해, RUN 중 일괄파일전송수단(26)을 기동하기 위한 코멘드를 발행한다.
스텝 S603에서, 제어계 CPU 유닛(1)이 주변장치(3)으로부터 RUN 중 일괄파일전송수단(26)의 코멘드를 수신하면, 그 코멘드의 명령을 해석하고, 스텝 S604로 이행하며, 마이크로프로그램 ROM(12)내의 RUN 중 일괄파일전송수단(26)의 프로그램을 판독실행한다.
RUN 중 일괄파일전송수단(26)에 따른 프로그램은, 외부 메모리(2)에 저장되어 있는 프로그램파일을, RUN 중 즉 END 처리시에 접속된 내부버스를 통해서 프로그램메모리(15)의 소정영역에 전송하는 처리를 실행한다.
이 RUN 중 일괄파일전송수단(26)에 의해, 프로그램파일을 외부메모리(2)로부터 프로그램메모리(15)의 소정영역에 전송할 때, 파일내부의 프로그램의 명령코드 및 부족정보가 소정범위내인지 아닌지 또는 1스켄분의 파링내부의 프로그램을 축차실행하고, 설정등에 문제가 없으며 새롭게 전송되는 프로그램이 정상적으로 실행가능한지의 여부를 RUN 중 일괄파일전송수단(26)에 따른 CPU(11)의 기능에 의해 체크하고 있다.
RUN 중에서의 프로그램 파일의 전송은, 외부메모리(2)로부터 내부버스를 통해서 프로그램메모리(15)에 전송하는 내부처리이기 때문에 스텝 S600에서 주변장치(3)로부터 통신회선을 통해서 대상 CPU 유닛(1)의 외부메모리(2)에 대해 파일을 전송하는 시간보다도, 파일을 전송하는데 시간이 짧아서 고속으로 처리를 할 수 있다.
이 때문에, 이로인해 프로그램메모리(15)내의 대용량 프로그램 RUN 중에 일괄해서 변경할 수가 있게 된다.
그리고, 스텝 S605에서 코멘드에 대한 정상완료 혹은 이상완료를 표시하는 응답데이터를 작성하고 스텝 S606으로 이행한다.
스텝 S606에서는 코멘드에 대한 처리가 정상완료되었는지의 여부를 검출하고, 이상완료이면 스텝 S607로 이행하며, 제어계 CPU 유닛(1)에 대한 코멘드가 실패한 것을 주변기기(3)에 통지하고 처리를 종료한다.
정상완료이면, 스텝 S605에서 작성한 응답을 버리고, 주변기기(3)로부터 송신되어온 코멘드와 같은 코멘드를 대기계 CPU 유닛(100)에 전송하기 위한 통신서비스요구 트래킹수단(41)을, 마이크로프로그램 ROM(12)으로부터 기동한다.
통신서비스요구 트래킹수단(41)에 의해, CPU(11)는, 주변기기(3)로부터 송신된 RUN 중 일괄파일전송수단(26)의 코멘드를 저장하고 있던 시스템 메모리(14)로부터 인출하고, 대기계 CPU 유닛(100)의 트래킹메모리(106)에 대해, 트래킹인터페이스를 통해 발행한다.
대기계 CPU 유닛(100)에서는, 스텝 S608에서 트래킹메모리(106)에 전송된 코멘드를 수신하면 스텝 S609로 이행한다.
스텝 S609에서, CPU(101)는 트래킹메모리(106)에 의해 수신한 코멘드의 명령문을 해석하고 이 코멘드는 제어계 CPU 유닛(1)로부터의 RUN 중 일괄파일전송인 것을 인식한다.
그리고, CPU(11)는 마이크로 프로그램 ROM(12)내의 RUN 중 일괄파일전송수단의 프로그램을 판독 실행하고, 스텝 S601에서 외부메모리(200)에 기록한 프로그램파일을, 접속되어 있는 내부버스를 통해서 프로그램메모리(105)의 소정영역에 전송한다.
이 대기계 CPU 유닛(100)에서의 전송처리때에도, 제어계 CPU 유닛(1)은 RUN 중 일괄파일전송수단에 따른 CPU(101)의 기능에 의한 체크를 하고 있다.
RUN 중에서의 프로그램파일의 전송은, 외부메모리(200)로부터 내부버스를 통해서 프로그램메모리(105)에 전송하는 내부처리이기 때문에, 스텝 S601에서 주변장치(3)으로부터 통신회선을 통해서 대상 CPU 유닛(1)의 외부메모리(200)에 대해 파일을 전송하는 시간보다도, 파일을 전송하는데 필요한 쪽이 짧고 고속으로 처리할 수 있다.
이 때문에, 이로인해 프로그램메모리(105)내의 대용량 프로그램을 RUN 중에 일괄해서 변경하는 것이 가능해진다.
그리고 스텝 S610에서, 코멘드에 대한 정상완료 혹은 이상완료를 표시하는 응답데이터를 작성하고, 스텝 S611에서 제어계 CPU 유닛(1)의 트래킹메모리(16)에 대해, 트래킹 인터페이스를 통해서 전송한다.
스텝 S612에서는, 제어계 CPU 유닛(1)은 대기계 CPU 유닛(100)으로부터의 정상완료 또는 이상완료를 표시하는 응답데이터를 수신하면, 수취한 응답데이터를 제어계 CPU 유닛(1)에 통신서비스기능(20)의 코멘드를 발행한 주변장치(3)에 대해 반송하고 일련의 처리를 종료한다.
또, 본 실시의 형태에서는, 제어계 CPU 유닛(1) 및 대기계 CPU 유닛(100)으로부터의 응답에 의해, 양계 모두가 각 외부 메모리로의 파일기록이 이상완료가 아닌 경우에 주변기기로부터 RUN 중 일괄파일기록요구를 발신해서, RUN 중 일괄파일기록을 하였으나, 대기계 CPU 유닛(100)으로부터 정상완료의 응답을 수신한 제어계 CPU 유닛(1)이 RUN 중 일괄파일기록요구를 내도 된다.
또, 대기계 CPU 유닛(100)에 코멘드가 송신되어 오는 것도, 제어계 CPU 유닛(1)에서 정상완료이기 때문에, 대기계 CPU 유닛(100)에서 정상완료이면 양계 모두 정상완료이고, 대기계 CPU 유닛(100)으로부터, 제어계 CPU 유닛(1)에 대해, RUN 중 일괄파일기록을 발행하여도 된다.
본 실시의 형태 3에 의하면, 종래 주변기기(3)을 제어계 CPU 유닛(1) 및 대기계 CPU 유닛(100) 각각에 접속하고, 파일을 기록하였던 처리를, CPU의 기능으로해서, 통신서비스요구 트래킹수단을 설치함으로써, 한번의 코멘드 발신에 의해, 제어계 CPU 유닛(1)가 같은 코멘드 대기계 CPU 유닛(100) 측에도 송신하며, 파일을 일괄해서 제어계 CPU 유닛(1) 및 대기계 CPU 유닛(100)의 외부메모리(2), (200) 각각에 기록할 수가 있다.
그리고, 외부메모리(2), (200)에 기록된 프로그램파일은, 외부메모리와 접속되어있는 내부버스 등에 의한 내부처리에 의해, 고속으로 일괄해서 프로그램메모리(15), (105)에 전송할 수가 있다.
그래서, 종래에는 RUN 중의 END 처리에 예를 들면 500K 밖에는 기록할 수 없던 프로그램파일을 본 실시의 형태 3에서는, 외부메모리로부터 버스를 통한 내부처리의 메릿을 살리고, 일괄기록을 실현시킬수가 있으며, 제어대상기기 등을 STOP로 할 필요가 없어지고, 생산성이 더욱 향상된다.
또, 대기용장화 시스템에서, 제어계 CPU 유닛(1) 및 대기계 CPU 유닛(100)은 같은 타이미응로 프로그램을 주행시키는 것이 중요하지만, 본 실시의 형태에 의하면, 동시에 프로그램을 일괄해서 변경하는 것도 가능하고, 보다 더 대기용장화 시스템의 신뢰성이 향상된다.
또 근년의 프로그램의 모듈화에서, 모듈이 되는 프로그램전부를 이로갈해서 RUN 중의 짧은 시간에 변경가능하고, 프로그램 변경에서의 작업효율, 신뢰성을 향상시킬 수가 있다.
또, 일괄해서 파일을 기록할때도, 대기계 CPU 유닛(100)로부터의 응답을 주변기기에 송신하고, 확실하게 파일이 기록되었는지의 여부를 주변기기에서 체크가 가능하고, 프로그램을 통신회선을 통해서 송신하는 경우에 문제가 되는 신뢰성도 고려할 수 있다.
이 때문에, 용장화 시스템의 특징인, 제어계 CPU 유닛(1)의 다운시에 대기계 CPU 유닛(100)이 계속해서 동일프로그램으로 제어를 할 수가 있다.
[실시의 형태 4]
본 실시의 형태 4에서는, 양계 동시에 파일내용 트래킹을 실행하는 처리에 대해 제7도의 대기용장화 시스템에서의 RUN 모드전, 즉 STOP 모드중에 기동되어 있는 플로차트를 사용해서 설명한다.
스텝 S700에서, 대기용장화 시스템의 제어계 CPU 유닛(1)에서 미리 설정되어 있는 대기계 CPU 유닛(100)로의 전송의 대상이 되어 있는 프로그램메모리(15) 혹은 외부메모리(2)의지정파일(복수설정가)을 일괄해서 추출하고, 마이크로프로그램 ROM(12)내의 파일내용 트래킹수단(42)에 의해, 파일일괄 전송을 표시하는 명령문과 그 파일내용으로 되는 코멘드를, 대기계 CPU 유닛(100)의 트래킹메모리(106)에대해 전송된다.
스텝 S701에서는, 대기계 CPU 유닛(100)의 CPU(101)은 제어계 CPU 유닛(1)로부터 트래킹메모리(106)에 전송된 코멘드를 해석하고, 파일일괄전송을 함으로써, 파일내용 트래킹수단을 기동해서 스텝 S702로 이행하고, 스텝 S700에서 추출된 프로그램메모리(15) 혹은 외부메모리(2) 내의 선택된 파일을 대상이 되는 프로그램메모리(105) 혹은 외부메모리(200)에 기록하며, 완료되면 대기계 CPU 유닛(100)은, 스텝 S703에서 제어계 CPU 유닛(1)의 트래킹메모리(6)에 대해 완료를 알리는 응답을 반송한다.
이로 인해 파일내용 트래킹기능을 완료한다.
본 실시의 형태에 의하면, 파일마다의 제어계 CPU 유닛(1) 및 대기계 CPU 유닛(100)의 정합성이 취해진다.
이 때문에, 종래 파일내에서의 대상영역만의 트래킹데이터에서는, 동일성이 유지될수 없었던 부분에서도, 파일마다의 동일성 유지에 의해 대기용장화 시스템에서의 데이터의 동일성이 향상되고, 시스템 자체의 신뢰성이 향상된다.
또, 여러장소에 걸치는 데이터의 트래킹에 소요되고 있던 시간을 일괄해서 트래킹가능하게 함으로써, 트래킹시간 단축을 도모할수 있다.
또, 종래 주변기기(3)를 쌍방으로 연결을 다시해서 파일마다의 동일성 보존을 하고있던 작어이 필요없게 되고 작업효율이 향상된다.
[실시의 형태 5]
본 실시의 형태에서는, 시스템 정보의 자동전송수단의 처리에 대해 제8도의 대기용장화 시스템에서의 RUN 모드중에 기동되어 있는 플로차트를 사용해서 설명한다. 스텝 S800에서, 대기용장화 시스템의 제어계 CPU 유닛(1)의 CPU(11)는, 마이크로프로그램 ROM(12)내의 시스템 정보검출수단(31)에 따라, 시스템메모리(14)내의 시스템정보, 디바이스메모리(13)내의 디바이스정보, 외부메모리(2)내의 파일레지스터 정보에서의 값이 변경의 유무를 항상 감시하고 있다.
구체적으로는, 시스템 메모리(14)상에 소정의 영역을 설치하고, 그 영역에 각각의 메모리의값이 변경(값이 기록된다)될때마다, 기록되는 어드레스 및 그 값을 시스템정보 검출수단(30)에 따른 CPU(11)의 기능에 의해 동시에 기억해 둔다.
그리고, 스텝 S801에서, 시스템메모리(14)내를 해석해서, 값의 변경이 발생하면, 제어계 CPU 유닛(1)로부터 대기계 CPU 유닛(100)의 트래킹메모리(106)에 대해, 데이터트래킹수단(43)에 의해 갱신되 정보의 장소와 값이 변경정보를 전송한다.
스텝 S802에서, 대기계 CPU 유닛(100)은, 데이터 트래킹수단에 의해 전송된 갱신된 정보의 저장장소와 값의 변경전보를 트래킹메모리(106)가 수신하면, 스텝 S803으로 이행하고, 상기 변경정보에 의해, 제어계 CPU 유닛(1)에서 추출한 갱신된 메모리(디바이스메모리, 프로그램메모리, 외부메모리가 대상)에 대해 변경치를 반영하며, 완료되면, 대기계 CPU 유닛(100)은, 스텝 S804에서 제어계 CPU 유닛(1)의 트래킹메모리(16)에 대해 완료를 알리는 응답을 반송한다.
이로 인해, 시스템정보의 자동트래킹 기능을 완료한다.
본 실시의 형태 5에 의하면, 자동적으로 변경된 메모리내의 데이터만 타계의 CPU 유니에 대해 트래킹데이터로서 송신하므로, 종래 설정도어 있던 모든 영역의 데이터를 트래킹 데이터로서 송신하는 일이 없고, 변경이 있는 부분만이 필요한 데이터를 트래킹 할 수가 있고, 트래킹에 대한 시간이 단축되며, 여분의 트래킹처리가 발생하지 않으므로 변경이 있는 처리만 트래킹할 수 있어 고속의 대기계 CPU 유닛에 반영할 수가 있다.
또 변경이 있었던 부분만의 트래킹도 가능하고, 사용자는 미리 트래킹하기 위한 디바이스범위를 조사할 필요도 없으며, 작업효율도 향상된다.
[실시의 형태 6]
본 실시의 형태 6에서는, 운전상태의 자동 추종수단의 처리에 대해 제9도의 대기용장화 시스템에서 기동되어 있는 플로차트를 사용해서 설명한다.
스텝 S900에서, 대기용장화 시스템의 제어계 CPU 유닛(1)의 CPU(11)는, 마이크로 프로그램 ROM(12)내의 운전상태검출수단(32)에 따라, 시스템메모리(14)내의 영역에 저장되는 제어계 CPU 유닛(1)의 운전상태의 변화를 항상 감시하고 있다.
구체적으로는, 시스템 메모리(14)상에 소정의 영역에, 제어계 CPU 유닛(1)의 운전상태의 이력(1스켄전의 상태)을 유지하고 그 데이터와 현재의 운전상태를 비교한다.
그리고, 스텝 S901에서, 운전상태의 비교결과, 운전상태가 변화하면, 제어계 CPU 유닛(1)로부터 대기계 CPU 유닛(100)의 트래킹메모리(106)에 대해, 운전상태변경후에 제어계 CPU 유닛(1)의 운전상태로 변경하는 운전상태변경수단(21)의 요구를 통신서비스 요구 트래킹수단(33)에 의해 전송한다.
스텝 S902에서, 대기계 CPU 유닛(100)은, 데이터 트래킹수단에 의해 전송된 운전상태변경의 요구를 대기계 CPU 유닛(100)의 트래킹메모리(106)가 수신하면 스텝 S903으로 이행한다.
스텝 S903에서는 운전상태변경수단(21)에 따른 CPU(11)에 의해 운전상태 변경후의 제어계 CPU 유닛(1)과 같은 운전상태로 변경되고, 완료되면 대기계 CPU 유닛(100)은, 스텝 S904에서 제어계 CPU 유닛(1)의 트래킹 메모리(16)에 대해 완료를 알리는 응답을 보낸다.
이로 인해, 운전상태의 자동운전상태 추종 기능을 완료한다.
본 실시의 형태 6에 의하면, 자동적으로 변경된 제어계 CPU 유닛(1)의 운전상태를 표시하는 데이터를 대기계 CPU 유닛(100)에 대해 코멘드로서 송신하고, 그 코멘드에 따라, 대기계 CPU 유닛(100)은, 운전상태를 제어계 CPU 유닛(1)과 같게 한다.
이 때문에, 대기계 CPU 유닛의 운전상태가 제어계 CPU 유닛의 운전상태의 변화에 자동추종하고, 양계의 운전상태를 항상 같게 유지하며, 그 전환의 타이밍도 변동되는 일 없이 대기 용장화 시스템을 보다 효율 좋게 유지할 수가 있다.
[발명의 효과]
본 발명은, 이상 설명한 바와 같이 구성되어 있으므로, 아래에 기재하는 바와 같은 효과를 나타낸다.
본 발명에 관한 대기용장화 시스템에서는, 제어 대상기기를 제어하는 제어계 CPU 유닛과 상기 제어대상기기를 상기 제어계 CPU 유닛에 대신하여 제어가능한 대기계 CPU 유닛을 구비한 대기용장장화시스템에 있어서, 주변기기로부터 입력되는 명령문 및 데이터로부터 구성되는 코멘드를, 일시보관하고, 그 코멘드에서의 명령문에 따른 상기 데이터의 처리를 하는 동시에 일시보관하고 있던 상기 코멘드를 타계의 CPU 유닛에 대해 전송하는 트래킹수단을 구비하였으므로 주변기기로부터의 코멘드에 의해 양계의 CPU 유닛과 함께 데이터를 명령에 따라 처리할 수 있고, 데이터의 동일성 유지를 위한 작업성이 향상된다.
또, 주변기기로부터 입력되는 명령문 및 프로그램으로부터 구성되는 코멘드를 일시보관하고, 그 코멘드에서의 상기 명령문에 따라 상기 프로그램을 내부 접속된 제1의 외부메모리에 대한 에러체크를 하면서 저장하는 동시에, 일시 보관했던 상기 코멘드를 제2의 CPU 유닛에 대해 전송하는 제1의 CPU 유닛과 전송된 코멘드의 상기 명령문에 따라, 상기 프로그램을 내부 접속된 제2의 외부메모리에 대한 에러 체크를 하면서 저장하는 동시에, 상기 체크결과를 상기 제1의 CPU 유닛에 송신하는 제2의 유닛을 구비하고, 각각 제1 및 제2의 외부메모리에 저장되어 있는 상기 프로그램을 시퀸스프로그램에 따른 RUN 중에 각각 대응하는 메모리에 기록하도록 하였으므로, 외부메모리부터 RUN 중에 일괄해서 대용량의 프로그램을 기록할 수가 있고, 종래 프로그램의 기록에 필요했던 STOP 처리를 하지 않아도 되며, 작업시간을 단축할 수 있다.
또 제어대상기기를 제어하는 제어계 CPU 유닛과, 상기 제어대상기기를 상기 제어계 CPU 유닛 대신에 제어가능한 대기계 CPU 유닛을 구비한 대기용장화 시스템에 있어서, 제어계 CPU 유닛의 운전상황을 스켄마다에 기억하고, 스켄종료마다에 현재의 운전상황 및 1 스켄전의 운전상황을 비교하면, 운전상황의 변화가 검출되면 대기계 CPU 유닛에 대해 운전상황을 변경시키기 위한 코멘드를 발행하도록 하였으므로, 제어계 CPU 유닛에 추종하고 있던 대기계 CPU 유닛의 운전상황을 전환할 수가 있고, 대기용장화시스템 자체가 신뢰성이 더욱 향상된다.

Claims (3)

  1. 제어대상기기를 제어하는 제어계 CPU 유닛과, 상기 제어대상기기를 상기 제어계 CPU 유닛 대신에 제어가능한 대기계 CPU 유닛을 구비한 대기용장화 시스템에 있어서, 주변기기로부터 입력되는 명령문 및 데이터로 구성되는 코멘드를 일시 보관하고, 그 코멘드에서의 명령문에 따른 상기 데이터의 처리를 하는 동시에, 일시 보관하고 있던 상기 코멘드를 타계의 CPU 유닛에 대해 전송하는 트래킹 수단을 구비한 것을 특징으로 하는 대기용장화 시스템.
  2. 주변기기로부터 입력되는 명령문 및 프로그램으로 구성되는 코멘드를 일시보관하고 그 코멘드에서의 상기 명령문에 따라 상기 프로그램을 스캔함으로써 내부 접속된 제1의 외부 메모리에 대한 에러체크를 하면서 저장하는 동시에, 일시보관하고 있던 상기 코멘드를 제2의 CPU 유닛에 대해 전송하는 상기킹수단을 갖는 제1의 CPU 유닛과, 전송되어온 코멘드의 상기 명령문에 따라, 상기 프로그램을 스캔함으로써 내부 접속된 제2의 외부메모리에 대한 에러체크를 하면서 저장하는 동시에, 상기 체크 결과를 상기 제1의 CPU 유닛에 전송하는 트래킹수단을 갖는 제2의 PCU 유닛을 구비하고, 양계 모두 에러가 없는 경우에 각각 제1 및 제2의 외부메모리에 저장되어 있는 상기 프로그램을, 시퀸스프로그램에 따른 RUN 중에 각각 대응하는 메모리에 기록하는 것을 특징으로 하는 대기용장화 시스템.
  3. 제어대상기를 제어하는 제어계 CPU 유닛과, 상기 제어대상기기를 상기 제어계 CPU 유닛 대신에 제어가능한 대기계 CPU 유닛을 구비한 대기용장화 시스템에 있어서, 제어계 CPU 유닛의 운전상황을 스켄마다에 기억하고, 스켄 종료마다에 현재의 운전상황 및 1스켄전의 운전상황을 비교해서, 운전상황의 변화가 검출되면, 대기계 CPU 유닛에 대해 운전상황을 변경시키기 위한 코멘드를 발행하는 것을 특징으로 하는 대기용장화 시스템.
KR1019970040384A 1997-02-27 1997-08-23 대기 용장화 시스템 KR100273103B1 (ko)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
JP9043954A JPH10240557A (ja) 1997-02-27 1997-02-27 待機冗長化システム
JP97-43954 1997-02-27

Publications (2)

Publication Number Publication Date
KR19980069899A KR19980069899A (ko) 1998-10-26
KR100273103B1 true KR100273103B1 (ko) 2000-12-01

Family

ID=12678107

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1019970040384A KR100273103B1 (ko) 1997-02-27 1997-08-23 대기 용장화 시스템

Country Status (4)

Country Link
US (1) US5978932A (ko)
JP (1) JPH10240557A (ko)
KR (1) KR100273103B1 (ko)
DE (1) DE19739513B4 (ko)

Families Citing this family (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6189111B1 (en) * 1997-03-28 2001-02-13 Tandem Computers Incorporated Resource harvesting in scalable, fault tolerant, single system image clusters
DE19836347C2 (de) * 1998-08-11 2001-11-15 Ericsson Telefon Ab L M Fehlertolerantes Computersystem
US6618783B1 (en) * 1999-10-29 2003-09-09 Hewlett-Packard Development Company, L.P. Method and system for managing a PCI bus coupled to another system
US7213167B1 (en) * 2000-01-18 2007-05-01 Verso Technologies, Inc. Redundant state machines in network elements
US7117390B1 (en) * 2002-05-20 2006-10-03 Sandia Corporation Practical, redundant, failure-tolerant, self-reconfiguring embedded system architecture
US20040153700A1 (en) * 2003-01-02 2004-08-05 Nixon Mark J. Redundant application stations for process control systems
DE10313318A1 (de) * 2003-03-25 2004-10-21 Giesecke & Devrient Gmbh Kontrollierte Ausführung eines für eine virtuelle Maschine vorgesehenen Programms auf einem tragbaren Datenträger
CA2527326C (en) * 2003-05-27 2015-07-28 International Business Machines Corporation Method and apparatus for specifying factors that impede power savings of a processor
JP4182948B2 (ja) * 2004-12-21 2008-11-19 日本電気株式会社 フォールト・トレラント・コンピュータシステムと、そのための割り込み制御方法
JP4116640B2 (ja) * 2005-10-28 2008-07-09 ファナック株式会社 多系統制御機能を有する数値制御装置
CN101202719A (zh) * 2006-12-15 2008-06-18 鸿富锦精密工业(深圳)有限公司 网络设备及其通信冗余方法
TW200832128A (en) * 2007-01-26 2008-08-01 Rdc Semiconductor Co Ltd Redundant system
US20100229029A1 (en) * 2009-03-06 2010-09-09 Frazier Ii Robert Claude Independent and dynamic checkpointing system and method
CN101886530B (zh) * 2010-07-10 2012-12-05 中国石油大学(华东) 基于fpga的深水防喷器组电控系统

Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH0675653A (ja) * 1992-08-25 1994-03-18 Nec Corp 計算機冗長制御方式

Family Cites Families (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
BE789828A (nl) * 1972-10-09 1973-04-09 Bell Telephone Mfg Gegevensverwerkend besturingsstelsel.
WO1983001135A1 (en) * 1981-09-18 1983-03-31 Rovsing As Christian Multiprocessor computer system
US4466098A (en) * 1982-06-11 1984-08-14 Siemens Corporation Cross channel circuit for an electronic system having two or more redundant computers
CA1320276C (en) * 1987-09-04 1993-07-13 William F. Bruckert Dual rail processors with error checking on i/o reads
JPH0281101A (ja) * 1988-09-19 1990-03-22 Toshiba Corp プログラマブルコントローラシステム
AU6894491A (en) * 1989-11-27 1991-06-26 Olin Corporation Method and apparatus for providing backup process control
US5157663A (en) * 1990-09-24 1992-10-20 Novell, Inc. Fault tolerant computer system
US5914953A (en) * 1992-12-17 1999-06-22 Tandem Computers, Inc. Network message routing using routing table information and supplemental enable information for deadlock prevention
US5841963A (en) * 1994-06-08 1998-11-24 Hitachi, Ltd. Dual information processing system having a plurality of data transfer channels
US5857208A (en) * 1996-05-31 1999-01-05 Emc Corporation Method and apparatus for performing point in time backup operation in a computer system

Patent Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH0675653A (ja) * 1992-08-25 1994-03-18 Nec Corp 計算機冗長制御方式

Also Published As

Publication number Publication date
JPH10240557A (ja) 1998-09-11
US5978932A (en) 1999-11-02
KR19980069899A (ko) 1998-10-26
DE19739513A1 (de) 1998-09-10
DE19739513B4 (de) 2006-02-16

Similar Documents

Publication Publication Date Title
KR100273103B1 (ko) 대기 용장화 시스템
US20080288829A1 (en) Method and apparatus for verifying data in a storage system
CN100388254C (zh) 直接存储器存取控制方法、直接存储器存取控制器、信息处理系统
US5416908A (en) Interface between industrial controller components using common memory
CN112313587B (zh) 数控系统的数据处理方法、计算机设备和存储介质
US20040267903A1 (en) Storage system, backup system, and backup method
US4884195A (en) Multiprocessor system for loading microprograms into a RAM control store of a bus controller
US5734918A (en) Computer system with an input/output processor which enables direct file transfers between a storage medium and a network
US6374335B1 (en) Data loading process
JP6917924B2 (ja) 分散制御システム及びその通信制御方法
JP2999516B2 (ja) 端末装置のための文字出力制御方法および装置
JP2626127B2 (ja) 予備系ルート試験方式
CN118409712B (zh) 一种raid卡管理系统、方法、设备、产品及介质
JP2752911B2 (ja) ポート接続確認方法
CN115157264A (zh) 机器人控制方法、装置、协作机器人及可读存储介质
JPS63126032A (ja) プログラム更新制御方式
JPH02230450A (ja) データ処理システム
JPS61206044A (ja) 情報処理システム
JPH1139241A (ja) 通信制御構成情報転送方式
JPH0113577B2 (ko)
JPH02231894A (ja) 局データ照合方法
JPH0385606A (ja) 数値制御プログラムの転送制御方式
JPH0417454B2 (ko)
JPS6319047A (ja) プログラムトレ−ス方法
JPH05143485A (ja) 計算機システム

Legal Events

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

Payment date: 20120821

Year of fee payment: 13

FPAY Annual fee payment

Payment date: 20130822

Year of fee payment: 14

LAPS Lapse due to unpaid annual fee