CTRDG_WriteAgbFlashSectorAsync

構文

#include <nitro/ctrdg.h>
void CTRDG_WriteAgbFlashSectorAsync(u16 sec_num, u8* src, CTRDG_TASK_FUNC callback);
  

引数

sec_num 対象セクタNo
src 書き込み元アドレス
callback データのWrite処理が終了したときに呼び出されるコールバック関数

返り値

なし。

説明

src アドレスから1セクタ分(4kbyte)のデータを非同期に対象セクタbノ書き込みます。
本ルーチン内で CTRDG_EraseAgbFlashSector( )をコールし、セクタを消去してから書き込みを行います。
本ルーチンの実行中、グローバル変数 flash_remainder を参照することで、残バイト数を知ることができます。
また、本ルーチンの呼び出し後に返ってくるコールバック関数の引数である構造体 CTRDGTaskInfo のメンバ result を参照することで、 Write処理に成功したのかを知ることができます。
Write処理に成功した場合は 0 、失敗した場合、対象セクタNo が範囲外の場合は 0 以外です。

アクセスサイクルの設定は関数内で行いますので、事前に行う必要はありません。
また、この関数ではタイムアウト測定用にチックを使用しますので事前に OS_InitTick( )を呼んでおく必要があります。

※この関数内では一定期間全ての割り込みが禁止され、カートリッジバスがロックされますので注意して下さい。
特に、本関数コール時はダイレクトサウンドおよびV・Hブランク同期、表示同期、カートリッジリクエスト等の特定のタイミングで自動起動するDMAは使用しないで下さい。

また IS-NITRO-DEBUGGER 1.66 以前のバージョンでは AGB バックアップデバイスに正常にアクセスすることはできませんので、注意してください。

/* コールバック関数 */
typedef u32 (*CTRDG_TASK_FUNC) (struct CTRDGiTaskInfo_tag *);

参照

CTRDG_EraseAgbFlashSector, CTRDG_WriteAgbFlashSector, CTRDG_WriteAndVerifyAgbFlash, CTRDG_WriteAndVerifyAgbFlashAsync

履歴

2006/05/25 IS-NITRO-DEBUGGER 1.66 以前のバージョンでは AGB バックアップデバイスに正常にアクセスできないことを追記
2006/04/07 初版