複数のISaGRAF Ver.4/5タスクが動作している時に、あるタスクに属しているC言語の変数を別のタスクから参照してはいけません。
これは、次のときに問題が発生します。
- 複数のタスクが同一のコードセクションを実行していて、かつOSが各タスクの変数のインスタンス化を管理していない場合
例えば、複数のISaGRAFのバーチャルマシンが実行中の場合や、システムレイヤのライブラリが複数のタスク(エクスチェンジディスパッチャ(IXD)、コンフィギュレーションマネージャ(CMG)等)から使用されている場合です。
このような場合、例えば、ISaGRAF Ver.4/5のバーチャルマシンどうしでは、同じ変数でも区別して使われるようにする必要があります。
共有すべきではない変数
以下の通りです。これらの変数はタスク毎に別途作成する必要があります。
-
1. カーネル変数
カーネル用変数はバーチャルマシン1つにつき1セット用意する必要があります。
2. システムレイヤ変数
システム関連の変数も、バーチャルマシン毎に1セット必要です。
また、このレイヤを使用するタスク(コンフィギュレーションマネージャ、エクスチェンジディスパッチャ等)毎にも1セットの変数が必要です。
解決方法
VxWorksターゲットの場合、このようなタスク間での変数の区別を下記のような方法で実現します。
- 各変数は1個の構造体の中のメンバとして宣言されています。カーネル用、システムレイヤ用それぞれがあります。
各タスクの初期化時に、これらの構造体のメモリを動的にアロケートします。全てのカーネル変数の構造体を1個のポインタ(pISa_KERGLOBINST)で指すように設定されています。全てのシステムレイヤ変数」も1個のポインタ(pISa_COMMONGLOBINST)で指すように設定されています。
OSがこれら2つの変数を保存できるようになっていれば良いことになります。タスクが待ち状態になったら自動的にタスクのコンテキストの一部として保存され、タスクが再度アクティブになった時にリストアされる、というようにです。具体的には下の図を参照してください。
VxWorks以外のOSで、同様の問題が発生する場合は、タスクの変数をコンテキストの一部として保存する機能をOSがサポートしているかどうかを確認してください。