JPS63317847A - プログラム内容解析装置 - Google Patents

プログラム内容解析装置

Info

Publication number
JPS63317847A
JPS63317847A JP62154055A JP15405587A JPS63317847A JP S63317847 A JPS63317847 A JP S63317847A JP 62154055 A JP62154055 A JP 62154055A JP 15405587 A JP15405587 A JP 15405587A JP S63317847 A JPS63317847 A JP S63317847A
Authority
JP
Japan
Prior art keywords
instruction
program
block
condition
output
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
JP62154055A
Other languages
English (en)
Other versions
JPH0820970B2 (ja
Inventor
Toshinori Yasuki
安木 寿教
Minoru Takahashi
稔 高橋
Masaki Hitotsuya
一津屋 正樹
Kiyoshi Yagi
八木 潔
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Denso Ten Ltd
Original Assignee
Denso Ten Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Denso Ten Ltd filed Critical Denso Ten Ltd
Priority to JP62154055A priority Critical patent/JPH0820970B2/ja
Publication of JPS63317847A publication Critical patent/JPS63317847A/ja
Publication of JPH0820970B2 publication Critical patent/JPH0820970B2/ja
Anticipated expiration legal-status Critical
Expired - Fee Related legal-status Critical Current

Links

Landscapes

  • Debugging And Monitoring (AREA)

Abstract

(57)【要約】本公報は電子出願前の出願データであるた
め要約のデータは記録されません。

Description

【発明の詳細な説明】 産業上の利用分野 本発明は、マイクロコンピュータなどを作動するために
用いられるプログラムの内容を解析する装置に関する。
従来技術 マイクロコンピュータ用などに設計されたプログラムの
点検は、以下のように行なわれる。まずシンタックスエ
ラーなどの基本的なバグを取除νまた後、プリントアウ
トされたプログラムリストに基づいて、人手によって、
該プログラムのvI造と、該プログラムに基づく各種入
出力装置のlll5作とを把握し、これを仕様書の記載
内容と照合する。さらに該プログラムが用いられる/N
−ドウエアに実際に組込み、プログラムの実行によって
要求される各種入力条件を入力して、シミュレーション
させ、プログラムの動作状態を確認する。
発明が解決しようとする問題点 しかしながら実際のプログラムは膨大なステツープ数に
及」ζことがあり、その中にはやはり膨大な分岐命令が
含まれている。したがってこれらの分岐命令に基づく処
理の流れの数はやはり膨大な数となり、上記人手による
内容把握作業では実現が困難である。したがって前述し
たようなシミュレーションまたはエミュレーションによ
るチェックが行なわれがちになり、仕様書の内容の遺漏
やバグなどを完全に解消するには、むやみに時間を要し
ていた。また、前述したようなシミュレーションやエミ
ュレーションを行なうには、実際のプログラム作動時に
おいて必要とされる入力要求をすべて充足させねばなら
ず、繁雑な手間を要していた。
本発明の目的は、上述の問題点を解決し、仕様書など、
プログラム内容のチェックの基牟となる物との照合が官
易な形態にプログラム内容を解析できるとともに、チェ
ック対象となる該プログラムを実行することなく、プロ
グラム内容の解析をイテなうようにできるプログラム内
容解析装置を提供することである。
問題点を解決するための手段 本発明は、プログラム中の出力命令を検出し、該出力命
令が規定するパラメータに関する入力命令を検出し、該
出力命令と入力命令間の命令を結合して実行内容を求め
るようにしたことを特徴とするプログラム内容解析装置
である。
また本発明は、プログラムの命令列を予め定める!!!
4Iで複数の部分に区分し、部分毎に実行条件を検出し
、 プログラム中の出力命令を検出し、 プログラムを構成する各命令の配列方向と反対方向に上
記出力命令以降の各命令を読取り、上記出力命令が規定
するパラメータに関する入力命令を検出し、 上記読取り時に命令が読取られた各プログラム部分毎の
実行条件の論理積を演算するようにしたことを特徴とす
るプログラム内容解析装置である。
作  用 本発明に従えば、プログラム中の出方命令が検出される
と、プログラムを構成する各命令の配列方向と反対方向
に上記出力命令以降の各命令を読取って、上記出力命令
が規定する出力元のパテメータに関する入力命令を検出
するようにした。またこのような命令の読取り処理に先
立って、プログラムの命令列を予め定める態様で複数の
部分に区分し、各部分毎に実行条件を検出するようにし
た。
このようにしてプログラム中の入力命令と出力命令とが
結合され、これらによる実行内容が、操作者の理解に容
易な形式で表現される。また上記反対方向への命令の読
取り時に、命令が読取られた各プログラム部分毎の実行
条件の論理積を演算することにより、上記入力命令と出
力命令との結合処理によって求まった実行内容を実行す
る条件を求めることができる。
実施例 第1図は本発明の一実施例のプログラム内容解析装置(
以下、解析装置と称する)1のvtra&を示すブロッ
ク図である。第1図を参照して、解析装置1は、従来技
術の項で述べたようなチェックが行なわれる被解析プロ
グラムが、シーケンシャルな形式で記憶されている磁気
テープ記録/再生装置(以下、磁気テープ装置と称する
)2と、ランダムな記憶が行なわれる磁気ディスク装置
3と、たとえばランダムアクセスメモリ(RA M )
などによって実現される内部記憶装[4と、たとえばC
RT(陰極線管)装置や液晶表示装置などによって実現
される表示装置5と、インパクト形または非インパクト
形などの印字装置6と、各+1キーやスイッチ類などに
よって実現されるキー人力装置7と、これらによって入
力される蕾報を処理し、またこのような情報の入力/出
力動乍を制御するマイクロプロセッサなどを含んで構成
される処理装r!18とを含む。
仕様書の内容に従って作成されたプログラムは、従来技
術の項で述べたように、まずシンタックスエ2−などの
基本的なバグを取除いた後、磁気テープ装置!!2に記
憶される。磁気テープ装r!12の被解析プログラムは
、解析装置1の内部記憶装置4へ転送され、後述するよ
うなチェック処理が行なわれる。その結果は再び磁気テ
ープ装置2へ記憶され、または磁気ディスク装置3へ記
憶される。
またこのような記憶処理とともに、表示装r!t5へ表
示出力され、また印字装置6によって印字出力される。
@2図は磁気テープ装置2や磁気ディスク装置3などの
記憶装置の記録状態を示す系統図である。
処理装置8にバス9などを介して接続された磁気テープ
装置2の記憶領域10は、前記被解析プログラムの実行
対象となるたとえばマイクロコンピュータに関するアー
キテクチャが記憶されるアーキテクチャ記憶領域10a
や、この被解析プログラムによる制御の対象となる入力
/出力に用いられるアナログ信号をデジタル信号に変換
する際の比較電圧値など、このようなアナログ/デジタ
ル変換器の諸元などを記憶するA/D変換器諸元記憶領
域10bや、本被解析プログラムの実行対象となるマイ
クロコンピュータの有す−る各端子の信号の出力状態と
、この端子に接続される各人力/出力装置の動作状態と
の関係の定義(たとえばマイクロコンピュータの成るピ
ンからハイレベルの信号が導出されると、LED(発光
ダイオード)が点灯する、などの定義)が、記憶される
定義記憶領域10cなどを含んで構成される。
第3図は第1図示の解析装r!11の基本的動作を説明
する70−チャートであり、第4図は解析装置!1の表
示装置5の表示例を示す図である。fpJ1図〜第4図
を参照して、解析装置1の基本的動作について説明する
。解析装r!11の電源が投入されると第3図ステップ
n1  以降の処理が開始され、表示装置5上に各種入
力要求を表示する。ステップn2  では、このような
入力要求に対応して、解析されるプログラムの実行対象
となるマイクロコンピュータの名称を入力する。この様
子は第4図(1)に示される。
続くステップn3  では、入力された名称のマイクロ
コンピュータのアーキテクチャが、アーキテクチャ領域
10aに存在するかどうかを判断する。
存在していればステップn4で当該アーキテクチャを呼
出し、たとえば内部記憶4に転送し、ステップn5  
でアナログ/デジタル変換器の名称を入力する。一方、
前記ステップn3  の杆断が否定であれば処理はステ
ップn6  に移り、解析装(11は、入力された名称
に対応するアーキテクチャが記憶されていないことを表
示し、新規登録を要求する。
この後、処理はステップn5  へ移る。
ステップn5  のアナログ/デジタル変換器の名称入
力の様子は、tIIJ4図(1)に示される。続くステ
ップn7  では、解析されるプログラムが動作対象と
するマイクロコンピュータに設定される各ボートの状態
と外部状態との関係を、第4図(2)に示すように入力
する。たとえばPORT17がハイレベルとなれば、ス
タートスイッチがオン状態に切換わり、PORT16が
ハイレベルになるとサーモスイッチがオン状態に切換わ
る。ステップn8  では、前記マイクロコンピュータ
の割込み端子の状態と、外部状態との関係の入力が、表
示装置5上で要求される。またアナログ/デジタル変換
器チャンネル用ボートについては、キー人力装rFi7
によって所定の事項を入力し、第4図(3)に示すよう
に所定のデータ項目を人力して各ボートを定義する。
ステップn9では、ステップn7.n8での各種人力が
正しく実行されたかどうかを判断する0判断結果が否定
であれば処理はステップn7  に戻り、上記入力され
たデータを訂正する0判断結果が肯定であればステップ
nlOに移り、たとえば磁気テープ装a2に記憶されて
いる被解析プログラムを内部記憶装置W4に転送して読
取る。ステップn11では、後述するような被解析プロ
グラムを解析し、ステップn12  で解析結果を出力
して処理を終了する。
第5図は第3図のステップnil  のプログラムの解
析処理の内容を説明する70−チャートである。第5図
を併せて参照して、解析装置1の掻作について説明する
。上述したように本発明は、たとえばマイクロコンピュ
ータ用にたとえばアセンブラ言語によって作成されたプ
ログラムの内容を解析する装置に関する。被解析プログ
ラムは、解析装置1の磁気テープ装置2に記憶されてお
り、第3図ステップn1o  で説明したように、この
ようなプログラムは磁気テープ装r!12からたとえば
内部記憶装ra4へ転送される。
本実施例では、被解析プログラムを以下の第1表に示す
プログラムと想定して説明する。
(以下余白) 第 1 表(プログラムリスト) 上記ml衰のプログラムの内容は、第6図および第7図
の70−チャートに示される。第6図および第7図のス
テップ番号al ta2 t・・・、a21は、上記第
1表・のプログラムリストの行番号に対応している。ま
た、第1表の全21行の各命令の実行に関する各7ラグ
の状態を示すフンデイシシンコードレノスタ (以下、
OCRと称する)は、下記第2表に示される。ここでは
、符号7ラグN1ゼロ7ラグZ1オーバ70−7ラグ■
およびキャリ7ラグCの状態を示す。
(以下余白) fj%2表 (注1)第2表中、記号「客」、「・」汀RJ、rS 
Jはそれぞれ[結果によってセットまたはリセットされ
る]、 「変化しない」、[リセット(クリア)される
」および「セットされる」を表わす。
(注2)上記プログラムには、レノスタ名称の定義、割
込み制御レジスタの設定、ポート入出力方向の設定、割
込みベクトルの設定等は省略されているが、割込みはC
APTIのみ許可、その割込みアドレス(ラベル)はC
APTとする。
上記第1表のプログラムリストで、 (1)入カニPORT1の第6ビツトにスイッチ人力(
スイッチONでハイレベルに変化): PORT2の第
0ビツトに可変周波信号入力 および、 (2)出カニPORT1の第7ビツトから発光グイオー
ド出力(出力ハイレベルで発光ダイオード点灯)の入出
力操作が行なわれる、と定義しておく。
これはtjS3図ステップn7で行なわれる。
上記Pt51表のプログラムリストが読込まれた解析波
f!!1では、第5図ステップ+11  でプログラム
の流れ構造の解析が行なわれる。
上述したように、第1表に示すプログラムリストは、第
6図および第7図に示す動作内容を有している。しかし
ながら、第1表のプログラムリストから第6図および第
7図示の70−チャートを得るには、人手によって、各
命令が単なる処理命令か条件文による分岐命令かを把握
する作業と、分岐命令の場合にはその分岐先の検出作業
などが含まれ、これらの作業に基づいて上記フローチャ
ートが作成される。
本発明の眼目の1つは、任意のプログラムリストから、
該プログラムの分岐命令と、該分岐命令によって定めら
れる分岐先命令とを把握した後、該プログラムの処理の
流れの構造の把握を人間の頭脳による作業を介すること
なく、解析装置によって自動的に行なうことができるよ
うにしたことである。またこれによって、後述するよう
に上記70−チャートと類似の形態の出力を得ることが
できる。
このような流れの構造を把握する処理を、第8図の70
−チャートにおいて示す、Pt58図ステップb1では
、命令行番号を示すパラメータkを「1」に初期化し、
ステップb2で第に命令(第1表における行番号にの命
令)の読取りを行なう、続くステップb3では、この読
取られた第に命令が分岐命令であるかどうかを判断する
。この判断はたとえば、第1表における命令を構成する
二−モニツクを読取ればよい。すなわち上述したように
、所望のマイクロコンピュータのアーキテクチャを呼出
した段階で、解析装置1の内部記憶4には、当該マイク
ロコンピュータに用いられるアセンブラ言語のコマンド
や、コマンドに関連する7?グなどのテーブルが別途記
憶され、これを参照することによって、11表の各命令
が分岐命令であるが否かを容易に判断できるからである
上記ステップb3  の判断結果が否定であれば、ステ
ップb4でパラメータkを+1インクリメントし、処理
をステップb2  に戻し、上述の説明と同様な処理を
行なう。このとき第1表のプログラムリストに従えば、
第4命令を読取ったと終、アーキテクチャが参照され、
この第4命令がゼロ7ラグZの状!!1(rlJまたは
「0」)を条件とする分岐命令であることが把握される
。したがって、第8図の処理において第4命令が読取ら
れたときステップb3の判断は肯定となり、処理はステ
ップb5に移る。
ステップb5  では、第1表の第4命令のオペランド
jLOOPJと対応するラベル名を検索する。
11表のプログラムリストでは、第2命令に上記オペラ
ンドと同一のラベルが付されており、したがってfI%
4命令の分岐先は、第2命令であることが理解される。
ステップb6  では、一般に分岐命令の行番号にと、
これに対応する分岐先命令行番号−との対(以下、ブロ
ック化情報と称する>(k、fi)を、内部記憶装ff
ff4に記憶する。この後、処理はステップb4  に
移り、行番号を+1インクリメントして次の行へ処理を
進める。
このような処理を行なうことによって、第1表のプログ
ラムリストにおける分岐命令と分岐先命令との行番号の
対(k、m)に関して、下記第3表のような結果が得ら
れる。
fpJa  表 この段階で解析装置!!1は、第1表に示すプログラム
リストの流れ構造が把握できたことになる。すなわち第
3表として得られた結果を操作者が容易に理解できる形
式に出力する場合、たとえばtjrJ1表のプログラム
リストの行番号1〜21を第9図に示すように一列に配
列し、上記第3表に基づいて、行番号kから行番号−へ
向かう分岐矢符をこれに付すことによって、プログラム
リストの流れ構造として第9図示のような出力が得られ
る。これによって操作者も、#1表のプログラムリスト
の流れ構造を容易に把握することができる。こうして第
5図ステップ−1の処理は終了する。
次に第5図ステップ−2では、ステップ論1で得られた
被解析プログラムの流れ構造の認識に基づいて、該プロ
グラムをブロックに区分する処理を打なう。このような
ブロック化処理には、以下のような利点がある。本発明
のプログラム内容解析処理が行なわれる被解析プログラ
ムは、一般にはたとえば数百ステップのような場合もあ
り、このようなプログラムには、各種分岐命令も大量に
含まれている。したがって、このような分岐命令の条件
の成立の是非に関する組合わせの数が膨大な数になるこ
とは、容易に想定される。このような膨大な組合わせ数
のプログラムの系統を逐次的に考察の対象とし、各系統
ごとに全命令のコンディションコードレノスタ(OCR
)を記憶するのは、極めて繁雑であるとともに膨大な記
憶容量が要求される。
したがって本発明の眼目の1つは、被解析プログラムを
後述するような条件の下で、複数のブロックに区分し、
各ブロックに対して第5図ステップ−3の分岐条件摘出
処理、ステップ−4の書込み命令単位の入出力結合処理
、およびステップ糟5のパイルの結合処理などから成る
同一内容の処理を施すようにしたことである。このよう
なブロックの区分点は、プログラムにおける分岐命令行
か分岐先命令行であり、1ブロツクは分岐命令行または
分岐先命令行で始まり、これらのいずれかで終了し、か
つその間にはこれら分岐命令または分岐先命令行を含ま
ないように選ぶ。
すなわち全プログラムは、このよろな複数のブロックの
結合として表現され、同一ブロック内のプログラムの異
なる流れの種類も極めて少数となる。これにより各ブロ
ックごとの内容解析を格段に容易に行なえるようになり
、全プログラムの内容解析は、ブロックごとに得られた
内容解析結果の結合として示される。
このようなブロック分は処理は、Pt4io図の70−
チャートに示される。このとき、前記第8図を参照して
説明した第5図ステップ輸1 の流れ溝近の解析処理に
よって得られたブロック化情報対(k、m)について、
第1表の全プログラムについて行なうことによって、第
3表に示したような結果が得られる。すなわち、このよ
うなブロック化情報対(kl 、w+1 )−(k2 
、m2 >、・” 、(ks、+ms) (本実施例で
は5=4)が、第1図示の内部記憶表ff14に記憶さ
れている。以下に説明する第10図の処理には、このブ
ロック化情報対列を用いる。なお上記ブロック化すa報
列の各数値k 1 、に2、− 、ks:m 1 、a
+2、− 。
1111について総称する場合には、それぞれ記号k 
+ +nを用いて示す。
第10図ステップC1Chは、第1表のプログラムの行
番号を示すパラメータiをrlJに初期化する。ステッ
プc2では上記行番号iに関して、この行番号iに等し
い上記ブロック化情報kまたはブロック化情報−が存在
するか否かを判断する。この判断が肯定であれば、ステ
ップC3でブロック化情報に、−によるブロック化処理
を行なう。
このブロック化処理は、以下のように行なわれる。まず
ステップC3において、判断が肯定となるブロック化情
報に、−が記憶される。次にステップc4で行番号iが
+1インクリメントされ、ステップC5では行番号iが
このような行番号の最終値すなわちM A X (i)
を超えたかどうかの判断を行なう。
判断結果が否定であれば、第10図に示すブロック化処
理は被解析プログラムの最終行まで到達していないこと
になり、ステップc2  に戻る。以下、同様の処理が
繰り返し行なわれ、ステップC2の判断が肯定となるブ
ロック化情報L’sがあった場合、前回ステップc2 
 の判断を↑〒定としたブロック化情報に、葎を呼び出
し、これらを組み合わせてブロック情報対(”+β)と
して記憶する。以下、このような処理がプログラムの最
終行まで繰り返し行なわれる。
上記ステップc1〜05で行なわれる処理は、たとえば
第1表のプログラムの第1行から第21行までを順番に
たどって、その中でブロック化情報(k、m)として示
される分岐命令行および分岐先命令行に関して、行番号
の増加方向において隣接する命令列の組をブロック情報
(atβ〉として記憶する処理である。
上記ステップc5  の判断が肯定となれば、処理はス
テップc6  に移り、上記ブロック化留報列(kjy
醜j)   ・・・(1) J”1t2v・・・、S によるブロック化処理を行なう。
このブロック化処理は、第1表のプログラムリストにお
いて、分岐処理を実現するブロックを決定する処理とな
る。すなわち第3表のブロック化情報(k、 糟)にお
いて、たとえばブロック化情報対(4,2)は、第4命
令がら第2命令へ処理が分岐する系統を規定している。
したがって、これらのブロック化情報対(k、 m)を
、前記ブロック情報対(α、β)と異なる内容をなす分
岐ブロック情報対<as β)brとして再定義するこ
とにより、第1表のプログラムリストに関して、分岐を
行なう系統を網羅でくる。ステップc6  による分岐
ブロック化処理が終了すると、第11図に示すブロック
分は結果が得られる。
また上述のように、ブロック情報対(at β)と、分
岐ブロック情報対(a、β)brとを定義することによ
り、第1表のプログラムリストのたとえば第9命令、第
10命令およびN%11命令からなるブロックと、第9
命令と第11命令とからなる分岐ブロックとを明瞭に区
分できる。このようなブロック情報対(α、β)および
分岐ブロック化情報対(atβ)brを、下記の第4表
に示す。
以下、得られた各ブロックを示すに際して、第11図に
示すように記号■、■、・・・、■ をもって示す、す
なわちブロック■は、行番号1.2の命令群を示してい
る。このような記法に従い、第1表のプログラムは第1
2図および第13図で示されるように表現される。ここ
で、#&1表のプログラムをPt512図および第13
図の2つの図に区分したのは、第12図は行番号1〜1
2のメイン処理ルーチンを表わし、第13図は行番号1
3〜21の後述するような割込み処理ルーチンを表わし
、これらは相互間に亘って分岐関係が存在しない独立な
内容だからである。このようにして、第5図ステップ輸
2 のブロック分は処理が終了する。
第5図ステップ113  では、分岐条件摘出処理が行
なわれる。このような分岐条件摘出処理は、第14図の
70−チャートに示される。第14図ステップd1  
では、上述したようなブロック化処理を行ない、各ブロ
ック情報jt(atβ)t(atβ)brを得る。ステ
ップd2では変敗jを「1」に初期化する。ステップd
3  以降の処理では、分岐条件として第1ブロツク■
、第2プaツク■、第3ブロツク■、・・・ 第13ブ
ロツク0を処理が通過する条件を求めることになる。
(1)PtS1プaツク■を通る条件 第1ブロツク■は第6図に明らかなように、第12命令
の無条件ジャンプ命令によって処理が無条件に通過する
ブロックである。
(2)第2ブロツク■を通る条件 第14図ステップd3  では、第3表を参照して第j
番目(現時点ではj=1)のブロック化情報対(k。
論)を参照する。ステップd4では、ステップd3にお
けるブロック化情報対(k、m)におt)て、第に命令
の分岐条件を支配するフラグを検出する。第4表によれ
ば、j=1のときに=4であり、第1表のプログラムの
第k(= 4 )命令rBNEJの分岐条件を支配する
フラグの検出を打なう。これはアーキテクチャによって
、各命令それ自体に規定される条件となる。すなわち上
記第4命令の場合には、ゼロ7ラグZである。
ステップd5  では、命令列の配列方向と反対方向に
一命令を読取る。この命令が上記フラグ(ゼロ7ラグZ
)を変化させる命令であるかどう力・のステップd6 
 における判断が否定であれば、ステップd5.d6を
繰り返す、肯定であれ1fステ・ノブd7  に移り、
フラグを変化させる命令を記憶する。
第1表のプログラムリストと第2表のCCRとを参照す
れば、この命令は第3命令rCMPA  C0UNTJ
であり、ゼロ7ラグZを変化させる命令であることが判
断される。ステップd8  では、第1表のプログラム
リストを参照して、ゼロ7ラグZに関する当該第3命令
中のパラメータを検出する。すなわちtlIJ3命令は
アキュムレータAに関する命令であり、パラメータとし
てアキュムレータAが検出される。
ステップd9  では、該命令が該パラメータを変化さ
せる命令か否かを判断する。この判断は前記アーキテク
チャに含まれる前記OCRを参照して行なわれる1判断
が肯定であれば、ステップd10に移り当該命令が記憶
され、ステップd11 に移る。tjS3命令[CMP
AJはアキュムレータAの内容を変化せず、ステップd
9  の判断が否定となり、ステップdlOを経ること
なくステップdi 1に移る。
ステップdll  では、現在検討中のブロックが第1
表のプログラムリスト中でループを構成するブロックか
どうかを判断する。現時点では、解析装置1は第4命令
および第3命令しか認識しておらず、この判断は否定と
なり、処理はステップd12に移り、ステップdlOで
記憶した命令が、前記パラメータの入力命令であるかど
うかを判断する。この判断が肯定であれば、ステップd
15に移る。一方、上記ステップd11 の判断が肯定
であれば、ステップd14  で分岐条件に後述するよ
うなループ要素を追加し、処理はステップd15に移る
ステップd15  では、当該分岐命令が第9図に示す
ような本実施例における被解析プログラムの構造におい
て、ネスティング構造に含まれるものであるかどうかを
判断する。判断結果が肯定ならば、ステップdi6  
で後述するようなネスティング要素を追加し、ステップ
d13  で記憶したブロック列の種類がすべて終了し
たかどうかを判断し、判断結果が肯定であればステップ
d17  で分岐対の□パラメータjをプラス1インク
リメントシ、処理はステップd3に戻る。前記ステップ
d15の判断が否定であれば、ステップd16  を経
ることなく、処理はステップd13  に移る。
第3命令[cMPAJについて、前記ステップd12の
判断は否定となり、処理はステップd19に移り、現在
検討中の命令が当該命令を含むブロックの先頭であるか
どうかを判断する。m3命令について判断結果は否定で
あり、ステップd20で命令列の配列方向と反対方向に
一命令を読取り、処理はステップd9  に移り、前述
の処理をn返す。
前記ステップd19  で判断結果が肯定ならば、ステ
ップd21  に移り、当該ブロックに処理が到達する
ブロック列の種類を記憶する。すなわち当該ブロックに
至るルートの種類を記憶する。ステップd22  では
、記憶したブロック列中から−ブロック列を選択し処理
はステップd20に戻る。
第1表のプログラムリストにおいて、fjrJ4命令か
ら上述の処理が繰り返される。このとさ、第1命令[■
、DAAJを解析する段階で、ステップcllOで記憶
されてきた命令は、オペランドで記述すると、 A=T  I ME−(COtlNT+ 1 )   
・・・(2)になる。
またステップclll  の判断は11定となり、第2
式の分岐条件にステップd14  でループ要素が付加
され、ド記Pt53式の分岐条件が得られる。すなわち
ループを1回繰返せば上記第2式は、A=T IME−
(COUNT+n)   ・=(3)と表される。この
実行内容がループをNIt成する条件は、第4命令で分
岐条件が成立すること、すなわちゼロ7ラグZに関して
、 2=0                 ・・・(4
)が成立する場合である。 したがって上記ステップd
lo  では最終的に、 T I ME   (COUNT+n)≠O・・・(5
)の条件が得られる。これは第2ブロツク■を処理が通
過する条件となる。
(3)第3ブロツク■を通る条件 この場合、第1表のプログラムリストにお0て、処理が
tpJ2ブロック■に進行しな(1条件、すなわち、上
記第5式の条件の否定 T I ME−(COUNT+n)=O=16)が求め
るべき条件となる。
(4)PtS4ブロツク■を通る条件 ステップd3  では、第4ブロツク■の最終行番号9
をブロック化情報にとする対(k、m)が、j=2の場
合として、第3表より(8,11)として読出される。
この第8命令に対して、上記第2ブロツク■を通る条件
を求めた処理と同様な処理が行なわれる。ステップd4
  では、第1表のプログラムの第k(= 8 )命令
[BMIJの分岐条件を支配するフラグの検出を行なう
、すなわち、上記第8命令の場合には、符号7ラグNで
ある。
ステップd5.d6では、この符号7ラグNを変化しう
る最近の命令を検索する。上記PIS1表および第2表
を参照すれば、第7命令rLDAB  PORTIJが
対応することが検出される。ステップd8  では、こ
の符号7ラグNに関する第7命令中のパラメータを検出
する。すなわち第7命令は7キユムレータBに関する命
令であり、このアキュムレータBがパラメータとして検
出される。
ステップd12  では、パラメータとしての7キユム
レータBの入力命令を検出する。第1表のプログラムリ
ストを参照すれば、上記第7命令自身が7キユムレータ
Bの人力命令であることが検出される。したがってステ
ップd12  の判断は肯定となり、ステップd15 
 でのネスティング構a判断は否となるため、第3ブロ
ツク■の実行内容をオペランドによって表現すれば、求
める分岐条件は、 PORT1?=O・・・(7) となる。ここで表記rPORT17=0.1は、入出カ
ポ−)PORTIの第7ビツトがrOJとなる状態を表
現する。この後、処理はステップd13  に移り判断
が否定となり、前述のような処理を経て処理はステップ
d3に戻る。
(5)第5ブロツク■を通る条件 ステップd3では、j=3の場合としてブロック化情報
対(k、m)= (9、11)が読出され、ステップd
4では第k(= 9 )命令rBEQ  NANNOI
Jの分岐条件を支配するフラグすなわちゼロ7ラグZが
検出される。続いてステップd5.d6では、このゼロ
7フグZを変化しうる最近の命令として、第1表および
tIS2表を参照して、PtS?命令rLDABJが検
出される。
このロード命令はアキュムレータBに[PORTIJの
内容を読込む内容であり、このアキュムレータBに関す
るゼロ7ラグZの成立の是非が分岐条件となる。したが
って、前述のような処理が繰り返された後、ステップd
lOでは、PORTIの少なくとも1つのビット=1・
・・(8) が得られる。この後、処理はステップd11 に移り、
第5ブロツク■がループ構造の一部をなすかどうかが判
断され、これは否定となる。
続くステップd12  の判断は肯定となり、ステップ
d15  で第5ブロツク■がネスティングtfItm
の一部を成すかどうかが判断される。第5ブロツク■は
2fiの冬スティング構造を構成しており、ステップd
16  で上記第8式の分岐条件にネステイング要素が
付加される。
すなわち、第12図に明らかなように、第5ブロツク■
は、第4ブロツク■を通過しなければ到達しない処理ブ
ロックであり、したがって第5ブロツク■の通過条件は
、第4ブロツク■の通過条件と上記第8式の条件との論
理積となる。すなわち、 PORT1?=0 かつ、 PORTIの少なくとも1つのビット=1・・・(9) の分岐条件が得られる。この後、ステップd13におい
て、記憶したブロック列はないので、処理はステップd
3に戻る。
(6)第6ブロツク■を通る条件 Pt514図の70−チャートにおいて、ステップd3
でj=4のとき、対応するブロック化情報に、 mが、
第3表を参照して存在しないことが判断される。したが
って、本件実施例のプログラム内容解析装置i’tlは
、現在の第6ブロツクの分岐条件を、以前の直鎖ブロッ
クと同一分岐条件として設定する。すなわち現在のtp
J6ブロツク■の分岐条件は、以前の直鎖ブロックであ
る第3ブロツク■の分岐条件、すなわち上記第6式の条
件として設定される。この後、処理は前記パラメータj
を+1インクリメントした後に、ステップd3に戻る。
(7)第7ブロツク■を通る条件 tjS7ブロツク■は、上記#S2ブロック■の分岐条
件を考察した段階で、第2ブロツク■と組合されてルー
プ構造を構成するブロックとして把握されている。した
がってttS7ブロツク■の分岐条件は、上記第3ブロ
ツクで挙げたループ処理の離脱条件の否定の形式の条件
である上記第5式の条件として示される。
(8)第8ブロツク■を通る条件 第8ブロツク■は、第3表および第4表に示す分岐ブロ
ック情報対(8,11)brで示される。したがって第
1表第8命令の分岐条件より、第8ブロツク■を処理が
通る条件は、第4ブロツク■を通る条件の否定、すなわ
ち、 PORT17=1               ・・
・(10)となる。
(9)第9ブロツク■を通る条件 第9ブロツク■も、第3表および第4表がら分岐ブロッ
ク情報(9,11)brによって規定されるブロックで
あり、したがって前記第5ブロツ〉■を通る条件を考察
した際に検討した第1表#IJ9命令の分岐条件(第8
式)の否定の条件と、第4ブロツク■を通る条件(第7
式)との論理積となる。すなわち、 PORTIの 全ビット=O かっ POR′rlの17ビ7)=0  −(11)の
条件が得られる。
(10)第10ブロツク[相]を通る条件110ブロツ
ククφは、第6ブロツク■と分岐命令を介在することな
く線形に続くブロックであり、したがって第10ブロツ
ク[相]を処理が通る条件は、第6ブロツク■を、通る
条件、すなわち第3ブロツク■を通る条件(上記第6式
)と同一になる。
(11)第11ブロツク0を通る条件 第1表のプラグラムリストから明かなように、第13命
令〜第21命令は、第1命令〜第12命令のメインルー
チンに対する割込み処理ルーチンである。その内容から
、上記第2表の欄外に付した入力/出力の定義において
、PORT2の第Oビットに立ち上がりエツジまたは立
ち下がりエツジの信号が入力された状態を表わす割込み
ベクトルの条件、 IRQ2=O・・・(12) が得られる。
(12)第12ブロツク@を通る条件 上記PIS4ブロック■を通る条件が導出された処理と
同様な処理を経て、第18命令rBNEJでゼロ7ラグ
Z=1となる条件が求められればよい。
すなわち第18命令からプラグラムリストをさがのぼり
、当該分岐命令を支配するフラグであるゼロ7ラグZを
変化させる最近の命令を検出する。
これは#S17命令でストア命令jsTAAJが検出さ
れ、パラメータとしてアキュムレータAが検出される。
アキュムレータAの入力命令として、第13命令でロー
ド命令1’LDDJが検出される。したがって第13命
令・〜第18命令の実行内容をオペランドで記述すれば
、 ICAPTI(D)−ZCAPT(D)lの上位バイト
=O・・・(13) が得られる。
(13)第13命令■を通る条件 この場合、第1表のプログラムリストにおいて、第13
命令以降の処理の進行において、処理が第12ブロツク
0に進行しない条件、すなわち上記第13式の条件の否
定、 ICAPTI(D)−ZCAPT(D)lの上位バイト
≠0・・・(14) が求めるべき条件となる。
この上う1こして第5図ステップ輸31こおいて摘出さ
れるべき分岐条件は、各ブロック■〜0を処理が通る条
件として導出された。これ以降、処理は第5図ステップ
−4に移る。
ステップm4  では、書込み命令単位の入出力結合処
理が行なわれる。ここに言う書込み命令とは、ストア命
令と、オペランドの直接操作命令(たとえばオペランド
の数値を+1増加させるインクリメント命令「INcJ
なと)とを指す、このような命令の検出は、第1表のプ
ログラムリストにおいて、各命令を読取ることによって
直ちに実現できる。
このような入出力の結合処理は、第15図の70−チャ
ートに示される。第15図 ステップel。
C2では、第1表で示されるプログラムに対して、前述
したブロック化処理と分岐条件の生成処理とを行なう、
この後、ステップe3  では、第1表に示されるプロ
グラムにおいて、書込命令が検出される。このような書
込み命令としては、第2命令jINcJ、第6命令[5
TAAJ、第11命令「5TAAJ、第16命令rST
XJ、第17命令[5TAAJおより第20命令[5T
AAJが、後述するよ)に検出される。
(1)第2命令rINcJについて 第5図ステップe4  では、当該命令に関するパラメ
ータを検出する。上述した残余の書込命令、たとえばt
IS6命令[5TAAJでは、このようなパラメータと
してたとえばアキュムレータAが検出されるが、第5命
令のようなメモリの直接操作命令では、本ステップを行
なうことなく、ステップe5  で当該命令がその命令
の所属するブロックの先頭であるかどうかを判断する。
否定であれば、ステップe6  に移って、命令列の配
列方向と反対方向に一命令を検出する。t!定であれば
ステップe7  で、当該ブロックに至るブロック列の
l!1類、すなわち当該ブロックに至る処理の系統の種
類を記憶する。
@2命令に関しては、第2命令を含む第2ブロツク■に
至るブロックは、上記ブロック化処理から得られた第1
2図および第13図の処理の流れ図に示されるように、
PIS1ブロック■および第7ブロツク■である。ステ
ップe8  では、このような記憶したブロック列中か
ら−ブロック (たとえば17ブロツク■)を選択し、
処理はステップe6に移る。
ステップe6  では、選択されたブロックにおいて、
命令列の配列方向と反対方向に一命令を検出し、現時点
では第4命令[BNEJを検出する。これによりステッ
プe9*el 1+ el 2の↑−断は、それぞれす
べて否定であり、したがって処理はステップe5  に
戻る。このようにして上述した処理を繰り返し行ない、
ステップe6  で第2命令が読取られたとき、ステッ
プel 1  でループになったことが判断され、ステ
ップe13  でループ要素が追加される。すなわち第
2命令の実行内容は、C0UNT4−C0UNT41 
    ・・・、(15)であるが、この処理がループ
構造にしたがってn同大行される場合を想定すると、 
 ′C0UNT←C0UNT+n     ・=(16
)となる、これが第2命令の実行内容の一般形であ耽 このときの実行条件は、上記第7ブロツク■を通る条件
、すなわち上記第5式の条件となる。したがって第2命
令に関しでは、 if   TtNE −(n+ C0IjHT)≠0t
hen  C0UNT−C0UNT4n       
  ・= (17)となる。
(2>tls (3命令について ステップe3  では、次の書込命令である第6命令を
検出し、ステップC4でptS6命令に関するパラメー
タすなわちアキュムレータ八を検出する6ステツプe5
の判断は否定となり、ステップe6で第5命令1−CL
RA、Jを検出する。
ス゛テップe9  では、この第5命令が上記パラメー
タであるアキュレータAを変化させろ命令であることが
鍔際され、ステップelOで第5命令が記憶される。ス
テップell  では、当該第5命令がループ構造に含
まれないことが判断され、ステップe12  では、t
jS5命令が7キユムレータへの入力命令であることが
判断される。この後、ステップe14  の判断で肯定
となり、処理はステップe15に移る。
したがって実行内容は、 C0UNT←0          ・・・(18)と
なり、実行条件は、処理が第3ブロツク■を通る条件、
すなわち上記第6式で示される条件と同一になり、これ
らを9埋すれば、 if   TIME−(n+C0UNT)= 0the
n  C0LINT= O−<19)の結果が得られる
(3)tjS11命令について 第11命令については、PIIJ15図に示されるステ
ップe3  で当該命令が検出された後、ステップe4
  でパラメータとしてアキュムレータAが検出される
。ステップe5  では、上記第3表および第4表を参
照して、第11命令が第6ブロツク■の先頭であること
が↑1断され、処理はステップc7ニ移ル。この判断に
よって、第1表のプログラムリストにおいて、第11命
令に到達するにはtjS5ブロック■、第9ブロツク■
お上り第8ブロツク■をそれぞれ通る3つの経路が存在
することが認識される。以下、後述する実行内容の検出
と実行条件の検出とを各経路毎に行ない、それらの結果
が論理和として出力される。
(ア)tjIJ5ブロック■を通る経路の場合ステップ
e4  でパラメータであるアキュムレータAを検出し
、プログラムをさかのぼると、第10命令でアキュムレ
ータAに関するロード命令が検出される。ここで第11
命令は、入出力ポートへの書込み命令であり、論理演算
として扱う、したがって1@10命令および第11命令
による実行内容は、Pt51表のプログラムリスト上の
表現では、PORT 1←¥80        −(
20)と表現されるが、論理演算の結果としては、上記
第10式と同等な PORT 17.−1         、−(10)
なる論理式が得られる。
このときの実行条件は、第5ブロツク■を処理が通る条
件(上記第9式)と、第2ブロツク■およびtjS7ブ
ロツク■からなるループを処理が離脱する条件、すなわ
ち処理が第3ブロツク■を通る条件(上記第6式)との
論理積となる。したがって、if   TIME  (
n+ C0UNT);0and  PORT17= 0 and  PORTI≠¥0O then  PORT17←1         −(
21)なるi!!1環式出力が得られる。
(イ)第8ブロツク■を通る場合 ステップe6  でプログラムをさかのぼると、第6命
令でストア命令[sTA/jlが検出される。したがっ
て求める実行内容は、前述の第6命令の場合と同様にし
て、PORTI←¥OOが求められる。
また実行条件は、前述したループの離脱条件すなわち第
3ブロツク■を通る条件(ff$6式)と、第8ブロツ
ク■を処理が通る条件(第10式)との論理積である。
したがってこれらをまとめて、if   TIME −
(n+C0UNT)= 0and  PORT17= 
1 then  PORT1+¥00          
・(22)の論理式出力が得られる。
(つ)第9ブロツク■を通る場合 ステップe4 で検出されるパラメータは、アキュムレ
ータAであり、第9ブロツク■を通ってプログラムをさ
かのぼると第6命令を検出する。したがってこの場合の
実行内容は、上記第22式と同一であり、実行条件はル
ープの離脱条件すなわち第3ブロツク■を通る条件(第
6式)と、第4ブロツク■を通る条件(第7式)と、$
9ブロック■を通る条件(第11式)との論理積である
。したがってこれらをまとめて、 if   TIME−(n+ C0UNT)= 0an
cl  PORT17= 0 and  (PORT17=’Q and PORT1
=¥00)tl+en  PORT14−¥00   
      ・(23)の出力が得られる。
このようにして、第11命令に関する入出力条件の結合
処理が実現された。
(4)第16命令について 第1表のプログラムリストにおいて、行番号13〜21
は割込みルーチンであり、行番号1〜12のメイン処理
ルーチンとは独立の内容となっている。したがって第1
5図ステップe4  で第16命令「5TXJが検出さ
れる。第16命令に関して検出されるパラメータは、イ
ンデックスレノスタXであり、ステップe6  でプロ
グラムをさかのぼると第15命令でロード命令が検出さ
れる。したかって第16命令に関する入出力結合結果は
、if   IRQ2=1 then  Z CA P T”CA P T 1  
  =−(24)の論理式出力が得られる。
(5)第17命令1”5TAAJについて第16命令と
同様にステップe4  で、パラメータとしてアキュム
レータAを検出する。ステップe6  でプログラムを
さかのぼると、第13命令でロード命令1”L D D
 Jが検出される。したがって第17命令でオペランド
[’MMEJにストアされるのは、オペランドrcAP
TIJおよびオペランドrZCAPTJの各上位バイト
情報である。また実行条件は第16命令と同一である。
したがってこれらをg埋して、 if   IRQ2=1 then  TIME”(CAPTI(D)−ZCAP
T(D))(II)・・・(25) 注:#%25式の右辺末尾の(H)は、右辺のオペラン
ドの上位バイトであることを示す。
(6)PtS20命令1’5TAAJについて第20命
令の場合には、第15図ステップe4で、当該命令に関
するパラメータすなわち7キユムレータAを検出する。
このパラメータを決定する最新の命令をプログラムをさ
かのぼってステップe6  で検索すると、第19命令
で7キユムレータAに関する繰作命令[DECAJが検
出される。
したがって第20命令の実行内容は、 C0UNT+A−1・・・(26) となる。
ここで第19命令は、第18命令の分岐命令でゼロ7ラ
グZ=1の場合であることを考慮すると、上記第25式
において、 TIME=7キユムレータA = (1・・・(27)
の場合に相当する。したがって上記第26式において、
アキュムレータA=0であり、 C0UNT←¥FF         ・・・(28)
が結論される。
その実行条件は、第11ブロツク■およびtpJ12ブ
ロック@を処理が通る条件、すなわち−上記第12式お
よび第13式で示される各条件の論理積となる。したが
ってこれらをまとめれば、if   IRQ2−1 and    (CAPT 1  (D)   ZCA
PT(D))(H)”  0then  C0UNT4
−¥FF         ・(29)が得られ、これ
で第1表のプログラムリストに関してtj%5図ステラ
ステップm4書込み分会単位の入出力結合処理が行なわ
れる。
続いて、第5図ステップ15  で後述するようなパイ
ルの結合処理が行なわれる。ここに言うパイルとは、プ
ログラムリスト中におけるオペランドの直接毘作命令を
含むたとえば上記第29式のよ□うな書込み命令が実行
されるための実行条件と実行内容との結合表記を指す、
その具体的処理内容は第16図の70−チャートに示さ
れる。
上述したように、第1表のプログラムリストには6個の
書込み命令があり、第3命令には第17式のパイルD7
、第6命令には第19式のパイルD6、第4命令にはr
lS21式〜第23式のパイルD 3 、D 2 、D
 1、第15命令には第24式のパイルD5、第17命
令には第25式のパイルD4、Pt520命令には第2
9式のD8がそれぞれ作成される。
以下、第16図を参照して、パイル結合処理について説
明する。ステップf1  では、ボートへの書込み命令
がある外部出力命令パイルD 1 、D 2 。
D3を検出する。
ステップf2  では、たとえばパイルD1中の未決定
パラメータを決定するパイルを検出する。すなわち、パ
イルD1の実行条件に関して、パラメータjTIMEJ
、rCOU N T Jが未決定である。
また、残余の外部出力命令パイルD2.D3についても
、それぞれ実行内容は異なるものの、未決定パラメータ
はパイルD1と同一のものが検出される。
以下、このようなパラメータを決定するパイルを検出す
る。パラメータrTIMEJについてはパイルD4が検
出され、続くステップ「3 では該パイルD4に含まれ
る全てのパラメータが決定されているかどうかを判断す
る。現時点では判断結果は否定であり、処理はステップ
f2  に戻り、パラメータrcAPTIJ、rZCA
PTJを決定するパイルを検出する。このとき第5パイ
ルD5が選ばれろ、このときステップf3  では、全
パラ/−タが決定されたことが判断され、処理はステッ
プf4に移り、外部出力命令パイルが終了したかどうか
を判断する。現時点では外部出力命令パイルD1のみを
検討しており、判断結果は否定となり、処理はステップ
f1  に戻る。
これ以降、パイルD2.D3が外部出力命令パイルとし
て検出され、それぞれについて前述の場合と同様な処理
が行なわれる。パイル1)1〜D3では、未決定のパラ
メータは共通であり、したがってステップf2  では
同一内容の処理が付なわれる。このようにしてパイルD
3に対するパイル結合が終了した後、ステップr4  
では判断結果が1ff定となり、ステップf5に移って
第17図(1−1)〜(3−3)のパイル結合結果が出
力されるにのようにして第5図ステップ鎗5 のパイル
の結合処理が終了する。
以上のように本実施例では、第5図ステップ13以降の
分岐条件摘出処理などを行なうに先だって、第5図ステ
ップ111  の流れ構造の解析処理を行なうようにし
た。したがってプロゲラA 中17) 9岐命令や分岐
先命令が事前に明らかとなり、OCRなどの制御情報は
、これらの命令に関してのみ記憶すればよい。したがっ
て被解析プログラムの動作内容を分析するに当り、たと
えばCCRを全命令にわたって記憶する必要がなく、装
置に要求される記憶容量を格段に削減できる。
上述の実施例で書込み命令単位の入出力結合処理を行な
うにあたって、fjS23式の実行条件に示されるよう
に冗長表現が発生する場合がある。すなわちPt523
式の実行条件 if  TIME−(n+ C01lNT)= 0an
d  PORT17=O and  (PORT17= 0 and  PORTI =¥00)        −
(30)において、第4行の条件rPORT1=¥00
」が成立すれば、m2行目の条件および第3打目の条件
は必ず成立する。したがって上記第23式の実行条件部
分は、 if  TIME −(n+ C0UNT)= 0an
d  FORTI =¥00        −(23
a)のように表現できることになる。このような冗長表
現の排除を行なう処理を第18図に示す。
第18図を併わせで参照して、入出力結合処理について
説明する。第18図の処理は、たと九ば第15図のステ
ップe15  に引続いて行なわれるようにしてもよい
、すなわち第15図のステップe15に引続いて第18
図のステップe16が実行され、第17式、第19式、
第21式〜第25式および第29式に示される入出力結
合処理に基づく実行条件と実行内容との結合された表記
において、論理積で表現された実行条件の各項目につい
て恒等表現であるかどうかを判断する。ここにいう恒等
表現は、論理積記号[andJの左右の命題が同一であ
るかどうかの〒1断である。
判断が否定であれば処理はステップe17  に移り、
論理積記号の左右の命題対に関して、一方が他方の十分
条件であるかどうかの判断を行なう。
すなわち命題A、Bに関して、 A−、B               ・・・(31
)が常に成立するならば、必要条件である命題Bの成立
条件は命題への成立条件に包含されることになる。した
がってこのような場合、実行条件jAandBJは実行
条件rAJに書換えることができる。
ステップe17  の判断が否定であれば、処理はステ
ップe18  に移り、前記実行条件を構成する各命題
が全頁であるかどうかの判断を行なう、すなわち成立条
件 A and B andC−(32) において命題Aが無条件に成立するならば、このような
命題Aを実行条件から除いても、第32式の実行条件に
はなんら影響がないからである。この判断が否定であれ
ば、処理は第19図ステップe1に戻る。
上記ステップe16  の判断が肯定であれば、処理は
ステップe19  に移る。このような判断は上記第2
3a式において成立し、第2行目と第3行目との命令に
関して出力判断が肯定となり、ステップe19ではいず
れか一方の表現が削除される。
上記ステップe17  において判断が肯定となれば、
処理はステップe19  へ移り、第31式の例では十
分条件である命題Aが削除される。#430式の例では
第3行目と第4行口とに関してこの判断が成立し、第4
行目が第3行目の十分条件となる。したがって第3行目
の条件が削除される。ステップelB  で判断を肯定
とする命題は、それ自身がステップe19  で削除さ
れる。このようにして上記入出力結合処理の結果としで
得られる実行条件と実行内容との結合表記において、実
行条件における冗長表現が削除され、記憶容量の削減と
これ以降の処理の簡便化を図ることができる。
上記129式の実行条件中の第2条件の左辺は、第25
式の実行内容に即して[TIMEJに置換えられる。し
たがって第25式の実行内容のような複雑なオペランド
から簡単なオペランドへの書換えが実行された場合、こ
れ以降の処理において、上記複雑なオペランドを簡単な
オペランドを用いて表記するようにすれば、必要とされ
る記憶容量を削減できるとともに、たとえば第29式の
ような入出力結合表記を簡略化することができる。この
ような処理手順を第19図に示す。
第19図ステップg1  で書込み命令とそのパラメー
タとの検出を行なう。第1表のプログラムにオイテ、第
20命令rSTAA  C0UNTJを検出した場合を
想定して説明する。上記パラメータとはfjfJ1オペ
ランドであり、120命令においてはアキュムレータA
が検出される。ステップg2では、上記パラメータ(ア
キュムレータA)の入力命令を検出する。これは曲述の
実施例で述べたようにプログラムをさかのぼって行なう
ことによって得られff113命令を検出する。
続くステップg3では該パラメータ(7キユムレータA
)に関する操作を、オペランドによって表現する。tj
tJ7図ステップa13〜a17の一連の繰作をオペラ
ンドに上ってまとめて表記すると、その最終的な実や〒
内容は第25式で表わされる。ステップg4  では、
上記出力命令(第17命令)以降の処理のオペランドに
よる表現が行なわれる。すなわち前記Pt517命令に
よって、 TIME= (CAPTI(D)−ZCAPT(D))
(H)   ・・・(33)と表現される。したがって
前記出力命令に引続く第18命令の分岐命令では、他の
実行条件と実行内容であるtj%25式の内容が下記の
第34式で表わされる。
if   IRQ2= 1 ancl  TIME= 0 then  C0UNT+¥FF        ・(
34)すなわち前記第17命令以降の処理において、第
33式右辺で表わされる内容を左辺で表わすようにする
ので、必要とされる記憶容量を格段に削減できる。
効  果 以上のように、本発明に従えばプログラム中の出力命令
が検出されると、プログラムを構成する各命令の配列方
向と反対方向に上記出力命令以降の各命令を読取って、
上記出力命令が規定する出力元のパラメータに関する入
力命令を検出するようにした。またこのような命令の読
取り処理に先立って、プログラムの命令列を予め定める
態様で複数の部分に区分し、各部分毎に実行条件を検出
するようにした。
このようにしてプログラム中の入力命令と出力命令とが
結合、され、これらによる実行内容が、操作者の理解に
容易な形式で表現される。また上記反対方向への命令の
読取り時に、命令が読取られた各プログラム部分毎の実
行条件の論理積を演算することにより、上記入力命令と
出力命令との結合処理によって求まった実行内容を実行
する条件を求めることができる。
【図面の簡単な説明】
第1図は本発明の一実施例のプログラム内容解析装置f
f 1の構成を示すブロック図、第2図は解析装置1の
記憶領域10の構成を示すブロック図、Pt53図はプ
ログラム内容解析装置1の基本的動作を示す70−チャ
ート、第4図は表示装置5の表示例を示す図、第5図は
解析装置1のプログラム内容解析処理手順を示す70−
チャート、第6図および第7図は被解析プログラム例の
動作内容を示すフローチャート、第8図は流れNF2造
の解析処理手順を示す70−チャート、Pt59図は流
れ構造の解析処理結果を示す系統図、第10図はブロッ
ク化処理手順を示すフローチャート、第11図はブロッ
ク化処理の中間結果を示す系統図、第12図および第1
3図はブロック化処理結果を示す系統図、114図は分
岐条件摘出処理手順を示すフローチャート、第15図は
入出力結合処理手順を示す70−チャート、第16図は
パイル結合処理手順を示す70−チャート、第17図は
パイル結合処理結果を示す系統図、第18図およびfj
S19図は本発明の他の実施例をそれぞれ説明する70
−チャートである。 1・・・プログラム内容解析装置、2・・・磁気テープ
装置、3・・・磁気ディスク装置、4・・・内部記憶装
置、5・・・表示装置、8・・・処理装置、10・・・
記憶領域、10a・・・アーキテクチャ記憶領域 代理人  弁理士 画数 圭一部 第3図 第4図 第 6図 メインルーチンへ 第8 図 13−−−− !’1込 第10図 N11図 第12図     第13図 第16図 第17図 ub               L)コ     
         υb第18図 ステ・ンブe15か6 ステ・ンブe1へ

Claims (2)

    【特許請求の範囲】
  1. (1)プログラム中の出力命令を検出し、 該出力命令が規定するパラメータに関する入力命令を検
    出し、該出力命令と入力命令間の命令を結合して実行内
    容を求めるようにしたことを特徴とするプログラム内容
    解析装置。
  2. (2)プログラムの命令列を予め定める態様で複数の部
    分に区分し、部分毎に実行条件を検出し、プログラム中
    の出力命令を検出し、 プログラムを構成する各命令の配列方向と反対方向に上
    記出力命令以降の各命令を読取り、上記出力命令が規定
    するパラメータに関する入力命令を検出し、 上記読取り時に命令が読取られた各プログラム部分毎の
    実行条件の論理積を演算するようにしたことを特徴とす
    るプログラム内容解析装置。
JP62154055A 1987-06-20 1987-06-20 プログラム内容解析装置 Expired - Fee Related JPH0820970B2 (ja)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP62154055A JPH0820970B2 (ja) 1987-06-20 1987-06-20 プログラム内容解析装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP62154055A JPH0820970B2 (ja) 1987-06-20 1987-06-20 プログラム内容解析装置

Publications (2)

Publication Number Publication Date
JPS63317847A true JPS63317847A (ja) 1988-12-26
JPH0820970B2 JPH0820970B2 (ja) 1996-03-04

Family

ID=15575926

Family Applications (1)

Application Number Title Priority Date Filing Date
JP62154055A Expired - Fee Related JPH0820970B2 (ja) 1987-06-20 1987-06-20 プログラム内容解析装置

Country Status (1)

Country Link
JP (1) JPH0820970B2 (ja)

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPS5854449A (ja) * 1981-09-28 1983-03-31 Fujitsu Ltd 分岐命令短縮化処理方式
JPS6081641A (ja) * 1983-10-11 1985-05-09 Matsushita Electric Ind Co Ltd レジスタトレース方法
JPS60107142A (ja) * 1983-11-16 1985-06-12 Matsushita Electric Ind Co Ltd プログラム翻訳装置
JPS6167131A (ja) * 1984-09-10 1986-04-07 Fujitsu Ltd ドキユメント自動出力制御方式

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPS5854449A (ja) * 1981-09-28 1983-03-31 Fujitsu Ltd 分岐命令短縮化処理方式
JPS6081641A (ja) * 1983-10-11 1985-05-09 Matsushita Electric Ind Co Ltd レジスタトレース方法
JPS60107142A (ja) * 1983-11-16 1985-06-12 Matsushita Electric Ind Co Ltd プログラム翻訳装置
JPS6167131A (ja) * 1984-09-10 1986-04-07 Fujitsu Ltd ドキユメント自動出力制御方式

Also Published As

Publication number Publication date
JPH0820970B2 (ja) 1996-03-04

Similar Documents

Publication Publication Date Title
Brooker et al. A general translation program for phrase structure languages
JPH03111971A (ja) ベクトル化診断方式
CN108228187B (zh) 一种数值程序的全局优化方法
JPS63317847A (ja) プログラム内容解析装置
JPH0820973B2 (ja) プログラム内容解析装置
JPS63317844A (ja) プログラム内容解析装置
JPS63317848A (ja) プログラム内容解析装置
JP2548197B2 (ja) プログラム内容解析装置
JPH0820972B2 (ja) プログラム内容解析装置
JPH0820968B2 (ja) プログラム内容解析装置
JPH0820971B2 (ja) プログラム内容解析装置
JPS63317845A (ja) プログラム内容解析装置
JPS63317851A (ja) プログラム内容解析装置
JPS63317846A (ja) プログラム内容解析装置
JPH0317136B2 (ja)
Bird A formal development of an efficient supercombinator compiler
JPH02128240A (ja) コンピユータプログラムの検査方法
JP2653880B2 (ja) プログラム内容解析装置
JPH0769856B2 (ja) プログラム内容解析装置
JPH0475550B2 (ja)
Carroll et al. An interactive‐computer program for the Johnson‐Neyman technique in the case of two groups, two predictor variables, and one criterion variable
JPH0193826A (ja) 高級言語プログラムのダイナミックステップカウント方式
JPH0769855B2 (ja) プログラム内容解析装置
JPH04147342A (ja) 宣言子解析方法
JPH02110669A (ja) ベクトル化処理方法

Legal Events

Date Code Title Description
LAPS Cancellation because of no payment of annual fees