JPH03230226A - 同期待ち時間測定方式 - Google Patents

同期待ち時間測定方式

Info

Publication number
JPH03230226A
JPH03230226A JP2671090A JP2671090A JPH03230226A JP H03230226 A JPH03230226 A JP H03230226A JP 2671090 A JP2671090 A JP 2671090A JP 2671090 A JP2671090 A JP 2671090A JP H03230226 A JPH03230226 A JP H03230226A
Authority
JP
Japan
Prior art keywords
synchronous
time
synchronization
execution
tasks
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.)
Pending
Application number
JP2671090A
Other languages
English (en)
Inventor
Kyoko Hanakada
羽中田 恭子
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.)
NEC Corp
Original Assignee
NEC Corp
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 NEC Corp filed Critical NEC Corp
Priority to JP2671090A priority Critical patent/JPH03230226A/ja
Publication of JPH03230226A publication Critical patent/JPH03230226A/ja
Pending legal-status Critical Current

Links

Abstract

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

Description

【発明の詳細な説明】 〔産業上の利用分野〕 本発明は同期待ち時間測定方式に関し、高級プログラミ
ング言語で記述されたプログラム単位を複数のタスクで
並列実行する場合に発生するタスク間の同期待ち時間測
定方式に関する。
〔従来の技術〕
従来の同期待ち時間測定方式は、タスク間の同期制御方
式がスピン・ループ方式で行われている場合に、他のタ
スクの同期待ちをしている間もプログラムが実行状態に
あるので、その待ち時間がシステム側では把握できない
。そのために、プログラムの中で同期待ち処理の開始時
刻と同期待ち処理の終了時刻とを測定し、その時刻の差
を同期待ち時間としていた。
〔発明が解決しようとする課題〕
従来の同期待ち時間測定方式は、同期制御箇所毎に同期
待ちの開始時刻と終了時刻とを採取するために、その都
度利用者プログラムからシステムプログラムに制御を移
動させて時刻情報を採取するので、同期待ち時間測定の
ためのオーバーヘッド時間がかかる。そのために、タス
ク間で同期待ち時間がほとんどない場合でも、同期待ち
時間測定のために利用者プログラムの同期待ち処理に時
間がかかるという欠点があった。
〔課題を解決するための手段〕
本発明の同期待ち時間測定方式は、マルチプロセッサ上
で、プログラムが複数個のタスクに分割されて、並列実
行中のそれらのタスク間で同期をとる場合に、同期をと
るタスクの実行が全て到達したか否かを示すタスク間の
共有データ(以降に、同期制御変数と称す)を設定する
とともに、同期箇所毎に同期制御変数に全てのタスクが
到達したことが確認されるまで同期制御変数の参照を繰
り返し実行すること(以降に、同期待ち処理と称す)で
タスク間の同期をとる同期処理方式(以降に、スピン・
ループ方式と称す)の同期待ち時間測定方式において、 複数のタスクで実行を行うプログラム単位を入力するこ
とにより、タスク毎に同期待ち処理の繰り返し数の格納
領域(以降に、繰り返!、数格納領域と称す)を設定し
、前記プログラム単位中の同期制御箇所毎の同期待ち処
理内に同期待ち処理の繰り返し数を測定する処理を挿入
したオブジェクトを生成するオブジェクト生成処理手段
を含むコンパイラと、 プログラムの実行中に同期待ち時間の採取要求が行われ
ることにより、前記オブジェクト生成処理手段て設定し
た繰り返し数格納領域を参照し、その繰り返し数および
同期待ち処理の実行時間から同期待ち時間を算出する同
期待ち時間算出処理手段を含む実行時間採取機構と、 を含んで構成されている。
〔実施例〕
次に本発明の実施例について図面を参照して説明する。
第1図は本発明の同期待ち時間測定方式の一実施例を示
す機能ブロック図である。
第1図に示すように、コンパイラ10は、原始プログラ
ム1を入力して、タスク毎に繰り返し数格納領域2aと
同期待ち処理の繰り返し数を測定する処理を同期待ち処
理に挿入したオブジェクト2bとを生成するオブジェク
ト生成手段11を含んでいる。
一方、実行時情報採取機構20は、プログラムの実行中
にタスクの実行待ち時間の要求が行われると、要求され
たタスクの繰り返し数格納領域2a内の繰り返し数に同
期待ち処理−回の実行時間である同期待ち処理時間の累
計である同期待ち時間3を算出する。
第2図は本実施例で実行するFORTRAN言語で記述
したプログラムの一例を示す図である。
第2図に示すように、プログラム単位100は、並列実
行不可部分110.130と二つのタスクで並列に実行
できる並列実行部分121゜122同期制御箇所123
を含む並列実行可能部分120とを含んでいる。
また、オブジェクト200.300は、プログラム単位
100を二つのタスクで並列実行するように翻訳した場
合の各々の実行命令列の例である。
プログラム単位100を実行すると、タスク1.2のオ
ブジェクト200.300が実行される。barrie
rは、0に、w a i t i dは、Onに、同期
箇所毎に初期化されているタスク間で参照可能な変数で
ある。cnt(1)は、タスク1の繰り返し数格納領域
、c n t (2)は、タスク2の繰り返し数格納領
域であり、プログラムの開始時に0で初期化されている
。また、ηockon/○ff (idl)で、タスク
間での排他制御か可能となる。
タスク1が、最初に同期制御箇所123に到達すると、
同期制御のために同期箇所に到達したタスク数を表すカ
ウンタbarrierに1を加算する。この時に、ba
rrierは1なので、同期制御変数waitidは、
onのまま変わらない タスク1は、waitidがタスク2によってoffに
されるまで同期待ち処理125を繰り返す。同期待ち処
理125内では、同期待ち処理回数c n t (1)
を処理の繰り返しの度に1ずつ加算する。
同様に、タスク2が同期制御箇所123に到達すると、
同期制御処理124を行い、タスク2が同期待ちをする
最後のタスクなので同期制御変数w a i t i 
dをoffにして実行再開を指示する。
そこで、タスク1は、w a i t i dを参照す
るとoffになっているので同期待ち処理125を終了
して次の実行に移る。
タスク2の同期待ち時間の合計は、waitidが既に
offになっているので、同期待ち処理回数が0で同期
待ち時開もOとなる。
タスク1の同期待ち時間の合計は、w a i t i
dがoffになるまでの繰り返し数に一回の同期待ち処
理の実行時間を乗じた値を同期待ち時間とする。
なお、同期待ち箇所毎の同期待ち時間の採取の方法とし
ては、繰り返し数格納領域を同期待ち箇所毎に用意して
測定する方法、およびタスク毎の同期待ち処理回数格納
領域が同期箇所で共通に使用される場合には、測定箇所
の前後で実行時間採取機構の同期待ち時間採取手段で待
ち時間を採取してその差から算出する方法等が考えられ
る。
〔発明の効果〕
・本発明の同期待ち時間測定方式は、同期待ち時間の測
定を、利用者プログラムからシステムプログラムへ制御
を移動して時刻情報を採取する代りに、同期待ち処理の
回数と同期待ち処理の実行時間とから算出することによ
り、情報採取のためのオーバーヘッド時間が少なくなる
という効果を有している。そのために、利用者プログラ
ムの同期制御箇所で同期待ち時間の測定のために発生す
る利用者プログラムの実行遅れが少なくなるという利点
がある。
【図面の簡単な説明】
第1図は本発明の同期待ち時間測定方式の一実施例を示
す機能ブロック図、第2図は本実施例で実行するプログ
ラムの一例を示す区である。 1・・・原始プログラム、2・・・コンパイルユニット
、3・・・同期待ち時間、10・・・コンパイラ、11
・・オブジェクト生成処理手段、20・・・実行時間採
取機構、21・・・同期待ち時間算出処理手段、22・
・・同期待ち処理時間係数、2a・・・繰り返し数格納
領域、2b・・・オブジェクト、100・・・プログラ
ム単位、110.130・・・並列実行不可部分、12
0・・・並列実行可能部分、123・・・同期制御箇所
、124・・・同期制御処理、125・・・同期待ち処
理、126・・・繰り返し数測定処理、200,300
・・・プログラム単位100のタスクのオブジェクト。

Claims (1)

  1. 【特許請求の範囲】 マルチプロセッサ上で、プログラムが複数個のタスクに
    分割されて、並列実行中のそれらのタスク間で同期をと
    る場合に、同期をとるタスクの実行が全て到達したか否
    かを示すタスク間の共有データ(以降に、同期制御変数
    と称す)を設定するとともに、同期箇所毎に同期制御変
    数に全てのタスクが到達したことが確認されるまで同期
    制御変数の参照を繰り返し実行すること(以降に、同期
    待ち処理と称す)でタスク間の同期をとる同期処理方式
    (以降に、スピン・ループ方式と称す)の同期待ち時間
    測定方式において、 複数のタスクで実行を行うプログラム単位を入力するこ
    とにより、タスク毎に同期待ち処理の繰り返し数の格納
    領域(以降に、繰り返し数格納領域と称す)を設定し、
    前記プログラム単位中の同期制御箇所毎の同期待ち処理
    内に同期待ち処理の繰り返し数を測定する処理を挿入し
    たオブジェクトを生成するオブジェクト生成処理手段を
    含むコンパイラと、 プログラムの実行中に同期待ち時間の採取要求が行われ
    ることにより、前記オブジェクト生成処理手段で設定し
    た繰り返し数格納領域を参照し、その繰り返し数および
    同期待ち処理の実行時間から同期待ち時間を算出する同
    期待ち時間算出処理手段を含む実行時間採取機構と、 を含むことを特徴とする同期待ち時間測定方式。
JP2671090A 1990-02-05 1990-02-05 同期待ち時間測定方式 Pending JPH03230226A (ja)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP2671090A JPH03230226A (ja) 1990-02-05 1990-02-05 同期待ち時間測定方式

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2671090A JPH03230226A (ja) 1990-02-05 1990-02-05 同期待ち時間測定方式

Publications (1)

Publication Number Publication Date
JPH03230226A true JPH03230226A (ja) 1991-10-14

Family

ID=12200923

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2671090A Pending JPH03230226A (ja) 1990-02-05 1990-02-05 同期待ち時間測定方式

Country Status (1)

Country Link
JP (1) JPH03230226A (ja)

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2009059316A (ja) * 2007-09-04 2009-03-19 Nec Corp 測定装置、測定プログラム、および、測定方法
WO2011087076A1 (ja) * 2010-01-14 2011-07-21 日本電気株式会社 並列計算機システム、同期方法、及びプログラム
CN104330849A (zh) * 2014-10-20 2015-02-04 大豪信息技术(威海)有限公司 一种短距离光纤切割刀

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2009059316A (ja) * 2007-09-04 2009-03-19 Nec Corp 測定装置、測定プログラム、および、測定方法
WO2011087076A1 (ja) * 2010-01-14 2011-07-21 日本電気株式会社 並列計算機システム、同期方法、及びプログラム
JPWO2011087076A1 (ja) * 2010-01-14 2013-05-20 日本電気株式会社 計算機、並列計算機システム、同期方法、及びコンピュータプログラム
JP5780157B2 (ja) * 2010-01-14 2015-09-16 日本電気株式会社 計算機、並列計算機システム、同期方法、及びコンピュータプログラム
CN104330849A (zh) * 2014-10-20 2015-02-04 大豪信息技术(威海)有限公司 一种短距离光纤切割刀

Similar Documents

Publication Publication Date Title
JP3480973B2 (ja) 並列処理システムの動作解析装置
US6079032A (en) Performance analysis of computer systems
JP2921190B2 (ja) 並列実行方式
JPH11259437A (ja) 不要バリア命令の削減方式
JPH0298741A (ja) マルチプロセッサコンピュータにおいてネスト式ループを実行する階層的方法
JPH01121938A (ja) オブジェクト生成方法
JP3924256B2 (ja) コンパイラ装置、コンパイラプログラム、記録媒体、コンパイル方法、実行時情報生成装置、及び実行時情報生成プログラム
Yip et al. Programming and timing analysis of parallel programs on multicores
JPH03230226A (ja) 同期待ち時間測定方式
Ghosh et al. PORTS: A parallel, optimistic, real-time simulator
Andonov et al. Two-dimensional orthogonal tiling: from theory to practice
RU2206119C2 (ru) Способ получения объектного кода
Heinz et al. Synchronization barrier elimination in synchronous FORALLs
Wang et al. Code transformations for enhancing the performance of speculatively parallel threads
JPS62217325A (ja) アセンブラコ−ド最適化方式
Moudgill et al. Run-time detection and recovery from incorrectly reordered memory operations
Thane et al. Handling interrupts in testing of distributed real-time systems
Castro et al. Soft real-time EPICS extensions for fast control: A case study applied to a TCV equilibrium algorithm
JP2007108838A (ja) コンパイル方法及びコンパイル装置
JP2004310651A (ja) コスト解析に基づいてループの自動並列化処理を行う情報処理装置
JP2001154998A (ja) 並列化解析指示方法と並列化汎用連成解析装置
JP2870218B2 (ja) 並列実行命令列生成方式
JPH01263574A (ja) テストパターンプログラム自動生成装置
Andersen et al. Describing a Signal Analyzer in the process algebra PMC—A case study
Kuper et al. Freeze after writing