

#include <nitro/wm.h>
WMErrCode WM_SetMPDataToPort(
WMCallbackFunc callback ,
const u16* sendData ,
u16 sendDataSize ,
u16 destBitmap ,
u16 port ,
u16 prio
);
| callback | 非同期処理が完了した時に呼び出されるコールバック関数を指定します。 このコールバックは割り込みハンドラ内から呼び出されます。 |
| sendData | 送信予約するデータへのポインタを指定します。 このデータの実体は強制的にキャッシュストアされる点に注意して下さい。 |
| sendDataSize | 送信予約するデータのサイズを指定します。 |
| destBitmap | 送信先子機のAIDを示すビットマップを指定します。(親機のみ有効) |
| port | データを送信するポート番号を指定します。0 〜 15 の値を指定して下さい。 |
| prio | データ送信の優先度を指定します。0 (最高) 〜 3 (最低) の値を指定して下さい。 |
WMErrCode列挙型の処理結果を返します。
MPで特定のポートに送信するデータをセットします。WMがMP_PARENTステートもしくはMP_CHILDステートの場合に実行可能です。
APIの戻り値がWM_ERRCODE_OPERATINGであった場合、MPにてデータ送信処理が完了した後にコールバックが発生します。コールバックが呼び出されるまでは引数sendDataの指しているバッファを書き換えてはいけません。他の無線APIの非同期関数と異なり、コールバックを待たずにこのAPIを連続して呼び出した際にcallbackにそれぞれ異なる関数ポインタを指定しても、正常に処理されます。
但しコールバックを待たずに連続して呼び出せる回数は全優先度を合わせて32回までという制限があり、32回を越えて連続で呼び出すと WM_ERRCODE_SEND_QUEUE_FULL がコールバックに返り、失敗します。
このAPIはargにNULLを指定したWM_SetMPDataToPortEx( ) の呼び出しと同等です。
引数に渡したデータ(sendData) は内部で強制的にキャッシュストアされます。キャッシュのトラブルを回避するには、32バイト境界に揃ったデータを渡す必要があります。
注意点などの詳細は「ワイヤレス通信ライブラリ解説 (AboutWirelessManager.pdf)」を参照してください。
WM_StartMP, WM_EndMP, WM_SetMPDataToPortEx, WM_SetPortCallback, WMPort
2009/10/27 コールバックを待たずに呼び出せる回数についての説明修正
2008/12/17 引数に渡したデータが内部で強制的にキャッシュストアされる点について注意を追記
2005/07/08 非同期に連続して呼び出すことができる制限回数を追記
2005/06/08 コールバックが割り込みハンドラから呼び出される旨を補足
2005/03/02 port引数について指定可能範囲を追記
2004/10/22 返り値の型を変更
2004/09/25 説明の加筆・修正
2004/09/09 WM_SetMPDataToPortEx についての記述を追加
2004/08/11 初版