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 RI850V4では,イベントフラグの待ちキューに複数のタスクをキューイング可能とするか否かをコンフィギュレーション時に定義させています。このため,すでに待ちタスクがキューイングされているイベントフラグ(TW_WSGL属性)に対して本サービス・コールを発行した場合,RI850V4は要求条件の即時成立/不成立を問わず,戻り値としてE_ILUSEを返します。

TA_WSGL属性: キューイング可能なタスクは,1個

TA_WMUL属性: キューイング可能なタスクは,複数

備考2 対象イベントフラグ(TA_CLR属性)の要求条件が満足した際,RI850V4はビット・パターンのクリア(0x0の設定)を行います。

備考3 本サービス・コールを発行した際,対象イベントフラグのビット・パターンが要求条件を満足していなかった場合,p_flgptnで指定された領域の内容は不定となります。

戻り値

マクロ

数値

意味

E_OK

0

正常終了

E_PAR

-17

パラメータの指定が不正である

- 要求ビット・パターンの指定が不正(waiptn = 0x0)である

- 要求条件wfmodeの指定が不正である

E_ID

-18

IDの指定が不正である

- flgid≦0x0

- flgid>生成されているイベントフラグの最大ID

E_CTX

-25

CPUロック状態から本サービス・コールを発行した

E_ILUSE

-28

すでに待ちタスクがキューイングされているイベントフラグ(TW_WSGL属性)に対して本サービス・コールを発行した

E_NOEXS

-42

対象イベントフラグが生成されていない

E_TMOUT

-50

対象イベントフラグのビット・パターンが要求条件を満足していない