From 3061ecca3d0fdfb87dabbf5f63c9e06c2a30f53a Mon Sep 17 00:00:00 2001 From: Trygve Laugstøl Date: Thu, 23 Aug 2018 17:08:59 +0200 Subject: o Initial import. --- .../external/fatfs/doc/ja/forward.html | 139 +++++++++++++++++++++ 1 file changed, 139 insertions(+) create mode 100644 thirdparty/nRF5_SDK_15.0.0_a53641a/external/fatfs/doc/ja/forward.html (limited to 'thirdparty/nRF5_SDK_15.0.0_a53641a/external/fatfs/doc/ja/forward.html') diff --git a/thirdparty/nRF5_SDK_15.0.0_a53641a/external/fatfs/doc/ja/forward.html b/thirdparty/nRF5_SDK_15.0.0_a53641a/external/fatfs/doc/ja/forward.html new file mode 100644 index 0000000..99456b2 --- /dev/null +++ b/thirdparty/nRF5_SDK_15.0.0_a53641a/external/fatfs/doc/ja/forward.html @@ -0,0 +1,139 @@ + + + + + + + + +FatFs - f_forward + + + + +
+

f_forward

+

ファイルからデータを読み出し、送信ストリームに直接転送します。

+
+FRESULT f_forward (
+  FIL* fp,                         /* [IN] ファイル オブジェクト構造体 */
+  UINT (*func)(const BYTE*,UINT),  /* [IN] データ転送関数 */
+  UINT btf,                        /* [IN] 転送するバイト数 */
+  UINT* bf                         /* [OUT] 転送されたバイト数 */
+);
+
+
+ +
+

引数

+
+
fp
+
ファイル オブジェクト構造体へのポインタを指定します。
+
func
+
データを渡すユーザ定義関数へのポインタを指定します。この関数の仕様はサンプルを参照してください。
+
btf
+
転送するバイト数(0~UINTの最大値)を指定します。
+
bf
+
実際に転送されたバイト数を格納する変数を指すポインタを指定します。
+
+
+ + +
+

戻り値

+

+FR_OK, +FR_DISK_ERR, +FR_INT_ERR, +FR_DENIED, +FR_INVALID_OBJECT, +FR_TIMEOUT +

+
+ + +
+

解説

+

ファイルのデータをバッファに読み出さずに送信ストリームに直接転送します。アプリケーション側でデータ バッファを必要としないので、メモリの限られた環境で有効です。リード/ライト ポインタは転送されたバイト数だけ進みます。指定されたバイト数の転送中にファイルの終端に達した場合や送信ストリームがビジーになった場合、*bfbtfよりも小さくなります。

+
+ + +
+

対応情報

+

_USE_FORWARD == 1のときに使用可能です。

+
+ + +
+

使用例(オーディオ再生)

+
+/*-----------------------------------------------------------------------*/
+/* f_forward関数から呼ばれるデータ送信関数の例                           */
+/*-----------------------------------------------------------------------*/
+
+UINT out_stream (   /* 戻り値: 転送されたバイト数またはストリームの状態 */
+    const BYTE *p,  /* 転送するデータを指すポインタ */
+    UINT btf        /* >0: 転送を行う(バイト数). 0: ストリームの状態を調べる */
+)
+{
+    UINT cnt = 0;
+
+
+    if (btf == 0) {     /* センス要求 */
+        /* ストリームの状態を返す (0: ビジー, 1: レディ) */
+        /* 一旦、レディを返したら、続く転送要求で少なくとも1バイトは */
+        /* 転送されないと f_forward関数は FR_INT_ERR となる。 */
+        if (FIFO_READY) cnt = 1;
+    }
+    else {              /* 転送要求 */
+        do {    /* 全てのバイトを転送するか、ストリームがビジーになるまで繰り返す */
+            FIFO_PORT = *p++;
+            cnt++;
+        } while (cnt < btf && FIFO_READY);
+    }
+
+    return cnt;
+}
+
+
+/*-----------------------------------------------------------------------*/
+/* f_forward関数の使用例                                                 */
+/*-----------------------------------------------------------------------*/
+
+FRESULT play_file (
+    char *fn        /* 再生するオーディオ ファイル名を指すポインタ */
+)
+{
+    FRESULT rc;
+    FIL fil;
+    UINT dmy;
+
+    /* ファイルを読み出しモードで開く */
+    rc = f_open(&fil, fn, FA_READ);
+    if (rc) return rc;
+
+    /* 全てのデータが転送されるかエラーが発生するまで続ける */
+    while (rc == FR_OK && !f_eof(&fil)) {
+
+        /* ほかの処理... */
+
+        /* 定期的または要求に応じてデータをストリームに送出する */
+        rc = f_forward(&fil, out_stream, 1000, &dmy);
+    }
+
+    /* ファイルを閉じて戻る */
+    f_close(&fil);
+    return rc;
+}
+
+
+ + +
+

参照

+

f_open, fgets, f_write, f_close, FIL

+
+ +

戻る

+ + -- cgit v1.2.3