Everything

pol_flg

ipol_flg

概要
ビット・パターンのチェック(ポーリング)
C言語形式
 ER      pol_flg ( ID flgid, FLGPTN waiptn, MODE wfmode, FLGPTN *p_flgptn );
 ER      ipol_flg ( ID flgid, FLGPTN waiptn, MODE wfmode, FLGPTN *p_flgptn );
パラメータ
I/O
パラメータ
説明
I
 ID      flgid;
イベントフラグのID
I
 FLGPTN  waiptn;
要求するビット・パターン
I
 MODE    wfmode;
要求条件の指定
TWF_ANDW: AND待ち
TWF_ORW: OR待ち
O
 FLGPTN  *p_flgptn;
条件成立時のビット・パターンを格納する領域へのポインタ

機能
waiptnで指定された要求ビット・パターンとwfmodeで指定された要求条件を満足するビット・パターンがflgidで指定されたイベントフラグに設定されているか否かをチェックします。
なお,要求条件を満足するビット・パターンが対象イベントフラグに設定されていた場合には,対象イベントフラグのビット・パターンをp_flgptnで指定された領域に格納します。
ただし,本サービス・コールを発行した際,対象イベントフラグのビット・パターンが要求条件を満足していなかった場合には,戻り値としてE_TMOUTを返します。
以下に,要求条件wfmodeの指定形式を示します。
- wfmode == TWF_ANDW
waiptnで1を設定している全ビットが対象イベントフラグに設定されているか否かをチェックします。
- wfmode == TWF_ORW
waiptnで1を設定しているビットのうち,いずれかのビットが対象イベントフラグに設定されているか否かをチェックします。
備考1 RI600PXでは,イベントフラグの待ちキューに複数のタスクをキューイング可能とするか否かをコンフィギュレーション時に定義させています。このため,すでに待ちタスクがキューイングされているイベントフラグ(TA_WSGL属性)に対して本サービス・コールを発行した場合,RI600PXは要求条件の即時成立/不成立を問わず,戻り値としてE_ILUSEを返します。
TA_WSGL属性: キューイング可能なタスクは,1個
TA_WMUL属性: キューイング可能なタスクは,複数
備考2 対象イベントフラグ(TA_CLR属性)の要求条件が満足した際,RI600PXはビット・パターンのクリア(0の設定)を行います。
戻り値
マクロ
数値
意味
E_OK
0
正常終了
E_PAR
-17
パラメータ・エラー
- waiptn == 0
- 要求条件wfmodeの指定が不正である。
- p_flgptn == NULL
E_ID
-18
不正ID番号
- flgid≦0
- flgid > VTMAX_FLG
E_CTX
-25
コンテキスト・エラー
- CPUロック状態から本サービス・コールを発行した。
- 「PSW.IPL > カーネル割り込みマスクレベル」の状態から本サービス・コールを発行した。
備考 タスクからipol_flgを発行した場合,および非タスクからpol_flgを発行した場合,コンテキスト・エラーは検出されず,システムの正常な動作は保証されません。
E_MACV
-26
メモリ・アクセス違反(pol_flgのみ)
- 呼び出しタスクからのp_flgptnが示す領域に対するオペランド・ライト・アクセス許可がない。
E_ILUSE
-28
サービス・コール不正使用
- すでに待ちタスクがキューイングされているイベントフラグ(TA_WSGL属性)に対して本サービス・コールを発行した。
E_NOEXS
-42
オブジェクト未生成
- flgidのイベントフラグが存在しない。
E_TMOUT
-50
ポーリング失敗