From 7b78a5a287827db9e9b16286f3604aef69b37c5c Mon Sep 17 00:00:00 2001 From: Leo C Date: Mon, 17 Nov 2014 14:47:05 +0100 Subject: [PATCH] Import fatfs R0.10c --- fatfs/doc/00index_e.html | 19 +- fatfs/doc/00index_j.html | 78 +++---- fatfs/doc/en/appnote.html | 18 +- fatfs/doc/en/dinit.html | 6 +- fatfs/doc/en/dioctl.html | 19 +- fatfs/doc/en/dread.html | 9 +- fatfs/doc/en/dstat.html | 10 +- fatfs/doc/en/dwrite.html | 4 +- fatfs/doc/en/eof.html | 2 +- fatfs/doc/en/error.html | 2 +- fatfs/doc/en/filename.html | 14 +- fatfs/doc/en/getcwd.html | 2 +- fatfs/doc/en/mkfs.html | 48 +++- fatfs/doc/en/mount.html | 2 +- fatfs/doc/en/rc.html | 6 +- fatfs/doc/en/readdir.html | 4 +- fatfs/doc/en/sfile.html | 2 +- fatfs/doc/en/sfileinfo.html | 4 +- fatfs/doc/en/stat.html | 40 ++++ fatfs/doc/img/app3.c | 2 +- fatfs/doc/img/mkfatimg.zip | Bin 0 -> 686662 bytes fatfs/doc/ja/appnote.html | 110 ++++----- fatfs/doc/ja/chdir.html | 30 +-- fatfs/doc/ja/chdrive.html | 22 +- fatfs/doc/ja/chmod.html | 40 ++-- fatfs/doc/ja/close.html | 26 +-- fatfs/doc/ja/closedir.html | 26 +-- fatfs/doc/ja/dinit.html | 22 +- fatfs/doc/ja/dioctl.html | 86 +++---- fatfs/doc/ja/dread.html | 47 ++-- fatfs/doc/ja/dstat.html | 22 +- fatfs/doc/ja/dwrite.html | 50 ++-- fatfs/doc/ja/eof.html | 28 +-- fatfs/doc/ja/error.html | 28 +-- fatfs/doc/ja/fattime.html | 30 +-- fatfs/doc/ja/fdisk.html | 48 ++-- fatfs/doc/ja/filename.html | 34 +-- fatfs/doc/ja/forward.html | 72 +++--- fatfs/doc/ja/getcwd.html | 28 +-- fatfs/doc/ja/getfree.html | 40 ++-- fatfs/doc/ja/getlabel.html | 34 +-- fatfs/doc/ja/gets.html | 36 +-- fatfs/doc/ja/lseek.html | 76 +++---- fatfs/doc/ja/mkdir.html | 24 +- fatfs/doc/ja/mkfs.html | 80 +++++-- fatfs/doc/ja/mount.html | 50 ++-- fatfs/doc/ja/open.html | 96 ++++---- fatfs/doc/ja/opendir.html | 28 +-- fatfs/doc/ja/printf.html | 44 ++-- fatfs/doc/ja/putc.html | 32 +-- fatfs/doc/ja/puts.html | 32 +-- fatfs/doc/ja/rc.html | 18 +- fatfs/doc/ja/read.html | 36 +-- fatfs/doc/ja/readdir.html | 60 ++--- fatfs/doc/ja/rename.html | 32 +-- fatfs/doc/ja/sdir.html | 28 +-- fatfs/doc/ja/setlabel.html | 38 ++-- fatfs/doc/ja/sfatfs.html | 48 ++-- fatfs/doc/ja/sfile.html | 34 +-- fatfs/doc/ja/sfileinfo.html | 48 ++-- fatfs/doc/ja/size.html | 26 +-- fatfs/doc/ja/stat.html | 67 ++++-- fatfs/doc/ja/sync.html | 26 +-- fatfs/doc/ja/tell.html | 26 +-- fatfs/doc/ja/truncate.html | 22 +- fatfs/doc/ja/unlink.html | 28 +-- fatfs/doc/ja/utime.html | 32 +-- fatfs/doc/ja/write.html | 36 +-- fatfs/doc/updates.txt | 6 + fatfs/src/00readme.txt | 7 +- fatfs/src/diskio.c | 66 +++--- fatfs/src/diskio.h | 16 +- fatfs/src/ff.c | 439 +++++++++++++++++++----------------- fatfs/src/ff.h | 9 +- fatfs/src/ffconf.h | 224 ++++++++++-------- fatfs/src/option/cc932.c | 6 +- fatfs/src/option/cc936.c | 4 +- fatfs/src/option/cc949.c | 4 +- fatfs/src/option/cc950.c | 4 +- fatfs/src/option/ccsbcs.c | 2 +- fatfs/src/option/syscall.c | 38 ++-- 81 files changed, 1635 insertions(+), 1407 deletions(-) create mode 100644 fatfs/doc/img/mkfatimg.zip diff --git a/fatfs/doc/00index_e.html b/fatfs/doc/00index_e.html index aa249b1..9dc9d8e 100644 --- a/fatfs/doc/00index_e.html +++ b/fatfs/doc/00index_e.html @@ -4,7 +4,10 @@ - + + + + FatFs - Generic FAT File System Module @@ -16,7 +19,7 @@
layer -

FatFs is a generic FAT file system module for small embedded systems. The FatFs is written in compliance with ANSI C and completely separated from the disk I/O layer. Therefore it is independent of hardware architecture. It can be incorporated into small microcontrollers with limited resource, such as AVR, 8051, PIC, ARM, Z80, 68k and etc. Also Petit FatFs module for tiny microcontrollers is available here.

+

FatFs is a generic FAT file system module for small embedded systems. The FatFs module is written in compliance with ANSI C (C89) and completely separated from the disk I/O layer. Therefore it is independent of the platform. It can be incorporated into small microcontrollers with limited resource, such as 8051, PIC, AVR, ARM, Z80, 78K and etc. Also Petit FatFs module for tiny microcontrollers is available here↗.

Features

@@ -81,7 +84,7 @@

Device Control Interface

-

Since the FatFs module is a file system driver, it is completely separated from physical devices, such as memory card, harddisk and any type of storage devices. The low level device control module is not a part of FatFs module. FatFs accesses the storage device via a simple interface described below. These functions are provided by implementer. Sample implementations for some platforms are also available in the downloads.

+

Since the FatFs module is a file system layer, it is completely separated from physical devices, such as memory card, harddisk and any type of storage devices. FatFs accesses the storage device via a simple interface described below. The low level device control module is not a part of FatFs module. It is provided by implementer. Also sample implementations for some platforms are available in the downloads.

diff --git a/fatfs/doc/00index_j.html b/fatfs/doc/00index_j.html index d5496e9..b13297d 100644 --- a/fatfs/doc/00index_j.html +++ b/fatfs/doc/00index_j.html @@ -4,34 +4,35 @@ - + - + + -FatFs 汎用FATファイルシステム・モジュール +FatFs 汎用FATファイルシステム モジュール -

FatFs 汎用FATファイルシステム・モジュール

+

FatFs 汎用FATファイルシステム モジュール


layer -

FatFsは小規模な組み込みシステム向けの汎用FATファイルシステム・モジュールです。ANSI C準拠でハードウェア・アーキテクチャには依存しないので、必要なワーク・エリアが確保できれば、8051, PIC, AVR, SH, Z80, 68k, H8, ARMなど安価なマイコンでも使用可能です。FatFsをシュリンクしたぷちFatFs↗もあります。

+

FatFsは小規模な組み込みシステム向けの汎用FATファイルシステム モジュールです。ANSI C(C89)準拠でハードウェア アーキテクチャには依存しないので、必要なワーク エリアが確保できれば、8051, PIC, AVR, SH, Z80, 68k, H8, ARMなど安価なマイコンでも使用可能です。このほか、FatFsを極小マイコン向けにシュリンクしたぷちFatFs↗ もあります。

FatFsモジュールの特徴

    -
  • Windows互換 FATファイル・システム
  • +
  • Windows互換 FATファイル システム
  • プラットフォーム非依存
  • コンパクトなコードとRAM使用量
  • 多くの構成オプション:
    • 複数のボリューム(物理ドライブ・区画)
    • -
    • DBCSを含む複数のANSI/OEMコード・ページ
    • -
    • 長いファイル名(LFN) (Unicode APIも選択可)
    • +
    • DBCSを含む複数のANSI/OEMコード ページの選択
    • +
    • 長いファイル名(LFN)への対応
    • マルチタスク関連
    • -
    • マルチ・セクタ・サイズ
    • -
    • リード・オンリー構成、一部APIの削除、バッファ構成、その他…
    • +
    • マルチ セクタ サイズ
    • +
    • リード オンリー構成、一部APIの削除、バッファ構成、その他…
@@ -39,50 +40,50 @@
-

上位レイヤ・インターフェース

-

FatFsモジュールは、アプリケーション・レイヤに対し、次のファイル操作関数(API)を提供します。つまり、このリストはFatFsにできることをシンプルに示しています。

+

上位レイヤ インターフェース

+

FatFsモジュールは、アプリケーション レイヤに対し、次のファイル操作関数(API)を提供します。つまり、このリストはFatFsにできることをシンプルに示しています。

  • f_mount - ワークエリアの登録・抹消
  • f_open - ファイルのオープン・作成
  • f_close - ファイルのクローズ
  • f_read - ファイルの読み出し
  • f_write - ファイルの書き込み
  • -
  • f_lseek - リード/ライト・ポインタの移動, ファイルの拡張
  • -
  • f_truncate - ファイル・サイズの切り詰め
  • +
  • f_lseek - リード/ライト ポインタの移動, ファイルの拡張
  • +
  • f_truncate - ファイル サイズの切り詰め
  • f_sync - キャッシュされたデータのフラッシュ
  • -
  • f_forward - ファイル・データをストリーム関数に転送
  • -
  • f_stat - ファイル/サブ・ディレクトリの存在チェックと情報の取得
  • +
  • f_forward - ファイル データをストリーム関数に転送
  • +
  • f_stat - ファイル/サブ ディレクトリの存在チェックと情報の取得
  • f_opendir - ディレクトリのオープン
  • f_closedir - ディレクトリのクローズ
  • f_readdir - ディレクトリの読み出し
  • -
  • f_mkdir - サブ・ディレクトリの作成
  • -
  • f_unlink - ファイル/サブ・ディレクトリの削除
  • -
  • f_chmod - ファイル/サブ・ディレクトリの属性の変更
  • -
  • f_utime - ファイル/サブ・ディレクトリのタイムスタンプの変更
  • -
  • f_rename - ファイル/サブ・ディレクトリの名前の変更・移動
  • -
  • f_chdir - カレント・ディレクトリの変更
  • -
  • f_chdrive - カレント・ドライブの変更
  • -
  • f_getcwd - カレント・ディレクトリの取得
  • +
  • f_mkdir - サブ ディレクトリの作成
  • +
  • f_unlink - ファイル/サブ ディレクトリの削除
  • +
  • f_chmod - ファイル/サブ ディレクトリの属性の変更
  • +
  • f_utime - ファイル/サブ ディレクトリのタイムスタンプの変更
  • +
  • f_rename - ファイル/サブ ディレクトリの名前の変更・移動
  • +
  • f_chdir - カレント ディレクトリの変更
  • +
  • f_chdrive - カレント ドライブの変更
  • +
  • f_getcwd - カレント ディレクトリの取得
  • f_getfree - ボリューム空き領域の取得
  • -
  • f_getlabel - ボリューム・ラベルの取得
  • -
  • f_setlabel - ボリューム・ラベルの設定
  • +
  • f_getlabel - ボリューム ラベルの取得
  • +
  • f_setlabel - ボリューム ラベルの設定
  • f_mkfs - 論理ドライブのフォーマット
  • f_fdisk - 物理ドライブの分割
  • f_gets - 文字列の読み出し
  • f_putc - 文字の書き込み
  • f_puts - 文字列の書き込み
  • f_printf - 書式化文字列の書き込み
  • -
  • f_tell - 現在のリード/ライト・ポインタの取得
  • +
  • f_tell - 現在のリード/ライト ポインタの取得
  • f_eof - ファイル終端の有無の取得
  • -
  • f_size - ファイル・サイズの取得
  • +
  • f_size - ファイル サイズの取得
  • f_error - ファイルのエラーの有無の取得
-

下位レイヤ・インターフェース

-

FatFsモジュールは、単なるファイル・システム・レイヤなので、ストレージ・デバイス制御レイヤは含まれません。使用するストレージに対応した制御関数は、ユーザによって提供される必要があります。FatFsモジュールは、下位レイヤに対し少なくとも次のインターフェースを要求します。OS関連機能を有効にしたときは、これに加えてプロセス/メモリ関連関数も必要になります。サンプル・プロジェクトに下位レイヤの実装例を示します。

+

下位レイヤ インターフェース

+

FatFsモジュールは、単なるファイル システム レイヤなので、ストレージ デバイス制御レイヤは含まれません。使用するプラットフォームやストレージ デバイスに対応した制御関数は、ユーザによって提供される必要があります。FatFsモジュールは、下位レイヤに対し標準的には次のインターフェースを要求します。拡張機能、たとえばOS関連機能を有効にしたときは、加えてプロセス/メモリ操作関数なども必要になります。サンプル プロジェクトに下位レイヤの実装例を示します。

  • disk_status - デバイスの状態取得
  • disk_initialize - デバイスの初期化
  • @@ -96,18 +97,19 @@

    資料

    -

    FatFsモジュールはフリー・ソフトウェアとして教育・研究・開発用に公開しています。どのような利用目的(個人利用から商用まで)でも使用・改変・配布について一切の制限はありませんが、全て利用者の責任の下での利用とします。詳しくはアプリケーション・ノートを参照してください。

    +

    FatFsモジュールはフリー ソフトウェアとして教育・研究・開発用に公開しています。どのような利用目的(個人利用から商用まで)でも使用・改変・配布について一切の制限はありませんが、全て利用者の責任の下での利用とします。詳しくはアプリケーション ノートを参照してください。

    diff --git a/fatfs/doc/en/appnote.html b/fatfs/doc/en/appnote.html index 7f5ad89..fee2af9 100644 --- a/fatfs/doc/en/appnote.html +++ b/fatfs/doc/en/appnote.html @@ -54,7 +54,7 @@ The FatFs module assumes that size of char/short/long are 8/16/32 bit and int is disk_write
    get_fattime
    disk_ioctl (CTRL_SYNC)_FS_READONLY == 0 disk_ioctl (GET_SECTOR_COUNT)
    disk_ioctl (GET_BLOCK_SIZE)_USE_MKFS == 1 disk_ioctl (GET_SECTOR_SIZE)_MAX_SS != _MIN_SS -disk_ioctl (CTRL_ERASE_SECTOR)_USE_ERASE == 1 +disk_ioctl (CTRL_TRIM)_USE_TRIM == 1 ff_convert
    ff_wtoupper_USE_LFN >= 1Unicode support functions.
    Available in option/unicode.c. ff_cre_syncobj
    ff_del_syncobj
    ff_req_grant
    ff_rel_grant_FS_REENTRANT == 1O/S dependent functions.
    Samples available in option/syscall.c. ff_mem_alloc
    ff_mem_free_USE_LFN == 3 @@ -98,7 +98,7 @@ _USE_STRFUNC 0 (Disable string functions) _USE_MKFS 0 (Disable f_mkfs function) _USE_FORWARD 0 (Disable f_forward function) _USE_FASTSEEK 0 (Disable fast seek feature) -_CODE_PAGE 932 (Japanese Shift-JIS) +_CODE_PAGE 932 (Japanese Shift_JIS) _USE_LFN 0 (Disable LFN feature) _MAX_SS 512 (Fixed sector size) _FS_RPATH 0 (Disable relative path feature) @@ -151,17 +151,17 @@ _FS_LOCK 0 (Disable file lock control)

    Long File Name

    -

    FatFs module supports LFN (long file name). The two different file names, SFN (short file name) and LFN, of a file is transparent on the API except for f_readdir() function. The LFN feature is disabled by default. To enable it, set _USE_LFN to 1, 2 or 3, and add option/unicode.c to the project. The LFN feature requiers a certain working buffer in addition. The buffer size can be configured by _MAX_LFN according to the available memory. The length of an LFN will reach up to 255 characters, so that the _MAX_LFN should be set to 255 for full featured LFN operation. If the size of working buffer is insufficient for the input file name, the file function fails with FR_INVALID_NAME. When enable the LFN feature with re-entrant configuration, _USE_LFN must be set to 2 or 3. In this case, the file function allocates the working buffer on the stack or heap. The working buffer occupies (_MAX_LFN + 1) * 2 bytes.

    +

    FatFs module supports LFN (long file name). The two different file names, SFN (short file name) and LFN, of a file is transparent on the API except for f_readdir() function. The LFN feature is disabled by default. To enable it, set _USE_LFN to 1, 2 or 3, and add option/unicode.c to the project. The LFN feature requiers a certain working buffer in addition. The buffer size can be configured by _MAX_LFN according to the available memory. The length of an LFN will reach up to 255 characters, so that the _MAX_LFN should be set to 255 for full featured LFN operation. If the size of working buffer is insufficient for the input file name, the file function fails with FR_INVALID_NAME. When enable the LFN feature under re-entrant configuration, _USE_LFN must be set to 2 or 3. In this case, the file function allocates the working buffer on the stack or heap. The working buffer occupies (_MAX_LFN + 1) * 2 bytes.

    - +
    LFN cfg on ARM7TDMI
    Code pageProgram size
    SBCS+3.7K
    932(Shift-JIS)+62K
    932(Shift_JIS)+62K
    936(GBK)+177K
    949(Korean)+139K
    950(Big5)+111K
    -

    When the LFN feature is enabled, the module size will be increased depends on the selected code page. Right table shows how many bytes increased when LFN feature is enabled with some code pages. Especially, in the CJK region, tens of thousands of characters are being used. Unfortunately, it requires a huge OEM-Unicode bidirectional conversion table and the module size will be drastically increased that shown in the table. As the result, the FatFs with LFN feature with those code pages will not able to be implemented to most 8-bit microcontrollers.

    +

    When the LFN feature is enabled, the module size will be increased depends on the selected code page. Right table shows how many bytes increased when LFN feature is enabled with some code pages. Especially, in the CJK region, tens of thousands of characters are being used. Unfortunately, it requires a huge OEM-Unicode bidirectional conversion table and the module size will be drastically increased as shown in the table. As the result, the FatFs with LFN feature with those code pages will not able to be implemented to most 8-bit microcontrollers.

    Note that the LFN feature on the FAT file system is a patent of Microsoft Corporation. This is not the case on FAT32 but most FAT32 drivers come with the LFN feature. FatFs can swich the LFN feature off by configuration option. When enable LFN feature on the commercial products, a license from Microsoft may be required depends on the final destination.

    @@ -181,7 +181,7 @@ _FS_LOCK 0 (Disable file lock control)

    Duplicated File Access

    FatFs module does not support the read/write collision control of duplicated open to a file. The duplicated open is permitted only when each of open method to a file is read mode. The duplicated open with one or more write mode to a file is always prohibited, and also open file must not be renamed and deleted. A violation of these rules can cause data colluption.

    -

    The file lock control can also be available by _FS_LOCK option. The value defines the number of open objects to manage simultaneously. In this case, if any open, rename or remove that violating the file shareing rule that described above is attempted, the file function will fail with FR_LOCKED. If number of open objects, files and sub-directories, gets larger than _FS_LOCK, the f_open(), f_optndir() function will fail with FR_TOO_MANY_OPEN_FILES.

    +

    The file lock control can be enabled by _FS_LOCK option. The value of option defines the number of open objects to manage simultaneously. In this case, if any open, rename or remove that violating the file shareing rule that described above is attempted, the file function will fail with FR_LOCKED. If number of open objects, files and sub-directories, is equal to _FS_LOCK, an extra f_open(), f_optndir() function will fail with FR_TOO_MANY_OPEN_FILES.

    @@ -196,7 +196,7 @@ _FS_LOCK 0 (Disable file lock control)

    Figure 3. Fully sector aligned read

    -

    The file I/O buffer is a sector buffer to read/write a partial data on the sector. The sector buffer is either file private sector buffer on each file object or shared sector buffer in the file system object. The buffer configuration option _FS_TINY determins which sector buffer is used for the file data transfer. When tiny buffer (1) is selected, data memory consumption is reduced 512 bytes each file object. In this case, FatFs module uses only a sector buffer in the file system object for file data transfer and FAT/directory access. The disadvantage of the tiny buffer configuration is: the FAT data cached in the sector buffer will be lost by file data transfer and it must be reloaded at every cluster boundary. However it will be suitable for most application from view point of the decent performance and low memory comsumption.

    +

    The file I/O buffer is a sector buffer to read/write a partial data on the sector. The sector buffer is either file private sector buffer on each file object or shared sector buffer in the file system object. The buffer configuration option _FS_TINY determins which sector buffer is used for the file data transfer. When tiny buffer configuration (1) is selected, data memory consumption is reduced _MAX_SS bytes each file object. In this case, FatFs module uses only a sector buffer in the file system object for file data transfer and FAT/directory access. The disadvantage of the tiny buffer configuration is: the FAT data cached in the sector buffer will be lost by file data transfer and it must be reloaded at every cluster boundary. However it will be suitable for most application from view point of the decent performance and low memory comsumption.

    Figure 1 shows that a partial sector, sector misaligned part of the file, is transferred via the file I/O buffer. At long data transfer shown in Figure 2, middle of transfer data that covers one or more sector is transferred to the application buffer directly. Figure 3 shows that the case of entier transfer data is aligned to the sector boundary. In this case, file I/O buffer is not used. On the direct transfer, the maximum extent of sectors are read with disk_read() function at a time but the multiple sector transfer is divided at cluster boundary even if it is contiguous.

    Therefore taking effort to sector aligned read/write accesss eliminates buffered data transfer and the read/write performance will be improved. Besides the effect, cached FAT data will not be flushed by file data transfer at the tiny configuration, so that it can achieve same performance as non-tiny configuration with small memory footprint.

    @@ -211,7 +211,7 @@ Figure 6. Comparison between Multiple/Single Sector Write

The write throughput of the flash memory media becomes the worst at single sector write transaction. The write throughput increases as the number of sectors per a write transaction. This effect more appers at faster interface speed and the performance ratio often becomes grater than ten. This graph is clearly explaining how fast is multiple block write (W:16K, 32 sectors) than single block write (W:100, 1 sector), and also larger card tends to be slow at single block write. The number of write transactions also affects the life time of the flash memory media. Therefore the application program should write the data in large block as possible. The ideal write chunk size and alighment is size of sector, and size of cluster is the best. Of course all layers between the application and the storage device must have consideration on multiple sector write, however most of open-source disk drivers lack it. Do not split a multiple sector write request into single sector write transactions or the write throughput gets poor. Note that FatFs module and its sample disk drivers supprt multiple sector read/write feature.

Forcing Memory Erase

-

When remove a file with f_remove() function, the data clusters occupied by the file are marked 'free' on the FAT. But the data sectors containing the file data are not that applied any process, so that the file data left occupies a part of the flash memory array as 'live block'. If the file data is forced erased on removing the file, those data blocks will be turned in to the free block pool. This may skip internal block erase operation to the data block on next write operation. As the result the write performance might be improved. FatFs can manage this feature by setting _USE_ERASE to 1. Note that this is an expectation of internal process of the flash memory storage and not that always effective. Also f_remove() function will take a time when remove a large file. Most applications will not need this feature.

+

When remove a file with f_remove() function, the data clusters occupied by the file are marked 'free' on the FAT. But the data sectors containing the file data are not that applied any process, so that the file data left occupies a part of the flash memory array as 'live block'. If the file data is forced erased on removing the file, those data blocks will be turned in to the free block pool. This may skip internal block erase operation to the data block on next write operation. As the result the write performance might be improved. FatFs can manage this feature by setting _USE_TRIM to 1. Note that this is an expectation of internal process of the flash memory storage and not that always effective. Also f_remove() function will take a time when remove a large file. Most applications will not need this feature.

@@ -267,7 +267,7 @@ Figure 5. Minimized critical section
/ * Redistributions of source code must retain the above copyright notice. / /-----------------------------------------------------------------------------/ -

Therefore FatFs license is one of the BSD-style licenses but there is a significant feature. Because FatFs is for embedded projects, the conditions of redistributions in binary form, such as embedded code, hex file, binary library or any forms without source code, are not specified in order to extend usability for commercial products. The documentation of the distributions need not include about FatFs and its license document, and it may also. This is equivalent to the BSD 1-Clause License. Of course FatFs is compatible with the projects under GNU GPL. When redistribute the FatFs with any modification or branch it as a folk, the license can also be changed to GNU GPL or BSD-style license.

+

Therefore FatFs license is one of the BSD-style licenses but there is a significant feature. Because FatFs is mainly intended for embedded projects, the redistributions in binary form, such as embedded code or any forms without source code, need not to explain about FatFs in order to extend usability for commercial products. The documentation of the distributions need not include about FatFs and its license documents, and it may also. This is equivalent to the BSD 1-Clause License. Of course FatFs is compatible with the projects under GNU GPL. When redistribute the FatFs with any modification or branch it as a fork, the license can also be changed to GNU GPL, BSD-style license or any free software licenses that not conflict with FatFs license.

Return

diff --git a/fatfs/doc/en/dinit.html b/fatfs/doc/en/dinit.html index c22df47..a85eecd 100644 --- a/fatfs/doc/en/dinit.html +++ b/fatfs/doc/en/dinit.html @@ -25,19 +25,19 @@ DSTATUS disk_initialize (

Parameter

pdrv
-
Physical drive number to identify the target device.
+
Physical drive number to identify the target device. Always zero at single drive system.

Return Values

-

This function returns a disk status as the result. For details of the disk status, refer to the disk_status() function.

+

This function returns the current drive status flags as the result. For details of the drive status, refer to the disk_status() function.

Description

-

This function initializes a storage device and put it ready to generic read/write data. When the function succeeded, STA_NOINIT flag in the return value is cleared.

+

This function initializes the storage device and put it ready to generic read/write. When the function succeeded, STA_NOINIT flag in the return value is cleared.

Application program MUST NOT call this function, or FAT structure on the volume can be broken. To re-initialize the file system, use f_mount() function instead. This function is called at volume mount process by FatFs module to manage the media change.

diff --git a/fatfs/doc/en/dioctl.html b/fatfs/doc/en/dioctl.html index 8cd30af..8fe62ec 100644 --- a/fatfs/doc/en/dioctl.html +++ b/fatfs/doc/en/dioctl.html @@ -57,19 +57,19 @@ DRESULT disk_ioctl ( - + - - - + + +
Standard ioctl command used by FatFs
CommandDescription
CTRL_SYNCMake sure that the device has finished pending write process. If the disk I/O module has a write back cache, the dirty buffers must be written back to the media immediately. Nothing to do for this command if each write operation to the media is completed within the disk_write() function. Required at _FS_READONLY == 0.
CTRL_SYNCMake sure that the device has finished pending write process. If the disk I/O module has a write back cache, the dirty buffers must be written back to the media immediately. Nothing to do for this command if each write operation to the media is completed within the disk_write() function.
GET_SECTOR_COUNTReturns number of available sectors on the drive into the DWORD variable pointed by buff. This command is used by only f_mkfs() and f_fdisk() function to determine the volume/partition size to be created. Required at _USE_MKFS == 1 or _MULTI_PARTITION == 1.
GET_SECTOR_SIZEReturns sector size of the media into the WORD variable pointed by buff. Valid return values of this command are 512, 1024, 2048 or 4096. This command is required at variable sector size configuration, _MAX_SS > _MIN_SS. Never used at fixed sector size configuration, _MAX_SS == _MIN_SS, and it must work at that sector size.
GET_BLOCK_SIZEReturns erase block size of the flash memory in unit of sector into the DWORD variable pointed by buff. The allowable value is from 1 to 32768 in power of 2. Return 1 if the erase block size is unknown or disk media. This command is used by only f_mkfs() function and it attempts to align data area to the erase block boundary. Required at _USE_MKFS == 1.
CTRL_ERASE_SECTORInforms device that the data on the block of sectors specified by a DWORD array {<start sector>, <end sector>} pointed by buff is no longer needed and may be erased. The device would force erased the memory block. This is a command similar to Trim command of ATA device. When this feature is not supported or not a flash memory media, nothing to do for this command. The FatFs does not check the result code and the file function is not affected even if the sectors ware not erased well. This command is called on removing a cluster chain and f_mkfs() function. Required at _USE_ERASE == 1.
GET_SECTOR_SIZEReturns sector size of the media into the WORD variable pointed by buff. Valid return values of this command are 512, 1024, 2048 and 4096. This command is required only at variable sector size configuration, _MAX_SS > _MIN_SS. At fixed sector size configuration, _MAX_SS == _MIN_SS, this command is not used and the device must work at that sector size.
GET_BLOCK_SIZEReturns erase block size of the flash memory media in unit of sector into the DWORD variable pointed by buff. The allowable value is from 1 to 32768 in power of 2. Return 1 if the erase block size is unknown or non flash memory media. This command is used by only f_mkfs() function and it attempts to align data area to the erase block boundary. Required at _USE_MKFS == 1.
CTRL_TRIMInforms the device the data on the block of sectors that specified by DWORD array {<start sector>, <end sector>} pointed by buff is no longer needed and it may be erased. This is an identical command to Trim of ATA device. When this feature is not supported or not a flash memory device, nothing to do for this command. The FatFs does not check the result code and the file function is not affected even if the sector block was not erased well. This command is called on removing a cluster chain and f_mkfs() function. Required at _USE_TRIM == 1.
-

FatFs never uses any device dependent command and user defined command. Following table shows an example of non-standard commands usable for some applications.

+

FatFs never uses any device dependent command nor user defined command. Following table shows an example of non-standard commands usable for some applications.

- + @@ -85,6 +85,13 @@ DRESULT disk_ioctl (
Example of optional ioctl command
CommandDescription
CTRL_FORMATCreate a physical format on the media. If buff is not null, it is pointer to the call-back function for progress notification.
CTRL_POWER_IDLEPut the device idle state. STA_NOINIT in status flag may not be set if the device would go active state by generic read/write function.
CTRL_POWER_IDLEPut the device idle state. STA_NOINIT in status flag may not be set if the device goes active state by generic read/write function.
CTRL_POWER_OFFPut the device off state. Shut-down the power to the device and deinitialize the device interface if needed. STA_NOINIT in status flag must be set. The device goes active state by disk_initialize() function.
CTRL_LOCKLock media eject mechanism.
CTRL_UNLOCKUnlock media eject mechanism.
+ +
+

QuickInfo

+

The disk_ioctl function is not needed when _FS_READONLY == 1 and _MAX_SS == _MIN_SS.

+
+ +

Return

diff --git a/fatfs/doc/en/dread.html b/fatfs/doc/en/dread.html index f81cf90..2e7c279 100644 --- a/fatfs/doc/en/dread.html +++ b/fatfs/doc/en/dread.html @@ -32,9 +32,9 @@ DRESULT disk_read (
buff
Pointer to the byte array to store the read data.
sector
-
Start sector number in logical block address (LBA).
+
Start sector number in 32-bit LBA.
count
-
Number of sectors to read. FatFs specifis it in range of from 1 to 128.
+
Number of sectors to read in range of from 1 to 128..
@@ -56,9 +56,10 @@ DRESULT disk_read (

Description

-

The memory address specified by buff is not that always aligned to word boundary because the type of argument is defined as BYTE*. The misaligned read/write request can occure at direct transfer. If the bus architecture, especially DMA controller, does not allow misaligned memory access, it should be solved in this function. There are some workarounds described below to avoid this issue.

+

The data read/write operation to the storage devices is done in unit of sector. FatFs supports the sector size in range of from 512 to 4096 bytes. When FatFs is configured to fixed sector size (_MIN_SS == MAX_SS, this will be the most case), the read/write function must work at that sector size. If variable sector size is selected (_MIN_SS < MAX_SS), FatFs inquires the sector size with disk_ioctl() after initialization. +

The memory address specified by buff is not that always aligned to word boundary because the argument is defined as BYTE*. The misaligned read/write request can occure at direct transfer. If the bus architecture, especially DMA controller, does not allow misaligned memory access, it should be solved in this function. There are some workarounds described below to avoid this issue.

diff --git a/fatfs/doc/en/dstat.html b/fatfs/doc/en/dstat.html index 5ae2775..c8204cc 100644 --- a/fatfs/doc/en/dstat.html +++ b/fatfs/doc/en/dstat.html @@ -13,7 +13,7 @@

disk_status

-

The disk_status function returns the current disk status.

+

The disk_status function returns the current drive status.

 DSTATUS disk_status (
   BYTE pdrv     /* [IN] Physical drive number */
@@ -25,21 +25,21 @@ DSTATUS disk_status (
 

Parameter

pdrv
-
Physical drive number to identify the target device.
+
Physical drive number to identify the target device. Always zero at single drive system.

Return Values

-

The disk status is returned in combination of following flags. FatFs refers only STA_NOINIT and STA_PROTECT.

+

The current drive status is returned in combination of status flags described below. FatFs refers only STA_NOINIT and STA_PROTECT.

STA_NOINIT
-
Indicates that the device is not initialized. This flag is set on system reset, media removal or failure of disk_initialize() function. It is cleared on disk_initialize() function succeeded. Media change that occurs asynchronously must be captured and reflect it to the status flags, or auto-mount feature will not work correctly. When media change detection feature is not supported, application program needs to de-initialize the file system object with f_mount() function after the media change.
+
Indicates that the device is not initialized. This flag is set on system reset, media removal or failure of disk_initialize() function. It is cleared on disk_initialize() function succeeded. Media change that occurs asynchronously must be captured and reflect it to the status flags, or auto-mount feature will not work correctly. If the system does not support media change detect feature, application program needs to force de-initialize the file system object with f_mount() function after the media change.
STA_NODISK
Indicates that no medium in the drive. This is always cleared on fixed disk drive. Note that FatFs does not refer this flag.
STA_PROTECT
-
Indicates that the medium is write protected. This is always cleared on the drives without write protect feature. Not valid while no medium in the drive.
+
Indicates that the medium is write protected. This is always cleared on the drives without write protect feature. Not valid if no medium in the drive.
diff --git a/fatfs/doc/en/dwrite.html b/fatfs/doc/en/dwrite.html index 67e3310..fd4bf48 100644 --- a/fatfs/doc/en/dwrite.html +++ b/fatfs/doc/en/dwrite.html @@ -32,9 +32,9 @@ DRESULT disk_write (
buff
Pointer to the byte array to be written. The size of data to be written is sector size * count bytes.
sector
-
Start sector number in logical block address (LBA).
+
Start sector number in 32-bit LBA.
count
-
Number of sectors to write. FatFs specifis it in range of from 1 to 128.
+
Number of sectors to write in range of from 1 to 128.
diff --git a/fatfs/doc/en/eof.html b/fatfs/doc/en/eof.html index 384c8d8..337697b 100644 --- a/fatfs/doc/en/eof.html +++ b/fatfs/doc/en/eof.html @@ -41,7 +41,7 @@ int f_eof (

Description

In this revision, this function is implemented as a macro.

-#define f_eof(fp) (((fp)->fptr) == ((fp)->fsize) ? 1 : 0)
+#define f_eof(fp) ((int)((fp)->fptr == (fp)->fsize))
 
diff --git a/fatfs/doc/en/error.html b/fatfs/doc/en/error.html index 7405d9e..a14deb1 100644 --- a/fatfs/doc/en/error.html +++ b/fatfs/doc/en/error.html @@ -41,7 +41,7 @@ int f_error (

Description

In this revision, this function is implemented as a macro.

-#define f_error(fp) (((fp)->flag & FA__ERROR) ? 1 : 0)
+#define f_error(fp) ((fp)->flag)
 
diff --git a/fatfs/doc/en/filename.html b/fatfs/doc/en/filename.html index 1209947..49dcc2d 100644 --- a/fatfs/doc/en/filename.html +++ b/fatfs/doc/en/filename.html @@ -17,9 +17,9 @@

The format of path name on the FatFs module is similer to the filename specs of DOS/Windos as follows:

"[drive:][/]directory/file"

The FatFs module supports long file name (LFN) and 8.3 format file name (SFN). The LFN can be used when LFN feature is enabled (_USE_LFN > 0). The sub directories are separated with a \ or / in the same way as DOS/Windows API. Duplicated separators are skipped and ignored. Only a difference is that the logical drive is specified in a numeral with a colon. When drive number is omitted, the drive number is assumed as default drive (drive 0 or current drive).

-

Control characters ('\0' to '\x1F') are recognized as end of the path name. Leading/embedded spaces in the path name are valid as a part of the name at LFN configuration but they are recognized as end of the path name at non-LFN configuration. Trailing spaces and dots are ignored.

+

Control characters ('\0' to '\x1F') are recognized as end of the path name. Leading/embedded spaces in the path name are valid as a part of the name at LFN configuration but the space is recognized as end of the path name at non-LFN configuration. Trailing spaces and dots are ignored at both configurations.

In default configuration (_FS_RPATH == 0), it does not have a concept of current directory like OS oriented file system. All objects on the volume are always specified in full path name that follows from the root directory. Dot directory names are not allowed. Heading separator is ignored and it can be exist or omitted. The default drive is fixed to drive 0.

-

When relative path feature is enabled (_FS_RPATH == 1), specified path is followed from the root directory if a heading separator is exist. If not, it is followed from the current directory of the drive set with f_chdir function. Dot names are also allowed for the path name. The default drive is the current drive set with f_chdrive function.

+

When relative path feature is enabled (_FS_RPATH == 1), specified path is followed from the root directory if a heading separator is exist. If not, it is followed from the current directory of the drive set by f_chdir function. Dot names are also allowed for the path name. The default drive is the current drive set by f_chdrive function.

@@ -35,13 +35,13 @@
Path name_FS_RPATH == 0_FS_RPATH == 1
file.txtA file in the root directory of the drive 0A file in the current directory of the current drive
dir1/..Invalid nameThe current directory
/..Invalid nameThe root directory (sticks the top level)
-

When option _STR_VOLUME_ID is specified, also pre-defined strings can be used as drive identifier in the path name instead of a numeral.

+

When option _STR_VOLUME_ID is specified, also pre-defined strings can be used as drive identifier in the path name instead of a numeral. e.g. "sd:file1.txt" or "ram:swapfile.dat".


Unicode API

-

The path names are input/output in either ANSI/OEM code (SBCS/DBCS) or Unicode depends on the configuration options. The type of arguments which specify the file names are defined as TCHAR. It is an alias of char in default. The code set used to the file name string is ANSI/OEM specifid by _CODE_PAGE. When _LFN_UNICODE is set to 1, the type of the TCHAR is switched to WCHAR to support Unicode (UTF-16 encoding). In this case, the LFN feature is fully supported and the Unicode specific characters, such as ✝☪✡☸☭, can also be used for the path name. It also affects data types and encoding of the string I/O functions. To define literal strings, _T(s) and _TEXT(s) macro are available to select either ANSI/OEM or Unicode automatically. The code shown below is an example to define the literal strings.

+

The path names are input/output in either ANSI/OEM code or Unicode depends on the configuration options. The type of arguments which specify the path names are defined as TCHAR. It is an alias of char by default. The code set used to the path name string is ANSI/OEM specifid by _CODE_PAGE. When _LFN_UNICODE is set to 1, the type of the TCHAR is switched to WCHAR to support Unicode (UTF-16 encoding). In this case, the LFN feature is fully supported and the Unicode specific characters, such as ✝☪✡☸☭, can also be used for the path name. It also affects data types and encoding of the string I/O functions. To define literal strings, _T(s) and _TEXT(s) macro are available to select either ANSI/OEM or Unicode automatically. The code shown below is an example to define the literal strings.

  f_open(fp, "filename.txt", FA_READ);      /* ANSI/OEM string */
  f_open(fp, L"filename.txt", FA_READ);     /* Unicode string */
@@ -64,13 +64,13 @@ PARTITION VolToPart[] = {
     {0, 3},     /* Logical drive 2 ==> Physical drive 0, 3rd partition */
     {1, 0}      /* Logical drive 3 ==> Physical drive 1 (auto detection) */
 };
-
-relationship between logical drive and physical drive
 
+
relationship between logical drive and physical drive

There are some considerations on using _MULTI_PARTITION configuration.

diff --git a/fatfs/doc/en/getcwd.html b/fatfs/doc/en/getcwd.html index df84287..045cce4 100644 --- a/fatfs/doc/en/getcwd.html +++ b/fatfs/doc/en/getcwd.html @@ -28,7 +28,7 @@ FRESULT f_getcwd (
buff
Pointer to the buffer to receive the current directory string.
len
-
Size of the buffer in unit of TCHAR.
+
Size of the buffer in unit of TCHAR.
diff --git a/fatfs/doc/en/mkfs.html b/fatfs/doc/en/mkfs.html index 573bdd7..5f733fa 100644 --- a/fatfs/doc/en/mkfs.html +++ b/fatfs/doc/en/mkfs.html @@ -31,7 +31,7 @@ FRESULT f_mkfs (
sfd
Specifies partitioning rule (FDISK(0) or SFD(1)). This argument will be ignored on some case.
au
-
Specifies size of the allocation unit (cluter) in unit of byte. The value must be sector size * n (n is 1 to 128 and power of 2). When a zero is given, the cluster size is determined depends on the volume size.
+
Specifies size of the allocation unit (cluter) in number of bytes or sectors. When the value is from 1 to 128, it specifies number of sectors. When the value is >= _MIN_SS, it specifies number of bytes. If any invalid value, zero or not power of 2, is given, the cluster size is automatically determined depends on the volume size.
@@ -51,11 +51,11 @@ FRESULT f_mkfs (

Description

-

The f_mkfs() function creates an FAT volume on the logical drive. When FDISK format is specified, a primary partition occupies the entire disk space is created and then an FAT volume is created on the partition. When SFD format is specified, the FAT volume starts from the first sector of the physical drive.

-

If the logical drive has been bound to any partition (1-4) by multiple partition feature (_MULTI_PARTITION), the FAT volume is created into the specified partition. In this case, the second argument sfd is ignored. The physical drive must have been partitioned with f_fdisk() function or any other partitioning tool prior to use this function.

-

Note that there are two partitioning rules, FDISK and SFD. The FDISK partitioning is usually used for harddisk, MMC, SDC, CFC and U Disk. It can divide a physical drive into one or more partitions with a partition table on the MBR. However Windows does not support multiple partition on the removable media. The SFD is non-partitioned method. The FAT volume starts from the first sector on the physical drive without partition table. It is usually used for floppy disk, Microdrive, optical disk and super-floppy media.

-

The FAT sub-type, FAT12/FAT16/FAT32, is determined by number of clusters on the volume and nothing else, according to the FAT specification issued by Microsoft. Thus which FAT sub-type is selected, is depends on the volume size and the specified cluster size. The cluster size affects performance of the file system and large cluster increases the performance.

-

When the number of clusters gets near the FAT sub-type boundaries, the function can fail with FR_MKFS_ABORTED.

+

The f_mkfs() function creates an FAT volume on the specified logical drive. When FDISK format is specified, a primary partition occupies entire space of the physical drive is created and then an FAT volume is created on the partition. When SFD format is specified, the FAT volume starts from the first sector of the physical drive.

+

If the logical drive is bound to the specific partition (1-4) by multiple partition feature (_MULTI_PARTITION), the FAT volume is created into the partition. In this case, the second argument sfd is ignored. The physical drive must have been partitioned with f_fdisk() function or any other partitioning tools prior to create the FAT volume with this function.

+

Note that there are two partitioning rules, FDISK and SFD. The FDISK partitioning is usually used for harddisk, MMC, SDC, CFC and U Disk. It can divide a physical drive into one or more partitions with a partition table on the MBR. However Windows does not support multiple partition on the removable disk. The SFD is non-partitioned method. The FAT volume starts from the first sector on the physical drive without partition table. It is usually used for floppy disk, Microdrive, optical disk and any type of super-floppy media.

+

The FAT sub-type, FAT12/FAT16/FAT32, is determined by number of clusters on the volume and nothing else, according to the FAT specification issued by Microsoft. Thus which FAT sub-type is selected, is depends on the volume size and the specified cluster size. The cluster size affects read/write throughput and space usage efficiency. Larger cluster size increases the read/write throughput and decreases the space usage efficiency of the volume.

+

In case of the number of clusters gets near the FAT sub-type boundaries, the function can fail with FR_MKFS_ABORTED.

@@ -63,6 +63,42 @@ FRESULT f_mkfs (

Available when _FS_READOLNY == 0 and _USE_MKFS == 1.

+
+

Example

+
+/* Format the default drive */
+int main (void)
+{
+    FATFS fs;      /* File system object (volume work area) */
+    FIL fil;       /* File object */
+    FRESULT res;   /* API result code */
+    UINT bw;       /* Bytes written */
+
+
+    /* Register work area */
+    f_mount(&fs, "", 0);
+
+    /* Create FAT volume with default cluster size */
+    res = f_mkfs("", 0, 0);
+    if (res) ...
+
+    /* Create a file as new */
+    res = f_open(&fil, "hello.txt", FA_CREATE_NEW | FA_WRITE);
+    if (res) ...
+
+    /* Write a message */
+    f_write(&fil, "Hello, World!\r\n", 15, &bw);
+    if (bw != 15) ...
+
+    /* Close the file */
+    f_close(&fil);
+
+    /* Unregister work area */
+    f_mount(0, "", 0);
+
+
+
+

See Also

Volume management, f_fdisk

diff --git a/fatfs/doc/en/mount.html b/fatfs/doc/en/mount.html index c4a00fc..0edb73a 100644 --- a/fatfs/doc/en/mount.html +++ b/fatfs/doc/en/mount.html @@ -62,7 +62,7 @@ FRESULT f_mount (
  • File system object is not initialized. It is cleared by f_mount().
  • Physical drive is not initialized. It is de-initialized by system reset or media removal.
  • -

    If the function with forced mount failed, it means that the file system object is registered but the volume is currently not available. Mount process will also be attempted in subsequent file access functions.

    +

    If the function with forced mount failed, it means that the file system object has been registered successfully but the volume is currently not ready to use. Mount process will also be attempted in subsequent file access functions.

    If implementation of the disk I/O layer lacks media change detection, application program needs to perform a f_mount() after each media change to force cleared the file system object.

    diff --git a/fatfs/doc/en/rc.html b/fatfs/doc/en/rc.html index c93479e..306671a 100644 --- a/fatfs/doc/en/rc.html +++ b/fatfs/doc/en/rc.html @@ -21,7 +21,7 @@
    FR_INT_ERR
    Assertion failed. An insanity is detected in the internal process. One of the following possibilities is suspected. Note that if once this error occured at any operation to an open file, the file object is aborted and all operations to the file except for close will be rejected. @@ -51,7 +51,7 @@ Note that if once this error occured at any operation to an open file, the file
    FR_INVALID_OBJECT
    The file/directory object structure is invalid or a null pointer is given. All open objects of the logical drive are invalidated by the voulme mount process.
    FR_WRITE_PROTECTED
    -
    Any write mode action against the write-protected media.
    +
    Any write mode operation against the write-protected media.
    FR_INVALID_DRIVE
    Invalid drive number is specified in the path name. A null pointer is given as the path name. (Related option: _VOLUMES)
    FR_NOT_ENABLED
    @@ -74,7 +74,7 @@ Note that if once this error occured at any operation to an open file, the file
    Not enough memory for the operation. There is one of the following reasons:
    FR_TOO_MANY_OPEN_FILES
    diff --git a/fatfs/doc/en/readdir.html b/fatfs/doc/en/readdir.html index 9808435..bf83ebe 100644 --- a/fatfs/doc/en/readdir.html +++ b/fatfs/doc/en/readdir.html @@ -77,7 +77,7 @@ FRESULT scan_files ( FILINFO fno; DIR dir; int i; - char *fn; /* This function is assuming non-Unicode cfg. */ + char *fn; /* This function assumes non-Unicode configuration */ #if _USE_LFN static char lfn[_MAX_LFN + 1]; /* Buffer to store the LFN */ fno.lfname = lfn; @@ -100,8 +100,8 @@ FRESULT scan_files ( if (fno.fattrib & AM_DIR) { /* It is a directory */ sprintf(&path[i], "/%s", fn); res = scan_files(path); - if (res != FR_OK) break; path[i] = 0; + if (res != FR_OK) break; } else { /* It is a file. */ printf("%s/%s\n", path, fn); } diff --git a/fatfs/doc/en/sfile.html b/fatfs/doc/en/sfile.html index e6edf70..1ed9899 100644 --- a/fatfs/doc/en/sfile.html +++ b/fatfs/doc/en/sfile.html @@ -13,7 +13,7 @@

    FIL

    -

    The FIL structure (file object) holds state of an open file. It is created by f_open() function and discarded by f_close() function. Application program must not modify any member in this structure except for cltbl. Note that a sector buffer is defined in this structure at non-tiny configuration, so that the FIL structures should not be defined as auto variable.

    +

    The FIL structure (file object) holds the state of an open file. It is created by f_open() function and discarded by f_close() function. Application program must not modify any member in this structure except for cltbl. Note that a sector buffer is defined in this structure at non-tiny configuration (_FS_TINY == 0), so that the FIL structures at that configuration should not be defined as auto variable.

     typedef struct {
    diff --git a/fatfs/doc/en/sfileinfo.html b/fatfs/doc/en/sfileinfo.html
    index 5674086..ac254a1 100644
    --- a/fatfs/doc/en/sfileinfo.html
    +++ b/fatfs/doc/en/sfileinfo.html
    @@ -60,9 +60,9 @@
     
    fname[]
    Indicates the file/directory name in 8.3 format null-terminated string. It is always returnd with upper case in non-LFN configuration but it can be returned with lower case in LFN configuration.
    lfname
    -
    Pointer to the LFN buffer to store the read LFN. This member must be initialized by application prior to use this structure. Set null pointer if LFN is not needed. Not available in non-LFN configuration.
    +
    Pointer to the LFN buffer to store the read LFN. This member must be initialized by application program prior to use this structure. Set a null pointer if LFN is not needed. Not available at non-LFN configuration.
    lfsize
    -
    Size of the LFN buffer in unit of TCHAR. This member must be initialized by application prior to use this structure. Not available in non-LFN configuration.
    +
    Size of the LFN buffer in unit of TCHAR. This member must be initialized by application program prior to use this structure. Not available at non-LFN configuration.

    Return

    diff --git a/fatfs/doc/en/stat.html b/fatfs/doc/en/stat.html index 8ea343b..db53c5d 100644 --- a/fatfs/doc/en/stat.html +++ b/fatfs/doc/en/stat.html @@ -55,6 +55,7 @@ FRESULT f_stat (

    Description

    The f_stat() function checks the existence of a file or sub-directory. If not exist, the function returns with FR_NO_FILE. If exist, the function returns with FR_OK and the informations of the object, file size, timestamp, attribute and SFN, are stored to the file information structure. For details of the file information, refer to the FILINFO structure and f_readdir() function.

    +

    When LFN feature is enabled, lfname in the file information structure must be NULLed prior to use it.

    @@ -64,6 +65,45 @@ FRESULT f_stat (
    +
    +

    Example

    +
    +    FRESULT fr;
    +    FILINFO fno;
    +
    +
    +    printf("Test for 'file.txt'...\n");
    +
    +#if _USE_LFN
    +    fno.lfname = 0;
    +#endif
    +    fr = f_stat("file.txt", &fno);
    +    switch (fr) {
    +
    +    case FR_OK:
    +        printf("Size: %u\n", fno.fsize);
    +        printf("Timestamp: %u/%02u/%02u, %02u:%02u\n",
    +               (fno.fdate >> 9) + 1980, fno.fdate >> 5 & 15, fno.fdate & 31,
    +               fno.ftime >> 11, fno.ftime >> 5 & 63);
    +        printf("Attributes: %c%c%c%c%c\n",
    +               (fno.fattrib & AM_DIR) ? 'D' : '-',
    +               (fno.fattrib & AM_RDO) ? 'R' : '-',
    +               (fno.fattrib & AM_HID) ? 'H' : '-',
    +               (fno.fattrib & AM_SYS) ? 'S' : '-',
    +               (fno.fattrib & AM_ARC) ? 'A' : '-');
    +        break;
    +
    +    case FR_NO_FILE:
    +        printf("It is not exist.\n");
    +        break;
    +
    +    default:
    +        printf("An error occured. (%d)\n", fr);
    +    }
    +
    +
    + +

    References

    f_opendir, f_readdir, FILINFO

    diff --git a/fatfs/doc/img/app3.c b/fatfs/doc/img/app3.c index 736c15a..662c403 100644 --- a/fatfs/doc/img/app3.c +++ b/fatfs/doc/img/app3.c @@ -6,7 +6,7 @@ / If the file has been opened without FA_WRITE flag, it only checks if / the file is contiguous and returns the resulut. */ -#if _FATFS != 8051 /* Check if R0.10b */ +#if _FATFS != 80367 /* Check if R0.10c */ #error This function may not be compatible with this revision of FatFs module. #endif diff --git a/fatfs/doc/img/mkfatimg.zip b/fatfs/doc/img/mkfatimg.zip new file mode 100644 index 0000000000000000000000000000000000000000..d0728b4ead1a7111d8dd79f8a3c2bf5313fb5e25 GIT binary patch literal 686662 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

    )KQp~F0gGis<$(#oI9rPuLxMMqF{5Hqs9p^O6S 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

    6$x2d1*q%N=?PXBrl0QVU`@FccTB>8RA@2 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 z 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

    q^AhHgQd<~h%tfM^4|Uc8 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 literal 0 HcmV?d00001 diff --git a/fatfs/doc/ja/appnote.html b/fatfs/doc/ja/appnote.html index 0fb5579..4985bae 100644 --- a/fatfs/doc/ja/appnote.html +++ b/fatfs/doc/ja/appnote.html @@ -6,24 +6,24 @@ -FatFsモジュール アプリケーション・ノート +FatFsモジュール アプリケーション ノート -

    FatFsモジュール アプリケーション・ノート

    +

    FatFsモジュール アプリケーション ノート

    1. ポーティングの際に配慮すべきこと
    2. 限界値
    3. メモリ使用量
    4. -
    5. モジュール・サイズの縮小
    6. +
    7. モジュール サイズの縮小
    8. 長いファイル名
    9. 日本語ファイル名の大文字変換
    10. Unicode入出力への対応
    11. リエントランシー
    12. -
    13. 多重ファイル・アクセス
    14. -
    15. 効率的なファイル・アクセス
    16. -
    17. フラッシュ・メモリの特性への配慮
    18. -
    19. クリチカル・セクション
    20. +
    21. 多重ファイル アクセス
    22. +
    23. 効率的なファイル アクセス
    24. +
    25. フラッシュ メモリの特性への配慮
    26. +
    27. クリチカル セクション
    28. APIの拡張的使用例
    29. FatFsのライセンスについて
    @@ -44,18 +44,18 @@ FatFsモジュールはANSI C(C89)準拠で記述されているので、普通

    システム構成

    下に示す依存関係図は、FatFsモジュール利用の組み込みシステムにおける代表的な構成を示します。

    システム構成図

    -

    (a) FatFs用に書かれたディスク・モジュールがある場合は、そのまま追加するだけです。 (b) しかし、多くの既存のディスク・モジュールはそのAPIをFatFsに合わせるため、グルー関数が必要になるでしょう。

    +

    (a) FatFs用に書かれたディスク モジュールがある場合は、そのまま追加するだけです。 (b) しかし、多くの既存のディスク モジュールはそのAPIをFatFsに合わせるため、グルー関数が必要になるでしょう。

    functional diagram

    ユーザの作成する関数

    -

    必要なのはFatFsモジュールの要求するディスク関数を用意することだけで、それ以外にすることはありません。既に動作しているディスク・モジュールがあるなら、そのAPIをFatFsに合わせるかグルー関数を介してつなぐだけで済みますが、無い場合はほかから移植するか最初から書くかする必要があります。定義されている全ての関数が常に必要なわけではありません。例えば、リード・オンリー構成では書き込み系関数は必要ありません。次の表に構成オプションと要求される関数の対応を示します。

    +

    必要なのはFatFsモジュールの要求するディスク関数を用意することだけで、それ以外にすることはありません。既に動作しているディスク モジュールがあるなら、そのAPIをFatFsに合わせるかグルー関数を介してつなぐだけで済みますが、無い場合はほかから移植するか最初から書くかする必要があります。定義されている全ての関数が常に必要なわけではありません。例えば、リード オンリー構成では書き込み系関数は必要ありません。次の表に構成オプションと要求される関数の対応を示します。

    - + @@ -66,18 +66,18 @@ FatFsモジュールはANSI C(C89)準拠で記述されているので、普通

    限界値

    • FATタイプ: FAT12, FAT16, FAT32。
    • -
    • 同時オープン・ファイル数: 無制限。(利用可能メモリによる)
    • +
    • 同時オープン ファイル数: 無制限。(利用可能メモリによる)
    • ボリューム数: 最大 10。
    • -
    • ファイル・サイズ: FAT規格に依存。(最大 4G-1バイト)
    • -
    • ボリューム・サイズ: FAT規格に依存。(最大 2Tバイト(512バイト/セクタ時))
    • -
    • クラスタ・サイズ: FAT規格に依存。(最大 64Kバイト(512バイト/セクタ時))
    • -
    • セクタ・サイズ: FAT規格に依存。(512~4096バイト)
    • +
    • ファイル サイズ: FAT規格に依存。(最大 4G-1バイト)
    • +
    • ボリューム サイズ: FAT規格に依存。(最大 2Tバイト(512バイト/セクタ時))
    • +
    • クラスタ サイズ: FAT規格に依存。(最大 64Kバイト(512バイト/セクタ時))
    • +
    • セクタ サイズ: FAT規格に依存。(512~4096バイト)

    メモリ使用量

    -

    次の表にいくつかのターゲットにおけるメモリ使用量の例を示します。テスト時の構成オプションはその下の通りです。数値の単位はバイトで、Vはボリューム数、Fは同時オープン・ファイル数を示します。コンパイラの最適化オプションはコード・サイズとしています。

    +

    次の表にいくつかのターゲットにおけるメモリ使用量の例を示します。テスト時の構成オプションはその下の通りです。数値の単位はバイトで、Vはボリューム数、Fは同時オープン ファイル数を示します。コンパイラの最適化オプションはコード サイズとしています。

    必要な関数必要となる条件備考
    disk_status
    disk_initialize
    disk_read
    常時ffsample.zip (サンプル)
    その他web上に多数
    disk_write
    get_fattime
    disk_ioctl (CTRL_SYNC)
    _FS_READONLY == 0
    disk_ioctl (GET_SECTOR_COUNT)
    disk_ioctl (GET_BLOCK_SIZE)
    _USE_MKFS == 1
    disk_ioctl (GET_SECTOR_SIZE)_MAX_SS != _MIN_SS
    disk_ioctl (CTRL_ERASE_SECTOR)_USE_ERASE == 1
    disk_ioctl (CTRL_TRIM)_USE_TRIM == 1
    ff_convert
    ff_wtoupper
    _USE_LFN >= 1option/unicode.c
    ff_cre_syncobj
    ff_rel_grant
    ff_req_grant
    ff_del_syncobj
    _FS_REENTRANT == 1option/syscall.c (サンプル)
    ff_mem_alloc
    ff_mem_free
    _USE_LFN == 3
    @@ -99,7 +99,7 @@ _USE_STRFUNC 0 (Disable string functions) _USE_MKFS 0 (Disable f_mkfs function) _USE_FORWARD 0 (Disable f_forward function) _USE_FASTSEEK 0 (Disable fast seek feature) -_CODE_PAGE 932 (Japanese Shift-JIS) +_CODE_PAGE 932 (Japanese Shift_JIS) _USE_LFN 0 (Disable LFN feature) _MAX_SS 512 (Fixed sector size) _FS_RPATH 0 (Disable relative path feature) @@ -112,7 +112,7 @@ _FS_LOCK 0 (Disable file lock control)
    -

    モジュール・サイズの縮小

    +

    モジュール サイズの縮小

    次の表は構成オプションの設定値によりどの機能が削除されるかを示します。

    ARM7
    32bit
    ARM7
    Thumb
    CM3
    Thumb-2
    AVRH8/300HPIC24RL78V850ESSH-2ARX600IA-32
    CompilerGCCGCCGCCGCCCH38C30CC78K0RCA850SHCRXCVC6
    @@ -152,19 +152,19 @@ _FS_LOCK 0 (Disable file lock control)

    長いファイル名

    -

    FatFsモジュールは、長いファイル名(LFN)をサポートします。ファイルに付けられた2つの異なる名前(短いファル名と長いファイル名)は、f_readdir()を除くファイル操作関数において透過です。デフォルト構成では、LFN機能はOFFになっています。LFN機能を有効にするには、_USE_LFNを1,2または3に設定し、option/unicode.cをプロジェクトに追加します。LFN機能は、加えてある程度のワーク・エリア(LFN操作バッファ)を必要とします。バッファ長は使用できるメモリに応じて_MAX_LFNオプションで構成されることができます。LFNの長さは最大255文字に達するので、LFN完全対応のためには_MAX_LFNは255に設定されるべきです。与えられたファイル名に対してバッファ長が不足した場合、ファイル関数はFR_INVALID_NAMEで失敗します。

    -

    ファイル関数に再入を行う条件の下でLFN機能を使用する場合は、_USE_LFNは2または3に設定されなければなりません。この場合、ファイル関数はワーク・エリアを動的に確保(スタックまたはヒープ)します。バッファ・サイズは、(_MAX_LFN + 1) * 2バイトになるので、スタック等のサイズはそれを考慮した十分なサイズでなければなりません。

    +

    FatFsモジュールは、長いファイル名(LFN)をサポートします。ファイルに付けられた2つの異なる名前(短いファル名と長いファイル名)は、f_readdir()を除くファイル操作関数において透過です。デフォルト構成では、LFN機能はOFFになっています。LFN機能を有効にするには、_USE_LFNを1,2または3に設定し、option/unicode.cをプロジェクトに追加します。LFN機能は、加えてある程度のワーク エリア(LFN操作バッファ)を必要とします。バッファ長は使用できるメモリに応じて_MAX_LFNオプションで構成されることができます。LFNの長さは最大255文字に達するので、LFN完全対応のためには_MAX_LFNは255に設定されるべきです。与えられたファイル名に対してバッファ長が不足した場合、ファイル関数はFR_INVALID_NAMEで失敗します。

    +

    ファイル関数に再入を行う条件の下でLFN機能を使用する場合は、_USE_LFNは2または3に設定されなければなりません。この場合、ファイル関数はワーク エリアを動的に確保(スタックまたはヒープ)します。バッファ サイズは、(_MAX_LFN + 1) * 2バイトになるので、スタック等のサイズはそれを考慮した十分なサイズでなければなりません。

    Function_FS_MINIMIZE_FS_READONLY_USE_STRFUNC_FS_RPATH_FS_LABEL_USE_MKFS_USE_FORWARD_MULTI_PARTITION
    - +
    LFN cfg on ARM7
    コードページコードサイズ[bytes]
    SBCS+3721
    932(Shift-JIS)+62609
    932(Shift_JIS)+62609
    936(GBK)+177797
    949(Korean)+139857
    950(Big5)+111497
    -

    LFN機能の上手な使い方は、それを使わないということです。実際、組み込み用途ではLFN機能がどうしても必要になるということはほとんど無いはずです。LFNを有効にすると、選択されたコード・ページに応じてモジュール・サイズが増大されます。右の表に各コード・ページにおけるLFNを有効にしたときのモジュール・サイズの違いを示します。特に、CJK地域では数万の文字が使われていますが、不幸なことにそれは巨大なOEM-Unicode相互変換テーブルを要求し、モジュール・サイズは劇的に増大されます。その結果、それらのコード・ページにおいてLFNを有効にしたFatFsモジュールは、AVRを含む殆どの8ビット・マイコンにインプリメントされることができません。

    -

    LFN機能のハードルはそれだけではありません。マイクロソフト社はFATファイル・システムについていくつかの特許を保有しています。いずれもLFN機能の実装に関するもので、その利用に対して$0.25/unitのライセンス料を要求しています。このため、商用製品でLFN機能を利用するときは、最終仕向地によってはライセンスが必要になります。最近のFAT32ドライバの多くはLFN機能を含んでいるため、それらの使用に当たってライセンスが必要になりますが、FatFsではLFN機能を構成オプションで任意にON/OFFできるため、無効にしてライセンス問題を回避することもできます。

    +

    LFN機能の上手な使い方は、それを使わないということです。実際、組み込み用途ではLFN機能がどうしても必要になるということはほとんど無いはずです。LFNを有効にすると、選択されたコード ページに応じてモジュール サイズが増大します。右の表に各コード ページにおけるLFNを有効にしたときのモジュール サイズの違いを示します。特に、CJK地域では数万の文字が使われていますが、不幸なことにそれは巨大なOEM-Unicode相互変換テーブルを要求し、モジュール サイズは劇的に増大します。その結果、それらのコード ページにおいてLFNを有効にしたFatFsモジュールは、多くの8ビット マイコンにインプリメントすることができません。

    +

    LFN機能のハードルはそれだけではありません。マイクロソフト社はFATファイル システムについていくつかの特許を保有しています。いずれもLFN機能の実装に関するもので、その利用に対して$0.25/unitのライセンス料を要求しています。このため、商用製品でLFN機能を利用するときは、最終仕向地によってはライセンスが必要になります。最近のFAT32ドライバの多くはLFN機能を含んでいるため、それらの使用に当たってライセンスが必要になりますが、FatFsではLFN機能を構成オプションで任意にON/OFFできるため、無効にしてライセンス問題を回避することもできます。

    @@ -179,61 +179,61 @@ _FS_LOCK 0 (Disable file lock control)

    リエントランシー

    -

    互いに異なるボリュームに対するファイル操作はリエントラントで、常に同時平行に動作できます。同じボリュームに対してはデフォルトではリエントラントではありませんが、_FS_REENTRANTオプションでリエントラント(スレッド・セーフ)にすることはできます。この場合、OS依存の同期オブジェクト操作関数ff_cre_syncobj(), ff_del_syncobj(), ff_req_grant(), ff_rel_grant()もまたプロジェクトに追加されなければなりません。サンプル・コードと解説はoption/syncobj.cにあります。

    +

    互いに異なるボリュームに対するファイル操作はリエントラントで、常に同時平行に動作できます。同じボリュームに対してはデフォルトではリエントラントではありませんが、_FS_REENTRANTオプションでリエントラント(スレッド セーフ)にすることはできます。この場合、OS依存の同期オブジェクト操作関数ff_cre_syncobj(), ff_del_syncobj(), ff_req_grant(), ff_rel_grant()もまたプロジェクトに追加されなければなりません。サンプル コードと解説はoption/syncobj.cにあります。

    この場合、あるタスクがボリュームを使用中に他のタスクからそのボリュームに対するファイル関数が呼び出されると、そのアクセスは先のタスクがファイル関数を抜けるまでブロックされます。もし、待ち時間が_TIMEOUTで指定された期間を越すと、その関数はFR_TIMEOUTでアボートします。いくつかのRTOSではタイムアウト機能はサポートされないかも知れません。

    -

    ひとつの例外がf_mount(), f_mkfs(), f_fdisk()にあります。これらの関数は同じボリューム(または関連する物理ドライブ)に対してリエントラントではありません。これらの関数を使用するときは、アプリケーション・レベルで排他制御しなければなりません。

    +

    ひとつの例外がf_mount(), f_mkfs(), f_fdisk()にあります。これらの関数は同じボリューム(または関連する物理ドライブ)に対してリエントラントではありません。これらの関数を使用するときは、アプリケーション レベルで排他制御しなければなりません。

    注: このセクションはFatFsモジュールそれ自体のリエントランシーについて説明しています。その下位のディスクI/Oモジュールのリエントランシーに関しては何の前提もありません。

    -

    多重ファイル・アクセス

    -

    FatFsモジュールではデフォルトでは多重アクセス制御機能をサポートしていません。ファイルに対する多重アクセスは、そのアクセス・モードによって制限されます。一つのファイルに対する多重オープンは、それらが全てリード・モードのときに限って許可されます。書き込みモードを含む多重オープン、また開かれているファイルに対するリネームや削除を行ってはなりません。さもないと、そのボリュームのFAT構造が破壊される可能性があります。

    -

    _FS_LOCKに1以上の値(値は同時に管理できるファイル数)をセットすることで多重アクセス制御機能が有効になり、ファイル単位のアクセス制御を自動で行うこともできます。この場合、上記のルールを破ったオープン・リネーム・削除を試みると、その関数はFR_LOCKEDで失敗します。また、_FS_LOCKを越える数のファイルやサブ・ディレクトリを同時にオープンしようとすると、FR_TOO_MANY_OPEN_FILESで失敗します。

    +

    多重ファイル アクセス

    +

    FatFsモジュールではデフォルトでは多重アクセス制御機能をサポートしていません。ファイルに対する多重アクセスは、そのアクセス モードによって制限されます。一つのファイルに対する多重オープンは、それらが全てリード モードのときに限って許可されます。書き込みモードを含む多重オープン、また開かれているファイルに対するリネームや削除を行ってはなりません。さもないと、そのボリュームのFAT構造が破壊される可能性があります。

    +

    _FS_LOCKに1以上の値(値は同時に管理できるファイル数)をセットすることで多重アクセス制御機能が有効になり、ファイル単位のアクセス制御を自動で行うこともできます。この場合、上記のルールを破ったオープン・リネーム・削除を試みると、その関数はFR_LOCKEDで失敗します。また、_FS_LOCKを越える数のファイルやサブ ディレクトリを同時にオープンしようとすると、FR_TOO_MANY_OPEN_FILESで失敗します。

    -

    効率的なファイル・アクセス

    -

    小規模な組込システムでのファイルの読み書きにおける効率の良いアクセスのため、アプリケーション・プログラマはFatFsモジュールの中でどのような処理が行われているか考慮すべきです。ストレージ上のデータはf_read()により次のシーケンスで転送されます。

    -

    図1. セクタ・ミスアラインド・リード (ショート)
    +

    効率的なファイル アクセス

    +

    小規模な組込システムでのファイルの読み書きにおける効率の良いアクセスのため、アプリケーション プログラマはFatFsモジュールの中でどのような処理が行われているか考慮すべきです。ストレージ上のデータはf_read()により次のシーケンスで転送されます。

    +

    図1. セクタ ミスアラインド リード (ショート)
    fig.1

    -

    図2. セクタ・ミスアラインド・リード (ロング)
    +

    図2. セクタ ミスアラインド リード (ロング)
    fig.2

    -

    図3. セクタ・アラインド・リード
    +

    図3. セクタ アラインド リード
    fig.3

    -

    ファイルI/Oバッファはセクタの一部のデータを読み書きするためのセクタ・バッファを意味します。セクタ・バッファは、それぞれのファイル・オブジェクト内のプライベート・セクタ・バッファまたはファイル・システム・オブジェクト内の共有セクタ・バッファのどちらかです。バッファ構成オプションの_FS_TINYは、データ転送にどちらを使うかを決定します。タイニー・バッファ(1)が選択されるとデータ・メモリの消費はそれぞれのファイル・オブジェクトで512バイト減少されます。この場合、FatFsモジュールはファイル・データの転送とFAT/ディレクトリ・アクセスにファイル・システム・オブジェクト内のセクタ・バッファだけを使用します。タイニー・バッファの欠点は、セクタ・バッファにキャッシュされたFATデータがファイル・データの転送により失われ、クラスタ境界の毎にリロードされなければならないことです。でも、悪くない性能と少ないメモリ消費の視点から多くのアプリケーションに適するでしょう。

    -

    図1はセクタの一部のデータがファイルI/Oバッファを経由で転送されることを示します。図2に示される長いデータの転送では、転送データの中間の1セクタまたはそれ以上のセクタにまたがる転送データがアプリケーション・バッファに直接転送されています。図3は転送データ全体がセクタ境界にアライメントされている場合を示しています。この場合、ファイルI/Oバッファは使用されません。直接転送においては最大の範囲のセクタがdisk_read()で一度に読み込まれますが、クラスタ境界を越えるマルチ・セクタ転送はそれが隣接であっても行われません。

    -

    このように、セクタにアライメントしたファイルの読み書きへの配慮はバッファ経由のデータ転送を避け、読み書き性能は改善されるでしょう。その効果に加え、タイニー構成でキャッシュされたFATデータがファイル・データの転送によりフラッシュされず、非タイニー構成と同じ性能を小さなメモリ・フットプリントで達成できます。

    +

    ファイルI/Oバッファはセクタの一部のデータを読み書きするためのセクタ バッファを意味します。セクタ バッファは、それぞれのファイル オブジェクト内のプライベート セクタ バッファまたはファイル システム オブジェクト内の共有セクタ バッファのどちらかです。バッファ構成オプションの_FS_TINYは、データ転送にどちらを使うかを決定します。タイニー バッファ(1)が選択されるとデータ メモリの消費はそれぞれのファイル オブジェクトで_MAX_SSバイト減少されます。この場合、FatFsモジュールはファイル データの転送とFAT/ディレクトリ アクセスにファイル システム オブジェクト内のセクタ バッファだけを使用します。タイニー バッファの欠点は、セクタ バッファにキャッシュされたFATデータがファイル データの転送により失われ、クラスタ境界の毎にリロードされなければならないことです。でも、悪くない性能と少ないメモリ消費の視点から多くのアプリケーションに適するでしょう。

    +

    図1はセクタの一部のデータがファイルI/Oバッファを経由で転送されることを示します。図2に示される長いデータの転送では、転送データの中間の1セクタまたはそれ以上のセクタにまたがる転送データがアプリケーション バッファに直接転送されています。図3は転送データ全体がセクタ境界にアライメントされている場合を示しています。この場合、ファイルI/Oバッファは使用されません。直接転送においては最大の範囲のセクタがdisk_read()で一度に読み込まれますが、クラスタ境界を越えるマルチ セクタ転送はそれが隣接であっても行われません。

    +

    このように、セクタにアライメントしたファイルの読み書きへの配慮はバッファ経由のデータ転送を避け、読み書き性能は改善されるでしょう。その効果に加え、タイニー構成でキャッシュされたFATデータがファイル データの転送によりフラッシュされず、非タイニー構成と同じ性能を小さなメモリ フットプリントで達成できます。

    -

    フラッシュ・メモリの特性への配慮

    -

    HDDなどのディスク・メディアとは異なり、SDCやCFCなどのフラッシュ・メモリ・メディアの性能を引き出すには、その特性を意識した制御が必要になります。

    -

    マルチ・セクタ書き込み

    +

    フラッシュ メモリの特性への配慮

    +

    HDDなどのディスク メディアとは異なり、SDCやCFCなどのフラッシュ メモリ メディアの性能を引き出すには、その特性を意識した制御が必要になります。

    +

    マルチ セクタ書き込み

    -図6. マルチ/シングル・セクタ・ライトの比較
    +図6. マルチ/シングル セクタ ライトの比較
    fig.6
    -

    フラッシュ・メモリ・メディアの書き込み速度はシングル・セクタ書き込みの時に最も低いものになり、一回のトランザクションで転送されるセクタ数が大きくなるほど書き込み速度は向上します。この効果はバス速度が高速になるほど顕著で、10倍以上の差が現れることも珍しくありません。テスト結果は、マルチ・セクタ書き込み(W:16K, 32 sectors)がシングル・セクタ書き込み(W:100, 1 sector)よりどの程度速いかを明確に示しています。大容量メディアほどシングル・セクタ書き込みが遅くなる点もまた重要です。書き込みトランザクションの回数はまた、メディアの寿命にも影響してきます。このため、アプリケーションはなるべく大きなブロック(クラスタ・サイズまたは2の累乗セクタ境界にアライメントした)で読み書きを行う必要があります。もちろん、アプリケーションからメディアに至る全てのレイヤがマルチ・セクタ転送に対応していないと意味がありません。残念ながら、既存のオープン・ソースのドライバの多くはマルチ・セクタ転送に未対応です。なお、FatFsモジュールおよびサンプル・ドライバはマルチ・セクタ転送に対応しています。

    +

    フラッシュ メモリ メディアの書き込み速度はシングル セクタ書き込みの時に最も低いものになり、一回のトランザクションで転送されるセクタ数が大きくなるほど書き込み速度は向上します。この効果はバス速度が高速になるほど顕著で、10倍以上の差が現れることも珍しくありません。テスト結果は、マルチ セクタ書き込み(W:16K, 32 sectors)がシングル セクタ書き込み(W:100, 1 sector)よりどの程度速いかを明確に示しています。大容量メディアほどシングル セクタ書き込みが遅くなる点もまた重要です。書き込みトランザクションの回数はまた、メディアの寿命にも影響してきます。このため、アプリケーションはなるべく大きなブロック(クラスタ サイズまたは2の累乗セクタ境界にアライメントした)で読み書きを行う必要があります。もちろん、アプリケーションからメディアに至る全てのレイヤがマルチ セクタ転送に対応していないと意味がありません。残念ながら、既存のオープン ソースのドライバの多くはマルチ セクタ転送に未対応です。なお、FatFsモジュールおよびサンプル ドライバはマルチ セクタ転送に対応しています。

    明示的なメモリ消去

    -

    通常のファイル消去では、記録されたデータに対して何らかの制御が行われるわけではなく、単にFAT上に未使用クラスタとして記録されているだけです。このため、ファイルが消去されたあともそれらは有効なメモリ・ブロックとしてフラッシュ・メモリ上に残ります。そこで、ファイルを消去するとき、占有していたデータ・セクタを明示的に消去(つまり未使用ブロックにする)することにより、メディア内の空きブロックを増やすことができます。これにより、次にそのブロックに書き込むときの消去動作が無くなり、書き込み性能が向上する可能性があります。また、ウェアレベリングに使えるブロックが増え、メディアの耐久性も向上するかも知れません。この機能を有効にするには、構成オプションの_USE_ERASEに1を設定します。これはフラッシュ・メモリ・メディアの内部動作に期待した制御なので、効果があるとは限りません。また、ファイル消去の時間が延びることも考慮に入れるべきです。

    +

    通常のファイル消去では、記録されたデータに対して何らかの制御が行われるわけではなく、単にFAT上に未使用クラスタとして記録されているだけです。このため、ファイルが消去されたあともそれらは有効なメモリ ブロックとしてフラッシュ メモリ上に残ります。そこで、ファイルを消去するとき、占有していたデータ セクタを明示的に消去(つまり未使用ブロックにする)することにより、メディア内の空きブロックを増やすことができます。これにより、次にそのブロックに書き込むときの消去動作が無くなり、書き込み性能が向上する可能性があります。また、ウェアレベリングに使えるブロックが増え、メディアの耐久性も向上するかも知れません。この機能を有効にするには、構成オプションの_USE_TRIMに1を設定します。これはフラッシュ メモリ メディアの内部動作に期待した制御なので、効果があるとは限りません。また、ファイル消去の時間が延びることも考慮に入れるべきです。

    -

    クリチカル・セクション

    -

    ストレージ上のFAT構造を操作している途中で、停電、不正なメディアの取り外し、回復不能なデータ・エラー等の障害が発生すると、処理が中途半端な状態で中断され、その結果としてFATボリュームの構造が破壊される可能性があります。次にFatFsモジュールにおけるクリチカル・セクションと、その間の障害により起きうるエラーの状態を示します。

    +

    クリチカル セクション

    +

    ストレージ上のFAT構造を操作している途中で、停電、不正なメディアの取り外し、回復不能なデータ エラー等の障害が発生すると、処理が中途半端な状態で中断され、その結果としてFATボリュームの構造が破壊される可能性があります。次にFatFsモジュールにおけるクリチカル セクションと、その間の障害により起きうるエラーの状態を示します。

    -図4. 長いクリチカル・セクション
    +図4. 長いクリチカル セクション
    fig.4
    -図5. 最小化したクリチカル・セクション
    +図5. 最小化したクリチカル セクション
    fig.5

    -

    赤で示したセクションを実行中に障害が発生した場合、クロス・リンクが発生して操作対象のファイル・ディレクトリが失われる可能性があります。黄色で示したセクションを実行中に障害が発生した場合、つぎのうちいずれかまたは複数の結果が生じる可能性があります。

    +

    赤で示したセクションを実行中に障害が発生した場合、クロス リンクが発生して操作対象のファイル ディレクトリが失われる可能性があります。黄色で示したセクションを実行中に障害が発生した場合、つぎのうちいずれかまたは複数の結果が生じる可能性があります。

    • 書き換え中のファイルのデータが破壊される。
    • 追記中のファイルがオープン前の状態に戻る。
    • @@ -241,7 +241,7 @@ _FS_LOCK 0 (Disable file lock control)
    • 新規または上書きで作成されたファイルの長さがゼロになって残る。
    • ロストチェーンの発生によりボリュームの利用効率が悪化する。
    -

    いずれも書き込み中や操作の対象でないファイルには影響はありません。これらのクリチカル・セクションは、ファイルを書き込みモードで開いている時間を最小限にするか、f_sync()を適宜使用することで図5のようにリスクを最小化することができます。

    +

    いずれも書き込み中や操作の対象でないファイルには影響はありません。これらのクリチカル セクションは、ファイルを書き込みモードで開いている時間を最小限にするか、f_sync()を適宜使用することで図5のようにリスクを最小化することができます。

    @@ -258,23 +258,23 @@ _FS_LOCK 0 (Disable file lock control)

    FatFsのライセンスについて

    -

    ソース・ファイルのヘッダにライセンス条件が記述されているので、利用の際はそれに従うこと。英語を読めない方のために以下に日本語訳を示しておきます。

    +

    ソース ファイルのヘッダにライセンス条件が記述されているので、利用の際はそれに従うこと。英語を読めない方のために以下に日本語訳を示しておきます。

    /*----------------------------------------------------------------------------/
     /  FatFs - FAT file system module  R0.10b                   (C)ChaN, 2014
     /-----------------------------------------------------------------------------/
    -/ FatFsモジュールは、小規模な組み込みシステム向けの汎用FATファイルシステム・
    -/ モジュールです。これはフリー・ソフトウェアとして、教育・研究・開発のために
    -/ 以下のライセンス・ポリシーの下で公開されています。
    +/ FatFsモジュールは、小規模な組み込みシステム向けの汎用FATファイルシステム 
    +/ モジュールです。これはフリー ソフトウェアとして、教育・研究・開発のために
    +/ 以下のライセンス ポリシーの下で公開されています。
     /
     /  Copyright (C) 2014, ChaN, all right reserved.
     /
    -/ * FatFsモジュールはフリー・ソフトウェアであり、また無保証です。
    +/ * FatFsモジュールはフリー ソフトウェアであり、また無保証です。
     / * 用途に制限はありません。あなたの責任の下において、個人的・非営利的な
     /   ものから商用製品の開発に及ぶ目的に使用・改変・再配布することができます。
    -/ * ソース・コードを再配布するときは、上記の著作権表示を保持しなければなりません。
    +/ * ソース コードを再配布するときは、上記の著作権表示を保持しなければなりません。
     /
     /-----------------------------------------------------------------------------/
    -

    要するにFatFsはタダで自由に使えるということです。ソース・コードを再配布するときは、このブロックをそのまま保持しておくこと。このようにFatFsはBSDライクなライセンスとしていますが、一つ大きな違いがあります。特に組み込み用途での利用価値を高めるため、バイナリ形式(ソース・コードを含まない形式全て)での再配布については、条件は設けていません。その場合は、FatFsおよびそのライセンス文書についてはドキュメントに明記してもしなくてもかまいません。これは、一条項BSDライセンスと等価ということです。もちろんGNU GPLプロジェクトとも共存可能です。何らかの変更を加えて再配布する際は、矛盾しない他のライセンス(GNU GPLや修正BSDライセンスなど)に変更することも可能です。

    +

    要するにFatFsはタダで自由に使えるということです。ソース コードを再配布するときは、このブロックをそのまま保持しておくこと。このようにFatFsはBSDライクなライセンスとしていますが、一つ大きな違いがあります。特に組み込み用途での利用価値を高めるため、バイナリ形式(ソース コードを含まない形式全て)での再配布については、条件は設けていません。その場合は、FatFsおよびそのライセンス文書についてはドキュメントに明記してもしなくてもかまいません。これは、一条項BSDライセンスと等価ということです。もちろんGNU GPLプロジェクトとも共存可能です。何らかの変更を加えて再配布する際は、矛盾しない他のライセンス(GNU GPLや修正BSDライセンスなど)に変更することも可能です。

    戻る

    diff --git a/fatfs/doc/ja/chdir.html b/fatfs/doc/ja/chdir.html index 4a68fe2..3b09207 100644 --- a/fatfs/doc/ja/chdir.html +++ b/fatfs/doc/ja/chdir.html @@ -1,7 +1,7 @@ - + @@ -13,25 +13,25 @@

    f_chdir

    -

    ƒJƒŒƒ“ƒgEƒfƒBƒŒƒNƒgƒŠ‚ð•ÏX‚µ‚Ü‚·B

    +

    カレント ディレクトリを変更します。

     FRESULT f_chdir (
    -  const TCHAR* path /* [IN] ƒfƒBƒŒƒNƒgƒŠ–¼‚ւ̃|ƒCƒ“ƒ^ */
    +  const TCHAR* path /* [IN] ディレクトリ名へのポインタ */
     );
     
    -

    ˆø”

    +

    引数

    path
    -
    ˆÚ“®‘Ώۂ̃fƒBƒŒƒNƒgƒŠ‚̃pƒX–¼‚ðŽ¦‚·ƒkƒ‹•¶Žš'\0'I’[‚Ì•¶Žš—ñ‚ðŽw’肵‚Ü‚·B
    +
    移動対象のディレクトリのパス名を示すヌル文字'\0'終端の文字列を指定します。
    -

    –ß‚è’l

    +

    戻り値

    FR_OK, FR_DISK_ERR, @@ -49,33 +49,33 @@ FRESULT f_chdir (

    -

    ‰ðà

    -

    Šeƒ{ƒŠƒ…[ƒ€‚̃JƒŒƒ“ƒgEƒfƒBƒŒƒNƒgƒŠ‚ð•ÏX‚µ‚Ü‚·BƒJƒŒƒ“ƒgEƒfƒBƒŒƒNƒgƒŠ‚́A‚»‚̃{ƒŠƒ…[ƒ€‚̃}ƒEƒ“ƒg“®ì‚ªs‚í‚ꂽ‚Æ‚«Aƒ‹[ƒgEƒfƒBƒŒƒNƒgƒŠ‚ɏ‰ŠúÝ’肳‚ê‚Ü‚·BƒJƒŒƒ“ƒgEƒfƒBƒŒƒNƒgƒŠ‚́Aƒtƒ@ƒCƒ‹EƒVƒXƒeƒ€EƒIƒuƒWƒFƒNƒg‚É•ÛŽ‚³‚ê‚邽‚߁A‚»‚̃{ƒŠƒ…[ƒ€‚ðŽg—p‚·‚é‘S‚Ẵ^ƒXƒN‚ɑ΂µ‚ĉe‹¿‚ð—^‚¦‚Ü‚·B

    +

    解説

    +

    各ボリュームのカレント ディレクトリを変更します。カレント ディレクトリは、そのボリュームのマウント動作が行われたとき、ルート ディレクトリに初期設定されます。カレント ディレクトリは、ファイル システム オブジェクトに保持されるため、そのボリュームを使用する全てのタスクに対して影響を与えます。

    -

    ‘Ήžî•ñ

    -

    _FS_RPATH == 1‚Ì‚Æ‚«‚ÉŽg—p‰Â”\‚Æ‚È‚è‚Ü‚·B

    +

    対応情報

    +

    _FS_RPATH == 1のときに使用可能となります。

    -

    Žg—p—á

    +

    使用例

    -    /* ƒJƒŒƒ“ƒgEƒhƒ‰ƒCƒu‚̃JƒŒƒ“ƒgEƒfƒBƒŒƒNƒgƒŠ‚ð•ÏX (ƒ‹[ƒg‰º‚Ìdir1‚Ö) */
    +    /* カレント ドライブのカレント ディレクトリを変更 (ルート下のdir1へ) */
         f_chdir("/dir1");
     
    -    /* ƒhƒ‰ƒCƒu2‚̃JƒŒƒ“ƒgEƒfƒBƒŒƒNƒgƒŠ‚ð•ÏX (eƒfƒBƒŒƒNƒgƒŠ‚Ö) */
    +    /* ドライブ2のカレント ディレクトリを変更 (親ディレクトリへ) */
         f_chdir("2:..");
     
    -

    ŽQÆ

    +

    参照

    f_chdrive

    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/chdrive.html b/fatfs/doc/ja/chdrive.html index 305b0a7..7571d4e 100644 --- a/fatfs/doc/ja/chdrive.html +++ b/fatfs/doc/ja/chdrive.html @@ -1,7 +1,7 @@ - + @@ -13,25 +13,25 @@

    f_chdrive

    -

    ƒJƒŒƒ“ƒgEƒhƒ‰ƒCƒu‚ð•ÏX‚µ‚Ü‚·B

    +

    カレント ドライブを変更します。

     FRESULT f_chdrive (
    -  const TCHAR* path  /* [IN] ‘Ώۃhƒ‰ƒCƒu‚ðŽw’肵‚Ü‚· */
    +  const TCHAR* path  /* [IN] 対象ドライブを指定します */
     );
     
    -

    ˆø”

    +

    引数

    path
    -
    ƒJƒŒƒ“ƒgEƒhƒ‰ƒCƒu‚ɐݒ肷‚é˜_—ƒhƒ‰ƒCƒu”ԍ†‚ðŽw’è‚·‚éƒpƒX–¼‚ðŽw’肵‚Ü‚·B
    +
    カレント ドライブに設定する論理ドライブ番号を指定するパス名を指定します。
    -

    –ß‚è’l

    +

    戻り値

    FR_OK, FR_INVALID_DRIVE @@ -40,19 +40,19 @@ FRESULT f_chdrive (

    -

    ‰ðà

    -

    ƒJƒŒƒ“ƒgEƒhƒ‰ƒCƒu‚ð•ÏX‚µ‚Ü‚·BƒVƒXƒeƒ€‹N“®Žž‚̏‰Šú’l‚̓hƒ‰ƒCƒu0‚Å‚·B‚±‚̐ݒè‚ÍFatFsƒ‚ƒWƒ…[ƒ‹‚̐ÓI•Ï”‚É‹L˜^‚³‚ê‚邽‚߁A‘S‚Ẵ^ƒXƒN‚ɑ΂µ‚ĉe‹¿‚ð—^‚¦‚Ü‚·B

    +

    解説

    +

    カレント ドライブを変更します。システム起動時の初期値はドライブ0です。この設定はFatFsモジュールの静的変数に記録されるため、全てのタスクに対して影響を与えます。

    -

    ‘Ήžî•ñ

    -

    _FS_RPATH == 1‚ŁAŠŽ‚Â_VOLUMES > 1‚Ì‚Æ‚«‚ÉŽg—p‰Â”\‚Æ‚È‚è‚Ü‚·B

    +

    対応情報

    +

    _FS_RPATH == 1で、且つ_VOLUMES > 1のときに使用可能となります。

    -

    ŽQÆ

    +

    参照

    f_chdir

    diff --git a/fatfs/doc/ja/chmod.html b/fatfs/doc/ja/chmod.html index e0d113e..cb8f2b3 100644 --- a/fatfs/doc/ja/chmod.html +++ b/fatfs/doc/ja/chmod.html @@ -1,7 +1,7 @@ - + @@ -13,39 +13,39 @@

    f_chmod

    -

    ƒtƒ@ƒCƒ‹‚Ü‚½‚̓TƒuEƒfƒBƒŒƒNƒgƒŠ‚Ì‘®«‚ð•ÏX‚µ‚Ü‚·B

    +

    ファイルまたはサブ ディレクトリの属性を変更します。

     FRESULT f_chmod (
    -  const TCHAR* path, /* [IN] ƒIƒuƒWƒFƒNƒg–¼‚ւ̃|ƒCƒ“ƒ^ */
    -  BYTE attr,         /* [IN] Ý’è’l */
    -  BYTE mask          /* [IN] •ÏXƒ}ƒXƒN */
    +  const TCHAR* path, /* [IN] オブジェクト名へのポインタ */
    +  BYTE attr,         /* [IN] 設定値 */
    +  BYTE mask          /* [IN] 変更マスク */
     );
     
    -

    ˆø”

    +

    引数

    path
    -
    ‘®«•ÏX‘Ώۂ̃IƒuƒWƒFƒNƒg‚̃pƒX–¼‚ðŽ¦‚·ƒkƒ‹•¶Žš'\0'I’[‚Ì•¶Žš—ñ‚ðŽw’肵‚Ü‚·B
    +
    属性変更対象のオブジェクトのパス名を示すヌル文字'\0'終端の文字列を指定します。
    attr
    -
    Ý’è‚·‚é‘®«BŽw’è‰Â”\‚È‘®«‚ÍŽŸ‚Ì’Ê‚è‚ŁA‚±‚ê‚ç‚Ì‘g‚ݍ‡‚킹‚ÅŽw’肵‚Ü‚·BŽw’肳‚ê‚È‚©‚Á‚½‘®«‚Í‰ðœ‚³‚ê‚Ü‚·B
    +
    設定する属性。指定可能な属性は次の通りで、これらの組み合わせで指定します。指定されなかった属性は解除されます。
    - - - - - + + + + +
    ’lˆÓ–¡
    AM_RDOƒŠ[ƒhEƒIƒ“ƒŠ[
    AM_ARCƒA[ƒJƒCƒu
    AM_SYSƒVƒXƒeƒ€
    AM_HIDƒqƒhƒDƒ“
    値意味
    AM_RDOリード オンリー
    AM_ARCアーカイブ
    AM_SYSシステム
    AM_HIDヒドゥン
    mask
    -
    •ÏX‚·‚é‘®«‚̃}ƒXƒNBŽw’肵‚½‘®«‚ªÝ’è‚Ü‚½‚Í‰ðœ‚³‚êAŽw’肳‚ê‚È‚©‚Á‚½‘®«‚͏ó‘Ô‚ª•ÛŽ‚³‚ê‚Ü‚·Battr‚Æ“¯‚¶’l‚ðŽg‚¢‚Ü‚·B
    +
    変更する属性のマスク。指定した属性が設定または解除され、指定されなかった属性は状態が保持されます。attrと同じ値を使います。
    -

    –ß‚è’l

    +

    戻り値

    FR_OK, FR_DISK_ERR, @@ -65,19 +65,19 @@ FRESULT f_chmod (

    -

    ‘Ήžî•ñ

    -

    _FS_READONLY == 0‚ŁAŠŽ‚Â_FS_MINIMIZE == 0‚Ì‚Æ‚«Žg—p‰Â”\‚Å‚·B

    +

    対応情報

    +

    _FS_READONLY == 0で、且つ_FS_MINIMIZE == 0のとき使用可能です。

    -

    Žg—p—á

    +

    使用例

    -    /* ƒŠ[ƒhƒIƒ“ƒŠ[‚ðƒZƒbƒgAƒA[ƒJƒCƒu‚ðƒNƒŠƒAA‚»‚Ì‘¼‚͕ύX‚µ‚È‚¢ */
    +    /* リードオンリーをセット、アーカイブをクリア、その他は変更しない */
         f_chmod("file.txt", AM_RDO, AM_RDO | AM_ARC);
     
    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/close.html b/fatfs/doc/ja/close.html index cefd795..71d3c01 100644 --- a/fatfs/doc/ja/close.html +++ b/fatfs/doc/ja/close.html @@ -1,7 +1,7 @@ - + @@ -13,25 +13,25 @@

    f_close

    -

    ƒtƒ@ƒCƒ‹‚ð•Â‚¶‚Ü‚·B

    +

    ファイルを閉じます。

     FRESULT f_close (
    -  FIL* fp     /* [IN] ƒtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg‚ւ̃|ƒCƒ“ƒ^ */
    +  FIL* fp     /* [IN] ファイル オブジェクトへのポインタ */
     );
     
    -

    ˆø”

    +

    引数

    fp
    -
    •Â‚¶‚悤‚Æ‚·‚éƒtƒ@ƒCƒ‹‚̃tƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg\‘¢‘̂ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B
    +
    閉じようとするファイルのファイル オブジェクト構造体へのポインタを指定します。
    -

    –ß‚è’l

    +

    戻り値

    FR_OK, FR_DISK_ERR, @@ -44,23 +44,23 @@ FRESULT f_close (

    -

    ‰ðà

    -

    ƒtƒ@ƒCƒ‹‚ð•Â‚¶‚Ü‚·B‰½‚ç‚©‚̏‘‚«ž‚݂̍s‚í‚ꂽƒtƒ@ƒCƒ‹‚̏ꍇAƒLƒƒƒbƒVƒ…‚³‚ꂽó‘Ô(ƒŠ[ƒh/ƒ‰ƒCƒgEƒoƒbƒtƒ@ã‚̃f[ƒ^A•ÏX‚³‚ꂽFAT‚âƒfƒBƒŒƒNƒgƒŠ€–Ú)‚̓fƒBƒXƒN‚ɏ‘‚«–ß‚³‚ê‚Ü‚·BŠÖ”‚ª³íI—¹‚·‚é‚ƁA‚»‚̃tƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg‚Í–³Œø‚É‚È‚èA‚»‚̃ƒ‚ƒŠ‚à‰ð•ú‚Å‚«‚Ü‚·B

    -

    ƒtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg‚ª“ǂݏo‚µê—pƒ‚[ƒh‚ŁA_FS_LOCKƒIƒvƒVƒ‡ƒ“‚ª‘I‘ð‚³‚ê‚Ä‚¢‚È‚¢ê‡‚́Aƒtƒ@ƒCƒ‹‚ð•Â‚¶‚¸‚Ƀtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg‚ð”jŠü‚·‚邱‚Æ‚à‚Å‚«‚Ü‚·B‚µ‚©‚µA‚±‚ê‚͏«—ˆ‚̌݊·«‚Ì“_‚Ő„§‚Í‚³‚ê‚Ü‚¹‚ñB

    +

    解説

    +

    ファイルを閉じます。何らかの書き込みの行われたファイルの場合、キャッシュされた状態(リード/ライト バッファ上のデータ、変更されたFATやディレクトリ項目)はディスクに書き戻されます。関数が正常終了すると、そのファイル オブジェクトは無効になり、そのメモリも解放できます。

    +

    ファイル オブジェクトが読み出し専用モードで、_FS_LOCKオプションが選択されていない場合は、ファイルを閉じずにファイル オブジェクトを破棄することもできます。しかし、これは将来の互換性の点で推奨はされません。

    -

    ‘Ήžî•ñ

    -

    ‘S‚Ă̍\¬‚ÅŽg—p‰Â”\‚Å‚·B

    +

    対応情報

    +

    全ての構成で使用可能です。

    -

    ŽQÆ

    +

    参照

    f_open, f_read, f_write, f_sync, FIL, FATFS
    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/closedir.html b/fatfs/doc/ja/closedir.html index 021e8c8..2ccafdb 100644 --- a/fatfs/doc/ja/closedir.html +++ b/fatfs/doc/ja/closedir.html @@ -1,7 +1,7 @@ - + @@ -13,25 +13,25 @@

    f_closedir

    -

    ƒfƒBƒŒƒNƒgƒŠ‚ð•Â‚¶‚Ü‚·B

    +

    ディレクトリを閉じます。

     FRESULT f_closedir (
    -  DIR* dp     /* [IN] ƒfƒBƒŒƒNƒgƒŠEƒIƒuƒWƒFƒNƒg‚ւ̃|ƒCƒ“ƒ^ */
    +  DIR* dp     /* [IN] ディレクトリ オブジェクトへのポインタ */
     );
     
    -

    ˆø”

    +

    引数

    dp
    -
    •Â‚¶‚悤‚Æ‚·‚éƒfƒBƒŒƒNƒgƒŠ‚̃fƒBƒŒƒNƒgƒŠEƒIƒuƒWƒFƒNƒg\‘¢‘̂ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B
    +
    閉じようとするディレクトリのディレクトリ オブジェクト構造体へのポインタを指定します。
    -

    –ß‚è’l

    +

    戻り値

    FR_OK, FR_INT_ERR, @@ -42,23 +42,23 @@ FRESULT f_closedir (

    -

    ‰ðà

    -

    ƒfƒBƒŒƒNƒgƒŠ‚ð•Â‚¶‚Ü‚·BŠÖ”‚ª³íI—¹‚·‚é‚ƁA‚»‚̃fƒBƒŒƒNƒgƒŠEƒIƒuƒWƒFƒNƒg‚Í–³Œø‚É‚È‚èA‚»‚̃ƒ‚ƒŠ‚à‰ð•ú‚Å‚«‚Ü‚·B

    -

    _FS_LOCKƒIƒvƒVƒ‡ƒ“‚ª‘I‘ð‚³‚ê‚Ä‚¢‚È‚¢ê‡‚́A‚±‚̏ˆ—‚ðs‚킸‚ɃfƒBƒŒƒNƒgƒŠEƒIƒuƒWƒFƒNƒg‚ð”jŠü‚·‚邱‚Æ‚à‚Å‚«‚Ü‚·B‚µ‚©‚µA‚±‚ê‚͏«—ˆ‚̌݊·«‚Ì“_‚Ő„§‚Í‚³‚ê‚Ü‚¹‚ñB

    +

    解説

    +

    ディレクトリを閉じます。関数が正常終了すると、そのディレクトリ オブジェクトは無効になり、そのメモリも解放できます。

    +

    _FS_LOCKオプションが選択されていない場合は、この処理を行わずにディレクトリ オブジェクトを破棄することもできます。しかし、これは将来の互換性の点で推奨はされません。

    -

    ‘Ήžî•ñ

    -

    _FS_MINIMIZE <= 1‚Ì‚Æ‚«Žg—p‰Â”\‚É‚È‚è‚Ü‚·B

    +

    対応情報

    +

    _FS_MINIMIZE <= 1のとき使用可能になります。

    -

    ŽQÆ

    +

    参照

    f_opendir, f_readdir, DIR
    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/dinit.html b/fatfs/doc/ja/dinit.html index 9168c0b..6329150 100644 --- a/fatfs/doc/ja/dinit.html +++ b/fatfs/doc/ja/dinit.html @@ -1,7 +1,7 @@ - + @@ -13,34 +13,34 @@

    disk_initialize

    -

    ƒXƒgƒŒ[ƒWEƒfƒoƒCƒX‚ð‰Šú‰»‚µ‚Ü‚·B

    +

    ストレージ デバイスを初期化します。

     DSTATUS disk_initialize (
    -  BYTE pdrv      /* [IN] •¨—ƒhƒ‰ƒCƒu”ԍ† */
    +  BYTE pdrv      /* [IN] 物理ドライブ番号 */
     );
     
    -

    ˆø”

    +

    引数

    pdrv
    -
    ‘Ώۂ̃fƒoƒCƒX‚ðŽ¦‚·•¨—ƒhƒ‰ƒCƒu”ԍ†(0-9)‚ªŽw’肳‚ê‚Ü‚·B
    +
    対象のデバイスを識別する物理ドライブ番号(0-9)が指定されます。
    -

    –ß‚è’l

    -

    ‚±‚̊֐”‚Í–ß‚è’l‚Æ‚µ‚ăfƒBƒXƒNEƒXƒe[ƒ^ƒX‚ð•Ô‚µ‚Ü‚·BƒfƒBƒXƒNEƒXƒe[ƒ^ƒX‚̏ڍׂɊւµ‚Ä‚Ídisk_status()‚ðŽQÆ‚µ‚Ä‚­‚¾‚³‚¢B

    +

    戻り値

    +

    この関数は戻り値としてディスク ステータスを返します。ディスク ステータスの詳細に関してはdisk_status()を参照してください。

    -

    ‰ðà

    -

    ƒXƒgƒŒ[ƒWEƒfƒoƒCƒX‚ð‰Šú‰»‚µAƒf[ƒ^‚̓ǂݏ‘‚«‚È‚Ç‘S‚Ä‚Ì“®ì‚ª‰Â”\‚ȏó‘Ô‚É‚µ‚Ü‚·BŠÖ”‚ª¬Œ÷‚·‚é‚ƁA–ß‚è’l‚ÌSTA_NOINITƒtƒ‰ƒO‚ªƒNƒŠƒA‚³‚ê‚Ü‚·B

    -

    ƒAƒvƒŠƒP[ƒVƒ‡ƒ“‚©‚ç‚Í‚±‚̊֐”‚ðŒÄ‚яo‚µ‚Ä‚Í‚È‚è‚Ü‚¹‚ñB‚³‚à‚È‚¢‚ƁAFATƒ{ƒŠƒ…[ƒ€‚ª”j‰ó‚³‚ê‚é‰Â”\«‚ª‚ ‚è‚Ü‚·BƒGƒ‰[“™‚É‚æ‚èÄ‰Šú‰»‚ª•K—v‚È‚Æ‚«‚́Af_mount()‚ðŽg—p‚µ‚Ä‚­‚¾‚³‚¢BFatFsƒ‚ƒWƒ…[ƒ‹‚́AŽ©“®ƒ}ƒEƒ“ƒg“®ì‚É‚æ‚èA•K—v‚ɉž‚¶‚Ä‚±‚̊֐”‚ðŒÄ‚яo‚µ‚Ü‚·B

    +

    解説

    +

    ストレージ デバイスを初期化し、データの読み書きなど全ての動作が可能な状態にします。関数が成功すると、戻り値のSTA_NOINITフラグがクリアされます。

    +

    アプリケーションからはこの関数を呼び出してはなりません。さもないと、FATボリュームが破壊される可能性があります。エラー等により再初期化が必要なときは、f_mount()を使用してください。FatFsモジュールは、自動マウント動作により、必要に応じてこの関数を呼び出します。

    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/dioctl.html b/fatfs/doc/ja/dioctl.html index 30e49e3..120d798 100644 --- a/fatfs/doc/ja/dioctl.html +++ b/fatfs/doc/ja/dioctl.html @@ -1,7 +1,7 @@ - + @@ -13,83 +13,83 @@

    disk_ioctl

    -

    ˆê”Ê“I‚ȃf[ƒ^“ǂݏ‘‚«ˆÈŠO‚̃XƒgƒŒ[ƒWEƒfƒoƒCƒXŽ©‘̂ɑ΂·‚é—lX‚Ȑ§Œä‚ðs‚¢‚Ü‚·B

    +

    一般的なデータ読み書き以外のストレージ デバイス自体に対する様々な制御を行います。

     DRESULT disk_ioctl (
    -  BYTE pdrv,    /* [IN] •¨—ƒhƒ‰ƒCƒu”ԍ† */
    -  BYTE cmd,     /* [IN] §ŒäƒRƒ}ƒ“ƒh */
    -  void* buff    /* [I/O] ƒf[ƒ^Žó‚¯“n‚µƒoƒbƒtƒ@ */
    +  BYTE pdrv,    /* [IN] 物理ドライブ番号 */
    +  BYTE cmd,     /* [IN] 制御コマンド */
    +  void* buff    /* [I/O] データ受け渡しバッファ */
     );
     
    -

    ˆø”

    +

    引数

    pdrv
    -
    ‘Ώۂ̃fƒoƒCƒX‚ðŽ¦‚·•¨—ƒhƒ‰ƒCƒu”ԍ†(0-9)‚ªŽw’肳‚ê‚Ü‚·B
    +
    対象のデバイスを示す物理ドライブ番号(0-9)が指定されます。
    cmd
    -
    §ŒäƒRƒ}ƒ“ƒhEƒR[ƒh‚ªŽw’肳‚ê‚Ü‚·B
    +
    制御コマンド コードが指定されます。
    buff
    -
    §ŒäƒRƒ}ƒ“ƒh‚Ɉˑ¶‚µ‚½ƒpƒ‰ƒ[ƒ^‚ðŽöŽó‚·‚éƒoƒbƒtƒ@‚ðŽw‚·ƒ|ƒCƒ“ƒ^‚ªŽw’肳‚ê‚Ü‚·Bƒpƒ‰ƒ[ƒ^‚ÌŽöŽó‚Ì‚È‚¢ƒRƒ}ƒ“ƒh‚̏ꍇ‚́A’l‚ɈӖ¡‚Í‚ ‚è‚Ü‚¹‚ñB
    +
    制御コマンドに依存したパラメータを授受するバッファを指すポインタが指定されます。パラメータの授受のないコマンドの場合は、値に意味はありません。
    -

    –ß‚è’l

    +

    戻り値

    RES_OK (0)
    -
    ³íI—¹B
    +
    正常終了。
    RES_ERROR
    -
    ‰½‚ç‚©‚̃Gƒ‰[‚ª”­¶‚µ‚½B
    +
    何らかのエラーが発生した。
    RES_PARERR
    -
    ƒRƒ}ƒ“ƒh‚ª•s³B
    +
    コマンドが不正。
    RES_NOTRDY
    -
    ƒhƒ‰ƒCƒu‚ª“®ì‰Â”\ó‘Ô‚Å‚Í‚È‚¢A‚Ü‚½‚͏‰Šú‰»‚³‚ê‚Ä‚¢‚È‚¢B
    +
    ドライブが動作可能状態ではない、または初期化されていない。
    -

    ‰ðà

    -

    ƒXƒgƒŒ[ƒWEƒfƒoƒCƒX‚ÌŽí—Þ‚É‚æ‚èƒTƒ|[ƒg‚³‚ê‚éƒRƒ}ƒ“ƒh‚͈قȂè‚Ü‚·‚ªAFatFsƒ‚ƒWƒ…[ƒ‹Ž©‘̂́AŽŸ‚̔ėpƒRƒ}ƒ“ƒh‚Ì‚ÝŽg—p‚µA“Á’è‚̃fƒoƒCƒX‚Ɉˑ¶‚µ‚½§Œä‚͍s‚¢‚Ü‚¹‚ñB

    +

    解説

    +

    ストレージ デバイスの種類によりサポートされるコマンドは異なりますが、FatFsモジュール自体は、次の汎用コマンドのみ使用し、特定のデバイスに依存した制御は行いません。

    - - - - - - - + + + + + + +
    •W€ioctlƒRƒ}ƒ“ƒh
    ƒRƒ}ƒ“ƒh‰ðà
    CTRL_SYNCƒXƒgƒŒ[ƒWEƒfƒoƒCƒX‚̃f[ƒ^‘‚«ž‚ݏˆ—‚ðŠ®—¹‚³‚¹‚Ü‚·Bƒ‰ƒCƒgEƒoƒbƒNEƒLƒƒƒbƒVƒ…‚È‚Ç‚ª‘¶Ý‚·‚éê‡‚́A‘‚«ž‚Ü‚ê‚Ä‚¢‚È‚¢ƒf[ƒ^‚𑦎ž‘‚«ž‚Ý‚Ü‚·BƒƒfƒBƒAã‚ւ̏‘‚«ž‚Ý‚ª‚»‚ꂼ‚êdisk_write()‚Ì“à‚ÅŠ®—¹‚·‚éê‡‚́A‚±‚̃Rƒ}ƒ“ƒh‚ɑ΂µ‚Ä‚·‚邱‚Æ‚Í‚ ‚è‚Ü‚¹‚ñB
    GET_SECTOR_COUNTbuff‚ÌŽw‚·DWORDŒ^•Ï”‚Ƀhƒ‰ƒCƒuã‚Ì‘ƒZƒNƒ^”‚ð•Ô‚µ‚Ü‚·Bf_mkfs()‚¨‚æ‚Ñf_fdisk()“à‚©‚çŒÄ‚яo‚³‚êAì¬‚·‚éƒ{ƒŠƒ…[ƒ€‚̃TƒCƒY‚ðŒˆ’è‚·‚邽‚ß‚ÉŽg—p‚³‚ê‚Ü‚·B
    GET_SECTOR_SIZEbuff‚ÌŽw‚·WORDŒ^•Ï”‚Ƀhƒ‰ƒCƒu‚̃ZƒNƒ^EƒTƒCƒY‚ð•Ô‚µ‚Ü‚·B—LŒø’l‚Í512A1024A2048‚Ü‚½‚Í4096‚Å‚·BƒZƒNƒ^EƒTƒCƒYŒÅ’è\¬(_MAX_SS ==_MIN_SS)‚Ì‚Æ‚«‚Í‚±‚̃Rƒ}ƒ“ƒh‚ÍŽg‚í‚ê‚邱‚Æ‚Í‚È‚­Aí‚É‚»‚̃ZƒNƒ^EƒTƒCƒY‚Å“®ì‚µ‚È‚¯‚ê‚΂Ȃè‚Ü‚¹‚ñB
    GET_BLOCK_SIZEbuff‚ÌŽw‚·DWORDŒ^•Ï”‚Ƀtƒ‰ƒbƒVƒ…Eƒƒ‚ƒŠ‚̏Á‹ŽƒuƒƒbƒNEƒTƒCƒY(ƒZƒNƒ^’PˆÊ)‚ð•Ô‚µ‚Ü‚·B1‚©‚ç32768‚͈̔͂Å2‚̗ݏæ‚Ì’l‚Å‚È‚¯‚ê‚΂Ȃè‚Ü‚¹‚ñB•s–¾‚ȏꍇ‚Ü‚½‚̓tƒ‰ƒbƒVƒ…Eƒƒ‚ƒŠˆÈŠO‚̃ƒfƒBƒA‚Å‚Í1‚ð•Ô‚µ‚Ü‚·Bf_mkfs()“à‚Å‚Ì‚ÝŽg—p‚³‚êAƒ{ƒŠƒ…[ƒ€‚̃f[ƒ^—̈æ‚Í‚±‚Ì‹«ŠE‚ɃAƒ‰ƒCƒƒ“ƒg‚³‚ê‚Ü‚·B
    CTRL_ERASE_SECTORƒtƒ‰ƒbƒVƒ…Eƒƒ‚ƒŠã‚̗̈æ‚Ì–¾Ž¦“IÁ‹ŽBbuff‚ÌŽw‚·DWORDŒ^”z—ñ‚ɂ͏Á‹Ž‚·‚é—̈æ {ŠJŽnƒZƒNƒ^,I—¹ƒZƒNƒ^} ‚ðŽw’肵‚ČĂяo‚³‚ê‚Ü‚·B_USE_ERASE‚ª1‚Ì‚Æ‚«AƒNƒ‰ƒXƒ^‚ª‰ð•ú‚³‚ê‚é‚Æ‚«‚ɌĂяo‚³‚ê‚Ü‚·B‚±‚ê‚́AATAƒRƒ}ƒ“ƒhEƒZƒbƒg‚ÌTrimƒRƒ}ƒ“ƒh‚Æ“™‰¿‚ŁA‚±‚Ì‹@”\‚ðƒTƒ|[ƒg‚µ‚È‚¢ê‡‚͉½‚à‚·‚é•K—v‚Í‚ ‚è‚Ü‚¹‚ñB‚Ü‚½A–ß‚è’l‚̓`ƒFƒbƒN‚³‚ꂸAÁ‹Ž‚ªŠ®‘S‚ɍs‚í‚ê‚È‚©‚Á‚½‚Æ‚µ‚Ä‚àFatFs‚Ì“®ì‚ɂ͉e‹¿‚ ‚è‚Ü‚¹‚ñB
    標準ioctlコマンド
    コマンド解説
    CTRL_SYNCデバイスのデータ書き込み処理を完了させます。ドライバがライト バック キャッシュなどを持っている場合は、書き込まれていないデータを即時書き込みます。メディア上への書き込みがそれぞれdisk_write()の中で完了する場合は、このコマンドに対してすることはありません。
    GET_SECTOR_COUNT総セクタ数の取得。buffの指すDWORD型変数にドライブ上の総セクタ数を返します。f_mkfs()およびf_fdisk()内から呼び出され、作成するボリュームのサイズを決定するために使用されます。
    GET_SECTOR_SIZEセクタ サイズの取得。buffの指すWORD型変数にドライブのセクタ サイズを返します。有効値は512、1024、2048または4096です。セクタ サイズが固定(_MAX_SS ==_MIN_SS)のときはこのコマンドは使われることはなく、デバイスは常にそのセクタ サイズで動作しなければなりません。
    GET_BLOCK_SIZE消去ブロック サイズの取得。buffの指すDWORD型変数にフラッシュ メモリの消去ブロック サイズ(セクタ単位)を返します。1から32768の範囲で2の累乗の値でなければなりません。ブロック サイズ不明またはフラッシュ メモリ以外のデバイスでは1を返します。f_mkfs()内でのみ使用され、作成されるボリュームのデータ領域はこの境界にアライメントされます。
    CTRL_TRIM不必要セクタの通知。buffの指すDWORD型配列には不必要になった領域 {開始セクタ,終了セクタ} を指定して呼び出されます。TRIM機能が有効(_USE_TRIM == 1)で、クラスタが解放されるとき、およびフォーマット時に呼び出されます。これは、ATAコマンド セットのTrimコマンドと等価で、この機能をサポートしないデバイスは何もする必要はありません。また、戻り値はチェックされず、結果によってFatFsの動作が影響を受けることはありません。
    -

    FatFsŽ©‘̂̓fƒoƒCƒXˆË‘¶ƒRƒ}ƒ“ƒh‚⃆[ƒU’è‹`ƒRƒ}ƒ“ƒh‚͈êØŽg—p‚µ‚Ü‚¹‚ñ‚ªAƒAƒvƒŠƒP[ƒVƒ‡ƒ“‚©‚牽‚ç‚©‚̃fƒoƒCƒX§Œä‚ªs‚¦‚é‚Æ•Ö—˜‚È‚±‚Æ‚ª‚ ‚è‚Ü‚·BƒAƒvƒŠƒP[ƒVƒ‡ƒ“ã‚Å•W€ˆÈŠO‚̐§Œä‚ª•K—v‚È‚Æ‚«‚́A•K—v‚ɉž‚¶‚ㆁ[ƒU’è‹`ƒRƒ}ƒ“ƒh‚ð’ljÁ‚µ‚Ä—˜—p‚·‚é‚Æ‚æ‚¢‚Å‚µ‚傤BŽŸ‚ɃRƒ}ƒ“ƒh‚Ì—á‚ðŽ¦‚µ‚Ü‚·B

    +

    FatFs自体はデバイス依存コマンドやユーザ定義コマンドは一切使用しませんが、アプリケーションから何らかのデバイス制御が行えると便利なことがあります。アプリケーション上で標準以外の制御が必要なときは、必要に応じてユーザ定義コマンドを追加して利用するとよいでしょう。次にコマンドの例を示します。

    - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + +
    ƒ†[ƒU’è‹`ioctlƒRƒ}ƒ“ƒh‚Ì—á
    ƒRƒ}ƒ“ƒh‰ðà
    CTRL_FORMATƒƒfƒBƒA‚Ì•¨—ƒtƒH[ƒ}ƒbƒg‚ðs‚¢‚Ü‚·Bbuff‚ÍNULL‚Å‚È‚¢‚Æ‚«Ais•\Ž¦‚Ì‚½‚߂̃R[ƒ‹ƒoƒbƒNŠÖ”‚̃AƒhƒŒƒX‚ðŽ¦‚µ‚Ü‚·B
    CTRL_POWER_IDLEƒfƒoƒCƒX‚ðƒAƒCƒhƒ‹ó‘Ô‚É‚µ‚Ü‚·B’ʏí‚̓ǂݏ‘‚«—v‹‚ŃAƒNƒeƒBƒuó‘Ô‚É–ß‚é‚È‚çASTA_NOINITƒtƒ‰ƒO‚ðƒZƒbƒg‚·‚é•K—v‚Í‚ ‚è‚Ü‚¹‚ñB
    CTRL_POWER_OFFƒfƒoƒCƒX‚ðƒVƒƒƒbƒgƒ_ƒEƒ“ó‘Ô‚É‚µ‚Ü‚·BSTA_NOINIT‚̓Zƒbƒg‚³‚ê‚Ü‚·BƒfƒoƒCƒX‚Ídisk_initialize()‚ŃAƒNƒeƒBƒuó‘Ô‚É–ß‚è‚Ü‚·B
    CTRL_LOCKƒ†[ƒU‚É‚æ‚郁ƒfƒBƒA‚ÌŽæ‚èo‚µ‚ð‹ÖŽ~‚µ‚Ü‚·B
    CTRL_UNLOCKƒ†[ƒU‚É‚æ‚郁ƒfƒBƒA‚ÌŽæ‚èo‚µ‚ð‹–‰Â‚µ‚Ü‚·B
    CTRL_EJECTƒƒfƒBƒA‚ð”ro‚µ‚Ü‚·BŠ®—¹ŒãASTA_NOINIT‚ÆSTA_NODISKƒtƒ‰ƒO‚̓Zƒbƒg‚³‚ê‚Ü‚·B
    MMC_GET_TYPEƒJ[ƒhEƒ^ƒCƒv‚ðŽ¦‚·ƒtƒ‰ƒO(b0:MMCv3, b1:SDv1, b2:SDv2+, b3:LBA)‚ðbuff‚ÌŽ¦‚·BYTE•Ï”‚ɓǂݏo‚µ‚Ü‚·B(MMC/SDƒJ[ƒhê—p)
    MMC_GET_CSDCSDƒŒƒWƒXƒ^‚Ì“à—e‚ðbuff‚ÌŽ¦‚·16ƒoƒCƒg‚̃oƒbƒtƒ@‚ɓǂݏo‚µ‚Ü‚·B(MMC/SDƒJ[ƒhê—p)
    MMC_GET_CIDCIDƒŒƒWƒXƒ^‚Ì“à—e‚ðbuff‚ÌŽ¦‚·16ƒoƒCƒg‚̃oƒbƒtƒ@‚ɓǂݏo‚µ‚Ü‚·B(MMC/SDƒJ[ƒhê—p)
    MMC_GET_OCROCRƒŒƒWƒXƒ^‚Ì“à—e‚ðbuff‚ÌŽ¦‚·4ƒoƒCƒg‚̃oƒbƒtƒ@‚ɓǂݏo‚µ‚Ü‚·B(MMC/SDƒJ[ƒhê—p)
    MMC_GET_SDSTATSD STATUSƒŒƒWƒXƒ^‚Ì“à—e‚ðbuff‚ÌŽ¦‚·64ƒoƒCƒg‚̃oƒbƒtƒ@‚ɓǂݏo‚µ‚Ü‚·B(SDƒJ[ƒhê—p)
    ATA_GET_REVƒŠƒrƒWƒ‡ƒ“EƒR[ƒh‚ðbuff‚ÌŽ¦‚·16ƒoƒCƒg‚̃oƒbƒtƒ@‚ɓǂݏo‚µ‚Ü‚·B(ATA/CFƒJ[ƒhê—p)
    ATA_GET_MODELƒ‚ƒfƒ‹EƒR[ƒh‚ðbuff‚ÌŽ¦‚·40ƒoƒCƒg‚̃oƒbƒtƒ@‚ɓǂݏo‚µ‚Ü‚·B(ATA/CFƒJ[ƒhê—p)
    ATA_GET_SNƒVƒŠƒAƒ‹”ԍ†‚ðbuff‚ÌŽ¦‚·20ƒoƒCƒg‚̃oƒbƒtƒ@‚ɓǂݏo‚µ‚Ü‚·B(ATA/CFƒJ[ƒhê—p)
    ユーザ定義ioctlコマンドの例
    コマンド解説
    CTRL_FORMATメディアの物理フォーマットを行います。buffはNULLでないとき、進行表示のためのコールバック関数のアドレスを示します。
    CTRL_POWER_IDLEデバイスをアイドル状態にします。通常の読み書き要求でアクティブ状態に戻るなら、STA_NOINITフラグをセットする必要はありません。
    CTRL_POWER_OFFデバイスをシャットダウン状態にします。STA_NOINITはセットされます。デバイスはdisk_initialize()でアクティブ状態に戻ります。
    CTRL_LOCKユーザによるメディアの取り出しを禁止します。
    CTRL_UNLOCKユーザによるメディアの取り出しを許可します。
    CTRL_EJECTメディアを排出します。完了後、STA_NOINITとSTA_NODISKフラグはセットされます。
    MMC_GET_TYPEカード タイプを示すフラグ(b0:MMCv3, b1:SDv1, b2:SDv2+, b3:LBA)をbuffの示すBYTE変数に読み出します。(MMC/SDカード専用)
    MMC_GET_CSDCSDレジスタの内容をbuffの示す16バイトのバッファに読み出します。(MMC/SDカード専用)
    MMC_GET_CIDCIDレジスタの内容をbuffの示す16バイトのバッファに読み出します。(MMC/SDカード専用)
    MMC_GET_OCROCRレジスタの内容をbuffの示す4バイトのバッファに読み出します。(MMC/SDカード専用)
    MMC_GET_SDSTATSD STATUSレジスタの内容をbuffの示す64バイトのバッファに読み出します。(SDカード専用)
    ATA_GET_REVリビジョン コードをbuffの示す16バイトのバッファに読み出します。(ATA/CFカード専用)
    ATA_GET_MODELモデル コードをbuffの示す40バイトのバッファに読み出します。(ATA/CFカード専用)
    ATA_GET_SNシリアル番号をbuffの示す20バイトのバッファに読み出します。(ATA/CFカード専用)
    -

    ‘Ήžî•ñ

    -

    ƒŠ[ƒhEƒIƒ“ƒŠ[\¬‚ŁA‚©‚ƒZƒNƒ^EƒTƒCƒYŒÅ’è\¬‚Ì‚Æ‚«‚́A‚±‚̊֐”‚Í•K—v‚Æ‚³‚ê‚Ü‚¹‚ñB

    +

    対応情報

    +

    リード オンリー構成で、かつセクタ サイズ固定構成のときは、この関数は必要とされません。

    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/dread.html b/fatfs/doc/ja/dread.html index 18b4238..2dac64e 100644 --- a/fatfs/doc/ja/dread.html +++ b/fatfs/doc/ja/dread.html @@ -1,7 +1,7 @@ - + @@ -13,59 +13,60 @@

    disk_read

    -

    ƒXƒgƒŒ[ƒWEƒfƒoƒCƒX‚©‚çƒf[ƒ^‚ð“ǂݏo‚µ‚Ü‚·B

    +

    ストレージ デバイスからデータを読み出します。

     DRESULT disk_read (
    -  BYTE pdrv,     /* [IN] •¨—ƒhƒ‰ƒCƒu”ԍ† */
    -  BYTE* buff,    /* [OUT] “ǂݏo‚µƒoƒbƒtƒ@‚ւ̃|ƒCƒ“ƒ^ */
    -  DWORD sector,  /* [IN] “ǂݏo‚µŠJŽnƒZƒNƒ^”ԍ† */
    -  UINT count     /* [IN] “ǂݏo‚·ƒZƒNƒ^” */
    +  BYTE pdrv,     /* [IN] 物理ドライブ番号 */
    +  BYTE* buff,    /* [OUT] 読み出しバッファへのポインタ */
    +  DWORD sector,  /* [IN] 読み出し開始セクタ番号 */
    +  UINT count     /* [IN] 読み出すセクタ数 */
     );
     
    -

    ˆø”

    +

    引数

    pdrv
    -
    ‘Ώۂ̃fƒoƒCƒX‚ðŽ¦‚·•¨—ƒhƒ‰ƒCƒu”ԍ†(0-9)‚ªŽw’肳‚ê‚Ü‚·B
    +
    対象のデバイスを示す物理ドライブ番号(0-9)が指定されます。シングル ドライブ システムでは、常に0が指定されます。
    buff
    -
    ƒXƒgƒŒ[ƒWEƒfƒoƒCƒX‚©‚ç“ǂݏo‚µ‚½ƒf[ƒ^‚ðŠi”[‚·‚éƒoƒCƒg”z—ñ‚ªŽw’肳‚ê‚Ü‚·B
    +
    ストレージ デバイスから読み出したデータを格納するバイト配列が指定されます。
    sector
    -
    “ǂݏo‚µ‚ðŠJŽn‚·‚éƒZƒNƒ^”ԍ†BLBA‚ÅŽw’肳‚ê‚Ü‚·B
    +
    読み出しを開始するセクタ番号。32ビットLBAで指定されます。
    count
    -
    “ǂݏo‚·ƒZƒNƒ^”BFatFs‚©‚ç‚̌Ăяo‚µ‚Å‚Í1`128‚͈̔͂ɌÀ‚ç‚ê‚Ü‚·B
    +
    読み出すセクタ数(1~128)。
    -

    –ß‚è’l

    +

    戻り値

    RES_OK (0)
    -
    ³íI—¹B
    +
    正常終了。
    RES_ERROR
    -
    “ǂݍž‚Ý’†‚ɃGƒ‰[‚ª”­¶‚µA‚»‚̉ñ•œ‚É‚àŽ¸”s‚µ‚½B
    +
    読み込み中にエラーが発生し、その回復にも失敗した。
    RES_PARERR
    -
    ƒpƒ‰ƒ[ƒ^‚ª•s³B
    +
    パラメータが不正。
    RES_NOTRDY
    -
    ƒhƒ‰ƒCƒu‚ª“®ì‰Â”\ó‘Ô‚Å‚Í‚È‚¢i‰Šú‰»‚³‚ê‚Ä‚¢‚È‚¢jB
    +
    ドライブが動作可能状態ではない(初期化されていない)。
    -

    ‰ðà

    -

    buff‚ÍBYTEŒ^‚Ȃ̂ŁAŽw’肳‚ê‚éƒAƒhƒŒƒX‚͏í‚Ƀ[ƒhEƒAƒ‰ƒCƒƒ“ƒg‚³‚ê‚Ä‚¢‚é‚Æ‚ÍŒÀ‚è‚Ü‚¹‚ñB”ñƒAƒ‰ƒCƒƒ“ƒgEƒAƒhƒŒƒX‚Ö‚Ì“]‘—‚́A’¼Ú“]‘—‚É‚¨‚¢‚Ä”­¶‚·‚邱‚Æ‚ª‚ ‚è‚Ü‚·B‚à‚µ‚àAƒn[ƒhƒEƒFƒAã‚̐§–ñ‚Å‚»‚̂悤‚È“]‘—‚ª•s‰Â”\‚È‚Æ‚«‚́A‚±‚̊֐”“à‚Å“ñ’i“]‘—‚·‚é‚È‚Ç‚µ‚Ä‰ðŒˆ‚·‚é‚©A‚Ü‚½‚Í•Ê‚Ì•û–@‚őΉž‚µ‚È‚¯‚ê‚΂Ȃè‚Ü‚¹‚ñBŽŸ‚É‚¢‚­‚‚©‚̑Ήž•û–@‚ðŽ¦‚µ‚Ü‚·(‚¢‚¸‚ê‚©ˆê‚‚ÅOK)B

    +

    解説

    +

    ストレージ デバイスに対するデータの読み書きは、セクタ単位で行われます。FatFsでは512~4096バイトのセクタ サイズをサポートします。固定セクタ サイズ構成(_MIN_SS == MAX_SS)のときは、暗黙的にそのセクタ サイズで動作しなければなりません。可変セクタ サイズ構成(_MIN_SS < MAX_SS)

    のときは、初期化後disk_ioctl()でセクタ サイズを問い合わせてくるので、それに対して正しい値を返す必要があります。 +

    buffはBYTE型なので、指定されるアドレスは常にワード アライメントされているとは限りません。非アライメント アドレスへの転送は、直接転送において発生することがあります。もしも、ハードウェア上の制約でそのような転送が不可能なときは、この関数内で二段転送するなどして解決するか、または別の方法で対応しなければなりません。次にいくつかの対応方法を示します(いずれか一つでOK)。

      -
    • ‚±‚̊֐”“à‚Å‰ðŒˆ‚·‚é - „§
    • -
    • f_read()‚É‚¨‚¢‚āAƒZƒNƒ^‘S‘Ì‚ðŠÜ‚Þ“]‘—‚ð”ð‚¯‚é - ’¼Ú“]‘—‚ª”­¶‚µ‚È‚¢
    • -
    • f_read(fp, buff, btr, &br)‚É‚¨‚¢‚āA(((UINT)buff & 3) == (f_tell(fp) & 3))‚ð–ž‘«‚³‚¹‚é - buff‚̃[ƒhEƒAƒ‰ƒCƒƒ“ƒg‚ª•ÛØ‚³‚ê‚é
    • +
    • この関数内で解決する - 推奨
    • +
    • f_read()において、セクタ全体を含む転送を避ける - 直接転送が発生しない
    • +
    • f_read(fp, buff, btr, &br)において、(((UINT)buff & 3) == (f_tell(fp) & 3))を満足させる - buffのワード アライメントが保証される
    -

    ˆê”Ê“I‚ɁA•¡”ƒZƒNƒ^‚Ì“]‘——v‹‚́AƒXƒgƒŒ[ƒWEƒfƒoƒCƒX‚ɑ΂µ‚ĉ”\‚ÈŒÀ‚èƒ}ƒ‹ƒ`EƒZƒNƒ^“]‘—‚µ‚È‚¯‚ê‚΂Ȃè‚Ü‚¹‚ñB•¡”‚̃Vƒ“ƒOƒ‹EƒZƒNƒ^“ǂݏo‚µ‚É•ª‰ð‚³‚ꂽê‡AƒXƒ‹[ƒvƒbƒg‚ª’ቺ‚·‚邱‚Æ‚ª‚ ‚è‚Ü‚·B

    +

    一般的に、複数セクタの転送要求は、ストレージ デバイスに対して可能な限りマルチ セクタ転送しなければなりません。複数のシングル セクタ読み出しに分解された場合、スループットが低下することがあります。

    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/dstat.html b/fatfs/doc/ja/dstat.html index a74fc30..6a30944 100644 --- a/fatfs/doc/ja/dstat.html +++ b/fatfs/doc/ja/dstat.html @@ -1,7 +1,7 @@ - + @@ -13,36 +13,36 @@

    disk_status

    -

    ƒXƒgƒŒ[ƒWEƒfƒoƒCƒX‚̏ó‘Ô‚ðŽæ“¾‚µ‚Ü‚·B

    +

    ストレージ デバイスの状態を取得します。

     DSTATUS disk_status (
    -  BYTE pdrv           /* [IN] •¨—ƒhƒ‰ƒCƒu”ԍ† */
    +  BYTE pdrv           /* [IN] 物理ドライブ番号 */
     );
     
    -

    ˆø”

    +

    引数

    pdrv
    -
    ‘Ώۂ̃fƒoƒCƒX‚ðŽ¦‚·•¨—ƒhƒ‰ƒCƒu”ԍ†(0-9)‚ªŽw’肳‚ê‚Ü‚·B
    +
    対象のデバイスを識別する物理ドライブ番号(0-9)が指定されます。物理ドライブが1台のときは、常に0になります。
    -

    –ß‚è’l

    -

    ƒXƒgƒŒ[ƒWEƒfƒoƒCƒX‚̏ó‘Ô‚ðŽŸ‚Ìƒtƒ‰ƒO‚Ì‘g‚ݍ‡‚킹’l‚Å•Ô‚µ‚Ü‚·B

    +

    戻り値

    +

    現在のストレージ デバイスの状態を次のフラグの組み合わせ値で返します。

    STA_NOINIT
    -
    ƒfƒoƒCƒX‚ª‰Šú‰»‚³‚ê‚Ä‚¢‚È‚¢‚±‚Æ‚ðŽ¦‚·ƒtƒ‰ƒOBƒVƒXƒeƒ€EƒŠƒZƒbƒg‚⃁ƒfƒBƒA‚ÌŽæ‚èŠO‚µ“™‚ŃZƒbƒg‚³‚êAdisk_initialize()‚̐³íI—¹‚ŃNƒŠƒAAŽ¸”s‚ŃZƒbƒg‚³‚ê‚Ü‚·BƒƒfƒBƒAŒðŠ·‚Í”ñ“¯Šú‚É”­¶‚·‚éƒCƒxƒ“ƒg‚Ȃ̂ŁA‰ß‹Ž‚ɃƒfƒBƒAŒðŠ·‚ª‚ ‚Á‚½ê‡‚à‚±‚̃tƒ‰ƒO‚É”½‰f‚³‚¹‚é•K—v‚ª‚ ‚è‚Ü‚·BFatFsƒ‚ƒWƒ…[ƒ‹‚́A‚±‚̃tƒ‰ƒO‚ðŽQÆ‚µ‚ÄŽ©“®ƒ}ƒEƒ“ƒg“®ì‚ðs‚¤‚©‚Ç‚¤‚©‚ð”»’f‚µ‚Ü‚·B
    +
    デバイスが初期化されていないことを示すフラグ。システム リセットやメディアの取り外し等でセットされ、disk_initialize()の正常終了でクリア、失敗でセットされます。メディア交換は非同期に発生するイベントなので、過去にメディア交換があった場合もこのフラグに反映させる必要があります。FatFsモジュールは、このフラグを参照してマウント動作が必要かどうかを判断します。
    STA_NODISK
    -
    ƒƒfƒBƒA‚ª‘¶Ý‚µ‚È‚¢‚±‚Æ‚ðŽ¦‚·ƒtƒ‰ƒOBƒƒfƒBƒA‚ªŽæ‚èŠO‚³‚ê‚Ä‚¢‚éŠÔ‚̓Zƒbƒg‚³‚êAƒZƒbƒg‚³‚ê‚Ä‚¢‚éŠÔ‚̓NƒŠƒA‚³‚ê‚Ü‚·BŒÅ’èƒfƒBƒXƒN‚ł͏í‚ɃNƒŠƒA‚µ‚Ü‚·B‚È‚¨A‚±‚̃tƒ‰ƒO‚ÍFatFsƒ‚ƒWƒ…[ƒ‹‚Å‚ÍŽQÆ‚³‚ê‚Ü‚¹‚ñB
    +
    メディアが存在しないことを示すフラグ。メディアが取り外されている間はセットされ、セットされている間はクリアされます。固定ディスクでは常にクリアします。なお、このフラグはFatFsモジュールでは参照されません。
    STA_PROTECT
    -
    ƒƒfƒBƒA‚ªƒ‰ƒCƒgEƒvƒƒeƒNƒg‚³‚ê‚Ä‚¢‚邱‚Æ‚ðŽ¦‚·ƒtƒ‰ƒOBƒ‰ƒCƒgEƒvƒƒeƒNƒg‹@”\‚ðƒTƒ|[ƒg‚µ‚È‚¢‚Æ‚«‚́Aí‚ɃNƒŠƒA‚µ‚Ü‚·BƒŠ[ƒhEƒIƒ“ƒŠ\¬‚Å‚ÍŽQÆ‚³‚ê‚Ü‚¹‚ñB
    +
    メディアがライト プロテクトされていることを示すフラグ。ライト プロテクト機能をサポートしないときは、常にクリアします。リード オンリ構成では参照されません。
    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/dwrite.html b/fatfs/doc/ja/dwrite.html index 41cebeb..15d4ead 100644 --- a/fatfs/doc/ja/dwrite.html +++ b/fatfs/doc/ja/dwrite.html @@ -1,7 +1,7 @@ - + @@ -13,64 +13,64 @@

    disk_write

    -

    ƒXƒgƒŒ[ƒWEƒfƒoƒCƒX‚Ƀf[ƒ^‚ð‘‚«ž‚Ý‚Ü‚·B

    +

    ストレージ デバイスにデータを書き込みます。

     DRESULT disk_write (
    -  BYTE pdrv,        /* [IN] •¨—ƒhƒ‰ƒCƒu”ԍ† */
    -  const BYTE* buff, /* [IN] ‘‚«ž‚Þƒf[ƒ^‚ւ̃|ƒCƒ“ƒ^ */
    -  DWORD sector,     /* [IN] ‘‚«ž‚ÝŠJŽnƒZƒNƒ^”ԍ† */
    -  UINT count        /* [IN] ‘‚«ž‚ÞƒZƒNƒ^” */
    +  BYTE pdrv,        /* [IN] 物理ドライブ番号 */
    +  const BYTE* buff, /* [IN] 書き込むデータへのポインタ */
    +  DWORD sector,     /* [IN] 書き込み開始セクタ番号 */
    +  UINT count        /* [IN] 書き込むセクタ数 */
     );
     
    -

    ˆø”

    +

    引数

    pdrv
    -
    ‘Ώۂ̃fƒoƒCƒX‚ðŽ¦‚·•¨—ƒhƒ‰ƒCƒu”ԍ†(0-9)‚ªŽw’肳‚ê‚Ü‚·B
    +
    対象のデバイスを示す物理ドライブ番号(0-9)が指定されます。
    buff
    -
    ƒXƒgƒŒ[ƒWEƒfƒoƒCƒX‚ɏ‘‚«ž‚ÞƒZƒNƒ^Eƒf[ƒ^‚ªŠi”[‚³‚ꂽƒoƒCƒg”z—ñ‚ªŽw’肳‚ê‚Ü‚·BƒoƒCƒg”‚́AƒZƒNƒ^EƒTƒCƒY*count‚Æ‚È‚è‚Ü‚·B
    +
    ストレージ デバイスに書き込むセクタ データが格納されたバイト配列が指定されます。バイト数は、セクタ サイズ*countとなります。
    sector
    -
    ‘‚«ž‚Ý‚ðŠJŽn‚·‚éƒZƒNƒ^”ԍ†BLBA‚ÅŽw’肳‚ê‚Ü‚·B
    +
    書き込みを開始するセクタ番号。32ビットLBAで指定されます。
    count
    -
    ‘‚«ž‚ÞƒZƒNƒ^”BFatFs‚©‚ç‚̌Ăяo‚µ‚Å‚Í1`128‚͈̔͂ɌÀ‚ç‚ê‚Ü‚·B
    +
    書き込むセクタ数(1~128)。
    -

    –ß‚è’l

    +

    戻り値

    RES_OK (0)
    -
    ³íI—¹B
    +
    正常終了。
    RES_ERROR
    -
    ‘‚«ž‚Ý’†‚ɃGƒ‰[‚ª”­¶‚µA‚»‚̉ñ•œ‚É‚àŽ¸”s‚µ‚½B
    +
    書き込み中にエラーが発生し、その回復にも失敗した。
    RES_WRPRT
    -
    ƒƒfƒBƒA‚ª‘‚«ž‚Ý‹ÖŽ~ó‘ԁB
    +
    メディアが書き込み禁止状態。
    RES_PARERR
    -
    ƒpƒ‰ƒ[ƒ^‚ª•s³B
    +
    パラメータが不正。
    RES_NOTRDY
    -
    ƒfƒoƒCƒX‚ª“®ì‰Â”\ó‘Ô‚Å‚Í‚È‚¢i‰Šú‰»‚³‚ê‚Ä‚¢‚È‚¢jB
    +
    デバイスが動作可能状態ではない(初期化されていない)。
    -

    ‰ðà

    -

    buff‚ÉŽw’肳‚ê‚éƒAƒhƒŒƒX‚͏í‚Ƀ[ƒhEƒAƒ‰ƒCƒƒ“ƒg‚³‚ê‚Ä‚¢‚é‚Æ‚ÍŒÀ‚è‚Ü‚¹‚ñBÚ×‚́Adisk_read()‚̉ðà‚ðŽQÆ‚µ‚Ä‚­‚¾‚³‚¢B

    -

    ˆê”Ê“I‚ɁA•¡”ƒZƒNƒ^‚Ì“]‘——v‹‚́AƒfƒoƒCƒX‚ɑ΂µ‚ĉ”\‚ÈŒÀ‚èƒ}ƒ‹ƒ`EƒZƒNƒ^“]‘—‚µ‚È‚¯‚ê‚΂Ȃè‚Ü‚¹‚ñB•¡”‚̃Vƒ“ƒOƒ‹EƒZƒNƒ^‘‚«ž‚Ý‚É•ª‰ð‚³‚ꂽê‡AƒXƒ‹[ƒvƒbƒg‚ª’˜‚µ‚­’ቺ‚·‚邱‚Æ‚ª‚ ‚è‚Ü‚·B

    -

    FatFs‚̓fƒBƒXƒNŠÖ”‚ª’x‰„‘‚«ž‚Ý‹@”\‚ðŽ‚Â‚±‚Æ‚à‘z’肵‚Ä‚¢‚Ü‚·B‚±‚̊֐”‚©‚ç–ß‚é‚Æ‚«AƒfƒoƒCƒX‚ª‘‚«ž‚Ý’†‚Æ‚©ƒLƒƒƒbƒVƒ…‚ɏ‘‚«ž‚܂ꂽ‚¾‚¯‚ȂǁA•K‚¸‚µ‚àƒf[ƒ^‚̏‘‚«ž‚Ý‚ªŠ®—¹‚µ‚Ä‚¢‚é•K—v‚Í‚ ‚è‚Ü‚¹‚ñB‚½‚¾‚µAbuff‚̃f[ƒ^‚́A‚±‚̊֐”‚©‚ç–ß‚é‚Æ–³Œø‚Æ‚È‚è‚Ü‚·B‘‚«ž‚ÝŠ®—¹‚Ì—v‹‚́Adisk_ioctl()‚ÌCTRL_SYNCƒRƒ}ƒ“ƒh‚É‚æ‚Á‚čs‚í‚ê‚Ü‚·B‚±‚̂悤‚È’x‰„‘‚«ž‚Ý‹@”\‚ªŽÀ‘•‚³‚ꂽê‡AƒXƒ‹[ƒvƒbƒg‚ð‚³‚ç‚ÉŒüã‚³‚¹‚邱‚Æ‚ª‚Å‚«‚Ü‚·B

    -

    ƒAƒvƒŠƒP[ƒVƒ‡ƒ“‚©‚ç‚Í‚±‚̊֐”‚ðŒÄ‚яo‚µ‚Ä‚Í‚È‚è‚Ü‚¹‚ñB‚³‚à‚È‚¢‚ƁAFATƒ{ƒŠƒ…[ƒ€‚ª”j‰ó‚³‚ê‚é‰Â”\«‚ª‚ ‚è‚Ü‚·B

    +

    解説

    +

    buffに指定されるアドレスは常にワード アライメントされているとは限りません。詳細は、disk_read()の解説を参照してください。

    +

    一般的に、複数セクタの転送要求は、デバイスに対して可能な限りマルチ セクタ転送しなければなりません。複数のシングル セクタ書き込みに分解された場合、スループットが著しく低下することがあります。

    +

    FatFsはディスク関数が遅延書き込み機能を持つことも想定しています。この関数から戻るとき、デバイスが書き込み中とかキャッシュに書き込まれただけなど、必ずしもメディアへの書き込みが完了している必要はありません。ただし、buffのデータは、この関数から戻ると無効となります。書き込み完了の要求は、disk_ioctl()のCTRL_SYNCコマンドによって行われます。このような遅延書き込み機能が実装された場合、スループットをさらに向上させることができます。

    +

    アプリケーションからはこの関数を呼び出してはなりません。さもないと、FATボリュームが破壊される可能性があります。

    -

    ‘Ήžî•ñ

    -

    ƒŠ[ƒhEƒIƒ“ƒŠ[\¬(_FS_READONLY == 1)‚Å‚Í‚±‚̊֐”‚Í•K—v‚Æ‚³‚ê‚Ü‚¹‚ñB

    +

    対応情報

    +

    リード オンリー構成(_FS_READONLY == 1)ではこの関数は必要とされません。

    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/eof.html b/fatfs/doc/ja/eof.html index b1f0e1a..b9098b3 100644 --- a/fatfs/doc/ja/eof.html +++ b/fatfs/doc/ja/eof.html @@ -1,7 +1,7 @@ - + @@ -13,50 +13,50 @@

    f_eof

    -

    ƒŠ[ƒh/ƒ‰ƒCƒgEƒ|ƒCƒ“ƒ^‚ªƒtƒ@ƒCƒ‹I’[‚É’B‚µ‚Ä‚¢‚é‚©‚Ç‚¤‚©’²‚ׂ܂·B.

    +

    リード/ライト ポインタがファイル終端に達しているかどうか調べます。.

     int f_eof (
    -  FIL* fp   /* [IN] ƒtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg */
    +  FIL* fp   /* [IN] ファイル オブジェクト */
     );
     
    -

    ˆø”

    +

    引数

    fp
    -
    ƒtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg\‘¢‘̂ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B
    +
    ファイル オブジェクト構造体へのポインタを指定します。
    -

    –ß‚è’l

    -

    ƒŠ[ƒh/ƒ‰ƒCƒgEƒ|ƒCƒ“ƒ^‚ªƒtƒ@ƒCƒ‹I’[‚É‚ ‚è“ǂݏo‚·ƒf[ƒ^‚ª‚È‚¢ê‡‚́A0ˆÈŠO‚Ì’l‚ð•Ô‚µ‚Ü‚·B‚»‚êˆÈŠO‚ÌŽž‚Í0‚ð•Ô‚µ‚Ü‚·B

    +

    戻り値

    +

    リード/ライト ポインタがファイル終端にあり読み出すデータがない場合は、0以外の値を返します。それ以外のときは0を返します。

    -

    ‰ðà

    -

    f_eofŠÖ”‚́AŒ»ƒŠƒrƒWƒ‡ƒ“‚ł̓}ƒNƒ‚Æ‚µ‚ÄŽÀ‘•‚³‚ê‚Ä‚¢‚Ü‚·B

    +

    解説

    +

    f_eof関数は、現リビジョンではマクロとして実装されています。

    -#define f_eof(fp) (((fp)->fptr) == ((fp)->fsize) ? 1 : 0)
    +#define f_eof(fp) ((int)((fp)->fptr == (fp)->fsize))
     
    -

    ‘Ήžî•ñ

    -

    í‚ÉŽg—p‰Â”\B

    +

    対応情報

    +

    常に使用可能。

    -

    ŽQÆ

    +

    参照

    f_open, f_lseek, FIL

    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/error.html b/fatfs/doc/ja/error.html index ccd2f07..bb01d80 100644 --- a/fatfs/doc/ja/error.html +++ b/fatfs/doc/ja/error.html @@ -1,7 +1,7 @@ - + @@ -13,50 +13,50 @@

    f_error

    -

    ƒGƒ‰[”­¶‚Ì—L–³‚𒲂ׂ܂·B

    +

    エラー発生の有無を調べます。

     int f_error (
    -  FIL* fp   /* [IN] ƒtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg */
    +  FIL* fp   /* [IN] ファイル オブジェクト */
     );
     
    -

    ˆø”

    +

    引数

    fp
    -
    ƒtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg\‘¢‘̂ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B
    +
    ファイル オブジェクト構造体へのポインタを指定します。
    -

    –ß‚è’l

    -

    ƒtƒ@ƒCƒ‹‚ª‘€ì’†‚̃Gƒ‰[‚É‚æ‚Á‚ďˆ—‚ª’†’f‚³‚ê‚Ä‚¢‚éê‡‚́A0ˆÈŠO‚Ì’l‚ð•Ô‚µ‚Ü‚·B‚»‚êˆÈŠO‚ÌŽž‚Í0‚ð•Ô‚µ‚Ü‚·B

    +

    戻り値

    +

    そのファイルにおいてハード エラーによって処理が中断されている場合は、0以外の値を返します。それ以外の時は0を返します。

    -

    ‰ðà

    -

    f_errorŠÖ”‚́AŒ»ƒŠƒrƒWƒ‡ƒ“‚ł̓}ƒNƒ‚Æ‚µ‚ÄŽÀ‘•‚³‚ê‚Ä‚¢‚Ü‚·B

    +

    解説

    +

    f_error関数は、現リビジョンではマクロとして実装されています。

    -#define f_error(fp) (((fp)->flag & FA__ERROR) ? 1 : 0)
    +#define f_error(fp) ((fp)->err)
     
    -

    ‘Ήžî•ñ

    -

    í‚ÉŽg—p‰Â”\B

    +

    対応情報

    +

    常に使用可能。

    -

    ŽQÆ

    +

    参照

    f_open, FIL

    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/fattime.html b/fatfs/doc/ja/fattime.html index 028ad53..c8bbed7 100644 --- a/fatfs/doc/ja/fattime.html +++ b/fatfs/doc/ja/fattime.html @@ -1,7 +1,7 @@ - + @@ -13,7 +13,7 @@

    get_fattime

    -

    Œ»ÝŽž‚ðŽæ“¾‚µ‚Ü‚·B

    +

    現在時刻を取得します。

     DWORD get_fattime (void);
     
    @@ -21,37 +21,37 @@ DWORD get_fattime (void);
    -

    –ß‚è’l

    -

    Œ»Ý‚̃[ƒJƒ‹Eƒ^ƒCƒ€‚ðDWORD’l‚ɃpƒbƒN‚µ‚Ä•Ô‚µ‚Ü‚·BƒrƒbƒgEƒtƒB[ƒ‹ƒh‚ÍŽŸ‚ÉŽ¦‚·‚悤‚É‚È‚è‚Ü‚·B

    +

    戻り値

    +

    現在のローカル タイムをDWORD値にパックして返します。ビット フィールドは次に示すようになります。

    bit31:25
    -
    1980”N‚ð‹N“_‚Æ‚µ‚½”N‚ð 0..127 ‚ŃZƒbƒgB
    +
    1980年を起点とした年を 0..127 でセット。
    bit24:21
    -
    ŒŽ‚ð 1..12 ‚Ì’l‚ŃZƒbƒgB
    +
    月を 1..12 の値でセット。
    bit20:16
    -
    “ú‚ð 1..31 ‚Ì’l‚ŃZƒbƒgB
    +
    日を 1..31 の値でセット。
    bit15:11
    -
    Žž‚ð 0..23 ‚Ì’l‚ŃZƒbƒgB
    +
    時を 0..23 の値でセット。
    bit10:5
    -
    •ª‚ð 0..59 ‚Ì’l‚ŃZƒbƒgB
    +
    分を 0..59 の値でセット。
    bit4:0
    -
    •b/2‚ð 0..29 ‚Ì’l‚ŃZƒbƒg
    +
    秒/2を 0..29 の値でセット
    -

    ‰ðà

    -

    RTC‚ðƒTƒ|[ƒg‚µ‚È‚¢ƒVƒXƒeƒ€‚Å‚àAƒ_ƒ~[‚Æ‚µ‚ĉ½‚ç‚©‚Ì“ú•t‚Æ‚µ‚Ä—LŒø‚È’l‚ð•Ô‚·‚ׂ«‚Å‚·B0‚È‚Ç‚ð•Ô‚µ‚½ê‡A‚»‚̃tƒ@ƒCƒ‹‚̃^ƒCƒ€ƒXƒ^ƒ“ƒv‚Í–³Œø‚É‚È‚è‚Ü‚·B

    +

    解説

    +

    RTCをサポートしないシステムでも、ダミーとして何らかの日付として有効な値を返すべきです。0などを返した場合、そのファイルのタイムスタンプは無効になります。

    -

    ‘Ήžî•ñ

    -

    ƒŠ[ƒhEƒIƒ“ƒŠ[\¬(_FS_READONLY == 1)‚Å‚Í‚±‚̊֐”‚Í•K—v‚Æ‚³‚ê‚Ü‚¹‚ñB

    +

    対応情報

    +

    リード オンリー構成(_FS_READONLY == 1)ではこの関数は必要とされません。

    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/fdisk.html b/fatfs/doc/ja/fdisk.html index 27f78b3..53b6cbb 100644 --- a/fatfs/doc/ja/fdisk.html +++ b/fatfs/doc/ja/fdisk.html @@ -1,7 +1,7 @@ - + @@ -13,30 +13,30 @@

    f_fdisk

    -

    •¨—ƒhƒ‰ƒCƒu‚𕪊„‚µ‚Ü‚·B

    +

    物理ドライブを分割します。

     FRESULT f_fdisk (
    -  BYTE  pdrv,         /* [IN] •¨—ƒhƒ‰ƒCƒu”ԍ† */
    -  const DWORD part[], /* [IN] ‹æ‰æƒ}ƒbƒvEƒe[ƒuƒ‹ */
    -  void* work          /* [-] ƒ[ƒNƒGƒŠƒA */
    +  BYTE  pdrv,         /* [IN] 物理ドライブ番号 */
    +  const DWORD part[], /* [IN] 区画マップ テーブル */
    +  void* work          /* [-] ワークエリア */
     );
     
    -

    ˆø”

    +

    引数

    pdrv
    -
    •ªŠ„‚·‚镨—ƒhƒ‰ƒCƒu‚̃hƒ‰ƒCƒu”ԍ†‚ðŽw’肵‚Ü‚·B
    +
    分割する物理ドライブのドライブ番号を指定します。
    part[]
    -
    ‹æ‰æƒ}ƒbƒvEƒe[ƒuƒ‹‚ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B
    +
    区画マップ テーブルへのポインタを指定します。
    work
    -
    ƒ[ƒNƒGƒŠƒA‚ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·BƒTƒCƒY‚Í_MAX_SSƒoƒCƒg•K—v‚Å‚·B
    +
    ワークエリアへのポインタを指定します。サイズは_MAX_SSバイト必要です。
    -

    –ß‚è’l

    +

    戻り値

    FR_OK, FR_DISK_ERR, @@ -47,41 +47,41 @@ FRESULT f_fdisk (

    -

    à–¾

    -

    ‚±‚̊֐”‚́AŽw’肳‚ꂽ•¨—ƒhƒ‰ƒCƒu‚ÌMBR‚É‹æ‰æƒe[ƒuƒ‹‚ðì¬‚µ‚Ü‚·B‹æ‰æ•ª‚¯‚͈ê”Ê“I‚ÈFDISKŒ`Ž®‚ōs‚¤‚½‚߁AÅ‘å4‚‚̊î–{‹æ‰æ‚ðì¬‚·‚邱‚Æ‚ª‚Å‚«‚Ü‚·BŠg’£‹æ‰æ‚ɂ͑Ήž‚µ‚Ä‚¢‚Ü‚¹‚ñB‹æ‰æƒ}ƒbƒvƒe[ƒuƒ‹part[]‚ɂ̓hƒ‰ƒCƒu‚ð‚ǂ̂悤‚É•ªŠ„‚·‚é‚©Žw’肵‚Ä“n‚µ‚Ü‚·B‚±‚Ì”z—ñ‚Í4‚‚̍€–Ú‚©‚琬‚èAæ“ª‚̍€–Ú‚ª1”Ԗڂ́AÅŒã‚̍€–Ú‚ª4”Ô–Ú‚Ì‹æ‰æ‚̃TƒCƒY‚ðŽ¦‚µ‚Ü‚·B’l‚ª100ˆÈ‰º‚̏ꍇAƒhƒ‰ƒCƒu‚Ì‘—e—ʂɑ΂·‚銄‡‚ðƒp[ƒZƒ“ƒg’PˆÊ‚ÅŽw’肵‚Ü‚·B100‚ð’´‚¦‚é’l‚̏ꍇ‚̓ZƒNƒ^”‚Ì’¼ÚŽw’è‚É‚È‚è‚Ü‚·B

    +

    説明

    +

    この関数は、指定された物理ドライブのMBRに区画テーブルを作成します。区画分けは一般的なFDISK形式で行うため、最大4つの基本区画を作成することができます。拡張区画には対応していません。区画マップテーブルpart[]にはドライブをどのように分割するか指定して渡します。この配列は4つの項目から成り、先頭の項目が1番目の、最後の項目が4番目の区画のサイズを示します。値が100以下の場合、ドライブの総容量に対する割合をパーセント単位で指定します。100を超える値の場合はセクタ数の直接指定になります。

    -

    ‘Ήžî•ñ

    -

    _FS_READOLNY == 0 ‚Å _USE_MKFS == 1 ‚Å _MULTI_PARTITION == 1 ‚Ì‚Æ‚«Žg—p‰Â”\‚Å‚·B

    +

    対応情報

    +

    _FS_READOLNY == 0 で _USE_MKFS == 1 で _MULTI_PARTITION == 1 のとき使用可能です。

    -

    Žg—p—á

    +

    使用例

    -    /* ƒ†[ƒU’è‹`‚̃{ƒŠƒ…[ƒ€ŠÇ—ƒe[ƒuƒ‹ (_MULTI_PARTITION == 1 ‚Ì‚Æ‚«•K—v) */
    +    /* ユーザ定義のボリューム管理テーブル (_MULTI_PARTITION == 1 のとき必要) */
     
         PARTITION VolToPart[] = {
    -        {0, 1},    /* ˜_—ƒhƒ‰ƒCƒu 0 ==> •¨—ƒhƒ‰ƒCƒu 0, ‘æ1‹æ‰æ */
    -        {0, 2},    /* ˜_—ƒhƒ‰ƒCƒu 1 ==> •¨—ƒhƒ‰ƒCƒu 0, ‘æ2‹æ‰æ */
    -        {1, 0}     /* ˜_—ƒhƒ‰ƒCƒu 2 ==> •¨—ƒhƒ‰ƒCƒu 1, Ž©“®ŒŸo */
    +        {0, 1},    /* 論理ドライブ 0 ==> 物理ドライブ 0, 第1区画 */
    +        {0, 2},    /* 論理ドライブ 1 ==> 物理ドライブ 0, 第2区画 */
    +        {1, 0}     /* 論理ドライブ 2 ==> 物理ドライブ 1, 自動検出 */
         };
     
    -    /* V‚µ‚¢•¨—ƒhƒ‰ƒCƒu(0)‚̏‰Šú‰» */
    +    /* 新しい物理ドライブ(0)の初期化 */
     
         FATFS fs;
    -    DWORD plist[] = {50, 50, 0, 0};  /* 2•ªŠ„ */
    +    DWORD plist[] = {50, 50, 0, 0};  /* 2分割 */
         BYTE work[_MAX_SS];
     
    -    f_fdisk(0, plist, work);  /* •¨—ƒhƒ‰ƒCƒu 0 ‚Ì•ªŠ„ */
    +    f_fdisk(0, plist, work);  /* 物理ドライブ 0 の分割 */
     
         f_mount(&fs "0:", 0);
    -    f_mkfs("0:", 0, 0);       /* ˜_—ƒhƒ‰ƒCƒu 0 ‚̃tƒH[ƒ}ƒbƒg. ‘æ“ñˆø”‚Í–³Ž‹‚³‚ê‚é.  */
    +    f_mkfs("0:", 0, 0);       /* 論理ドライブ 0 のフォーマット. 第二引数は無視される.  */
         f_mount(0, "0:", 0);
     
         f_mount(&fs, "1:", 0);
    -    f_mkfs("1:", 0, 0);       /* ˜_—ƒhƒ‰ƒCƒu 0 ‚̃tƒH[ƒ}ƒbƒg. ‘æ“ñˆø”‚Í–³Ž‹‚³‚ê‚é.  */
    +    f_mkfs("1:", 0, 0);       /* 論理ドライブ 0 のフォーマット. 第二引数は無視される.  */
         f_mount(0, "1:", 0);
     
     
    diff --git a/fatfs/doc/ja/filename.html b/fatfs/doc/ja/filename.html index c57d7aa..524566c 100644 --- a/fatfs/doc/ja/filename.html +++ b/fatfs/doc/ja/filename.html @@ -12,28 +12,28 @@

    パス名のフォーマット

    -

    ファイル・ディレクトリ名

    +

    ファイル ディレクトリ名

    FatFsモジュールでのファイル、ディレクトリ、ドライブの指定方法はDOS/Windows APIとほぼ同じです。パス名のフォーマットは次の通りです。

    "[論理ドライブ番号:][/]ディレクトリ名/ファイル名"
    -

    FatFsモジュールは長いファイル名(LFN)および8.3形式ファイル名(SFN)に対応しています。LFNは、(_USE_LFN > 0)のとき使用可能になります。ディレクトリ・セパレータにはDOS/Windows APIと同じく'/'と'\'を使用します。連続したセパレータは無視され1個として扱われます。唯一の違いは、論理ドライブの指定だけです。論理ドライブ番号は、'0'~'9'の一文字の数字とコロンで指定し、省略した場合はデフォルト・ドライブ(0またはカレント・ドライブ)が選択されます。

    +

    FatFsモジュールは長いファイル名(LFN)および8.3形式ファイル名(SFN)に対応しています。LFNは、(_USE_LFN > 0)のとき使用可能になります。ディレクトリ セパレータにはDOS/Windows APIと同じく'/'と'\'を使用します。連続したセパレータは無視され1個として扱われます。唯一の違いは、論理ドライブの指定だけです。論理ドライブ番号は、'0'~'9'の一文字の数字とコロンで指定し、省略した場合はデフォルト ドライブ(0またはカレント ドライブ)が選択されます。

    ヌル文字や制御文字('\0'~'\x1F')は、パス名の終端として認識されます。パス名に先行あるいは中に含まれるスペースは、LFN構成では名前の一部として有効ですが、非LFN構成ではスペースはパス名の終端として認識されます。

    -

    標準構成(_FS_RPATH == 0)のときは、全てのオブジェクトがルート・ディレクトリから辿る絶対パスで指定されます。OS指向なカレント・ディレクトリという概念は無く、またドット・ディレクトリ("."や"..")は使用できません。パス名先頭のセパレータは無視されます。デフォルト・ドライブ番号は常に0になります。

    -

    相対パスを有効(_FS_RPATH == 1)にしたときは、先行するセパレータの有無によって検索開始ディレクトリが変わり、セパレータがある場合はルート・ディレクトリから、無い場合はf_chdir()で設定されるカレント・ディレクトリからになります。またパス名にドット・ディレクトリが使用できます。デフォルト・ドライブ番号はf_chdrive()で設定された値となります。

    +

    標準構成(_FS_RPATH == 0)のときは、全てのオブジェクトがルート ディレクトリから辿る絶対パスで指定されます。OS指向なカレント ディレクトリという概念は無く、またドット ディレクトリ("."や"..")は使用できません。パス名先頭のセパレータは無視されます。デフォルト ドライブ番号は常に0になります。

    +

    相対パスを有効(_FS_RPATH == 1)にしたときは、先行するセパレータの有無によって検索開始ディレクトリが変わり、セパレータがある場合はルート ディレクトリから、無い場合はf_chdir()で設定されるカレント ディレクトリからになります。またパス名にドット ディレクトリが使用できます。デフォルト ドライブ番号はf_chdrive()で設定された値となります。

    - - - - - - + + + + + + - - - + + +
    パス名の例_FS_RPATH == 0_FS_RPATH == 1
    file.txtドライブ0のルート・ディレクトリ下のファイルカレント・ドライブのカレント・ディレクトリ下のファイル
    /file.txtドライブ0のルート・ディレクトリ下のファイルカレント・ドライブのルート・ディレクトリ下のファイル
    ドライブ0のルート・ディレクトリカレント・ドライブのカレント・ディレクトリ
    2:ドライブ2のルート・ディレクトリドライブ2のカレント・ディレクトリ
    2:file1.txtドライブ2のルート・ディレクトリ下のファイルドライブ2のカレント・ディレクトリ下のファイル
    2:/ドライブ2のルート・ディレクトリドライブ2のルート・ディレクトリ
    file.txtドライブ0のルート ディレクトリ下のファイルカレント ドライブのカレント ディレクトリ下のファイル
    /file.txtドライブ0のルート ディレクトリ下のファイルカレント ドライブのルート ディレクトリ下のファイル
    ドライブ0のルート ディレクトリカレント ドライブのカレント ディレクトリ
    2:ドライブ2のルート ディレクトリドライブ2のカレント ディレクトリ
    2:file1.txtドライブ2のルート ディレクトリ下のファイルドライブ2のカレント ディレクトリ下のファイル
    2:/ドライブ2のルート ディレクトリドライブ2のルート ディレクトリ
    ../file.txt無効親ディレクトリ下のファイル
    .無効このディレクトリ
    ..無効カレント・ディレクトリの親ディレクトリ
    dir1/..無効カレント・ディレクトリ
    /..無効ルート・ディレクトリ(その上は辿れない)
    ..無効カレント ディレクトリの親ディレクトリ
    dir1/..無効カレント ディレクトリ
    /..無効ルート ディレクトリ(その上は辿れない)
    -

    また、_STR_VOLUME_IDオプションを有効にすることでドライブ番号の識別には数字のほか、任意の文字列を使用することも可能になります。

    +

    また、_STR_VOLUME_IDオプションを有効にすることでドライブ番号の識別には数字のほか、"sd:file1.txt"や"ram:swapfile.dat"のように、任意の文字列を使用することも可能になります。


    @@ -62,13 +62,13 @@ PARTITION VolToPart[] = { {0, 3}, /* 論理ドライブ 2 ==> 物理ドライブ 0, 第3区画 */ {1, 0} /* 論理ドライブ 3 ==> 物理ドライブ 1, 自動検出 */ }; - -論理ドライブと物理ドライブの関係 +
    論理ドライブと物理ドライブの関係

    複数区画指定を使用する場合、次の点に注意しなければなりません。

      -
    • マウント可能な区画は基本区画のみで、拡張区画内には対応しない。
    • 複数のマウントされた区画を持つ物理ドライブは、非リムーバブルでなければならず、システム動作中のメディア交換は禁止。
    • +
    • 基本区画のみマウント可能で、拡張区画内の区画には対応しない。
    • +
    • Windowsは、リムーバブル ドライブでは複数区画をサポートせず、先頭区画のみ認識する。
    diff --git a/fatfs/doc/ja/forward.html b/fatfs/doc/ja/forward.html index ffb2e60..e9212ce 100644 --- a/fatfs/doc/ja/forward.html +++ b/fatfs/doc/ja/forward.html @@ -1,7 +1,7 @@ - + @@ -13,34 +13,34 @@

    f_forward

    -

    ƒtƒ@ƒCƒ‹‚©‚çƒf[ƒ^‚ð“ǂݏo‚µA‘—MƒXƒgƒŠ[ƒ€‚É’¼Ú“]‘—‚µ‚Ü‚·B

    +

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

     FRESULT f_forward (
    -  FIL* fp,                         /* [IN] ƒtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg\‘¢‘Ì */
    -  UINT (*func)(const BYTE*,UINT),  /* [IN] ƒf[ƒ^“]‘—ŠÖ” */
    -  UINT btf,                        /* [IN] “]‘—‚·‚éƒoƒCƒg” */
    -  UINT* bf                         /* [OUT] “]‘—‚³‚ꂽƒoƒCƒg” */
    +  FIL* fp,                         /* [IN] ファイル オブジェクト構造体 */
    +  UINT (*func)(const BYTE*,UINT),  /* [IN] データ転送関数 */
    +  UINT btf,                        /* [IN] 転送するバイト数 */
    +  UINT* bf                         /* [OUT] 転送されたバイト数 */
     );
     
    -

    ˆø”

    +

    引数

    fp
    -
    ƒtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg\‘¢‘̂ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B
    +
    ファイル オブジェクト構造体へのポインタを指定します。
    func
    -
    ƒf[ƒ^‚ð“n‚·ƒ†[ƒU’è‹`ŠÖ”‚ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B‚±‚̊֐”‚ÌŽd—l‚̓Tƒ“ƒvƒ‹‚ðŽQÆ‚µ‚Ä‚­‚¾‚³‚¢B
    +
    データを渡すユーザ定義関数へのポインタを指定します。この関数の仕様はサンプルを参照してください。
    btf
    -
    “]‘—‚·‚éƒoƒCƒg”(0`UINT‚̍őå’l)‚ðŽw’肵‚Ü‚·B
    +
    転送するバイト数(0~UINTの最大値)を指定します。
    bf
    -
    ŽÀÛ‚É“]‘—‚³‚ꂽƒoƒCƒg”‚ðŠi”[‚·‚é•Ï”‚ðŽw‚·ƒ|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B
    +
    実際に転送されたバイト数を格納する変数を指すポインタを指定します。
    -

    –ß‚è’l

    +

    戻り値

    FR_OK, FR_DISK_ERR, @@ -54,40 +54,40 @@ FRESULT f_forward (

    -

    ‰ðà

    -

    ƒtƒ@ƒCƒ‹‚̃f[ƒ^‚ðƒoƒbƒtƒ@‚ɓǂݏo‚³‚¸‚É‘—MƒXƒgƒŠ[ƒ€‚É’¼Ú“]‘—‚µ‚Ü‚·BƒAƒvƒŠƒP[ƒVƒ‡ƒ“‘¤‚Ńf[ƒ^Eƒoƒbƒtƒ@‚ð•K—v‚Æ‚µ‚È‚¢‚̂ŁAƒƒ‚ƒŠ‚ÌŒÀ‚ç‚ꂽŠÂ‹«‚Å—LŒø‚Å‚·BƒŠ[ƒh/ƒ‰ƒCƒgEƒ|ƒCƒ“ƒ^‚Í“]‘—‚³‚ꂽƒoƒCƒg”‚¾‚¯i‚Ý‚Ü‚·BŽw’肳‚ꂽƒoƒCƒg”‚Ì“]‘—’†‚Ƀtƒ@ƒCƒ‹‚̏I’[‚É’B‚µ‚½ê‡‚â‘—MƒXƒgƒŠ[ƒ€‚ªƒrƒW[‚É‚È‚Á‚½ê‡A*bf‚Íbtf‚æ‚è‚à¬‚³‚­‚È‚è‚Ü‚·B

    +

    解説

    +

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

    -

    ‘Ήžî•ñ

    -

    _USE_FORWARD == 1‚ŁAŠŽ‚Â_FS_TINY == 1‚Ì‚Æ‚«‚ÉŽg—p‰Â”\‚Å‚·B

    +

    対応情報

    +

    _USE_FORWARD == 1で、且つ_FS_TINY == 1のときに使用可能です。

    -

    Žg—p—áiƒI[ƒfƒBƒIÄ¶j

    +

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

     /*-----------------------------------------------------------------------*/
    -/* f_forwardŠÖ”‚©‚çŒÄ‚΂ê‚éƒf[ƒ^‘—MŠÖ”‚Ì—á                           */
    +/* f_forward関数から呼ばれるデータ送信関数の例                           */
     /*-----------------------------------------------------------------------*/
     
    -UINT out_stream (   /* –ß‚è’l: “]‘—‚³‚ꂽƒoƒCƒg”‚Ü‚½‚̓XƒgƒŠ[ƒ€‚̏ó‘Ô */
    -    const BYTE *p,  /* “]‘—‚·‚éƒf[ƒ^‚ðŽw‚·ƒ|ƒCƒ“ƒ^ */
    -    UINT btf        /* >0: “]‘—‚ðs‚¤(ƒoƒCƒg”). 0: ƒXƒgƒŠ[ƒ€‚̏ó‘Ԃ𒲂ׂé */
    +UINT out_stream (   /* 戻り値: 転送されたバイト数またはストリームの状態 */
    +    const BYTE *p,  /* 転送するデータを指すポインタ */
    +    UINT btf        /* >0: 転送を行う(バイト数). 0: ストリームの状態を調べる */
     )
     {
         UINT cnt = 0;
     
     
    -    if (btf == 0) {     /* ƒZƒ“ƒX—v‹ */
    -        /* ƒXƒgƒŠ[ƒ€‚̏ó‘Ô‚ð•Ô‚· (0: ƒrƒW[, 1: ƒŒƒfƒB) */
    -        /* ˆê’UAƒŒƒfƒB‚ð•Ô‚µ‚½‚çA‘±‚­“]‘——v‹‚ŏ­‚È‚­‚Æ‚à1ƒoƒCƒg‚Í */
    -        /* “]‘—‚³‚ê‚È‚¢‚Æ f_forwardŠÖ”‚Í FR_INT_ERR ‚Æ‚È‚éB */
    +    if (btf == 0) {     /* センス要求 */
    +        /* ストリームの状態を返す (0: ビジー, 1: レディ) */
    +        /* 一旦、レディを返したら、続く転送要求で少なくとも1バイトは */
    +        /* 転送されないと f_forward関数は FR_INT_ERR となる。 */
             if (FIFO_READY) cnt = 1;
         }
    -    else {              /* “]‘——v‹ */
    -        do {    /* ‘S‚ẴoƒCƒg‚ð“]‘—‚·‚é‚©AƒXƒgƒŠ[ƒ€‚ªƒrƒW[‚É‚È‚é‚Ü‚ÅŒJ‚è•Ô‚· */
    +    else {              /* 転送要求 */
    +        do {    /* 全てのバイトを転送するか、ストリームがビジーになるまで繰り返す */
                 FIFO_PORT = *p++;
                 cnt++;
             } while (cnt < btf && FIFO_READY);
    @@ -98,31 +98,31 @@ UINT out_stream (   /* 
     
     
     /*-----------------------------------------------------------------------*/
    -/* f_forwardŠÖ”‚ÌŽg—p—á                                                 */
    +/* f_forward関数の使用例                                                 */
     /*-----------------------------------------------------------------------*/
     
     FRESULT play_file (
    -    char *fn        /* Ä¶‚·‚éƒI[ƒfƒBƒIEƒtƒ@ƒCƒ‹–¼‚ðŽw‚·ƒ|ƒCƒ“ƒ^ */
    +    char *fn        /* 再生するオーディオ ファイル名を指すポインタ */
     )
     {
         FRESULT rc;
         FIL fil;
         UINT dmy;
     
    -    /* ƒtƒ@ƒCƒ‹‚ð“ǂݏo‚µƒ‚[ƒh‚ÅŠJ‚­ */
    +    /* ファイルを読み出しモードで開く */
         rc = f_open(&fil, fn, FA_READ);
         if (rc) return rc;
     
    -    /* ‘S‚Ẵf[ƒ^‚ª“]‘—‚³‚ê‚é‚©ƒGƒ‰[‚ª”­¶‚·‚é‚Ü‚Å‘±‚¯‚é */
    +    /* 全てのデータが転送されるかエラーが発生するまで続ける */
         while (rc == FR_OK && fil.fptr < fil.fsize) {
     
    -        /* ‚Ù‚©‚̏ˆ—... */
    +        /* ほかの処理... */
     
    -        /* ’èŠú“I‚Ü‚½‚Í—v‹‚ɉž‚¶‚ăf[ƒ^‚ðƒXƒgƒŠ[ƒ€‚É‘—o‚·‚é */
    +        /* 定期的または要求に応じてデータをストリームに送出する */
             rc = f_forward(&fil, out_stream, 1000, &dmy);
         }
     
    -    /* ƒtƒ@ƒCƒ‹‚ð•Â‚¶‚Ä–ß‚é */
    +    /* ファイルを閉じて戻る */
         f_close(&fil);
         return rc;
     }
    @@ -131,10 +131,10 @@ FRESULT play_file (
     
     
     
    -

    ŽQÆ

    +

    参照

    f_open, fgets, f_write, f_close, FIL

    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/getcwd.html b/fatfs/doc/ja/getcwd.html index b48f3fc..24e4844 100644 --- a/fatfs/doc/ja/getcwd.html +++ b/fatfs/doc/ja/getcwd.html @@ -1,7 +1,7 @@ - + @@ -13,28 +13,28 @@

    f_getcwd

    -

    ƒJƒŒƒ“ƒgEƒfƒBƒŒƒNƒgƒŠ‚𓾂܂·B

    +

    カレント ディレクトリを得ます。

     FRESULT f_getcwd (
    -  TCHAR* buff, /* [OUT] ƒoƒbƒtƒ@ */
    -  UINT len     /* [IN] ƒoƒbƒtƒ@EƒTƒCƒY */
    +  TCHAR* buff, /* [OUT] バッファ */
    +  UINT len     /* [IN] バッファ サイズ */
     );
     
    -

    ˆø”

    +

    引数

    buff
    -
    ƒJƒŒƒ“ƒgEƒfƒBƒŒƒNƒgƒŠ‚̃pƒX–¼•¶Žš—ñ‚ðŠi”[‚·‚éƒoƒbƒtƒ@
    +
    カレント ディレクトリのパス名文字列を格納するバッファ
    len
    -
    TCHAR’PˆÊ‚̃oƒbƒtƒ@EƒTƒCƒY
    +
    TCHAR単位のバッファ サイズ
    -

    –ß‚è’l

    +

    戻り値

    FR_OK, FR_DISK_ERR, @@ -49,22 +49,22 @@ FRESULT f_getcwd (

    -

    ‰ðà

    -

    ƒJƒŒƒ“ƒgEƒhƒ‰ƒCƒu‚̃JƒŒƒ“ƒgEƒfƒBƒŒƒNƒgƒŠ‚̃tƒ‹EƒpƒX•¶Žš—ñ‚ðŽæ“¾‚µ‚Ü‚·B_VOLUMES‚ª2ˆÈã‚Ì‚Æ‚«‚́A˜_—ƒhƒ‰ƒCƒu”ԍ†‚Ì•t‰Á‚³‚ꂽƒpƒX–¼‚Æ‚È‚è‚Ü‚·B

    +

    解説

    +

    カレント ドライブのカレント ディレクトリのフル パス文字列を取得します。_VOLUMESが2以上のときは、論理ドライブ番号の付加されたパス名となります。

    -

    ‘Ήžî•ñ

    -

    _FS_RPATH == 2‚Ì‚Æ‚«Žg—p‰Â”\‚Å‚·B

    +

    対応情報

    +

    _FS_RPATH == 2のとき使用可能です。

    -

    ŽQÆ

    +

    参照

    f_chdrive, f_chdir

    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/getfree.html b/fatfs/doc/ja/getfree.html index 4de40de..8b99c76 100644 --- a/fatfs/doc/ja/getfree.html +++ b/fatfs/doc/ja/getfree.html @@ -1,7 +1,7 @@ - + @@ -13,31 +13,31 @@

    f_getfree

    -

    ƒ{ƒŠƒ…[ƒ€ã‚̋󂫗̈æ‚̃TƒCƒY‚ðŽæ“¾‚µ‚Ü‚·B

    +

    ボリューム上の空き領域のサイズを取得します。

     FRESULT f_getfree (
    -  const TCHAR* path,  /* [IN] ‘Ώۃhƒ‰ƒCƒu‚ðŽw’肵‚Ü‚· */
    -  DWORD* nclst,       /* [OUT] ‹ó‚«ƒNƒ‰ƒXƒ^”‚ðŠi”[‚·‚é•Ï”‚ւ̃|ƒCƒ“ƒ^ */
    -  FATFS** fatfs       /* [OUT] ƒtƒ@ƒCƒ‹EƒVƒXƒeƒ€EƒIƒuƒWƒFƒNƒg‚ðŽw‚·ƒ|ƒCƒ“ƒ^‚ւ̃|ƒCƒ“ƒ^ */
    +  const TCHAR* path,  /* [IN] 対象ドライブを指定します */
    +  DWORD* nclst,       /* [OUT] 空きクラスタ数を格納する変数へのポインタ */
    +  FATFS** fatfs       /* [OUT] ファイル システム オブジェクトを指すポインタへのポインタ */
     );
     
    -

    ˆø”

    +

    引数

    path
    -
    ’²‚ׂé‘Ώۂ̘_—ƒhƒ‰ƒCƒu‚ðŽ¦‚·ƒpƒX–¼‚ðŽ¦‚·ƒkƒ‹•¶Žš'\0'I’[‚Ì•¶Žš—ñ‚ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·Bƒkƒ‹•¶Žš—ñ‚̓JƒŒƒ“ƒgEƒhƒ‰ƒCƒu‚ðˆÓ–¡‚µ‚Ü‚·B
    +
    調べる対象の論理ドライブを示すパス名を示すヌル文字'\0'終端の文字列へのポインタを指定します。ヌル文字列はカレント ドライブを意味します。
    nclst
    -
    ‹ó‚«ƒNƒ‰ƒXƒ^”‚ðŠi”[‚·‚éDWORDŒ^•Ï”‚ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B
    +
    空きクラスタ数を格納するDWORD型変数へのポインタを指定します。
    fatfs
    -
    ‘Ώۃhƒ‰ƒCƒu‚̃tƒ@ƒCƒ‹EƒVƒXƒeƒ€EƒIƒuƒWƒFƒNƒg‚ðŽw‚·ƒ|ƒCƒ“ƒ^‚ª•Ô‚³‚ê‚Ü‚·B
    +
    対象ドライブのファイル システム オブジェクトを指すポインタが返されます。
    -

    –ß‚è’l

    +

    戻り値

    FR_OK, FR_DISK_ERR, @@ -52,33 +52,33 @@ FRESULT f_getfree (

    -

    ‰ðà

    -

    ˜_—ƒhƒ‰ƒCƒuã‚̋󂫗̈æ‚̃TƒCƒY‚ðƒNƒ‰ƒXƒ^’PˆÊ‚Ŏ擾‚µ‚Ü‚·B•Ô‚³‚ꂽƒtƒ@ƒCƒ‹EƒVƒXƒeƒ€EƒIƒuƒWƒFƒNƒg‚Ìcsizeƒƒ“ƒo‚ªƒNƒ‰ƒXƒ^‚ ‚½‚è‚̃ZƒNƒ^”‚ðŽ¦‚µ‚Ä‚¢‚é‚̂ŁA‚±‚ê‚ðŒ³‚ÉƒZƒNƒ^’PˆÊ‚̋󂫃TƒCƒY‚ªŒvŽZ‚Å‚«‚Ü‚·BFAT32ƒ{ƒŠƒ…[ƒ€‚É‚¨‚¢‚ẮAFSINFO‚̏î•ñ‚ªŽÀÛ‚̋󂫃Nƒ‰ƒXƒ^”‚Æ“¯Šú‚µ‚Ä‚¢‚È‚¢ê‡A•s³Šm‚È’l‚ð•Ô‚·‰Â”\«‚ª‚ ‚è‚Ü‚·B‚±‚Ì–â‘è‚ð”ð‚¯‚é‚½‚߁A_FS_NOFSINFOƒIƒvƒVƒ‡ƒ“‚Ń}ƒEƒ“ƒgŒã‚̏‰‰ñ‚Í•K‚¸ƒtƒ‹FATƒXƒLƒƒƒ“‚ð‚·‚é‚悤‚ɍ\¬‚·‚邱‚Æ‚à‚Å‚«‚Ü‚·B

    +

    解説

    +

    論理ドライブ上の空き領域のサイズをクラスタ単位で取得します。返されたファイル システム オブジェクトのcsizeメンバがクラスタあたりのセクタ数を示しているので、これを元にセクタ単位の空きサイズが計算できます。FAT32ボリュームにおいては、FSINFOの情報が実際の空きクラスタ数と同期していない場合、不正確な値を返す可能性があります。この問題を避けるため、_FS_NOFSINFOオプションでマウント後の初回は必ずフルFATスキャンをするように構成することもできます。

    -

    ‘Ήžî•ñ

    -

    _FS_READONLY == 0‚ŁAŠŽ‚Â_FS_MINIMIZE == 0‚Ì‚Æ‚«Žg—p‰Â”\‚Å‚·B

    +

    対応情報

    +

    _FS_READONLY == 0で、且つ_FS_MINIMIZE == 0のとき使用可能です。

    -

    Žg—p—á

    +

    使用例

         FATFS *fs;
         DWORD fre_clust, fre_sect, tot_sect;
     
     
    -    /* ƒhƒ‰ƒCƒu1‚̃{ƒŠƒ…[ƒ€î•ñ‚Ƌ󂫃Nƒ‰ƒXƒ^”‚𓾂é */
    +    /* ドライブ1のボリューム情報と空きクラスタ数を得る */
         res = f_getfree("1:", &fre_clust, &fs);
         if (res) die(res);
     
    -    /* ‘SƒZƒNƒ^”‚Ƌ󂫃ZƒNƒ^”‚ðŒvŽZ */
    +    /* 全セクタ数と空きセクタ数を計算 */
         tot_sect = (fs->n_fatent - 2) * fs->csize;
         fre_sect = fre_clust * fs->csize;
     
    -    /* ƒ{ƒŠƒ…[ƒ€‘S‘̂̃TƒCƒY‚Ƌ󂫂̃TƒCƒY‚ð•\Ž¦ (512ƒoƒCƒg/ƒZƒNƒ^‚Ɖ¼’è) */
    +    /* ボリューム全体のサイズと空きのサイズを表示 (512バイト/セクタと仮定) */
         printf("%10lu KiB total drive space.\n%10lu KiB available.\n",
                tot_sect / 2, fre_sect / 2);
     
    @@ -86,10 +86,10 @@ FRESULT f_getfree (
    -

    ŽQÆ

    +

    参照

    FATFS
    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/getlabel.html b/fatfs/doc/ja/getlabel.html index 957d212..bfcad0d 100644 --- a/fatfs/doc/ja/getlabel.html +++ b/fatfs/doc/ja/getlabel.html @@ -1,7 +1,7 @@ - + @@ -13,31 +13,31 @@

    f_getlabel

    -

    ƒ{ƒŠƒ…[ƒ€Eƒ‰ƒxƒ‹‚ðŽæ“¾‚µ‚Ü‚·B

    +

    ボリューム ラベルを取得します。

     FRESULT f_getlabel (
    -  const TCHAR* path,  /* [IN] ‘Ώۃhƒ‰ƒCƒu */
    -  TCHAR* label,       /* [OUT] ƒ{ƒŠƒ…[ƒ€–¼‚ðŠi”[‚·‚éƒoƒbƒtƒ@ */
    -  DWORD* vsn          /* [OUT] ƒ{ƒŠƒ…[ƒ€EƒVƒŠƒAƒ‹”ԍ†‚ðŠi”[‚·‚é•Ï” */
    +  const TCHAR* path,  /* [IN] 対象ドライブ */
    +  TCHAR* label,       /* [OUT] ボリューム名を格納するバッファ */
    +  DWORD* vsn          /* [OUT] ボリューム シリアル番号を格納する変数 */
     );
     
    -

    ˆø”

    +

    引数

    path
    -
    ‘ΏۂƂȂé˜_—ƒhƒ‰ƒCƒu‚̃pƒX–¼‚ðŽ¦‚·ƒkƒ‹•¶Žš'\0'I’[‚Ì•¶Žš—ñ‚ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·Bƒkƒ‹•¶Žš—ñ‚̏ꍇ‚́AƒfƒtƒHƒ‹ƒgEƒhƒ‰ƒCƒu‚ðŽw’肵‚½‚±‚Æ‚É‚È‚è‚Ü‚·B
    +
    対象となる論理ドライブのパス名を示すヌル文字'\0'終端の文字列へのポインタを指定します。ヌル文字列の場合は、デフォルト ドライブを指定したことになります。
    label
    -
    ƒ{ƒŠƒ…[ƒ€–¼‚ðŠi”[‚·‚é”z—ñ‚ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B­‚È‚­‚Æ‚à12—v‘f‚̃TƒCƒY‚ª•K—v‚Å‚·Bƒ{ƒŠƒ…[ƒ€–¼‚ª‚È‚¢ê‡‚̓kƒ‹•¶Žš—ñ‚ª•Ô‚³‚ê‚Ü‚·B‚±‚̏î•ñ‚ª•s—v‚È‚Æ‚«‚̓kƒ‹Eƒ|ƒCƒ“ƒ^‚ðŽw’肵‚Ä‚­‚¾‚³‚¢B
    +
    ボリューム名を格納する配列へのポインタを指定します。少なくとも12要素のサイズが必要です。ボリューム名がない場合はヌル文字列が返されます。この情報が不要なときはヌル ポインタを指定してください。
    vsn
    -
    ƒ{ƒŠƒ…[ƒ€EƒVƒŠƒAƒ‹”ԍ†‚ðŠi”[‚·‚éDWORDŒ^•Ï”‚ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B‚±‚̏î•ñ‚ª•s—v‚È‚Æ‚«‚̓kƒ‹Eƒ|ƒCƒ“ƒ^‚ðŽw’肵‚Ä‚­‚¾‚³‚¢B
    +
    ボリューム シリアル番号を格納するDWORD型変数へのポインタを指定します。この情報が不要なときはヌル ポインタを指定してください。
    -

    –ß‚è’l

    +

    戻り値

    FR_OK, FR_DISK_ERR, @@ -52,31 +52,31 @@ FRESULT f_getlabel (

    -

    ‘Ήžî•ñ

    -

    _USE_LABEL == 1‚Ì‚Æ‚«‚ÉŽg—p‰Â”\‚Å‚·B

    +

    対応情報

    +

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

    -

    Žg—p—á

    +

    使用例

         char str[12];
     
    -    /* ƒfƒtƒHƒ‹ƒgEƒhƒ‰ƒCƒu‚̃{ƒŠƒ…[ƒ€–¼‚𓾂é */
    +    /* デフォルト ドライブのボリューム名を得る */
         f_getlabel("", str, 0);
     
    -    /* ƒhƒ‰ƒCƒu2‚̃{ƒŠƒ…[ƒ€–¼‚𓾂é */
    +    /* ドライブ2のボリューム名を得る */
         f_getlabel("2:", str, 0);
     
    -

    ŽQÆ

    +

    参照

    f_setlabel
    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/gets.html b/fatfs/doc/ja/gets.html index 2babef0..74e0b22 100644 --- a/fatfs/doc/ja/gets.html +++ b/fatfs/doc/ja/gets.html @@ -1,7 +1,7 @@ - + @@ -13,53 +13,53 @@

    f_gets

    -

    ƒtƒ@ƒCƒ‹‚©‚當Žš—ñ‚ð“ǂݏo‚µ‚Ü‚·B

    +

    ファイルから文字列を読み出します。

     TCHAR* f_gets (
    -  TCHAR* buff, /* [OUT] ƒoƒbƒtƒ@ */
    -  int len,     /* [IN] ƒoƒbƒtƒ@‚̃TƒCƒY */
    -  FIL* fp      /* [IN] ƒtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg */
    +  TCHAR* buff, /* [OUT] バッファ */
    +  int len,     /* [IN] バッファのサイズ */
    +  FIL* fp      /* [IN] ファイル オブジェクト */
     );
     
    -

    ˆø”

    +

    引数

    buff
    -
    •¶Žš—ñ‚ð“ǂݏo‚·ƒoƒbƒtƒ@‚ðŽw‚·ƒ|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B
    +
    文字列を読み出すバッファを指すポインタを指定します。
    len
    -
    ƒoƒbƒtƒ@‚̃TƒCƒY‚ð—v‘f”‚ÅŽw’肵‚Ü‚·B
    +
    バッファのサイズを要素数で指定します。
    fp
    -
    ƒtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg\‘¢‘̂ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B
    +
    ファイル オブジェクト構造体へのポインタを指定します。
    -

    –ß‚è’l

    -

    ŠÖ”‚ª¬Œ÷‚·‚é‚Æbuff‚ª•Ô‚³‚ê‚Ü‚·B

    +

    戻り値

    +

    関数が成功するとbuffが返されます。

    -

    ‰ðà

    -

    ‚±‚̊֐”‚Íf_read()‚̃‰ƒbƒp[ŠÖ”‚Å‚·B“ǂݏo‚µ“®ì‚́AÅ‰‚Ì'\n'‚ð“ǂݍž‚Þ‚©Aƒtƒ@ƒCƒ‹I’[‚É’B‚·‚é‚©Alen - 1•¶Žš‚ð“ǂݏo‚·‚Ü‚Å‘±‚«‚Ü‚·B“ǂݍž‚܂ꂽ•¶Žš—ñ‚̏I’[‚É‚Í'\0'‚ª•t‰Á‚³‚ê‚Ü‚·BŠù‚Ƀtƒ@ƒCƒ‹I’[‚Å1•¶Žš‚à“ǂݍž‚Ü‚ê‚È‚©‚Á‚½‚Æ‚«A‚Ü‚½‚͉½‚ç‚©‚̃Gƒ‰[‚ª”­¶‚µ‚½‚Æ‚«‚͊֐”‚ÍŽ¸”s‚µƒkƒ‹Eƒ|ƒCƒ“ƒ^‚ð•Ô‚µ‚Ü‚·Bƒtƒ@ƒCƒ‹I’[‚©ƒGƒ‰[‚©‚Íf_eof(),f_error()ƒ}ƒNƒ‚Å’²‚ׂç‚ê‚Ü‚·B

    -

    Unicode API\¬(_LFN_UNICODE == 1)‚ª‘I‘ð‚³‚ê‚Ä‚¢‚é‚Æ‚«‚́Abuff‚ÍUTF-16•¶Žš—ñ‚É‚È‚è‚Ü‚·‚ªAƒtƒ@ƒCƒ‹ã‚̃Gƒ“ƒR[ƒh‚́A_STRF_ENCODEƒIƒvƒVƒ‡ƒ“‚Å‘I‘ð‚Å‚«‚Ü‚·B‚»‚êˆÈŠO‚ÌŽž‚Í–³•ÏŠ·(1ƒoƒCƒg/1•¶Žš)‚œǂݏo‚µ‚Ü‚·B

    +

    解説

    +

    この関数はf_read()のラッパー関数です。読み出し動作は、最初の'\n'を読み込むか、ファイル終端に達するか、len - 1文字を読み出すまで続きます。読み込まれた文字列の終端には'\0'が付加されます。既にファイル終端で1文字も読み込まれなかったとき、または何らかのエラーが発生したときは関数は失敗しヌル ポインタを返します。ファイル終端かエラーかはf_eof(),f_error()マクロで調べられます。

    +

    Unicode API構成(_LFN_UNICODE == 1)が選択されているときは、buffはUTF-16文字列になりますが、ファイル上のエンコードは、_STRF_ENCODEオプションで選択できます。それ以外の時は無変換(1バイト/1文字)で読み出します。

    -

    ‘Ήžî•ñ

    -

    _USE_STRFUNC‚ª1‚Ü‚½‚Í2‚Ì‚Æ‚«Žg—p‰Â”\‚Å‚·B2‚Ì‚Æ‚«‚́Aƒtƒ@ƒCƒ‹‚ÉŠÜ‚Ü‚ê‚é'\r'‚ªŽæ‚菜‚©‚ê‚ăoƒbƒtƒ@‚ɓǂݍž‚Ü‚ê‚Ü‚·B

    +

    対応情報

    +

    _USE_STRFUNCが1または2のとき使用可能です。2のときは、ファイルに含まれる'\r'が取り除かれてバッファに読み込まれます。

    -

    ŽQÆ

    +

    参照

    f_open, f_read, f_putc, f_puts, f_printf, f_close, FIL

    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/lseek.html b/fatfs/doc/ja/lseek.html index 5578852..88e1ab2 100644 --- a/fatfs/doc/ja/lseek.html +++ b/fatfs/doc/ja/lseek.html @@ -1,7 +1,7 @@ - + @@ -13,28 +13,28 @@

    f_lseek

    -

    ƒtƒ@ƒCƒ‹‚̃Š[ƒh/ƒ‰ƒCƒgEƒ|ƒCƒ“ƒ^‚ðˆÚ“®‚µ‚Ü‚·B‚Ü‚½A‚‘¬ƒV[ƒN‹@”\Žg—pŽž‚É‚ÍCLMT(Œãq)‚̍쐬‚É‚àŽg—p‚µ‚Ü‚·B

    +

    ファイルのリード/ライト ポインタを移動します。また、高速シーク機能使用時にはCLMT(後述)の作成にも使用します。

     FRESULT f_lseek (
    -  FIL* fp,    /* [IN] ƒtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg\‘¢‘̂ւ̃|ƒCƒ“ƒ^ */
    -  DWORD ofs   /* [IN] ˆÚ“®æƒIƒtƒZƒbƒg */
    +  FIL* fp,    /* [IN] ファイル オブジェクト構造体へのポインタ */
    +  DWORD ofs   /* [IN] 移動先オフセット */
     );
     
    -

    ˆø”

    +

    引数

    fp
    -
    ‘ΏۂƂȂéƒtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg\‘¢‘̂ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B
    +
    対象となるファイル オブジェクト構造体へのポインタを指定します。
    ofs
    -
    ˆÚ“®æ‚̃IƒtƒZƒbƒg(ƒŠ[ƒh/ƒ‰ƒCƒgEƒ|ƒCƒ“ƒ^)’lBƒtƒ@ƒCƒ‹æ“ª‚©‚ç‚̃IƒtƒZƒbƒg‚ðƒoƒCƒg’PˆÊ‚ÅŽw’肵‚Ü‚·B
    +
    移動先のオフセット(リード/ライト ポインタ)値。ファイル先頭からのオフセットをバイト単位で指定します。
    -

    –ß‚è’l

    +

    戻り値

    FR_OK, FR_DISK_ERR, @@ -48,82 +48,82 @@ FRESULT f_lseek (

    -

    ‰ðà

    -

    ƒtƒ@ƒCƒ‹‚̃Š[ƒh/ƒ‰ƒCƒgEƒ|ƒCƒ“ƒ^(ŽŸ‚ɓǂݏo‚µE‘‚«ž‚Ý‚³‚ê‚éƒoƒCƒg‚̃IƒtƒZƒbƒg)‚ðˆÚ“®‚µ‚Ü‚·BƒIƒtƒZƒbƒg‚ÌŒ´“_‚̓tƒ@ƒCƒ‹æ“ª‚Å‚·B‘‚«ž‚݃‚[ƒh‚Ńtƒ@ƒCƒ‹EƒTƒCƒY‚æ‚è‘å‚«‚È’l‚ðŽw’è‚·‚é‚ƁA‚»‚±‚܂Ńtƒ@ƒCƒ‹EƒTƒCƒY‚ªŠg’£‚³‚êAŠg’£‚³‚ꂽ•”•ª‚̃f[ƒ^‚Í–¢’è‹`‚Æ‚È‚è‚Ü‚·Bƒf[ƒ^‚ð’x‰„–³‚­‚‘¬‚ɏ‘‚«ž‚Ý‚½‚¢‚Æ‚«‚́A—\‚ß‚±‚̊֐”‚Å•K—v‚ȃTƒCƒY‚܂Ńtƒ@ƒCƒ‹EƒTƒCƒY‚ðŠg’£‚µ‚Ä‚¨‚­‚Æ—Ç‚¢‚Å‚µ‚傤Bf_lseek()‚ª³íI—¹‚µ‚½‚ ‚Ƃ́AƒŠ[ƒh/ƒ‰ƒCƒgEƒ|ƒCƒ“ƒ^‚ª³‚µ‚­ˆÚ“®‚µ‚½‚©ƒ`ƒFƒbƒN‚·‚é‚ׂ«‚Å‚·BƒŠ[ƒh/ƒ‰ƒCƒgEƒ|ƒCƒ“ƒ^‚ªŽw’è‚æ‚菬‚³‚¢‚Æ‚«‚́AŽŸ‚ÌŒ´ˆö‚ªl‚¦‚ç‚ê‚Ü‚·B

    +

    解説

    +

    ファイルのリード/ライト ポインタ(次に読み出し・書き込みされるバイトのオフセット)を移動します。オフセットの原点はファイル先頭です。書き込みモードでファイル サイズより大きな値を指定すると、そこまでファイル サイズが拡張され、拡張された部分のデータは未定義となります。データを遅延無く高速に書き込みたいときは、予めこの関数で必要なサイズまでファイル サイズを拡張しておくと良いでしょう。f_lseek()が正常終了したあとは、リード/ライト ポインタが正しく移動したかチェックするべきです。リード/ライト ポインタが指定より小さいときは、次の原因が考えられます。

      -
    • ”ñ‘‚«ž‚݃‚[ƒh‚Ü‚½‚͍‚‘¬ƒV[ƒNEƒ‚[ƒh‚Ì‚½‚߁Aƒtƒ@ƒCƒ‹EƒTƒCƒY‚ŃNƒŠƒbƒv‚³‚ꂽB
    • -
    • ƒtƒ@ƒCƒ‹Šg’£’†‚ɃfƒBƒXƒN‚ª–ž”t‚É‚È‚Á‚½B
    • +
    • 非書き込みモードまたは高速シーク モードのため、ファイル サイズでクリップされた。
    • +
    • ファイル拡張中にディスクが満杯になった。
    -

    _USE_FASTSEEK‚ª1‚ŁAŠŽ‚ƒtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg‚Ìcltblƒƒ“ƒo‚ªNULLˆÈŠO(f_open()‚ÅNULL‚ɐݒ肳‚ê‚é)‚Ì‚Æ‚«A‚‘¬ƒV[ƒNEƒ‚[ƒh‚É‚È‚è‚Ü‚·B‚±‚ê‚̓tƒ@ƒCƒ‹‚̃Nƒ‰ƒXƒ^”z’uî•ñ(CLMT)‚ðƒƒ‚ƒŠã‚É•ÛŽ‚µ‚Ä‚¨‚­‚±‚Æ‚É‚æ‚èAFAT‚ɃAƒNƒZƒX‚·‚邱‚Æ‚È‚­Œã•ûƒV[ƒN‚⃍ƒ“ƒOEƒV[ƒN‚ð‚‘¬‚ɍs‚¤‹@”\‚Å‚·B‚‘¬ƒV[ƒNEƒ‚[ƒh‚́Af_read()/f_wtite()‚Ì“®ì‚É‚à“K—p‚³‚ê‚Ü‚·B‚‘¬ƒV[ƒNEƒ‚[ƒh‚Å‚Íf_wtite()/f_lseek()‚É‚æ‚éƒtƒ@ƒCƒ‹EƒTƒCƒY‚ÌŠg’£‚Í‚Å‚«‚Ü‚¹‚ñB

    -

    ‚‘¬ƒV[ƒN“®ì‚ðs‚¤‘O‚ɁACLMT‚ðì¬‚µ‚Ä‚¨‚­•K—v‚ª‚ ‚è‚Ü‚·B‚±‚ê‚ðì¬‚·‚é‚ɂ́A‚Ü‚¸CLMTŠi”[ƒoƒbƒtƒ@(DWORDŒ^”z—ñ)‚ð€”õ‚µAcltblƒƒ“ƒo‚É‚»‚̃|ƒCƒ“ƒ^‚ðƒZƒbƒg‚µ‚Ü‚·B‚»‚µ‚āA”z—ñ‚̐擪—v‘f‚É‚»‚Ì”z—ñ‚̃TƒCƒY(—v‘f”)‚ð“ü‚êAf_lseek()‚ðofs‚ÉCREATE_LINKMAP‚ðŽw’肵‚ČĂяo‚µ‚Ü‚·BŠÖ”‚ª¬Œ÷‚·‚é‚ÆCLMT‚ªì¬‚³‚êAˆÈ~‚Ìf_read()/f_write()/f_lseek()‚Å‚ÍFAT‚ւ̃AƒNƒZƒX‚Í”­¶‚µ‚Ü‚¹‚ñBFR_NOT_ENOUGH_CORE‚ÅŽ¸”s‚µ‚½‚Æ‚«‚Í”z—ñƒTƒCƒY‚ª•s‘«‚ŁAæ“ª—v‘f‚É‚ÍŽÀÛ‚É•K—v‚Æ‚È‚é—v‘f”‚ª•Ô‚³‚ê‚Ü‚·B•K—v‚È—v‘f”‚́A(ƒtƒ@ƒCƒ‹‚Ì•ªŠ„” + 1) * 2 ‚Å‚·B‚½‚Æ‚¦‚΁Aƒtƒ@ƒCƒ‹‚ª5‚‚̃tƒ‰ƒOƒƒ“ƒg‚É•ª’f‚³‚ê‚Ä‚¢‚é‚Æ‚«‚É•K—v‚È—v‘f”‚́A12‚Æ‚È‚è‚Ü‚·B

    +

    _USE_FASTSEEKが1で、且つファイル オブジェクトのcltblメンバがNULL以外(f_open()でNULLに設定される)のとき、高速シーク モードになります。これはファイルのクラスタ配置情報(CLMT)をメモリ上に保持しておくことにより、FATにアクセスすることなく後方シークやロング シークを高速に行う機能です。高速シーク モードは、f_read()/f_wtite()の動作にも適用されます。高速シーク モードではf_wtite()/f_lseek()によるファイル サイズの拡張はできません。

    +

    高速シーク動作を行う前に、CLMTを作成しておく必要があります。これを作成するには、まずCLMT格納バッファ(DWORD型配列)を準備し、cltblメンバにそのポインタをセットします。そして、配列の先頭要素にその配列のサイズ(要素数)を入れ、f_lseek()をofsにCREATE_LINKMAPを指定して呼び出します。関数が成功するとCLMTが作成され、以降のf_read()/f_write()/f_lseek()ではFATへのアクセスは発生しません。FR_NOT_ENOUGH_COREで失敗したときは配列サイズが不足で、先頭要素には実際に必要となる要素数が返されます。必要な要素数は、(ファイルの分割数 + 1) * 2 です。たとえば、ファイルが5つのフラグメントに分断されているときに必要な要素数は、12となります。

    -

    ‘Ήžî•ñ

    -

    _FS_MINIMIZE < 3‚Ì‚Æ‚«Žg—p‰Â”\‚Å‚·B

    +

    対応情報

    +

    _FS_MINIMIZE < 3のとき使用可能です。

    -

    Žg—p—á

    +

    使用例

    -    /* ƒtƒ@ƒCƒ‹‚ðŠJ‚­ */
    +    /* ファイルを開く */
         fp = malloc(sizeof (FIL));
         res = f_open(fp, "file.dat", FA_READ|FA_WRITE);
         if (res) ...
     
    -    /* ƒtƒ@ƒCƒ‹EƒIƒtƒZƒbƒg5000‚ÖˆÚ“® */
    +    /* ファイル オフセット5000へ移動 */
         res = f_lseek(fp, 5000);
     
    -    /* ƒtƒ@ƒCƒ‹I’[‚ÖˆÚ“®(ƒtƒ@ƒCƒ‹’Ç‹L‚̏€”õ) */
    +    /* ファイル終端へ移動(ファイル追記の準備) */
         res = f_lseek(fp, f_size(fp));
     
    -    /* 3000ƒoƒCƒgi‚ß‚é */
    +    /* 3000バイト進める */
         res = f_lseek(fp, f_tell(fp) + 3000);
     
    -    /* 2000ƒoƒCƒg–ß‚· (ƒ‰ƒbƒvƒAƒ‰ƒEƒ“ƒh‚É’ˆÓ) */
    +    /* 2000バイト戻す (ラップアラウンドに注意) */
         res = f_lseek(fp, f_tell(fp) - 2000);
     
    -/* ƒNƒ‰ƒXƒ^æsŠ„‚è“–‚Ä (ƒXƒgƒŠ[ƒ~ƒ“ƒOEƒ‰ƒCƒgŽž‚̃oƒbƒtƒ@EƒI[ƒo[ƒ‰ƒ“–hŽ~) */
    +/* クラスタ先行割り当て (ストリーミング ライト時のバッファ オーバーラン防止) */
     
    -    res = f_open(fp, "record.wav", FA_CREATE_NEW | FA_WRITE);    /* ƒtƒ@ƒCƒ‹ì¬ */
    +    res = f_open(fp, "record.wav", FA_CREATE_NEW | FA_WRITE);    /* ファイル作成 */
     
    -    res = f_lseek(fp, MAX_SIZE);             /* \•ª‚ȃNƒ‰ƒXƒ^‚̐æsŠ„‚è“–‚Ä */
    -    if (res || f_tell(fp) != PRE_SIZE) ...   /* ³‚µ‚­ƒtƒ@ƒCƒ‹‚ªŠg’£‚³‚ꂽ‚©ƒ`ƒFƒbƒN */
    +    res = f_lseek(fp, MAX_SIZE);             /* 十分なクラスタの先行割り当て */
    +    if (res || f_tell(fp) != PRE_SIZE) ...   /* 正しくファイルが拡張されたかチェック */
     
    -    res = f_lseek(fp, DATA_START);           /* ƒf[ƒ^EƒXƒgƒŠ[ƒ€‚Ì‹L˜^(ƒAƒƒP[ƒVƒ‡ƒ“ƒfƒBƒŒƒC–³‚µ) */
    +    res = f_lseek(fp, DATA_START);           /* データ ストリームの記録(アロケーションディレイ無し) */
         ...
     
    -    res = f_truncate(fp);                    /* •s—v—̈æ‚̐؂èŽÌ‚Ä */
    -    res = f_lseek(fp, 0);                    /* ƒwƒbƒ_‚Ì‹L˜^ */
    +    res = f_truncate(fp);                    /* 不要領域の切り捨て */
    +    res = f_lseek(fp, 0);                    /* ヘッダの記録 */
         ...
     
         res = f_close(fp);
     
    -/* ‚‘¬ƒV[ƒN‹@”\‚ðŽg‚¤ */
    +/* 高速シーク機能を使う */
     
    -    DWORD clmt[SZ_TBL];                    /* ƒŠƒ“ƒNEƒ}ƒbƒvEƒe[ƒuƒ‹Ši”[ƒoƒbƒtƒ@ */
    +    DWORD clmt[SZ_TBL];                    /* リンク マップ テーブル格納バッファ */
     
    -    res = f_lseek(fp, ofs1);               /* ’ʏíƒV[ƒN (ƒI[ƒvƒ“ŽžAcltbl‚ÍNULL‚ɏ‰Šú‰»‚³‚ê‚é) */
    +    res = f_lseek(fp, ofs1);               /* 通常シーク (オープン時、cltblはNULLに初期化される) */
     
    -    fp->cltbl = clmt;                      /* ‚‘¬ƒV[ƒN‹@”\‚Ì—LŒø‰» */
    -    clmt[0] = SZ_TBL;                      /* æ“ª—v‘f‚É”z—ñ—v‘f”‚ðƒZƒbƒg */
    -    res = f_lseek(fp, CREATE_LINKMAP);     /* CLMT‚̍쐬 */
    +    fp->cltbl = clmt;                      /* 高速シーク機能の有効化 */
    +    clmt[0] = SZ_TBL;                      /* 先頭要素に配列要素数をセット */
    +    res = f_lseek(fp, CREATE_LINKMAP);     /* CLMTの作成 */
         ...
     
    -    res = f_lseek(fp, ofs2);               /* ˆÈ~Af_read/f_write/f_lseek‚ÅFATƒAƒNƒZƒX‚Í”­¶‚µ‚È‚¢ */
    +    res = f_lseek(fp, ofs2);               /* 以降、f_read/f_write/f_lseekでFATアクセスは発生しない */
     
    -

    ŽQÆ

    +

    参照

    f_open, FIL

    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/mkdir.html b/fatfs/doc/ja/mkdir.html index ef107d3..63da707 100644 --- a/fatfs/doc/ja/mkdir.html +++ b/fatfs/doc/ja/mkdir.html @@ -1,7 +1,7 @@ - + @@ -13,25 +13,25 @@

    f_mkdir

    -

    ƒfƒBƒŒƒNƒgƒŠ‚ðì¬‚µ‚Ü‚·B

    +

    ディレクトリを作成します。

     FRESULT f_mkdir (
    -  const TCHAR* path /* [IN] ì¬‚·‚éƒfƒBƒŒƒNƒgƒŠ–¼‚ւ̃|ƒCƒ“ƒ^ */
    +  const TCHAR* path /* [IN] 作成するディレクトリ名へのポインタ */
     );
     
    -

    ˆø”

    +

    引数

    path
    -
    ì¬‚·‚éƒfƒBƒŒƒNƒgƒŠ‚̃pƒX–¼‚ðŽ¦‚·ƒkƒ‹•¶Žš'\0'I’[‚Ì•¶Žš—ñ‚ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B
    +
    作成するディレクトリのパス名を示すヌル文字'\0'終端の文字列へのポインタを指定します。
    -

    –ß‚è’l

    +

    戻り値

    FR_OK, FR_DISK_ERR, @@ -52,19 +52,19 @@ FRESULT f_mkdir (

    -

    ‰ðà

    -

    ‹ó‚̃fƒBƒŒƒNƒgƒŠ‚ðì¬‚µ‚Ü‚·B

    +

    解説

    +

    空のディレクトリを作成します。

    -

    ‘Ήžî•ñ

    -

    _FS_READONLY == 0‚ŁAŠŽ‚Â_FS_MINIMIZE == 0‚Ì‚Æ‚«Žg—p‰Â”\‚Å‚·B

    +

    対応情報

    +

    _FS_READONLY == 0で、且つ_FS_MINIMIZE == 0のとき使用可能です。

    -

    Žg—p—á

    +

    使用例

         res = f_mkdir("sub1");
         if (res) die(res);
    @@ -75,6 +75,6 @@ FRESULT f_mkdir (
     
    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/mkfs.html b/fatfs/doc/ja/mkfs.html index 7e09696..19b4341 100644 --- a/fatfs/doc/ja/mkfs.html +++ b/fatfs/doc/ja/mkfs.html @@ -1,7 +1,7 @@ - + @@ -13,30 +13,30 @@

    f_mkfs

    -

    ˜_—ƒhƒ‰ƒCƒuã‚ÉFATƒ{ƒŠƒ…[ƒ€‚ðì¬(ƒtƒH[ƒ}ƒbƒg)‚µ‚Ü‚·B

    +

    論理ドライブ上にFATボリュームを作成(フォーマット)します。

     FRESULT f_mkfs (
    -  const TCHAR* path, /* [IN] ˜_—ƒhƒ‰ƒCƒu”ԍ† */
    -  BYTE  sfd,         /* [IN] ‹æ‰æì¬•û–@ */
    -  UINT  au           /* [IN] ƒNƒ‰ƒXEƒ^ƒTƒCƒY */
    +  const TCHAR* path, /* [IN] 論理ドライブ番号 */
    +  BYTE  sfd,         /* [IN] 区画作成方法 */
    +  UINT  au           /* [IN] クラス タサイズ */
     );
     
    -

    ˆø”

    +

    引数

    path
    -
    ƒtƒH[ƒ}ƒbƒg‘Ώۂ̘_—ƒhƒ‰ƒCƒu‚ðŽ¦‚·ƒpƒX–¼‚ðŽ¦‚·ƒkƒ‹•¶Žš'\0'I’[‚Ì•¶Žš—ñ‚ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·Bƒhƒ‰ƒCƒu”ԍ†‚ðŠÜ‚Ü‚È‚¢ê‡‚́AƒJƒŒƒ“ƒgEƒhƒ‰ƒCƒu‚ðˆÓ–¡‚µ‚Ü‚·B
    +
    フォーマット対象の論理ドライブを示すパス名を示すヌル文字'\0'終端の文字列へのポインタを指定します。ドライブ番号を含まない場合は、カレント ドライブを意味します。
    sfd
    -
    ƒp[ƒe[ƒVƒ‡ƒ“Œ`Ž®B(0(FDISK) ‚Ü‚½‚Í 1(SFD))
    +
    パーテーション形式。(0(FDISK) または 1(SFD))
    au
    -
    ƒNƒ‰ƒXƒ^EƒTƒCƒY‚ðƒoƒCƒg’PˆÊ‚ÅŽw’肵‚Ü‚·B’l‚͑Ώۃhƒ‰ƒCƒu‚̃ZƒNƒ^EƒTƒCƒY‚Ìn”{(n = 1`128‚ŁA2‚̗ݏæ)‚Å‚È‚¯‚ê‚΂Ȃè‚Ü‚¹‚ñB0‚È‚Ç‚Ì–³Œø’l‚ðŽw’肵‚½ê‡Aƒ{ƒŠƒ…[ƒ€‚̃TƒCƒY‚ɉž‚¶‚½ƒfƒtƒHƒ‹ƒg‚̃Nƒ‰ƒXƒ^EƒTƒCƒY‚ª‘I‘ð‚³‚ê‚Ü‚·B
    +
    クラスタ サイズをバイト数またはセクタ数で指定します。値が1~128の範囲場合は、セクタ数を示します。値が_MIN_SS以上の場合は、バイト数を示します。無効値(0または2の累乗でない値など)を指定した場合、ボリュームのサイズに応じたデフォルトのクラスタ サイズが自動選択されます。
    -

    –ß‚è’l

    +

    戻り値

    FR_OK, FR_DISK_ERR, @@ -48,26 +48,64 @@ FRESULT f_mkfs (

    -

    à–¾

    -

    •¨—ƒhƒ‰ƒCƒuã‚ÉFATƒ{ƒŠƒ…[ƒ€‚ðì¬‚µ‚Ü‚·BFDISKŒ`Ž®‚ªŽw’肳‚ꂽê‡‚́A•¨—ƒhƒ‰ƒCƒu‘S‘Ì‚ðè‚ß‚éŠî–{‹æ‰æ(ƒp[ƒe[ƒVƒ‡ƒ“)‚ªì¬‚³‚êA‚»‚Ì’†‚ÉFATƒ{ƒŠƒ…[ƒ€‚ªì¬‚³‚ê‚Ü‚·BSFDŒ`Ž®‚ł́AFATƒ{ƒŠƒ…[ƒ€‚ª•¨—ƒhƒ‰ƒCƒu‚̐擪ƒZƒNƒ^‚©‚çƒxƒ^‚ō쐬‚³‚ê‚Ü‚·B

    -

    ƒtƒH[ƒ}ƒbƒg‚·‚é˜_—ƒhƒ‰ƒCƒu‚ªƒ}ƒ‹ƒ`Eƒp[ƒe[ƒVƒ‡ƒ“‹@”\(_MULTI_PARTITION)‚É‚æ‚Á‚Ä“Á’è‚Ì‹æ‰æ(1`4)‚ÉŒ‹‚Ñ•t‚¯‚ç‚ê‚Ä‚¢‚éê‡‚́A‚»‚Ì‹æ‰æ‚Ì’†‚ÉFATƒ{ƒŠƒ…[ƒ€‚ªì¬‚³‚ê‚Ü‚·Bsfd‚Í–³Ž‹‚³‚êA‚Ü‚½‘Ήž‚·‚镨—ƒhƒ‰ƒCƒu‚Í‚±‚ê‚ɐ旧‚¿Af_fdisk()‚Ü‚½‚Í‘¼‚̃c[ƒ‹‚Å“KØ‚É‹æ‰æÝ’肳‚ê‚Ä‚¢‚é•K—v‚ª‚ ‚è‚Ü‚·B

    -

    ƒp[ƒe[ƒVƒ‡ƒ“Œ`Ž®‚ɂ́AFDISKŒ`Ž®‚ÆSFDŒ`Ž®‚Ì“ñ’Ê‚è‚ ‚è‚Ü‚·BFDISKŒ`Ž®‚́Aƒn[ƒhƒfƒBƒXƒNAMMCASDCACFCAU Disk‚È‚Ç‚Å•W€“I‚ÉŽg—p‚³‚ê‚Ü‚·BFDISKŒ`Ž®‚ł͈ê‘ä‚Ì•¨—ƒhƒ‰ƒCƒuã‚Ɉê‚‚܂½‚Í•¡”‚Ì‹æ‰æ‚ðì¬‚·‚邱‚Æ‚ª‚Å‚«‚Ü‚·B‹æ‰æŠÇ—î•ñ‚ÍMBR(•¨—ƒhƒ‰ƒCƒu‚̐擪ƒZƒNƒ^)‚É‹L˜^‚³‚ê‚Ü‚·BSFDŒ`Ž®‚Í’P‚ɉ½‚Ì•ªŠ„‚às‚í‚È‚¢Œ`Ž®‚ŁAƒ{ƒŠƒ…[ƒ€‚Í•¨—ƒhƒ‰ƒCƒu‚̐擪ƒZƒNƒ^‚©‚çŠJŽn‚µ‚Ü‚·BSFDŒ`Ž®‚́Aƒtƒƒbƒs[EƒfƒBƒXƒNAƒ}ƒCƒNƒƒhƒ‰ƒCƒuAŒõŠwƒfƒBƒXƒNA‚¨‚æ‚Ñ‚»‚Ì‘¼ƒX[ƒp[Eƒtƒƒbƒs[EƒƒfƒBƒA‚Å•W€“I‚ÉŽg—p‚³‚ê‚Ä‚¢‚Ü‚·B

    -

    FATƒ^ƒCƒv(FAT12/FAT16/FAT32)‚́A‚»‚̃{ƒŠƒ…[ƒ€ã‚̃Nƒ‰ƒXƒ^”‚É‚æ‚Á‚Ä‚Ì‚ÝŒˆ’肳‚ê‚錈‚Ü‚è[FATŽd—l‘‚æ‚è]‚É‚È‚Á‚Ä‚¢‚āA‚»‚êˆÈŠO‚Ì—vˆö‚Í‚ ‚è‚Ü‚¹‚ñB‚µ‚½‚ª‚Á‚āA‚Ç‚ÌFATƒ^ƒCƒv‚É‚È‚é‚©‚̓{ƒŠƒ…[ƒ€EƒTƒCƒY‚ƃNƒ‰ƒXƒ^EƒTƒCƒY‚Ɉˑ¶‚µ‚Ü‚·BƒNƒ‰ƒXƒ^EƒTƒCƒY‚Í‘å‚«‚­‚·‚é‚قǐ«”\‚ªã‚ª‚è‚Ü‚·B

    -

    ƒNƒ‰ƒXƒ^”‚ªFATƒ^ƒCƒv‚Ì‹«ŠE‚É‹ß‚­‚È‚é‚Æ‚«‚́AFR_MKFS_ABORTED‚Ŋ֐”‚ªŽ¸”s‚·‚é‰Â”\«‚ª‚ ‚è‚Ü‚·B

    +

    説明

    +

    物理ドライブ上にFATボリュームを作成します。FDISK形式が指定された場合は、物理ドライブ全体を占める基本区画(パーテーション)が作成され、その中にFATボリュームが作成されます。SFD形式では、FATボリュームが物理ドライブの先頭セクタからベタで作成されます。

    +

    フォーマットする論理ドライブがマルチ パーテーション機能(_MULTI_PARTITION)によって特定の区画(1~4)に結び付けられている場合は、その区画の中にFATボリュームが作成されます。sfdは無視され、また対応する物理ドライブはこれに先立ち、f_fdisk()または他のツールで適切に区画設定されている必要があります。

    +

    パーテーション形式には、FDISK形式とSFD形式の二通りあります。FDISK形式は、ハードディスク、MMC、SDC、CFC、U Diskなどで標準的に使用されます。FDISK形式では一台の物理ドライブ上に一つまたは複数の区画を作成することができます。区画管理情報はMBR(物理ドライブの先頭セクタ)に記録されます。SFD形式は単に何の分割も行わない形式で、ボリュームは物理ドライブの先頭セクタから開始します。SFD形式は、フロッピー ディスク、マイクロドライブ、光学ディスク、およびその他スーパー フロッピー メディアで標準的に使用されています。

    +

    FATタイプ(FAT12/FAT16/FAT32)は、そのボリューム上のクラスタ数によってのみ決定される決まり[FAT仕様書より]になっていて、それ以外の要因はありません。したがって、どのFATタイプになるかはボリューム サイズとクラスタ サイズに依存します。クラスタ サイズは大きくするほど性能が上がります。

    +

    クラスタ数がFATタイプの境界に近くなるときは、FR_MKFS_ABORTEDで関数が失敗する可能性があります。

    -

    ‘Ήžî•ñ

    -

    _FS_READONLY == 0‚ŁAŠŽ‚Â_USE_MKFS == 1‚Ì‚Æ‚«Žg—p‰Â”\‚Å‚·B

    +

    対応情報

    +

    _FS_READONLY == 0で、且つ_USE_MKFS == 1のとき使用可能です。

    +
    + + +
    +

    使用例

    +
    +/* Format the default drive */
    +int main (void)
    +{
    +    FATFS fs;      /* File system object (volume work area) */
    +    FIL fil;       /* File object */
    +    FRESULT res;   /* API result code */
    +    UINT bw;       /* Bytes written */
    +
    +
    +    /* Register work area */
    +    f_mount(&fs, "", 0);
    +
    +    /* Create FAT volume with default cluster size */
    +    res = f_mkfs("", 0, 0);
    +    if (res) ...
    +
    +    /* Create a file as new */
    +    res = f_open(&fil, "hello.txt", FA_CREATE_NEW | FA_WRITE);
    +    if (res) ...
    +
    +    /* Write a message */
    +    f_write(&fil, "Hello, World!\r\n", 15, &bw);
    +    if (bw != 15) ...
    +
    +    /* Close the file */
    +    f_close(&fil);
    +
    +    /* Unregister work area */
    +    f_mount(0, "", 0);
    +
    +
    -

    –ß‚é

    + +

    戻る

    diff --git a/fatfs/doc/ja/mount.html b/fatfs/doc/ja/mount.html index c6bc9f1..d465edb 100644 --- a/fatfs/doc/ja/mount.html +++ b/fatfs/doc/ja/mount.html @@ -1,7 +1,7 @@ - + @@ -13,30 +13,30 @@

    f_mount

    -

    ˜_—ƒhƒ‰ƒCƒu‚Ƀtƒ@ƒCƒ‹EƒVƒXƒeƒ€EƒIƒuƒWƒFƒNƒg‚ð“o˜^E–•Á‚µ‚Ü‚·B

    +

    論理ドライブにファイル システム オブジェクトを登録・抹消します。

     FRESULT f_mount (
    -  FATFS*       fs,     /* [IN] ƒtƒ@ƒCƒ‹EƒVƒXƒeƒ€EƒIƒuƒWƒFƒNƒg */
    -  const TCHAR* path,   /* [IN] ˜_—ƒhƒ‰ƒCƒu”ԍ† */
    -  BYTE         opt     /* [IN] ƒIƒvƒVƒ‡ƒ“ */
    +  FATFS*       fs,     /* [IN] ファイル システム オブジェクト */
    +  const TCHAR* path,   /* [IN] 論理ドライブ番号 */
    +  BYTE         opt     /* [IN] オプション */
     );
     
    -

    ˆø”

    +

    引数

    fs
    -
    “o˜^‚·‚éƒtƒ@ƒCƒ‹EƒVƒXƒeƒ€EƒIƒuƒWƒFƒNƒg‚ւ̃|ƒCƒ“ƒ^B
    +
    登録するファイル システム オブジェクトへのポインタ。
    path
    -
    ‘ΏۂƂȂé˜_—ƒhƒ‰ƒCƒu‚̃pƒX–¼‚ðŽ¦‚·ƒkƒ‹•¶Žš'\0'I’[‚Ì•¶Žš—ñ‚ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·Bƒhƒ‰ƒCƒu”ԍ†‚ðŠÜ‚Ü‚È‚¢ê‡‚́AƒfƒtƒHƒ‹ƒgEƒhƒ‰ƒCƒu‚ðŽw’肵‚½‚±‚Æ‚É‚È‚è‚Ü‚·B
    +
    対象となる論理ドライブのパス名を示すヌル文字'\0'終端の文字列へのポインタを指定します。パス名にドライブ番号が含まれない場合は、デフォルト ドライブを指定したことになります。
    opt
    -
    ƒtƒ@ƒCƒ‹EƒVƒXƒeƒ€EƒIƒuƒWƒFƒNƒg‚Ì“o˜^‚Æ“¯Žž‚Ƀ}ƒEƒ“ƒg“®ì‚ðs‚¤‚©‚Ç‚¤‚©‚ðŽw’è‚·‚éƒtƒ‰ƒOB“o˜^–•Á‚Ì‚Æ‚«‚͈Ӗ¡‚ðŽ‚¿‚Ü‚¹‚ñB
    +
    ファイル システム オブジェクトの登録と同時にマウント動作を行うかどうかを指定するフラグ。登録抹消のときは意味を持ちません。
    -

    –ß‚è’l

    +

    戻り値

    FR_OK, FR_INVALID_DRIVE, @@ -48,35 +48,35 @@ FRESULT f_mount (

    -

    ‰ðà

    -

    FatFsƒ‚ƒWƒ…[ƒ‹‚ł́A‚»‚ꂼ‚ê‚̘_—ƒhƒ‰ƒCƒu‚Ƀtƒ@ƒCƒ‹EƒVƒXƒeƒ€EƒIƒuƒWƒFƒNƒg‚Æ‚¢‚¤ƒ[ƒNEƒGƒŠƒA‚ª•K—v‚Å‚·B‚±‚̊֐”‚͘_—ƒhƒ‰ƒCƒu‚Ƀtƒ@ƒCƒ‹EƒVƒXƒeƒ€EƒIƒuƒWƒFƒNƒg‚ð“o˜^‚µ‚½‚è–•Á‚µ‚½‚肵‚Ü‚·B‰½‚ç‚©‚̃tƒ@ƒCƒ‹ŠÖ”‚ðŽg—p‚·‚é‘O‚ɁA‚±‚̊֐”‚Å‚»‚̘_—ƒhƒ‰ƒCƒu‚̃tƒ@ƒCƒ‹EƒVƒXƒeƒ€EƒIƒuƒWƒFƒNƒg‚ð—^‚¦‚Ä‚¨‚©‚È‚¯‚ê‚΂Ȃè‚Ü‚¹‚ñBfs‚Ƀkƒ‹Eƒ|ƒCƒ“ƒ^‚ðŽw’è‚·‚é‚ƁA‚»‚̘_—ƒhƒ‰ƒCƒu‚̃tƒ@ƒCƒ‹EƒVƒXƒeƒ€EƒIƒuƒWƒFƒNƒg‚Ì“o˜^‚Í–•Á‚³‚ê‚邾‚¯‚Å‚·B“o˜^–•Á‚³‚ꂽƒtƒ@ƒCƒ‹EƒVƒXƒeƒ€EƒIƒuƒWƒFƒNƒg‚̃ƒ‚ƒŠ‚͉ð•ú‚Å‚«‚Ü‚·B‘€ì‘Ώۂ̘_—ƒhƒ‰ƒCƒuã‚ÉŠJ‚©‚ê‚Ä‚¢‚éƒtƒ@ƒCƒ‹‚âƒfƒBƒŒƒNƒgƒŠ‚ª‚ ‚Á‚½ê‡A‚»‚ê‚ç‚Í‘S‚Ä–³Œø‚É‚È‚è‚Ü‚·B‚±‚̊֐”‚Ì“à•”ˆ—‚ÍŽŸ‚̂悤‚ȏ‡‚ɍs‚í‚ê‚Ü‚·B

    +

    解説

    +

    FatFsモジュールでは、それぞれの論理ドライブにファイル システム オブジェクトというワーク エリアが必要です。この関数は論理ドライブにファイル システム オブジェクトを登録したり抹消したりします。何らかのファイル関数を使用する前に、この関数でその論理ドライブのファイル システム オブジェクトを与えておかなければなりません。fsにヌル ポインタを指定すると、その論理ドライブのファイル システム オブジェクトの登録は抹消されるだけです。登録抹消されたファイル システム オブジェクトのメモリは解放できます。操作対象の論理ドライブ上に開かれたままのファイルやディレクトリがあった場合、それらに対して作成された構造体は全て無効になります。この関数の内部処理は次のような順に行われます。

      -
    1. ‘Ώۂ̘_—ƒhƒ‰ƒCƒu‚ðpath‚©‚瓾‚éB
    2. -
    3. Šù‚É“o˜^‚³‚ê‚Ä‚¢‚éƒtƒ@ƒCƒ‹EƒVƒXƒeƒ€EƒIƒuƒWƒFƒNƒg‚̓NƒŠƒA‚µA“o˜^‚ð‰ðœ‚·‚éB
    4. -
    5. fs‚ª—LŒø‚ȃ|ƒCƒ“ƒ^‚Ì‚Æ‚«‚́A‚»‚̃tƒ@ƒCƒ‹EƒVƒXƒeƒ€EƒIƒuƒWƒFƒNƒg‚ðƒNƒŠƒA‚µ“o˜^‚·‚éB
    6. -
    7. ƒ}ƒEƒ“ƒg“®ì‚ªŽw’肳‚ê‚Ä‚¢‚é‚Æ‚«‚́A‚»‚ê‚ðŽÀs‚·‚éB
    8. +
    9. 対象の論理ドライブをpathから得る。
    10. +
    11. 既に登録されているファイル システム オブジェクトはクリアし、登録を解除する。
    12. +
    13. fsが有効なポインタのときは、そのファイル システム オブジェクトをクリアし登録する。
    14. +
    15. マウント動作が指定されているときは、それを実行する。
    -

    opt‚É0‚ðŽw’è‚·‚é‚ƁAƒ}ƒEƒ“ƒg“®ì(•¨—ƒhƒ‰ƒCƒu‚̏‰Šú‰»AFATƒ{ƒŠƒ…[ƒ€‚ÌŒŸõABPB‚ð‰ðÍ‚µƒtƒ@ƒCƒ‹EƒVƒXƒeƒ€EƒIƒuƒWƒFƒNƒg‚ð‰Šú‰»)‚͍s‚í‚ꂸAŠÖ”‚Í•¨—ƒhƒ‰ƒCƒu‚̏ó‘Ô‚ÉŠÖ‚í‚炸í‚ɐ¬Œ÷‚µ‚Ü‚·BŠÖ”“à‚ł͉ºˆÊƒŒƒCƒ„‚ւ̃AƒNƒZƒX‚Í”­¶‚¹‚¸AŽw’肳‚ꂽƒtƒ@ƒCƒ‹EƒVƒXƒeƒ€EƒIƒuƒWƒFƒNƒg‚ðƒNƒŠƒA(–³Œø‰»)‚µA‚»‚̃AƒhƒŒƒX‚ð“à•””z—ñ‚É“o˜^‚·‚邾‚¯‚Å‚·B’P‚É“o˜^Ï‚݂̃tƒ@ƒCƒ‹EƒVƒXƒeƒ€EƒIƒuƒWƒFƒNƒg‚ðƒNƒŠƒA‚·‚é–Ú“I‚É‚àŽg‚¦‚Ü‚·B‚»‚µ‚āA‘±‚¢‚ă{ƒŠƒ…[ƒ€‚ւ̃AƒNƒZƒX‚ªs‚í‚ꂽ‚Æ‚«ŽŸ‚Ì‚¤‚¿‚¢‚¸‚ê‚©‚Å‚à^‚̏ꍇ‚́AŽÀÛ‚̃}ƒEƒ“ƒg“®ì‚ªs‚í‚ê‚Ü‚·B

    +

    optに0を指定すると、マウント動作(物理ドライブの初期化、FATボリュームの検索、BPBを解析しファイル システム オブジェクトを初期化)は行われず、関数は物理ドライブの状態に関わらず常に成功します。関数内では下位レイヤへのアクセスは発生せず、指定されたファイル システム オブジェクトをクリア(無効化)し、そのアドレスを内部配列に登録するだけです。単に登録済みのファイル システム オブジェクトをクリアする目的にも使えます。実際のマウント動作は、ボリュームへのアクセス(パス名を渡すもの全て)が行われたときに、次のうちいずれかの条件が真の場合に行われます。

      -
    • ƒtƒ@ƒCƒ‹EƒVƒXƒeƒ€EƒIƒuƒWƒFƒNƒg‚ªƒNƒŠƒA(–³Œø)ó‘Ô(f_mount()‚ÌŽÀs‚É‚æ‚é)
    • -
    • •¨—ƒhƒ‰ƒCƒu‚ª–¢‰Šú‰»ó‘Ô(ƒVƒXƒeƒ€EƒŠƒZƒbƒg‚⃁ƒfƒBƒA‚ÌŒðŠ·‚É‚æ‚é)
    • +
    • ファイル システム オブジェクトがクリア(無効)状態(f_mount()の実行による)
    • +
    • 物理ドライブが未初期化状態(システム リセットやメディアの交換による)
    -

    opt‚É1‚ðŽw’è‚·‚é‚ƁA“o˜^‚É‘±‚¢‚ă}ƒEƒ“ƒg“®ì‚ªs‚í‚ê‚Ü‚·Bƒ}ƒEƒ“ƒg‚ÉŽ¸”s‚·‚é‚ƑΉž‚·‚éƒGƒ‰[‚ð•Ô‚µ‚Ü‚·‚ªA“o˜^‚Í—LŒø‚È‚Ì‚Å‘±‚­ƒ{ƒŠƒ…[ƒ€‚ւ̃AƒNƒZƒX‚ōĂу}ƒEƒ“ƒg“®ì‚ªŽÀs‚³‚ê‚Ü‚·B

    -

    ‰ºˆÊƒŒƒCƒ„‚ÌŽÀ‘•ãƒƒfƒBƒAŒðŠ·‚ÌŒŸo‚ªƒTƒ|[ƒg‚³‚ê‚È‚¢(disk_status()‚É”½‰f‚³‚ê‚È‚¢)‚Æ‚«‚́AƒAƒvƒŠƒP[ƒVƒ‡ƒ“‚̓ƒfƒBƒAŒðŠ·‚̌ケ‚̊֐”‚Ńtƒ@ƒCƒ‹EƒVƒXƒeƒ€EƒIƒuƒWƒFƒNƒg‚𖾎¦“I‚ɃNƒŠƒA‚µ‚čă}ƒEƒ“ƒg‚ª³í‚ɍs‚¦‚é‚悤‚É‚·‚é•K—v‚ª‚ ‚è‚Ü‚·B

    +

    optに1を指定すると、ファイル システムオブジェクトの登録に続きマウント動作が行われます。メディアが無いなどの理由でマウント動作に失敗すると対応するエラーを返しファイル システム オブジェクト無効状態のままになりますが、登録自体は有効なので続いてボリュームへのアクセスがあれば再びマウント動作が実行されます。

    +

    下位レイヤの実装上メディア交換の検出がサポートされない(disk_status()に反映されない)ときは、アプリケーションはメディア交換の後この関数でファイル システム オブジェクトを明示的にクリアし、マウント動作が正常に行えるようにする必要があります。

    -

    ‘Ήžî•ñ

    -

    ‘S‚Ă̍\¬‚ÅŽg—p‰Â”\‚Å‚·B

    +

    対応情報

    +

    全ての構成で使用可能です。

    -

    ŽQÆ

    +

    参照

    f_open, FATFS

    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/open.html b/fatfs/doc/ja/open.html index a4c4a18..c308398 100644 --- a/fatfs/doc/ja/open.html +++ b/fatfs/doc/ja/open.html @@ -1,7 +1,7 @@ - + @@ -13,33 +13,33 @@

    f_open

    -

    ƒtƒ@ƒCƒ‹‚ðƒI[ƒvƒ“‚Ü‚½‚͍쐬‚µ‚Ü‚·B

    +

    ファイルをオープンまたは作成します。

     FRESULT f_open (
    -  FIL* fp,           /* [OUT] ‹ó‚̃tƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg\‘¢‘̂ւ̃|ƒCƒ“ƒ^ */
    -  const TCHAR* path, /* [IN] ƒtƒ@ƒCƒ‹–¼‚ւ̃|ƒCƒ“ƒ^ */
    -  BYTE mode          /* [IN] ƒ‚[ƒhƒtƒ‰ƒO */
    +  FIL* fp,           /* [OUT] 空のファイル オブジェクト構造体へのポインタ */
    +  const TCHAR* path, /* [IN] ファイル名へのポインタ */
    +  BYTE mode          /* [IN] モードフラグ */
     );
     
    -

    ˆø”

    +

    引数

    fp
    -
    V‚µ‚­ì¬‚·‚éƒtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg\‘¢‘̂ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·BˆÈ~A‚»‚̃tƒ@ƒCƒ‹‚ð•Â‚¶‚é‚Ü‚Å‚±‚̃tƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg‚ðŽg—p‚µ‚ătƒ@ƒCƒ‹‘€ì‚ð‚µ‚Ü‚·B
    +
    新しく作成するファイル オブジェクト構造体へのポインタを指定します。以降、そのファイルを閉じるまでこのファイル オブジェクトを使用してファイル操作をします。
    path
    -
    ŠJ‚­ƒtƒ@ƒCƒ‹‚̃tƒ@ƒCƒ‹–¼‚ðŽ¦‚·ƒkƒ‹•¶Žš'\0'I’[‚Ì•¶Žš—ñ‚ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B
    +
    開くファイルのファイル名を示すヌル文字'\0'終端の文字列へのポインタを指定します。
    mode
    -
    ƒtƒ@ƒCƒ‹‚̃AƒNƒZƒX•û–@‚âƒI[ƒvƒ“•û–@‚ðŒˆ‚ß‚éƒtƒ‰ƒO‚Å‚·B‚±‚̃pƒ‰ƒ[ƒ^‚É‚ÍŽŸ‚Ì‘g‚ݍ‡‚킹‚ðŽw’肵‚Ü‚·B
    +
    ファイルのアクセス方法やオープン方法を決めるフラグです。このパラメータには次の組み合わせを指定します。
    - - - - - - - + + + + + + +
    ’lˆÓ–¡
    FA_READ“ǂݏo‚µƒ‚[ƒh‚ÅŠJ‚«‚Ü‚·B“ǂݏ‘‚«‚·‚éê‡‚ÍFA_WRITE‚Æ‹¤‚ÉŽw’肵‚Ü‚·B
    FA_WRITE‘‚«ž‚݃‚[ƒh‚ÅŠJ‚«‚Ü‚·B“ǂݏ‘‚«‚·‚éê‡‚ÍFA_READ‚Æ‹¤‚ÉŽw’肵‚Ü‚·B
    FA_OPEN_EXISTINGŠù‘¶‚̃tƒ@ƒCƒ‹‚ðŠJ‚«‚Ü‚·Bƒtƒ@ƒCƒ‹‚ª–³‚¢‚Æ‚«‚̓Gƒ‰[‚É‚È‚è‚Ü‚·B(ƒfƒtƒHƒ‹ƒg)
    FA_OPEN_ALWAYSŠù‘¶‚̃tƒ@ƒCƒ‹‚ðŠJ‚«‚Ü‚·Bƒtƒ@ƒCƒ‹‚ª–³‚¢‚Æ‚«‚̓tƒ@ƒCƒ‹‚ðì¬‚µ‚Ü‚·B’Ç‹L‚̏ꍇ‚́A‚±‚Ì•û–@‚ŃI[ƒvƒ“‚µ‚½ŒãAf_lseek()‚Ńtƒ@ƒCƒ‹‚̍Ōã”ö‚Ɉړ®‚µ‚Ä‚­‚¾‚³‚¢B
    FA_CREATE_NEWƒtƒ@ƒCƒ‹‚ðì¬‚µ‚Ü‚·B“¯–¼‚̃tƒ@ƒCƒ‹‚ª‚ ‚éê‡‚́AFR_EXIST‚ÅŽ¸”s‚µ‚Ü‚·B
    FA_CREATE_ALWAYSƒtƒ@ƒCƒ‹‚ðì¬‚µ‚Ü‚·B“¯–¼‚̃tƒ@ƒCƒ‹‚ª‚ ‚éê‡‚́AƒTƒCƒY‚ð0‚É‚µ‚Ä‚©‚çŠJ‚«‚Ü‚·B
    値意味
    FA_READ読み出しモードで開きます。読み書きする場合はFA_WRITEと共に指定します。
    FA_WRITE書き込みモードで開きます。読み書きする場合はFA_READと共に指定します。
    FA_OPEN_EXISTING既存のファイルを開きます。ファイルが無いときはエラーになります。(デフォルト)
    FA_OPEN_ALWAYS既存のファイルを開きます。ファイルが無いときはファイルを作成します。追記の場合は、この方法でオープンした後、f_lseek()でファイルの最後尾に移動してください。
    FA_CREATE_NEWファイルを作成します。同名のファイルがある場合は、FR_EXISTで失敗します。
    FA_CREATE_ALWAYSファイルを作成します。同名のファイルがある場合は、サイズを0にしてから開きます。
    @@ -47,7 +47,7 @@ FRESULT f_open (
    -

    –ß‚è’l

    +

    戻り値

    FR_OK, FR_DISK_ERR, @@ -72,86 +72,86 @@ FRESULT f_open (

    -

    ‰ðà

    -

    Šù‘¶‚̃tƒ@ƒCƒ‹‚ðŠJ‚¢‚½‚èAV‚µ‚¢ƒtƒ@ƒCƒ‹‚ðì¬‚µ‚Ü‚·BŠÖ”‚ª¬Œ÷‚·‚é‚ƃtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg‚ªì¬‚³‚êAˆÈ~‚»‚̃tƒ@ƒCƒ‹‚ɑ΂·‚éƒAƒNƒZƒX‚ÉŽg—p‚µ‚Ü‚·Bƒtƒ@ƒCƒ‹‚ð•Â‚¶‚é‚Æ‚«‚́Af_close()‚ðŽg—p‚µ‚Ü‚·B‰½‚ç‚©‚̕ύX‚ªs‚í‚ꂽƒtƒ@ƒCƒ‹‚ª‚»‚̌㐳‚µ‚­•Â‚¶‚ç‚ê‚È‚©‚Á‚½ê‡A‚»‚̃tƒ@ƒCƒ‹‚ª”j‘¹‚·‚éê‡‚ª‚ ‚è‚Ü‚·B

    -

    Šù‚ÉŠJ‚©‚ê‚Ä‚¢‚éƒtƒ@ƒCƒ‹‚ðŠJ‚­•K—v‚ª‚ ‚éê‡‚́A‘½dƒAƒNƒZƒX§Œä‚ðŽQÆ‚µ‚Ä‚­‚¾‚³‚¢B‚µ‚©‚µAˆê‚‚̃tƒ@ƒCƒ‹‚ɑ΂·‚鏑‚«ž‚݃‚[ƒh‚ðŠÜ‚ޏd•¡ƒI[ƒvƒ“‚͏í‚É‹ÖŽ~‚Å‚·B

    -

    ƒtƒ@ƒCƒ‹EƒAƒNƒZƒX‚ðŠJŽn‚·‚é‘O‚ɁAf_mount()‚ðŽg‚Á‚Ä‚»‚ꂼ‚ê‚̘_—ƒhƒ‰ƒCƒu‚Ƀ[ƒNEƒGƒŠƒA(ƒtƒ@ƒCƒ‹EƒVƒXƒeƒ€EƒIƒuƒWƒFƒNƒg)‚ð—^‚¦‚é•K—v‚ª‚ ‚è‚Ü‚·B‚±‚̏‰Šú‰»‚ÌŒãA‚»‚̘_—ƒhƒ‰ƒCƒu‚ɑ΂µ‚Ä‘S‚Ẵtƒ@ƒCƒ‹ŠÖ”‚ªŽg‚¦‚é‚悤‚É‚È‚è‚Ü‚·B

    +

    解説

    +

    既存のファイルを開いたり、新しいファイルを作成します。関数が成功するとファイル オブジェクトが作成され、以降そのファイルに対するアクセスに使用します。ファイルを閉じるときは、f_close()を使用します。何らかの変更が行われたファイルがその後正しく閉じられなかった場合、そのファイルが破損する場合があります。

    +

    既に開かれているファイルを開く必要がある場合は、多重アクセス制御を参照してください。しかし、一つのファイルに対する書き込みモードを含む重複オープンは常に禁止です。

    +

    ファイル アクセスを開始する前に、f_mount()を使ってそれぞれの論理ドライブにワーク エリア(ファイル システム オブジェクト)を与える必要があります。この初期化の後、その論理ドライブに対して全てのファイル関数が使えるようになります。

    -

    ‘Ήžî•ñ

    -

    ‘S‚Ă̍\¬‚ÅŽg—p‰Â”\‚Å‚·B_FS_READONLY == 1‚Ì‚Æ‚«‚́AFA_WRITE, FA_CREATE_ALWAYS, FA_CREATE_NEW, FA_OPEN_ALWAYS‚ÌŠeƒtƒ‰ƒO‚̓Tƒ|[ƒg‚³‚ê‚Ü‚¹‚ñB

    +

    対応情報

    +

    全ての構成で使用可能です。_FS_READONLY == 1のときは、FA_WRITE, FA_CREATE_ALWAYS, FA_CREATE_NEW, FA_OPEN_ALWAYSの各フラグはサポートされません。

    -

    Žg—p—á

    +

    使用例

    -/* ƒeƒLƒXƒgƒtƒ@ƒCƒ‹‚ð“ǂݏo‚µ‚Ä•\Ž¦ */
    +/* テキストファイルを読み出して表示 */
     
    -FATFS FatFs;   /* ˜_—ƒhƒ‰ƒCƒu‚̃[ƒNEƒGƒŠƒA(ƒtƒ@ƒCƒ‹EƒVƒXƒeƒ€EƒIƒuƒWƒFƒNƒg) */
    +FATFS FatFs;   /* 論理ドライブのワーク エリア(ファイル システム オブジェクト) */
     
     int main (void)
     {
    -    FIL fil;       /* ƒtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg */
    -    char line[82]; /* sƒoƒbƒtƒ@ */
    -    FRESULT fr;    /* –ß‚è’l */
    +    FIL fil;       /* ファイル オブジェクト */
    +    char line[82]; /* 行バッファ */
    +    FRESULT fr;    /* 戻り値 */
     
     
    -    /* ƒfƒtƒHƒ‹ƒgEƒhƒ‰ƒCƒu‚Ƀ[ƒNƒGƒŠƒA‚ð—^‚¦‚é */
    +    /* デフォルト ドライブにワークエリアを与える */
         f_mount(&FatFs, "", 0);
     
    -    /* ƒeƒLƒXƒgEƒtƒ@ƒCƒ‹‚ðŠJ‚­ */
    +    /* テキスト ファイルを開く */
         fr = f_open(&fil, "message.txt", FA_READ);
         if (fr) return (int)fr;
     
    -    /* 1s‚¸‚“ǂݏo‚µ‚Ä•\Ž¦ */
    +    /* 1行ずつ読み出して表示 */
         while (f_gets(line, sizeof line, &fil))
             printf(line);
     
    -    /* ƒtƒ@ƒCƒ‹‚ð•Â‚¶‚é */
    +    /* ファイルを閉じる */
         f_close(&fil);
     
         return 0;
     }
     
    -/* ƒhƒ‰ƒCƒu1‚̃tƒ@ƒCƒ‹ "file.bin" ‚ðƒhƒ‰ƒCƒu0‚ÖƒRƒs[ */
    +/* ドライブ1のファイル "file.bin" をドライブ0へコピー */
     
     int main (void)
     {
    -    FATFS fs[2];         /* ˜_—ƒhƒ‰ƒCƒu‚̃[ƒNƒGƒŠƒA(ƒtƒ@ƒCƒ‹EƒVƒXƒeƒ€EƒIƒuƒWƒFƒNƒg) */
    -    FIL fsrc, fdst;      /* ƒtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg */
    +    FATFS fs[2];         /* 論理ドライブのワークエリア(ファイル システム オブジェクト) */
    +    FIL fsrc, fdst;      /* ファイル オブジェクト */
         BYTE buffer[4096];   /* File copy buffer */
         FRESULT fr;          /* FatFs function common result code */
         UINT br, bw;         /* File R/W count */
     
    -    /* ƒhƒ‰ƒCƒu0,1‚Ƀ[ƒNEƒGƒŠƒA‚ð—^‚¦‚é */
    +    /* ドライブ0,1にワーク エリアを与える */
         f_mount(&fs[0], "0:", 0);
         f_mount(&fs[1], "1:", 0);
     
    -    /* ƒhƒ‰ƒCƒu1‚̃Rƒs[Œ³ƒtƒ@ƒCƒ‹‚ðŠJ‚­ */
    +    /* ドライブ1のコピー元ファイルを開く */
         res = f_open(&fsrc, "1:file.dat", FA_OPEN_EXISTING | FA_READ);
         if (fr) return (int)fr;
     
    -    /* ƒhƒ‰ƒCƒu0‚ɃRƒs[æƒtƒ@ƒCƒ‹‚ðì¬‚·‚é */
    +    /* ドライブ0にコピー先ファイルを作成する */
         res = f_open(&fdst, "0:file.dat", FA_CREATE_ALWAYS | FA_WRITE);
         if (fr) return (int)fr;
     
    -    /* ƒRƒs[Œ³‚©‚çƒRƒs[æ‚Ƀf[ƒ^“]‘—‚·‚é */
    +    /* コピー元からコピー先にデータ転送する */
         for (;;) {
    -        res = f_read(&fsrc, buffer, sizeof buffer, &br); /* ƒRƒs[Œ³‚©‚ç‚©‚ç“ǂݏo‚· */
    -        if (res || br == 0) break;   /* ƒGƒ‰[‚©ƒtƒ@ƒCƒ‹I’[ */
    -        res = f_write(&fdst, buffer, br, &bw);           /* ‚»‚ê‚ðƒRƒs[æ‚ɏ‘‚«ž‚Þ */
    -        if (res || bw < br) break;   /* ƒGƒ‰[‚©ƒfƒBƒXƒN–ž”t */
    +        res = f_read(&fsrc, buffer, sizeof buffer, &br); /* コピー元からから読み出す */
    +        if (res || br == 0) break;   /* エラーかファイル終端 */
    +        res = f_write(&fdst, buffer, br, &bw);           /* それをコピー先に書き込む */
    +        if (res || bw < br) break;   /* エラーかディスク満杯 */
         }
     
    -    /* ‘S‚Ẵtƒ@ƒCƒ‹‚ð•Â‚¶‚é */
    +    /* 全てのファイルを閉じる */
         f_close(&fsrc);
         f_close(&fdst);
     
    -    /* ƒ[ƒNEƒGƒŠƒA‚ðŠJ•ú‚·‚é */
    +    /* ワーク エリアを開放する */
         f_mount(NULL, "0:", 0);
         f_mount(NULL, "1:", 0);
     
    @@ -162,10 +162,10 @@ int main (void)
     
     
     
    -

    ŽQÆ

    +

    参照

    f_read, f_write, f_close, FIL, FATFS

    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/opendir.html b/fatfs/doc/ja/opendir.html index 9309160..ae40984 100644 --- a/fatfs/doc/ja/opendir.html +++ b/fatfs/doc/ja/opendir.html @@ -1,7 +1,7 @@ - + @@ -13,28 +13,28 @@

    f_opendir

    -

    ƒfƒBƒŒƒNƒgƒŠ‚ðŠJ‚«‚Ü‚·B

    +

    ディレクトリを開きます。

     FRESULT f_opendir (
    -  DIR* dp,           /* [OUT] ƒfƒBƒŒƒNƒgƒŠEƒuƒWƒFƒNƒg\‘¢‘̂ւ̃|ƒCƒ“ƒ^ */
    -  const TCHAR* path  /* [IN] ƒfƒBƒŒƒNƒgƒŠ–¼‚ւ̃|ƒCƒ“ƒ^ */
    +  DIR* dp,           /* [OUT] ディレクトリ ブジェクト構造体へのポインタ */
    +  const TCHAR* path  /* [IN] ディレクトリ名へのポインタ */
     );
     
    -

    ˆø”

    +

    引数

    dp
    -
    ‹ó‚̃fƒBƒŒƒNƒgƒŠEƒIƒuƒWƒFƒNƒg\‘¢‘̂ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B
    +
    空のディレクトリ オブジェクト構造体へのポインタを指定します。
    path
    -
    ƒI[ƒvƒ“‚·‚éƒfƒBƒŒƒNƒgƒŠ‚̃pƒX–¼‚ðŽ¦‚·ƒkƒ‹•¶Žš'\0'I’[‚Ì•¶Žš—ñ‚ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B
    +
    オープンするディレクトリのパス名を示すヌル文字'\0'終端の文字列へのポインタを指定します。
    -

    –ß‚è’l

    +

    戻り値

    FR_OK, FR_DISK_ERR, @@ -55,22 +55,22 @@ FRESULT f_opendir (

    -

    ‰ðà

    -

    ƒfƒBƒŒƒNƒgƒŠ‚ðŠJ‚«‚Ü‚·B³íI—¹‚µ‚½‚çAì¬‚³‚ꂽDIR\‘¢‘Ì‚ðŽg‚Á‚Ä‚±‚̃fƒBƒŒƒNƒgƒŠ‚̍€–Ú‚ð‡ŽŸ“ǂݏo‚¹‚Ü‚·B

    +

    解説

    +

    ディレクトリを開きます。正常終了したら、作成されたDIR構造体を使ってこのディレクトリの項目を順次読み出せます。

    -

    ‘Ήžî•ñ

    -

    _FS_MINIMIZE <= 1‚Ì‚Æ‚«Žg—p‰Â”\‚É‚È‚è‚Ü‚·B

    +

    対応情報

    +

    _FS_MINIMIZE <= 1のとき使用可能になります。

    -

    ŽQÆ

    +

    参照

    f_readdir, f_closedir, DIR

    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/printf.html b/fatfs/doc/ja/printf.html index b5c22e0..4de1da2 100644 --- a/fatfs/doc/ja/printf.html +++ b/fatfs/doc/ja/printf.html @@ -1,7 +1,7 @@ - + @@ -13,56 +13,56 @@

    f_printf

    -

    ƒtƒ@ƒCƒ‹‚ɏ‘Ž®‰»•¶Žš—ñ‚ð‘‚«ž‚Ý‚Ü‚·B

    +

    ファイルに書式化文字列を書き込みます。

     int f_printf (
    -  FIL* fp,           /* [IN] ƒtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg */
    -  const TCHAR* fmt,  /* [IN] ‘Ž®§Œä•¶Žš—ñ */
    +  FIL* fp,           /* [IN] ファイル オブジェクト */
    +  const TCHAR* fmt,  /* [IN] 書式制御文字列 */
       ...
     );
     
    -

    ˆø”

    +

    引数

    fp
    -
    ƒtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg\‘¢‘̂ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B
    +
    ファイル オブジェクト構造体へのポインタを指定します。
    fmt
    -
    ƒkƒ‹•¶Žš'\0'I’[‚̏‘Ž®§Œä•¶Žš—ñ‚ðŽw‚·ƒ|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·Bƒkƒ‹•¶Žš‚͏‘‚«ž‚Ü‚ê‚Ü‚¹‚ñB
    +
    ヌル文字'\0'終端の書式制御文字列を指すポインタを指定します。ヌル文字は書き込まれません。
    ...
    -
    ƒIƒvƒVƒ‡ƒ“‚̈ø”B
    +
    オプションの引数。
    -

    –ß‚è’l

    -

    •¶Žš—ñ‚ª³í‚ɏ‘‚«ž‚Ü‚ê‚é‚ƁA‘‚«ž‚܂ꂽ•¶Žš”‚ª•Ô‚³‚ê‚Ü‚·BƒfƒBƒXƒN‚ª–ž”t‚Ü‚½‚Í‚»‚Ì‘¼ƒGƒ‰[‚É‚æ‚萳í‚ɏ‘‚«ž‚Ü‚ê‚È‚©‚Á‚½‚Æ‚«‚́AŠÖ”‚ÍŽ¸”s‚µEOF (-1)‚ª•Ô‚³‚ê‚Ü‚·B

    +

    戻り値

    +

    文字列が正常に書き込まれると、書き込まれた文字数が返されます。ディスクが満杯またはその他エラーにより正常に書き込まれなかったときは、関数は失敗しEOF (-1)が返されます。

    -

    ‰ðà

    -

    ‚±‚̊֐”‚́Af_putc()‚¨‚æ‚Ñf_puts()‚̃‰ƒbƒp[ŠÖ”‚Å‚·B‘Ž®§Œä‹@”\‚ÍC•W€ƒ‰ƒCƒuƒ‰ƒŠ‚̃TƒuƒZƒbƒg‚Æ‚È‚Á‚Ä‚¢‚āA‘Ž®§Œä•¶Žš‚ÍŽŸ‚ÉŽ¦‚·‚à‚Ì‚ªŽg—p‰Â”\‚Å‚·B

    +

    解説

    +

    この関数は、f_putc()およびf_puts()のラッパー関数です。書式制御機能はC標準ライブラリのサブセットとなっていて、書式制御文字は次に示すものが使用可能です。

      -
    • ƒ^ƒCƒv: c C s S d D u U x X b B
    • -
    • ¸“xŽw’è: l L
    • -
    • ƒtƒ‰ƒO: 0 -
    • +
    • タイプ: c C s S d D u U x X b B
    • +
    • 精度指定: l L
    • +
    • フラグ: 0 -
    -

    ‘Ήžî•ñ

    -

    _FS_READONLY == 0‚ŁAŠŽ‚Â_USE_STRFUNC‚ª1‚Ü‚½‚Í2‚Ì‚Æ‚«Žg—p‰Â”\‚É‚È‚è‚Ü‚·B2‚ÌŽž‚́Ao—Í‚ÉŠÜ‚Ü‚ê‚é'\n'‚ª'\r'+'\n'‚É“WŠJ‚³‚ê‚ătƒ@ƒCƒ‹‚ɏ‘‚«ž‚Ü‚ê‚Ü‚·B

    -

    API‚ÉUnicode‚ª‘I‘ð(_LFN_UNICODE‚ª1)‚³‚ê‚Ä‚¢‚é‚Æ‚«‚́Afmt‚ÍUnicode•¶Žš—ñ‚É‚È‚è‚Ü‚·‚ªAƒtƒ@ƒCƒ‹ã‚̃Gƒ“ƒR[ƒh‚́A_STRF_ENCODEƒIƒvƒVƒ‡ƒ“‚Å‘I‘ð‚Å‚«‚Ü‚·B‚»‚êˆÈŠO‚ÌŽž‚Í–³•ÏŠ·(1ƒoƒCƒg/1•¶Žš)‚ŏ‘‚«ž‚Ý‚Ü‚·B

    +

    対応情報

    +

    _FS_READONLY == 0で、且つ_USE_STRFUNCが1または2のとき使用可能になります。2の時は、出力に含まれる'\n'が'\r'+'\n'に展開されてファイルに書き込まれます。

    +

    APIにUnicodeが選択(_LFN_UNICODEが1)されているときは、fmtはUnicode文字列になりますが、ファイル上のエンコードは、_STRF_ENCODEオプションで選択できます。それ以外の時は無変換(1バイト/1文字)で書き込みます。

    -

    Žg—p—á

    +

    使用例

         f_printf(&fil, "%d", 1234);            /* "1234" */
         f_printf(&fil, "%6d,%3d%%", -200, 5);  /* "  -200,  5%" */
    @@ -78,16 +78,16 @@ int f_printf (
         f_printf(&fil, "%8s", "abc");          /* "     abc" */
         f_printf(&fil, "%-8s", "abc");         /* "abc     " */
         f_printf(&fil, "%c", 'a');             /* "a" */
    -    f_printf(&fil, "%f", 10.0);            /* •‚“®¬”“_‚Í–¢ƒTƒ|[ƒg */
    +    f_printf(&fil, "%f", 10.0);            /* 浮動小数点は未サポート */
     
    -

    ŽQÆ

    +

    参照

    f_open, f_putc, f_puts, f_gets, f_close, FIL

    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/putc.html b/fatfs/doc/ja/putc.html index 724f4c2..6b80b1a 100644 --- a/fatfs/doc/ja/putc.html +++ b/fatfs/doc/ja/putc.html @@ -1,7 +1,7 @@ - + @@ -13,50 +13,50 @@

    f_putc

    -

    ƒtƒ@ƒCƒ‹‚É•¶Žš‚ð‘‚«ž‚Ý‚Ü‚·B

    +

    ファイルに文字を書き込みます。

     int f_putc (
    -  TCHAR chr,  /* [IN] ‘‚«ž‚Þ•¶Žš */
    -  FIL* fp     /* [IN] ƒtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg */
    +  TCHAR chr,  /* [IN] 書き込む文字 */
    +  FIL* fp     /* [IN] ファイル オブジェクト */
     );
     
    -

    ˆø”

    +

    引数

    chr
    -
    ‘‚«ž‚Þ•¶Žš‚ðŽw’肵‚Ü‚·B
    +
    書き込む文字を指定します。
    fp
    -
    ƒtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg\‘¢‘̂ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B
    +
    ファイル オブジェクト構造体へのポインタを指定します。
    -

    –ß‚è’l

    -

    •¶Žš‚ª³í‚ɏ‘‚«ž‚Ü‚ê‚é‚Ə‘‚«ž‚ñ‚¾•¶Žš”‚ª•Ô‚³‚ê‚Ü‚·BƒfƒBƒXƒN‚ª–ž”t‚Ü‚½‚̓Gƒ‰[‚É‚æ‚菑‚«ž‚Ü‚ê‚È‚©‚Á‚½‚Æ‚«‚ÍEOF (-1)‚ª•Ô‚³‚ê‚Ü‚·B

    -

    API‚ÉUnicode‚ª‘I‘ð(_LFN_UNICODE‚ª1)‚³‚ê‚Ä‚¢‚é‚Æ‚«‚́Achr‚ÍUTF-16•¶Žš‚É‚È‚è‚Ü‚·‚ªAƒtƒ@ƒCƒ‹ã‚̃Gƒ“ƒR[ƒh‚́A_STRF_ENCODEƒIƒvƒVƒ‡ƒ“‚Å‘I‘ð‚Å‚«‚Ü‚·B‚»‚êˆÈŠO‚ÌŽž‚Í–³•ÏŠ·(1ƒoƒCƒg/1•¶Žš)‚ŏ‘‚«ž‚Ý‚Ü‚·B

    +

    戻り値

    +

    文字が正常に書き込まれると書き込んだ文字数が返されます。ディスクが満杯またはエラーにより書き込まれなかったときはEOF (-1)が返されます。

    +

    APIにUnicodeが選択(_LFN_UNICODEが1)されているときは、chrはUTF-16文字になりますが、ファイル上のエンコードは、_STRF_ENCODEオプションで選択できます。それ以外の時は無変換(1バイト/1文字)で書き込みます。

    -

    ‰ðà

    -

    1•¶Žš‚ðƒtƒ@ƒCƒ‹‚ɏ‘‚«ž‚Ý‚Ü‚·B‚±‚̊֐”‚Íf_write()‚̃‰ƒbƒp[ŠÖ”‚Å‚·B

    +

    解説

    +

    1文字をファイルに書き込みます。この関数はf_write()のラッパー関数です。

    -

    ‘Ήžî•ñ

    -

    _FS_READONLY == 0‚ŁAŠŽ‚Â_USE_STRFUNC‚ª 1‚Ü‚½‚Í 2‚Ì‚Æ‚«Žg—p‰Â”\‚Å‚·B2‚ðŽw’è‚·‚é‚ƁA'\n'‚Í'\r'+'\n'‚É“WŠJ‚³‚ê‚ătƒ@ƒCƒ‹‚ɏ‘‚«ž‚Ü‚ê‚Ü‚·B

    +

    対応情報

    +

    _FS_READONLY == 0で、且つ_USE_STRFUNCが 1または 2のとき使用可能です。2を指定すると、'\n'は'\r'+'\n'に展開されてファイルに書き込まれます。

    -

    ŽQÆ

    +

    参照

    f_open, f_puts, f_printf, f_gets, f_close, FIL

    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/puts.html b/fatfs/doc/ja/puts.html index d815311..4f3167c 100644 --- a/fatfs/doc/ja/puts.html +++ b/fatfs/doc/ja/puts.html @@ -1,7 +1,7 @@ - + @@ -13,50 +13,50 @@

    f_puts

    -

    ƒtƒ@ƒCƒ‹‚É•¶Žš—ñ‚ð‘‚«ž‚Ý‚Ü‚·B

    +

    ファイルに文字列を書き込みます。

     int f_puts (
    -  const TCHAR* str,  /* [IN] ‘‚«ž‚Þ•¶Žš—ñ */
    -  FIL* fp            /* [IN] ƒtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg */
    +  const TCHAR* str,  /* [IN] 書き込む文字列 */
    +  FIL* fp            /* [IN] ファイル オブジェクト */
     );
     
    -

    ˆø”

    +

    引数

    str
    -
    ‘‚«ž‚Þƒkƒ‹•¶Žš'\0'I’[‚Ì•¶Žš—ñ‚ðŽw‚·ƒ|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·Bƒkƒ‹•¶Žš‚͏‘‚«ž‚Ü‚ê‚Ü‚¹‚ñB
    +
    書き込むヌル文字'\0'終端の文字列を指すポインタを指定します。ヌル文字は書き込まれません。
    fp
    -
    ƒtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg\‘¢‘̂ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B
    +
    ファイル オブジェクト構造体へのポインタを指定します。
    -

    –ß‚è’l

    -

    •¶Žš—ñ‚ª³í‚ɏ‘‚«ž‚Ü‚ê‚é‚ƁA‘‚«ž‚܂ꂽ•¶Žš”‚ª•Ô‚³‚ê‚Ü‚·BƒfƒBƒXƒN‚ª–ž”t‚Ü‚½‚̓Gƒ‰[‚É‚æ‚菑‚«ž‚Ý‚ª’†’f‚³‚ꂽ‚Æ‚«‚ÍEOF (-1)‚ª•Ô‚³‚ê‚Ü‚·B

    -

    API‚ÉUnicode‚ª‘I‘ð(_LFN_UNICODE‚ª1)‚³‚ê‚Ä‚¢‚é‚Æ‚«‚́Astr‚ÍUTF-16•¶Žš—ñ‚É‚È‚è‚Ü‚·‚ªAƒtƒ@ƒCƒ‹ã‚̃Gƒ“ƒR[ƒh‚́A_STRF_ENCODEƒIƒvƒVƒ‡ƒ“‚Å‘I‘ð‚Å‚«‚Ü‚·B‚»‚êˆÈŠO‚ÌŽž‚Í–³•ÏŠ·(1ƒoƒCƒg/1•¶Žš)‚ŏ‘‚«ž‚Ý‚Ü‚·B

    +

    戻り値

    +

    文字列が正常に書き込まれると、書き込まれた文字数が返されます。ディスクが満杯またはエラーにより書き込みが中断されたときはEOF (-1)が返されます。

    +

    APIにUnicodeが選択(_LFN_UNICODEが1)されているときは、strはUTF-16文字列になりますが、ファイル上のエンコードは、_STRF_ENCODEオプションで選択できます。それ以外の時は無変換(1バイト/1文字)で書き込みます。

    -

    ‰ðà

    -

    •¶Žš—ñ‚ðƒtƒ@ƒCƒ‹‚ɏ‘‚«ž‚Ý‚Ü‚·B‚±‚̊֐”‚Íf_write()‚̃‰ƒbƒp[ŠÖ”‚Å‚·B

    +

    解説

    +

    文字列をファイルに書き込みます。この関数はf_write()のラッパー関数です。

    -

    ‘Ήžî•ñ

    -

    _FS_READONLY == 0‚ŁAŠŽ‚Â_USE_STRFUNC‚ª1‚Ü‚½‚Í2‚Ì‚Æ‚«Žg—p‰Â”\‚Å‚·B2‚ðŽw’è‚·‚é‚ƁA•¶Žš—ñ‚ÉŠÜ‚Ü‚ê‚é'\n'‚Í'\r'+'\n'‚É“WŠJ‚³‚ê‚ătƒ@ƒCƒ‹‚ɏ‘‚«ž‚Ü‚ê‚Ü‚·B

    +

    対応情報

    +

    _FS_READONLY == 0で、且つ_USE_STRFUNCが1または2のとき使用可能です。2を指定すると、文字列に含まれる'\n'は'\r'+'\n'に展開されてファイルに書き込まれます。

    -

    ŽQÆ

    +

    参照

    f_open, f_putc, f_printf, f_gets, f_close, FIL

    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/rc.html b/fatfs/doc/ja/rc.html index 8bcfb24..45a4738 100644 --- a/fatfs/doc/ja/rc.html +++ b/fatfs/doc/ja/rc.html @@ -11,20 +11,20 @@

    ファイル関数の戻り値

    -

    FatFsのAPIでは、一部の関数を除き結果に応じた共通のリザルト・コード(FRESULT型(enum))を返します。関数が成功した場合は0を返します。失敗した場合は0以外の値を返し、値はエラーの種類を示します。

    +

    FatFsのAPIでは、一部の関数を除き結果に応じた共通のリザルト コード(FRESULT型(enum))を返します。関数が成功した場合は0を返します。失敗した場合は0以外の値を返し、値はエラーの種類を示します。

    FR_OK (0)
    関数は成功した。
    FR_DISK_ERR
    -
    下位レイヤ(disk_read(), disk_write(), disk_ioctl()関数)で回復不能なエラーが発生した。
    ※開かれたファイルの操作においてこのエラーが発生すると、そのファイル・オブジェクトはアボート状態となり、クローズ以外のの操作ができなくなります。
    +
    下位レイヤ(disk_read(), disk_write(), disk_ioctl()関数)で回復不能なエラーが発生した。
    ※開かれたファイルの操作においてこのエラーが発生すると、そのファイル オブジェクトはアボート状態となり、クローズ以外のの操作ができなくなります。
    FR_INT_ERR
    内部処理の健全性に異常が検出された。原因としては次のようなことが考えられます。
    • ボリューム上のFAT構造にエラーがある。
    • -
    • スタック不足や不正なメモリ操作等によるワーク・エリアの破壊。多くはこれが原因。
    • +
    • スタック不足や不正なメモリ操作等によるワーク エリアの破壊。多くはこれが原因。
    -※開かれたファイルの操作においてこのエラーが発生すると、そのファイル・オブジェクトはアボート状態となり、クローズ以外の操作ができなくなります。
    +※開かれたファイルの操作においてこのエラーが発生すると、そのファイル オブジェクトはアボート状態となり、クローズ以外の操作ができなくなります。
    FR_NOT_READY
    物理ドライブが動作可能な状態にない。または、ドライブの初期化に失敗した。
    FR_NO_FILE
    @@ -38,22 +38,22 @@
    • 書き込み禁止属性(AM_RDO)を持つファイルを書き込みモードで開こうとした。
    • 書き込み禁止属性を持つファイルやディレクトリを削除しようとした。
    • -
    • 空でないディレクトリまたはカレント・ディレクトリを削除しようとした。
    • +
    • 空でないディレクトリまたはカレント ディレクトリを削除しようとした。
    • FA_READフラグを付けずに開いたファイルに対して読み出しを行った。
    • FA_WRITEフラグを付けずに開いたファイルに対して書き込みまたはそれに類する操作を行った。
    • -
    • ボリュームまたはディレクトリ・テーブルが満杯でファイルやディレクトリを作成できなかった。
    • +
    • ボリュームまたはディレクトリ テーブルが満杯でファイルやディレクトリを作成できなかった。
    FR_EXIST
    新しく作成しようとしたオブジェクトと同じ名前のオブジェクトが既に存在する。
    FR_INVALID_OBJECT
    -
    指定されたファイル・オブジェクトやディレクトリ・オブジェクトが無効(オープンされていない、既に閉じられた、破損しているなど)、またはヌル・ポインタが渡された。また、開かれたままのオブジェクトは、それの属するボリュームのマウント動作により無効となります。
    +
    指定されたファイル オブジェクトやディレクトリ オブジェクトが無効(オープンされていない、既に閉じられた、破損しているなど)、またはヌル ポインタが渡された。また、開かれたままのオブジェクトは、それの属するボリュームのマウント動作により無効となります。
    FR_WRITE_PROTECTED
    物理ドライブが書き込み禁止状態のとき、書き込みを伴う操作を行おうとした。
    FR_INVALID_DRIVE
    -
    パス名中に指定されたドライブ番号が無効、またはパス名にヌル・ポインタが渡された。(関連オプション: _VOLUMES)
    +
    パス名中に指定されたドライブ番号が無効、またはパス名にヌル ポインタが渡された。(関連オプション: _VOLUMES)
    FR_NOT_ENABLED
    -
    そのボリュームの操作に必要なワーク・エリア(ファイル・システム・オブジェクト構造体)が与えられていない。
    +
    そのボリュームの操作に必要なワーク エリア(ファイル システム オブジェクト構造体)が与えられていない。
    FR_NO_FILESYSTEM
    物理ドライブ上に有効なFATボリュームが見つからなかった。
    FR_MKFS_ABORTED
    diff --git a/fatfs/doc/ja/read.html b/fatfs/doc/ja/read.html index 04ef8b3..c7f2d25 100644 --- a/fatfs/doc/ja/read.html +++ b/fatfs/doc/ja/read.html @@ -1,7 +1,7 @@ - + @@ -13,34 +13,34 @@

    f_read

    -

    ƒtƒ@ƒCƒ‹‚©‚çƒf[ƒ^‚ð“ǂݏo‚µ‚Ü‚·B

    +

    ファイルからデータを読み出します。

     FRESULT f_read (
    -  FIL* fp,     /* [IN] ƒtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg\‘¢‘Ì */
    -  void* buff,  /* [OUT] “ǂݏo‚µ‚½ƒf[ƒ^‚ðŠi”[‚·‚éƒoƒbƒtƒ@ */
    -  UINT btr,    /* [IN] “ǂݏo‚·ƒoƒCƒg” */
    -  UINT* br     /* [OUT] “ǂݏo‚³‚ꂽƒoƒCƒg” */
    +  FIL* fp,     /* [IN] ファイル オブジェクト構造体 */
    +  void* buff,  /* [OUT] 読み出したデータを格納するバッファ */
    +  UINT btr,    /* [IN] 読み出すバイト数 */
    +  UINT* br     /* [OUT] 読み出されたバイト数 */
     );
     
    -

    ˆø”

    +

    引数

    fp
    -
    ƒtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg\‘¢‘̂ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B
    +
    ファイル オブジェクト構造体へのポインタを指定します。
    buff
    -
    “ǂݏo‚µ‚½ƒf[ƒ^‚ðŠi”[‚·‚éƒoƒbƒtƒ@‚ðŽw‚·ƒ|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B
    +
    読み出したデータを格納するバッファを指すポインタを指定します。
    btr
    -
    “ǂݏo‚·ƒoƒCƒg”(0`UINTŒ^‚̍őå’l)‚ðŽw’肵‚Ü‚·B
    +
    読み出すバイト数(0~UINT型の最大値)を指定します。
    br
    -
    ŽÀÛ‚ɓǂݏo‚³‚ꂽƒoƒCƒg”‚ðŠi”[‚·‚é•Ï”‚ðŽw‚·ƒ|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B–ß‚è’l‚͊֐”‚̐¬”Û‚É‚©‚©‚í‚炸í‚É—LŒø‚Å‚·B
    +
    実際に読み出されたバイト数を格納する変数を指すポインタを指定します。戻り値は関数の成否にかかわらず常に有効です。
    -

    –ß‚è’l

    +

    戻り値

    FR_OK, FR_DISK_ERR, @@ -54,22 +54,22 @@ FRESULT f_read (

    -

    ‰ðà

    -

    “ǂݍž‚ÝŠJŽnˆÊ’u‚́AŒ»Ý‚̃Š[ƒh/ƒ‰ƒCƒgEƒ|ƒCƒ“ƒ^‚©‚ç‚É‚È‚è‚Ü‚·BƒŠ[ƒh/ƒ‰ƒCƒgEƒ|ƒCƒ“ƒ^‚͓ǂݍž‚܂ꂽƒoƒCƒg”‚¾‚¯i‚Ý‚Ü‚·BŠÖ”‚ª³íI—¹‚µ‚½Œã‚́A*br‚Ì’l‚ðƒ`ƒFƒbƒN‚·‚ׂ«‚Å‚·B*br‚ªbtr‚æ‚è‚à¬‚³‚¢‚Æ‚«‚́A“ǂݍž‚Ý’†‚Ƀtƒ@ƒCƒ‹‚̏I’[‚É’B‚µ‚½‚±‚Æ‚ðŽ¦‚µ‚Ä‚¢‚Ü‚·B

    +

    解説

    +

    読み込み開始位置は、現在のリード/ライト ポインタからになります。リード/ライト ポインタは読み込まれたバイト数だけ進みます。関数が正常終了した後は、*brの値をチェックすべきです。*brがbtrよりも小さいときは、読み込み中にファイルの終端に達したことを示しています。

    -

    ‘Ήžî•ñ

    -

    ‘S‚Ă̍\¬‚ÅŽg—p‰Â”\‚Å‚·B

    +

    対応情報

    +

    全ての構成で使用可能です。

    -

    ŽQÆ

    +

    参照

    f_open, fgets, f_write, f_close, FIL

    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/readdir.html b/fatfs/doc/ja/readdir.html index bd1c34e..fc8fc5c 100644 --- a/fatfs/doc/ja/readdir.html +++ b/fatfs/doc/ja/readdir.html @@ -1,7 +1,7 @@ - + @@ -13,28 +13,28 @@

    f_readdir

    -

    ƒfƒBƒŒƒNƒgƒŠ€–Ú‚ð“ǂݏo‚µ‚Ü‚·B

    +

    ディレクトリ項目を読み出します。

     FRESULT f_readdir (
    -  DIR* dp,      /* [IN] ƒfƒBƒŒƒNƒgƒŠEƒuƒWƒFƒNƒg\‘¢‘̂ւ̃|ƒCƒ“ƒ^ */
    -  FILINFO* fno  /* [OUT] ƒtƒ@ƒCƒ‹î•ñ\‘¢‘̂ւ̃|ƒCƒ“ƒ^ */
    +  DIR* dp,      /* [IN] ディレクトリ ブジェクト構造体へのポインタ */
    +  FILINFO* fno  /* [OUT] ファイル情報構造体へのポインタ */
     );
     
    -

    ˆø”

    +

    引数

    dp
    -
    —LŒø‚ȃfƒBƒŒƒNƒgƒŠEƒIƒuƒWƒFƒNƒg\‘¢‘̂ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B
    +
    有効なディレクトリ オブジェクト構造体へのポインタを指定します。
    fno
    -
    “ǂݏo‚µ‚½ƒfƒBƒŒƒNƒgƒŠ€–Ú‚ðŠi”[‚·‚éƒtƒ@ƒCƒ‹î•ñ\‘¢‘̂ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B
    +
    読み出したディレクトリ項目を格納するファイル情報構造体へのポインタを指定します。
    -

    –ß‚è’l

    +

    戻り値

    FR_OK, FR_DISK_ERR, @@ -48,37 +48,37 @@ FRESULT f_readdir (

    -

    ‰ðà

    -

    ƒfƒBƒŒƒNƒgƒŠ‚̍€–Ú(ƒtƒ@ƒCƒ‹‚ƃfƒBƒŒƒNƒgƒŠ)‚ð‡ŽŸ“ǂݏo‚µ‚Ü‚·B‚±‚̊֐”‚ðŒJ‚è•Ô‚µŽÀs‚·‚邱‚Æ‚É‚æ‚è‚»‚̃fƒBƒŒƒNƒgƒŠ‚Ì‘S‚Ă̍€–Ú‚ð“ǂݏo‚·‚±‚Æ‚ª‚Å‚«‚Ü‚·B“¾‚ç‚ê‚éƒtƒ@ƒCƒ‹î•ñ‚̏ڍׂɂ‚¢‚Ä‚Í FILINFO\‘¢‘Ì‚ðŽQÆ‚µ‚Ä‚­‚¾‚³‚¢B‘S‚Ă̍€–Ú‚ª“ǂݏo‚³‚êA“ǂݏo‚·€–Ú‚ª‚à‚¤–³‚¢‚Æ‚«‚́Afname[]ƒƒ“ƒo‚Ƀkƒ‹•¶Žš—ñ‚ª•Ô‚³‚ê‚Ü‚·Bfno‚Ƀkƒ‹Eƒ|ƒCƒ“ƒ^‚ðŽw’è‚·‚é‚ƁA‚»‚̃fƒBƒŒƒNƒgƒŠ‚̃Š[ƒhEƒCƒ“ƒfƒbƒNƒX‚ðæ“ª‚ÉŠª‚«–ß‚µ‚Ü‚·B‚Ü‚½A‚±‚̊֐”‚ÍŽŸ‚ÉŽ¦‚·‚悤‚ÉŠÖ˜A‚·‚é\¬ƒIƒvƒVƒ‡ƒ“‚É‚æ‚è“®ì‚ª•Ï‚í‚è‚Ü‚·B

    -

    ƒhƒbƒgEƒGƒ“ƒgƒŠ("."A"..")‚́A‘Š‘΃pƒX‚ª—LŒø‚È‚Æ‚«(_FS_RPATH >= 1)‚ɂ̂ݏo—Í‚ÉŒ»‚ê‚Ü‚·B

    -

    LFN‹@”\‚ª—LŒø‚ÈŽž‚́A‚±‚̊֐”‚̌Ăяo‚µ‚ɐ旧‚Á‚ÄFILINFO\‘¢‘Ì‚Ìlfname‚Ælfsize‚ª—LŒø‚È’l‚ŏ‰Šú‰»‚³‚ê‚Ä‚¢‚È‚¯‚ê‚΂Ȃè‚Ü‚¹‚ñBlfname‚ÍLFN‚ðŠi”[‚·‚éƒoƒbƒtƒ@‚ŁAlfsize‚Í‚»‚̃oƒbƒtƒ@‚Ì—v‘f”‚Å‚·BLFN‚ð“ǂݏo‚·•K—v‚ª‚È‚¢‚Æ‚«‚́Alfname‚Ƀkƒ‹Eƒ|ƒCƒ“ƒ^‚ðƒZƒbƒg‚µ‚Ä‚­‚¾‚³‚¢BŽŸ‚ÌðŒ‚Éˆê‚‚łàŠY“–‚·‚éê‡‚́ALFNŠi”[ƒoƒbƒtƒ@‚Ƀkƒ‹•¶Žš—ñ‚ª•Ô‚³‚ê‚Ü‚·B

    +

    解説

    +

    ディレクトリの項目(ファイルとディレクトリ)を順次読み出します。この関数を繰り返し実行することによりそのディレクトリの全ての項目を読み出すことができます。得られるファイル情報の詳細については FILINFO構造体を参照してください。全ての項目が読み出され、読み出す項目がもう無いときは、fname[]メンバにヌル文字列が返されます。fnoにヌル ポインタを指定すると、そのディレクトリのリード インデックスを先頭に巻き戻します。また、この関数は次に示すように関連する構成オプションにより動作が変わります。

    +

    ドット エントリ("."、"..")は、相対パスが有効なとき(_FS_RPATH >= 1)にのみ出力に現れます。

    +

    LFN機能が有効な時は、この関数の呼び出しに先立ってFILINFO構造体のlfnameとlfsizeが有効な値で初期化されていなければなりません。lfnameはLFNを格納するバッファで、lfsizeはそのバッファの要素数です。LFNを読み出す必要がないときは、lfnameにヌル ポインタをセットしてください。次の条件に一つでも該当する場合は、LFN格納バッファにヌル文字列が返されます。

      -
    • ƒfƒBƒŒƒNƒgƒŠ€–Ú‚ÉLFNî•ñ‚ª‘¶Ý‚µ‚È‚¢B
    • -
    • LFN‚Ì’·‚³‚ɑ΂µ‚ÄLFNŠi”[ƒoƒbƒtƒ@‚Ü‚½‚ÍLFN‘€ìƒoƒbƒtƒ@‚̃TƒCƒY‚ª•s\•ªB
    • -
    • LFN‚ÉŒ»Ý‚ÌOEMƒR[ƒh‚É‘¶Ý‚µ‚È‚¢•¶Žš‚ªŠÜ‚Ü‚ê‚Ä‚¢‚éB(”ñUnicode\¬‚Ì‚Æ‚«)
    • +
    • ディレクトリ項目にLFN情報が存在しない。
    • +
    • LFNの長さに対してLFN格納バッファまたはLFN操作バッファのサイズが不十分。
    • +
    • LFNに現在のOEMコードに存在しない文字が含まれている。(非Unicode構成のとき)
    -

    ‚Ü‚½AƒfƒBƒŒƒNƒgƒŠ€–Ú‚ÉLFNî•ñ‚ª‘¶Ý‚µ‚È‚¢ê‡‚́Afname[]‚ɉp¬•¶Žš‚ªŠÜ‚Ü‚ê‚éê‡‚ª‚ ‚è‚Ü‚·B

    +

    また、ディレクトリ項目にLFN情報が存在しない場合は、fname[]に英小文字が含まれる場合があります。

    -

    ‘Ήžî•ñ

    -

    _FS_MINIMIZE <= 1‚Ì‚Æ‚«‚ÉŽg—p‰Â”\‚Å‚·B

    +

    対応情報

    +

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

    -

    Žg—p—á

    +

    使用例

     FRESULT scan_files (
    -    char* path        /* ŠJŽnƒm[ƒh (ƒ[ƒNƒGƒŠƒA‚Æ‚µ‚Ä‚àŽg—p) */
    +    char* path        /* 開始ノード (ワークエリアとしても使用) */
     )
     {
         FRESULT res;
         FILINFO fno;
         DIR dir;
         int i;
    -    char *fn;   /* ”ñUnicode\¬‚ð‘z’è */
    +    char *fn;   /* 非Unicode構成を想定 */
     #if _USE_LFN
         static char lfn[_MAX_LFN + 1];
         fno.lfname = lfn;
    @@ -86,24 +86,24 @@ FRESULT scan_files (
     #endif
     
     
    -    res = f_opendir(&dir, path);                       /* ƒfƒBƒŒƒNƒgƒŠ‚ðŠJ‚­ */
    +    res = f_opendir(&dir, path);                       /* ディレクトリを開く */
         if (res == FR_OK) {
             i = strlen(path);
             for (;;) {
    -            res = f_readdir(&dir, &fno);                   /* ƒfƒBƒŒƒNƒgƒŠ€–Ú‚ð1ŒÂ“ǂݏo‚· */
    -            if (res != FR_OK || fno.fname[0] == 0) break;  /* ƒGƒ‰[‚Ü‚½‚͍€–Ú–³‚µ‚Ì‚Æ‚«‚Í”²‚¯‚é */
    -            if (fno.fname[0] == '.') continue;             /* ƒhƒbƒgƒGƒ“ƒgƒŠ‚Í–³Ž‹ */
    +            res = f_readdir(&dir, &fno);                   /* ディレクトリ項目を1個読み出す */
    +            if (res != FR_OK || fno.fname[0] == 0) break;  /* エラーまたは項目無しのときは抜ける */
    +            if (fno.fname[0] == '.') continue;             /* ドットエントリは無視 */
     #if _USE_LFN
                 fn = *fno.lfname ? fno.lfname : fno.fname;
     #else
                 fn = fno.fname;
     #endif
    -            if (fno.fattrib & AM_DIR) {                    /* ƒfƒBƒŒƒNƒgƒŠ */
    +            if (fno.fattrib & AM_DIR) {                    /* ディレクトリ */
                     sprintf(&path[i], "/%s", fn);
                     res = scan_files(path);
    -                if (res != FR_OK) break;
                     path[i] = 0;
    -            } else {                                       /* ƒtƒ@ƒCƒ‹ */
    +                if (res != FR_OK) break;
    +            } else {                                       /* ファイル */
                     printf("%s/%s\n", path, fn);
                 }
             }
    @@ -117,10 +117,10 @@ FRESULT scan_files (
     
     
     
    -

    ŽQÆ

    +

    参照

    f_opendir, f_closedir, f_stat, FILINFO, DIR

    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/rename.html b/fatfs/doc/ja/rename.html index 0eafa49..5259846 100644 --- a/fatfs/doc/ja/rename.html +++ b/fatfs/doc/ja/rename.html @@ -1,7 +1,7 @@ - + @@ -13,28 +13,28 @@

    f_rename

    -

    ƒtƒ@ƒCƒ‹‚Ü‚½‚̓TƒuEƒfƒBƒŒƒNƒgƒŠ‚Ì–¼‘O‚̕ύX‚Ü‚½‚͈ړ®‚µ‚Ü‚·B

    +

    ファイルまたはサブ ディレクトリの名前の変更または移動します。

     FRESULT f_rename (
    -  const TCHAR* old_name, /* [IN] ŒÃ‚¢ƒIƒuƒWƒFƒNƒg–¼ */
    -  const TCHAR* new_name  /* [IN] V‚µ‚¢ƒIƒuƒWƒFƒNƒg–¼ */
    +  const TCHAR* old_name, /* [IN] 古いオブジェクト名 */
    +  const TCHAR* new_name  /* [IN] 新しいオブジェクト名 */
     );
     
    -

    ˆø”

    +

    引数

    old_name
    -
    •ÏX‘Ώۂ̃tƒ@ƒCƒ‹‚Ü‚½‚̓TƒuEƒfƒBƒŒƒNƒgƒŠ‚̃pƒX–¼‚ðŽ¦‚·ƒkƒ‹•¶Žš'\0'I’[‚Ì•¶Žš—ñ‚ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B
    +
    変更対象のファイルまたはサブ ディレクトリのパス名を示すヌル文字'\0'終端の文字列へのポインタを指定します。
    new_name
    -
    V‚µ‚¢ƒpƒX–¼‚ðŽ¦‚·ƒkƒ‹•¶Žš'\0'I’[‚Ì•¶Žš—ñ‚ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·BŠù‚É‘¶Ý‚·‚éƒIƒuƒWƒFƒNƒg‚Æ“¯‚¶–¼‘O‚ÍŽg‚¦‚Ü‚¹‚ñB‚Ü‚½Aƒhƒ‰ƒCƒu”ԍ†‚ÍŽw’肵‚Ä‚à–³Ž‹‚³‚êAold_name‚ÅŒˆ‚ß‚ç‚ꂽ˜_—ƒhƒ‰ƒCƒuã‚̃IƒuƒWƒFƒNƒg‚Æ‚µ‚Ĉµ‚í‚ê‚Ü‚·B
    +
    新しいパス名を示すヌル文字'\0'終端の文字列へのポインタを指定します。既に存在するオブジェクトと同じ名前は使えません。また、ドライブ番号は指定しても無視され、old_nameで決められた論理ドライブ上のオブジェクトとして扱われます。
    -

    –ß‚è’l

    +

    戻り値

    FR_OK, FR_DISK_ERR, @@ -55,28 +55,28 @@ FRESULT f_rename (

    -

    ‰ðà

    -

    ƒtƒ@ƒCƒ‹‚Ü‚½‚̓TƒuEƒfƒBƒŒƒNƒgƒŠ‚Ì–¼‘O‚ð•ÏX‚µ‚Ü‚·B‚Ü‚½A“¯Žž‚ɕʂ̃fƒBƒŒƒNƒgƒŠ‚ւ̈ړ®‚à‰Â”\‚Å‚·‚ªAˆÙ‚È‚éƒhƒ‰ƒCƒu‚ւ̈ړ®‚Í‚Å‚«‚Ü‚¹‚ñBŠJ‚©‚ê‚Ä‚¢‚éƒIƒuƒWƒFƒNƒg‚ɑ΂µ‚ÄŽg—p‚µ‚Ä‚Í‚È‚è‚Ü‚¹‚ñB

    +

    解説

    +

    ファイルまたはサブ ディレクトリの名前を変更します。また、同時に別のディレクトリへの移動も可能ですが、異なるドライブへの移動はできません。開かれているオブジェクトに対して使用してはなりません。

    -

    ‘Ήžî•ñ

    -

    _FS_READONLY == 0‚ŁAŠŽ‚Â_FS_MINIMIZE == 0‚Ì‚Æ‚«‚ÉŽg—p‰Â”\‚Å‚·B

    +

    対応情報

    +

    _FS_READONLY == 0で、且つ_FS_MINIMIZE == 0のときに使用可能です。

    -

    Žg—p—á

    +

    使用例

    -    /* ƒtƒ@ƒCƒ‹‚Ü‚½‚̓TƒuƒfƒBƒŒƒNƒgƒŠ‚Ì–¼‘O‚ð•ÏX‚·‚é */
    +    /* ファイルまたはサブディレクトリの名前を変更する */
         f_rename("oldname.txt", "newname.txt");
     
    -    /* ƒtƒ@ƒCƒ‹‚Ü‚½‚̓TƒuƒfƒBƒŒƒNƒgƒŠ‚Ì–¼‘O‚̕ύX‚ƕʂ̃fƒBƒŒƒNƒgƒŠ‚ւ̈ړ® */
    +    /* ファイルまたはサブディレクトリの名前の変更と別のディレクトリへの移動 */
         f_rename("oldname.txt", "dir1/newname.txt");
     
    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/sdir.html b/fatfs/doc/ja/sdir.html index 3e6f712..3390549 100644 --- a/fatfs/doc/ja/sdir.html +++ b/fatfs/doc/ja/sdir.html @@ -1,7 +1,7 @@ - + @@ -13,28 +13,28 @@

    DIR

    -

    DIR\‘¢‘̂́Af_opendir(), f_readdir()‚̃[ƒNEƒGƒŠƒA‚Æ‚µ‚ÄŽg—p‚³‚ê‚Ü‚·BƒAƒvƒŠƒP[ƒVƒ‡ƒ“‚́A‚±‚̍\‘¢‘̂̃ƒ“ƒo‚ð‘‚«Š·‚¦‚Ä‚Í‚È‚è‚Ü‚¹‚ñB

    +

    DIR構造体は、f_opendir(), f_readdir()のワーク エリアとして使用されます。アプリケーションは、この構造体のメンバを書き換えてはなりません。

     typedef struct {
    -    FATFS*  fs;        /* eƒtƒ@ƒCƒ‹EƒVƒXƒeƒ€EƒIƒuƒWƒFƒNƒg‚ւ̃|ƒCƒ“ƒ^ */
    -    WORD    id;        /* eƒtƒ@ƒCƒ‹EƒVƒXƒeƒ€EƒIƒuƒWƒFƒNƒg‚̃}ƒEƒ“ƒgID */
    -    WORD    index;     /* ŽŸ‚ÉŒŸõŠJŽn‚·‚éƒfƒBƒŒƒNƒgƒŠEƒCƒ“ƒfƒbƒNƒX”ԍ† */
    -    DWORD   sclust;    /* ƒe[ƒuƒ‹ŠJŽnƒNƒ‰ƒXƒ^ (0:ƒ‹[ƒg) */
    -    DWORD   clust;     /* Œ»Ý‚̃Nƒ‰ƒXƒ^”ԍ† */
    -    DWORD   sect;      /* Œ»Ý‚̃ZƒNƒ^”ԍ† */
    -    BYTE*   dir;       /* Œ»Ý‚ÌSFNƒGƒ“ƒgƒŠ‚ւ̃|ƒCƒ“ƒ^ */
    -    BYTE*   fn;        /* SFNƒoƒbƒtƒ@‚ւ̃|ƒCƒ“ƒ^ (in/out) {file[8],ext[3],status[1]} */
    +    FATFS*  fs;        /* 親ファイル システム オブジェクトへのポインタ */
    +    WORD    id;        /* 親ファイル システム オブジェクトのマウントID */
    +    WORD    index;     /* 次に検索開始するディレクトリ インデックス番号 */
    +    DWORD   sclust;    /* テーブル開始クラスタ (0:ルート) */
    +    DWORD   clust;     /* 現在のクラスタ番号 */
    +    DWORD   sect;      /* 現在のセクタ番号 */
    +    BYTE*   dir;       /* 現在のSFNエントリへのポインタ */
    +    BYTE*   fn;        /* SFNバッファへのポインタ (in/out) {file[8],ext[3],status[1]} */
     #if _FS_LOCK
    -    UINT    lockid;    /* ƒƒbƒNID */
    +    UINT    lockid;    /* ロックID */
     #endif
     #if _USE_LFN
    -    WCHAR*  lfn;       /* LFNƒoƒbƒtƒ@‚ւ̃|ƒCƒ“ƒ^ (in/out) */
    -    WORD    lfn_idx;   /* LFNƒGƒ“ƒgƒŠ‚̐擪ƒCƒ“ƒfƒbƒNƒX (0xFFFF:–³Œø) */
    +    WCHAR*  lfn;       /* LFNバッファへのポインタ (in/out) */
    +    WORD    lfn_idx;   /* LFNエントリの先頭インデックス (0xFFFF:無効) */
     #endif
     } DIR;
     
    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/setlabel.html b/fatfs/doc/ja/setlabel.html index af4a243..dc71ac3 100644 --- a/fatfs/doc/ja/setlabel.html +++ b/fatfs/doc/ja/setlabel.html @@ -1,7 +1,7 @@ - + @@ -13,25 +13,25 @@

    f_setlabel

    -

    ƒ{ƒŠƒ…[ƒ€‚Ƀ{ƒŠƒ…[ƒ€Eƒ‰ƒxƒ‹‚ðÝ’肵‚Ü‚·B

    +

    ボリュームにボリューム ラベルを設定します。

     FRESULT f_setlabel (
    -  const TCHAR* label  /* [IN] Ý’è‚·‚éƒ{ƒŠƒ…[ƒ€Eƒ‰ƒxƒ‹‚ւ̃|ƒCƒ“ƒ^ */
    +  const TCHAR* label  /* [IN] 設定するボリューム ラベルへのポインタ */
     );
     
    -

    ˆø”

    +

    引数

    label
    -
    Ý’è‚·‚éƒ{ƒŠƒ…[ƒ€Eƒ‰ƒxƒ‹‚ðŽ¦‚·ƒkƒ‹•¶Žš'\0'I’[‚Ì•¶Žš—ñ‚ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B
    +
    設定するボリューム ラベルを示すヌル文字'\0'終端の文字列へのポインタを指定します。
    -

    –ß‚è’l

    +

    戻り値

    FR_OK, FR_DISK_ERR, @@ -48,42 +48,42 @@ FRESULT f_setlabel (

    -

    ‰ðà

    -

    •¶Žš—ñ‚̐擪‚Ƀhƒ‰ƒCƒu”ԍ†‚ðŠÜ‚ޏꍇ‚́A‚»‚̘_—ƒhƒ‰ƒCƒu‚ɑ΂µ‚Đݒ肳‚ê‚Ü‚·BŠÜ‚Ü‚È‚¢ê‡‚́AƒfƒtƒHƒ‹ƒgEƒhƒ‰ƒCƒu‚ɐݒ肳‚ê‚Ü‚·Bƒ{ƒŠƒ…[ƒ€Eƒ‰ƒxƒ‹‚ðíœ‚·‚é‚Æ‚«‚́Aƒkƒ‹•¶Žš—ñ‚ðŽw’肵‚Ü‚·Bƒ{ƒŠƒ…[ƒ€Eƒ‰ƒxƒ‹‚̃tƒH[ƒ}ƒbƒg‚́Aƒtƒ@ƒCƒ‹–¼(SFN)‚Æ‚Ù‚Ú“¯‚¶‚Å‚·‚ªAŽŸ‚Ì“_‚ªˆÙ‚È‚è‚Ü‚·B

    +

    解説

    +

    文字列の先頭にドライブ番号を含む場合は、その論理ドライブに対して設定されます。含まない場合は、デフォルト ドライブに設定されます。ボリューム ラベルを削除するときは、ヌル文字列を指定します。ボリューム ラベルのフォーマットは、ファイル名(SFN)とほぼ同じですが、次の点が異なります。

      -
    • ƒ[ƒJƒ‹•¶ŽšƒR[ƒhŠ·ŽZ‚Å11ƒoƒCƒgˆÈ‰ºBLFNŠg’£‚Í“K—p‚³‚ê‚Ü‚¹‚ñB
    • -
    • ƒsƒŠƒIƒh‚ðŠÜ‚Þ‚±‚Æ‚Í‚Å‚«‚È‚¢B
    • -
    • ”CˆÓ‚̈ʒu‚ɃXƒy[ƒX‚ð’u‚­‚±‚Æ‚ª‚Å‚«‚éB‚½‚¾‚µAÅŒã”ö‚Æ‚È‚éƒXƒy[ƒX‚͏œ‹Ž‚³‚ê‚éB
    • +
    • ローカル文字コード換算で11バイト以下。LFN拡張は適用されません。
    • +
    • ピリオドを含むことはできない。
    • +
    • 任意の位置にスペースを置くことができる。ただし、最後尾となるスペースは除去される。
    -

    ‘Ήžî•ñ

    -

    _FS_READONLY == 0‚ŁAŠŽ‚Â_USE_LABEL == 1‚Ì‚Æ‚«‚ÉŽg—p‰Â”\‚Å‚·B

    +

    対応情報

    +

    _FS_READONLY == 0で、且つ_USE_LABEL == 1のときに使用可能です。

    -

    Žg—p—á

    +

    使用例

    -    /* ƒfƒtƒHƒ‹ƒgEƒhƒ‰ƒCƒu‚Ƀ{ƒŠƒ…[ƒ€Eƒ‰ƒxƒ‹‚ðÝ’è */
    +    /* デフォルト ドライブにボリューム ラベルを設定 */
         f_setlabel("DATA DISK");
     
    -    /* ƒhƒ‰ƒCƒu2‚Ƀ{ƒŠƒ…[ƒ€Eƒ‰ƒxƒ‹‚ðÝ’è */
    +    /* ドライブ2にボリューム ラベルを設定 */
         f_setlabel("2:DISK 3 OF 4");
     
    -    /* ƒhƒ‰ƒCƒu2‚̃{ƒŠƒ…[ƒ€Eƒ‰ƒxƒ‹‚ðíœ */
    +    /* ドライブ2のボリューム ラベルを削除 */
         f_setlabel("2:");
     
    -

    ŽQÆ

    +

    参照

    f_getlabel
    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/sfatfs.html b/fatfs/doc/ja/sfatfs.html index ed5ac87..93b9e7c 100644 --- a/fatfs/doc/ja/sfatfs.html +++ b/fatfs/doc/ja/sfatfs.html @@ -1,7 +1,7 @@ - + @@ -13,43 +13,43 @@

    FATFS

    -

    FATFS\‘¢‘Ì(ƒtƒ@ƒCƒ‹EƒVƒXƒeƒ€EƒIƒuƒWƒFƒNƒg)‚́AŒÂX‚̘_—ƒhƒ‰ƒCƒu‚̃_ƒCƒiƒ~ƒbƒNEƒ[ƒNEƒGƒŠƒA‚ð•ÛŽ‚µAf_mount()‚ÅFatFsƒ‚ƒWƒ…[ƒ‹‚É“o˜^‚³‚ê‚Ü‚·B‰Šú‰»‚ªs‚í‚ê‚éƒ^ƒCƒ~ƒ“ƒO‚́Af_mount()(‹­§ƒ}ƒEƒ“ƒgŽw’è)‚ÌŽÀs‚Ü‚½‚̓ƒfƒBƒAŒðŠ·‚ÌŒã‚̍ŏ‰‚̃tƒ@ƒCƒ‹EƒAƒNƒZƒX‚ÌŽž‚Å‚·BƒAƒvƒŠƒP[ƒVƒ‡ƒ“‚́A‚±‚̍\‘¢‘̂̃ƒ“ƒo‚ð‘‚«Š·‚¦‚Ä‚Í‚È‚è‚Ü‚¹‚ñB

    +

    FATFS構造体(ファイル システム オブジェクト)は、個々の論理ドライブのダイナミック ワーク エリアを保持し、f_mount()でFatFsモジュールに登録されます。初期化が行われるタイミングは、f_mount()(強制マウント指定)の実行またはメディア交換の後の最初のファイル アクセスの時です。アプリケーションは、この構造体のメンバを書き換えてはなりません。

     typedef struct {
    -    BYTE    fs_type;      /* FATƒ^ƒCƒv */
    -    BYTE    drv;          /* •¨—ƒhƒ‰ƒCƒu”ԍ† */
    -    BYTE    csize;        /* ƒNƒ‰ƒXƒ^“–‚½‚è‚̃ZƒNƒ^” (1,2,4,8,...,128)*/
    -    BYTE    n_fats;       /* FAT‚Ì‘½d‰»” (1,2) */
    -    BYTE    wflag;        /* win[]ƒ_[ƒeƒBEƒtƒ‰ƒO */
    -    BYTE    fsi_flag;     /* FSINFOƒtƒ‰ƒO (b7:Disabled, b0:Dirty)*/
    -    WORD    id;           /* ƒtƒ@ƒCƒ‹EƒVƒXƒeƒ€Eƒ}ƒEƒ“ƒgID */
    -    WORD    n_rootdir;    /* ƒ‹[ƒgEƒfƒBƒŒƒNƒgƒŠ‚̃Gƒ“ƒgƒŠ” (FAT12/16) */
    +    BYTE    fs_type;      /* FATタイプ */
    +    BYTE    drv;          /* 物理ドライブ番号 */
    +    BYTE    csize;        /* クラスタ当たりのセクタ数 (1,2,4,8,...,128)*/
    +    BYTE    n_fats;       /* FATの多重化数 (1,2) */
    +    BYTE    wflag;        /* win[]ダーティ フラグ */
    +    BYTE    fsi_flag;     /* FSINFOフラグ (b7:Disabled, b0:Dirty)*/
    +    WORD    id;           /* ファイル システム マウントID */
    +    WORD    n_rootdir;    /* ルート ディレクトリのエントリ数 (FAT12/16) */
     #if _MAX_SS != _MIN_SS
    -    WORD    ssize;        /* ƒZƒNƒ^EƒTƒCƒY (512, 1024, 2048 or 4096) */
    +    WORD    ssize;        /* セクタ サイズ (512, 1024, 2048 or 4096) */
     #endif
     #if _FS_REENTRANT
    -    _SYNC_t sobj;         /* “¯ŠúƒIƒuƒWƒFƒNƒgID */
    +    _SYNC_t sobj;         /* 同期オブジェクトID */
     #endif
     #if !_FS_READONLY
    -    DWORD   last_clust;   /* FSINFO: ÅŒã‚ÉŠ„‚è“–‚Ä‚ç‚ꂽƒNƒ‰ƒXƒ^”ԍ† */
    -    DWORD   free_clust;   /* FSINFO: ‹ó‚«ƒNƒ‰ƒXƒ^” */
    +    DWORD   last_clust;   /* FSINFO: 最後に割り当てられたクラスタ番号 */
    +    DWORD   free_clust;   /* FSINFO: 空きクラスタ数 */
     #endif
     #if _FS_RPATH
    -    DWORD   cdir;         /* ƒJƒŒƒ“ƒgEƒfƒBƒŒƒNƒgƒŠ‚̃Nƒ‰ƒXƒ^ (0:ƒ‹[ƒg) */
    +    DWORD   cdir;         /* カレント ディレクトリのクラスタ (0:ルート) */
     #endif
    -    DWORD   n_fatent;     /* FATƒGƒ“ƒgƒŠ” (‘ƒNƒ‰ƒXƒ^” + 2) */
    -    DWORD   fsize;        /* FAT 1ŒÂ‚̃ZƒNƒ^” */
    -    DWORD   volbase;      /* ƒ{ƒŠƒ…[ƒ€ŠJŽnƒZƒNƒ^ */
    -    DWORD   fatbase;      /* FAT—̈æŠJŽnƒZƒNƒ^ */
    -    DWORD   dirbase;      /* ƒ‹[ƒgEƒfƒBƒŒƒNƒgƒŠ—̈æŠJŽnƒZƒNƒ^(ƒNƒ‰ƒXƒ^) */
    -    DWORD   database;     /* ƒf[ƒ^—̈æŠJŽnƒZƒNƒ^ */
    -    DWORD   winsect;      /* win[]‚ÉŒ»‚ê‚Ä‚¢‚éƒZƒNƒ^”ԍ† */
    -    BYTE    win[_MAX_SS]; /* ƒfƒBƒXƒNEƒAƒNƒZƒXEƒEƒBƒ“ƒhƒE */
    +    DWORD   n_fatent;     /* FATエントリ数 (総クラスタ数 + 2) */
    +    DWORD   fsize;        /* FAT 1個のセクタ数 */
    +    DWORD   volbase;      /* ボリューム開始セクタ */
    +    DWORD   fatbase;      /* FAT領域開始セクタ */
    +    DWORD   dirbase;      /* ルート ディレクトリ領域開始セクタ(クラスタ) */
    +    DWORD   database;     /* データ領域開始セクタ */
    +    DWORD   winsect;      /* win[]に現れているセクタ番号 */
    +    BYTE    win[_MAX_SS]; /* ディスク アクセス ウィンドウ */
     } FATFS;
     
    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/sfile.html b/fatfs/doc/ja/sfile.html index 36a73b3..5da60f9 100644 --- a/fatfs/doc/ja/sfile.html +++ b/fatfs/doc/ja/sfile.html @@ -1,7 +1,7 @@ - + @@ -13,36 +13,36 @@

    FIL

    -

    FIL\‘¢‘Ì(ƒtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg)‚́Af_open()‚ŏ‰Šú‰»‚³‚êAˆÈŒã‚»‚̃tƒ@ƒCƒ‹‚̏ó‘Ô‚ð•ÛŽ‚µ‚Ü‚·B‚Ü‚½Af_close()‚Ńtƒ@ƒCƒ‹‚ª•Â‚¶‚ç‚ê‚é‚Æ–³Œø‰»‚³‚ê‚Ü‚·BƒAƒvƒŠƒP[ƒVƒ‡ƒ“‚́A‚±‚̍\‘¢‘̂̃ƒ“ƒo‚ð‘‚«Š·‚¦‚Ä‚Í‚È‚è‚Ü‚¹‚ñ(cltbl‚Í—áŠO)B”ñƒ^ƒCƒj[\¬‚ł́A“à•”‚ɃZƒNƒ^Eƒoƒbƒtƒ@‚ªŠm•Û‚³‚ê‚é‚̂ŁAè—LƒTƒCƒY‚É’ˆÓ‚ª•K—v‚Å‚·B

    +

    FIL構造体(ファイル オブジェクト)は、f_open()で初期化され、以後そのファイルの状態を保持します。また、f_close()でファイルが閉じられると無効化されます。アプリケーションは、この構造体のメンバを書き換えてはなりません(cltblは例外)。非タイニー構成(_FS_TINY == 0)では、内部に_MAX_SSバイトのセクタ バッファが確保されるので、そのサイズには注意が必要です。

     typedef struct {
    -    FATFS*  fs;           /* eƒtƒ@ƒCƒ‹EƒVƒXƒeƒ€EƒIƒuƒWƒFƒNƒg‚ւ̃|ƒCƒ“ƒ^ */
    -    WORD    id;           /* eƒtƒ@ƒCƒ‹EƒVƒXƒeƒ€EƒIƒuƒWƒFƒNƒg‚̃}ƒEƒ“ƒgID */
    -    BYTE    flag;         /* ƒtƒ@ƒCƒ‹EƒXƒe[ƒ^ƒXEƒtƒ‰ƒO */
    -    BYTE    err;          /* ƒGƒ‰[’†’fƒtƒ‰ƒO */
    -    DWORD   fptr;         /* ƒtƒ@ƒCƒ‹“ǂݏ‘‚«ƒ|ƒCƒ“ƒ^ (ƒtƒ@ƒCƒ‹æ“ª‚©‚ç‚̃oƒCƒgEƒIƒtƒZƒbƒg) */
    -    DWORD   fsize;        /* ƒtƒ@ƒCƒ‹EƒTƒCƒY(ƒoƒCƒg’PˆÊ) */
    -    DWORD   sclust;       /* ƒtƒ@ƒCƒ‹ŠJŽnƒNƒ‰ƒXƒ^”ԍ† (0:Š„‚è“–‚Ä–³‚µ) */
    -    DWORD   clust;        /* Œ»Ý‚̃Nƒ‰ƒXƒ^ */
    -    DWORD   dsect;        /* Œ»Ý‚̃f[ƒ^EƒZƒNƒ^ */
    +    FATFS*  fs;           /* 親ファイル システム オブジェクトへのポインタ */
    +    WORD    id;           /* 親ファイル システム オブジェクトのマウントID */
    +    BYTE    flag;         /* ファイル ステータス フラグ */
    +    BYTE    err;          /* エラー中断フラグ */
    +    DWORD   fptr;         /* ファイル読み書きポインタ (ファイル先頭からのバイト オフセット) */
    +    DWORD   fsize;        /* ファイル サイズ(バイト単位) */
    +    DWORD   sclust;       /* ファイル開始クラスタ番号 (0:割り当て無し) */
    +    DWORD   clust;        /* 現在のクラスタ */
    +    DWORD   dsect;        /* 現在のデータ セクタ */
     #if !_FS_READONLY
    -    DWORD   dir_sect;     /* ‚±‚̃tƒ@ƒCƒ‹‚̃fƒBƒŒƒNƒgƒŠEƒGƒ“ƒgƒŠ‚Ì‚ ‚éƒZƒNƒ^ */
    -    BYTE*   dir_ptr;      /* ‚±‚̃tƒ@ƒCƒ‹‚̃fƒBƒŒƒNƒgƒŠ‚ւ̃|ƒCƒ“ƒ^ */
    +    DWORD   dir_sect;     /* このファイルのディレクトリ エントリのあるセクタ */
    +    BYTE*   dir_ptr;      /* このファイルのディレクトリへのポインタ */
     #endif
     #if _USE_FASTSEEK
    -    DWORD*  cltbl;        /* ƒtƒ@ƒCƒ‹‚̃Nƒ‰ƒXƒ^EƒŠƒ“ƒNî•ñ‚ւ̃|ƒCƒ“ƒ^ (ƒI[ƒvƒ“Žž‚ÉNULL‚ªƒZƒbƒg‚³‚ê‚é) */
    +    DWORD*  cltbl;        /* ファイルのクラスタ リンク情報へのポインタ (オープン時にNULLがセットされる) */
     #endif
     #if _FS_LOCK
    -    UINT    lockid;       /* ƒtƒ@ƒCƒ‹EƒƒbƒNID */
    +    UINT    lockid;       /* ファイル ロックID */
     #endif
     #if !_FS_TINY
    -    BYTE    buf[_MAX_SS]; /* ƒtƒ@ƒCƒ‹Eƒvƒ‰ƒCƒx[ƒgEƒf[ƒ^“]‘—ƒoƒbƒtƒ@ */
    +    BYTE    buf[_MAX_SS]; /* ファイル プライベート データ転送バッファ */
     #endif
     } FIL;
     
    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/sfileinfo.html b/fatfs/doc/ja/sfileinfo.html index 1a3db24..a9167f1 100644 --- a/fatfs/doc/ja/sfileinfo.html +++ b/fatfs/doc/ja/sfileinfo.html @@ -1,7 +1,7 @@ - + @@ -13,58 +13,58 @@

    FILINFO

    -

    FILINFO\‘¢‘̂́Af_stat(), f_readdir()‚Å•Ô‚³‚ê‚éƒtƒ@ƒCƒ‹î•ñ‚ð•ÛŽ‚µ‚Ü‚·B

    +

    FILINFO構造体は、f_stat(), f_readdir()で返されるファイル情報を保持します。

     typedef struct {
    -    DWORD fsize;     /* ƒtƒ@ƒCƒ‹EƒTƒCƒY */
    -    WORD fdate;      /* ÅŒã‚ɍXV‚³‚ꂽ“ú•t */
    -    WORD ftime;      /* ÅŒã‚ɍXV‚³‚ꂽŽž  */
    -    BYTE fattrib;    /* ƒAƒgƒŠƒrƒ…[ƒg */
    -    TCHAR fname[13]; /* ’Z‚¢ƒtƒ@ƒCƒ‹–¼ (8.3ƒtƒH[ƒ}ƒbƒg) */
    +    DWORD fsize;     /* ファイル サイズ */
    +    WORD fdate;      /* 最後に更新された日付 */
    +    WORD ftime;      /* 最後に更新された時刻  */
    +    BYTE fattrib;    /* アトリビュート */
    +    TCHAR fname[13]; /* 短いファイル名 (8.3フォーマット) */
     #if _USE_LFN
    -    TCHAR* lfname;   /* ’·‚¢ƒtƒ@ƒCƒ‹–¼‚̃oƒbƒtƒ@‚ւ̃|ƒCƒ“ƒ^ */
    -    int lfsize;      /* ’·‚¢ƒtƒ@ƒCƒ‹–¼‚̃oƒbƒtƒ@‚̃TƒCƒY [•¶Žš”] */
    +    TCHAR* lfname;   /* 長いファイル名のバッファへのポインタ */
    +    int lfsize;      /* 長いファイル名のバッファのサイズ [文字数] */
     #endif
     } FILINFO;
     
    -

    ƒƒ“ƒo

    +

    メンバ

    fsize
    -
    ƒtƒ@ƒCƒ‹‚̃oƒCƒg’PˆÊ‚̃TƒCƒY‚ªŠi”[‚³‚ê‚Ü‚·BƒfƒBƒŒƒNƒgƒŠ‚̏ꍇ‚͏í‚É0‚Å‚·B
    +
    ファイルのバイト単位のサイズが格納されます。ディレクトリの場合は常に0です。
    fdate
    -
    ƒtƒ@ƒCƒ‹‚̕ύX‚³‚ꂽ“ú•tA‚Ü‚½‚̓fƒBƒŒƒNƒgƒŠ‚̍쐬‚³‚ꂽ“ú•t‚ªŠi”[‚³‚ê‚Ü‚·B
    +
    ファイルの変更された日付、またはディレクトリの作成された日付が格納されます。
    bit15:9
    -
    1980”N‚ð‹N“_‚Æ‚µ‚½”N‚ª 0..127 ‚Å“ü‚è‚Ü‚·B
    +
    1980年を起点とした年が 0..127 で入ります。
    bit8:5
    -
    ŒŽ‚ª 1..12 ‚Ì’l‚Å“ü‚è‚Ü‚·B
    +
    月が 1..12 の値で入ります。
    bit4:0
    -
    “ú‚ª 1..31 ‚Ì’l‚Å“ü‚è‚Ü‚·B
    +
    日が 1..31 の値で入ります。
    ftime
    -
    ƒtƒ@ƒCƒ‹‚̕ύX‚³‚ꂽŽžA‚Ü‚½‚̓fƒBƒŒƒNƒgƒŠ‚̍쐬‚³‚ꂽŽž‚ªŠi”[‚³‚ê‚Ü‚·B
    +
    ファイルの変更された時刻、またはディレクトリの作成された時刻が格納されます。
    bit15:11
    -
    Žž‚ª 0..23 ‚Ì’l‚Å“ü‚è‚Ü‚·B
    +
    時が 0..23 の値で入ります。
    bit10:5
    -
    •ª‚ª 0..59 ‚Ì’l‚Å“ü‚è‚Ü‚·B
    +
    分が 0..59 の値で入ります。
    bit4:0
    -
    •b/2‚ª 0..29 ‚Ì’l‚Å“ü‚è‚Ü‚·B
    +
    秒/2が 0..29 の値で入ります。
    fattrib
    -
    ‘®«ƒtƒ‰ƒO‚ªŠi”[‚³‚ê‚Ü‚·Bƒtƒ‰ƒO‚ÍAM_DIR, AM_RDO, AM_HID, AM_SYS, AM_ARC‚Ì‘g‚ݍ‡‚킹‚Æ‚È‚è‚Ü‚·B
    +
    属性フラグが格納されます。フラグはAM_DIR, AM_RDO, AM_HID, AM_SYS, AM_ARCの組み合わせとなります。
    fname[]
    -
    8.3Œ`Ž®‚Ì–¼‘O‚ª'\0'‚ŏI‚í‚镶Žš—ñ‚Æ‚µ‚ÄŠi”[‚³‚ê‚Ü‚·B”ñLFN\¬‚Ì‚Æ‚«‚́Aí‚ɑ啶Žš‚Å•Ô‚³‚ê‚Ü‚·BLFN\¬‚Ì‚Æ‚«‚Í’Z‚¢–¼‘O‚ª•Ô‚³‚ê‚Ü‚·‚ªAASCII‰pŽš‚ª¬•¶Žš‚É‚È‚éê‡‚ª‚ ‚è‚Ü‚·B
    +
    8.3形式の名前が'\0'で終わる文字列として格納されます。非LFN構成のときは、常に大文字で返されます。LFN構成のときは短い名前が返されますが、ASCII英字が小文字になる場合があります。
    lfname
    -
    •Ô‚³‚ê‚é’·‚¢ƒtƒ@ƒCƒ‹–¼‚ðŠi”[‚·‚éƒoƒbƒtƒ@‚ւ̃|ƒCƒ“ƒ^B‚±‚̍\‘¢‘Ì‚ðŽg—p‚·‚é‘O‚ɃAƒvƒŠƒP[ƒVƒ‡ƒ“‚É‚æ‚菉Šú‰»‚³‚ê‚È‚¯‚ê‚΂Ȃè‚Ü‚¹‚ñB‚±‚̃ƒ“ƒo‚ÉNULL‚ªÝ’肳‚ê‚é‚ÆLFN‚Í•Ô‚³‚ê‚Ü‚¹‚ñB”ñLFN\¬‚Ì‚Æ‚«‚Í‚±‚̃ƒ“ƒo‚Í‘¶Ý‚µ‚Ü‚¹‚ñB
    +
    返される長いファイル名を格納するバッファへのポインタ。この構造体を使用する前にアプリケーションにより初期化されなければなりません。このメンバにNULLが設定されるとLFNは返されません。非LFN構成のときはこのメンバは存在しません。
    lfsize
    -
    ’·‚¢ƒtƒ@ƒCƒ‹–¼‚ðŠi”[‚·‚éƒoƒbƒtƒ@‚̃TƒCƒY(—v‘f”)B‚±‚̍\‘¢‘Ì‚ðŽg—p‚·‚é‘O‚ɃAƒvƒŠƒP[ƒVƒ‡ƒ“‚É‚æ‚菉Šú‰»‚³‚ê‚È‚¯‚ê‚΂Ȃè‚Ü‚¹‚ñB”ñLFN\¬‚Ì‚Æ‚«‚Í‚±‚̃ƒ“ƒo‚Í‘¶Ý‚µ‚Ü‚¹‚ñB
    +
    長いファイル名を格納するバッファのサイズ(要素数)。この構造体を使用する前にアプリケーションにより初期化されなければなりません。非LFN構成のときはこのメンバは存在しません。
    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/size.html b/fatfs/doc/ja/size.html index caff05d..d75ffc3 100644 --- a/fatfs/doc/ja/size.html +++ b/fatfs/doc/ja/size.html @@ -1,7 +1,7 @@ - + @@ -13,33 +13,33 @@

    f_size

    -

    ƒtƒ@ƒCƒ‹‚̃TƒCƒY‚ðŽæ“¾‚µ‚Ü‚·B

    +

    ファイルのサイズを取得します。

     DWORD f_size (
    -  FIL* fp   /* [IN] ƒtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg */
    +  FIL* fp   /* [IN] ファイル オブジェクト */
     );
     
    -

    ˆø”

    +

    引数

    fp
    -
    ƒtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg\‘¢‘̂ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B
    +
    ファイル オブジェクト構造体へのポインタを指定します。
    -

    –ß‚è’l

    -

    ƒoƒCƒg’PˆÊ‚̃tƒ@ƒCƒ‹EƒTƒCƒY‚ª•Ô‚è‚Ü‚·B

    +

    戻り値

    +

    バイト単位のファイル サイズが返ります。

    -

    ‰ðà

    -

    f_sizeŠÖ”‚́AŒ»ƒŠƒrƒWƒ‡ƒ“‚ł̓}ƒNƒ‚Æ‚µ‚ÄŽÀ‘•‚³‚ê‚Ä‚¢‚Ü‚·B

    +

    解説

    +

    f_size関数は、現リビジョンではマクロとして実装されています。

     #define f_size(fp) ((fp)->fsize)
     
    @@ -47,16 +47,16 @@ DWORD f_size (
    -

    ‘Ήžî•ñ

    -

    í‚ÉŽg—p‰Â”\B

    +

    対応情報

    +

    常に使用可能。

    -

    ŽQÆ

    +

    参照

    f_open, f_lseek, FIL

    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/stat.html b/fatfs/doc/ja/stat.html index 5337f34..724a9d5 100644 --- a/fatfs/doc/ja/stat.html +++ b/fatfs/doc/ja/stat.html @@ -1,7 +1,7 @@ - + @@ -13,28 +13,28 @@

    f_stat

    -

    ƒtƒ@ƒCƒ‹‚Ü‚½‚̓TƒuEƒfƒBƒŒƒNƒgƒŠ‚Ì‘¶Ý‚𒲂ׁA‚Ü‚½‚»‚̏î•ñ‚ðŽæ“¾‚µ‚Ü‚·B

    +

    ファイルまたはサブ ディレクトリの存在を調べ、またその情報を取得します。

     FRESULT f_stat (
    -  const TCHAR* path,  /* [IN] ƒIƒuƒWƒFƒNƒg–¼‚ւ̃|ƒCƒ“ƒ^ */
    -  FILINFO* fno        /* [OUT] ƒtƒ@ƒCƒ‹î•ñ\‘¢‘̂ւ̃|ƒCƒ“ƒ^ */
    +  const TCHAR* path,  /* [IN] オブジェクト名へのポインタ */
    +  FILINFO* fno        /* [OUT] ファイル情報構造体へのポインタ */
     );
     
    -

    ˆø”

    +

    引数

    path
    -
    ƒ`ƒFƒbƒN‚·‚éƒIƒuƒWƒFƒNƒg–¼‚ðŽ¦‚·ƒkƒ‹•¶Žš'\0'I’[‚Ì•¶Žš—ñ‚ðŽw‚·ƒ|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B
    +
    チェックするオブジェクト名を示すヌル文字'\0'終端の文字列を指すポインタを指定します。
    fno
    -
    ƒIƒuƒWƒFƒNƒg‚ª‘¶Ý‚µ‚½‚Æ‚«‚É‚»‚̏î•ñ‚ðŠi”[‚·‚éƒtƒ@ƒCƒ‹î•ñ\‘¢‘̂ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B‚±‚̏î•ñ‚ª•s—v‚È‚Æ‚«‚̓kƒ‹Eƒ|ƒCƒ“ƒ^‚ðŽw’肵‚Ä‚­‚¾‚³‚¢B
    +
    オブジェクトが存在したときにその情報を格納するファイル情報構造体へのポインタを指定します。この情報が不要なときはヌル ポインタを指定してください。
    -

    –ß‚è’l

    +

    戻り値

    FR_OK, FR_DISK_ERR, @@ -53,22 +53,61 @@ FRESULT f_stat (

    -

    ‰ðà

    -

    Žw’肳‚ꂽƒtƒ@ƒCƒ‹‚Ü‚½‚̓TƒuEƒfƒBƒŒƒNƒgƒŠ‚Ì‘¶Ý‚𒲂ׂ܂·B‘¶Ý‚µ‚È‚¢ê‡‚́AFR_NO_FILE‚ª‹A‚è‚Ü‚·B‘¶Ý‚·‚éê‡‚ÍFR_OK‚ª‹A‚èAƒtƒ@ƒCƒ‹î•ñ\‘¢‘Ì‚É‚»‚êŠÖ‚·‚éî•ñ(ƒTƒCƒYAƒ^ƒCƒ€ƒXƒ^ƒ“ƒvA‘®«‚¨‚æ‚Ñ’Z‚¢ƒtƒ@ƒCƒ‹–¼)‚ªƒXƒgƒA‚³‚ê‚Ü‚·B

    +

    解説

    +

    指定されたファイルまたはサブ ディレクトリの存在を調べます。存在しない場合は、FR_NO_FILEが帰ります。存在する場合はFR_OKが帰り、ファイル情報構造体にそれ関する情報(サイズ、タイムスタンプ、属性および短いファイル名)がストアされます。

    -

    ‘Ήžî•ñ

    -

    _FS_MINIMIZE == 0‚Ì‚Æ‚«‚ÉŽg—p‰Â”\‚Å‚·B

    +

    対応情報

    +

    _FS_MINIMIZE == 0のときに使用可能です。

    +
    + + +
    +

    使用例

    +
    +    FRESULT fr;
    +    FILINFO fno;
    +
    +
    +    printf("Test for 'file.txt'...\n");
    +
    +#if _USE_LFN
    +    fno.lfname = 0;
    +#endif
    +    fr = f_stat("file.txt", &fno);
    +    switch (fr) {
    +
    +    case FR_OK:
    +        printf("Size: %u\n", fno.fsize);
    +        printf("Timestamp: %u/%02u/%02u, %02u:%02u\n",
    +               (fno.fdate >> 9) + 1980, fno.fdate >> 5 & 15, fno.fdate & 31,
    +               fno.ftime >> 11, fno.ftime >> 5 & 63);
    +        printf("Attributes: %c%c%c%c%c\n",
    +               (fno.fattrib & AM_DIR) ? 'D' : '-',
    +               (fno.fattrib & AM_RDO) ? 'R' : '-',
    +               (fno.fattrib & AM_HID) ? 'H' : '-',
    +               (fno.fattrib & AM_SYS) ? 'S' : '-',
    +               (fno.fattrib & AM_ARC) ? 'A' : '-');
    +        break;
    +
    +    case FR_NO_FILE:
    +        printf("It is not exist.\n");
    +        break;
    +
    +    default:
    +        printf("An error occured. (%d)\n", fr);
    +    }
    +
    -

    ŽQÆ

    +

    参照

    f_opendir, f_readdir, FILINFO, DIR

    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/sync.html b/fatfs/doc/ja/sync.html index 74f7910..4b594d6 100644 --- a/fatfs/doc/ja/sync.html +++ b/fatfs/doc/ja/sync.html @@ -1,7 +1,7 @@ - + @@ -13,25 +13,25 @@

    f_sync

    -

    ‘‚«ž‚Ý’†‚̃tƒ@ƒCƒ‹‚̃LƒƒƒbƒVƒ…‚³‚ꂽî•ñ‚ðƒtƒ‰ƒbƒVƒ…‚µ‚Ü‚·B

    +

    書き込み中のファイルのキャッシュされた情報をフラッシュします。

     FRESULT f_sync (
    -  FIL* fp     /* [IN] ƒtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg\‘¢‘̂ւ̃|ƒCƒ“ƒ^ */
    +  FIL* fp     /* [IN] ファイル オブジェクト構造体へのポインタ */
     );
     
    -

    ˆø”

    +

    引数

    fp
    -
    sync‚·‚éƒtƒ@ƒCƒ‹‚̃tƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg\‘¢‘̂ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B
    +
    syncするファイルのファイル オブジェクト構造体へのポインタを指定します。
    -

    –ß‚è’l

    +

    戻り値

    FR_OK, FR_DISK_ERR, @@ -44,23 +44,23 @@ FRESULT f_sync (

    -

    ‰ðà

    -

    ‚±‚̊֐”‚Íf_close()‚Æ“¯‚¶ˆ—‚ðŽÀs‚µ‚Ü‚·‚ªAƒtƒ@ƒCƒ‹‚͈ø‚«‘±‚«ŠJ‚©‚ꂽ‚Ü‚Ü‚É‚È‚èA“ǂݏ‘‚«‚𑱍s‚Å‚«‚Ü‚·BƒƒMƒ“ƒO‚ȂǁA‘‚«ž‚݃‚[ƒh‚Å’·ŽžŠÔƒtƒ@ƒCƒ‹‚ªŠJ‚©‚ê‚Ä‚¢‚éƒAƒvƒŠƒP[ƒVƒ‡ƒ“‚É‚¨‚¢‚āA’èŠú“I‚Ü‚½‚Í‹æØ‚è‚Ì—Ç‚¢‚Æ‚±‚ë‚Å‚±‚̊֐”‚ðŽg—p‚·‚邱‚Æ‚É‚æ‚èA•sˆÓ‚Ì“dŒ¹’f‚⃁ƒfƒBƒA‚ÌŽæ‚èŠO‚µ‚É‚æ‚莸‚í‚ê‚éƒf[ƒ^‚ðÅ¬‚É‚·‚邱‚Æ‚ª‚Å‚«‚Ü‚·B‚±‚Ì”wŒi‚ɂ‚¢‚ẮAƒAƒvƒŠƒP[ƒVƒ‡ƒ“Eƒm[ƒg‚àŽQÆ‚µ‚Ä‚­‚¾‚³‚¢B

    -

    ŽÀÛ‚Ì‚Æ‚±‚ëAf_close()“à‚Å‚Í‚±‚̊֐”‚ðŒÄ‚яo‚µ‚½Œãƒtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg‚𖳌ø‰»‚µ‚Ä‚¢‚邾‚¯‚Ȃ̂ŁAf_close()’¼‘O‚Éf_sync()‚ð’u‚­‚±‚Æ‚Í–³ˆÓ–¡‚Å‚·B

    +

    解説

    +

    この関数はf_close()と同じ処理を実行しますが、ファイルは引き続き開かれたままになり、読み書きを続行できます。ロギングなど、書き込みモードで長時間ファイルが開かれているアプリケーションにおいて、定期的または区切りの良いところでこの関数を使用することにより、不意の電源断やメディアの取り外しにより失われるデータを最小にすることができます。この背景については、アプリケーション ノートも参照してください。

    +

    実際のところ、f_close()内ではこの関数を呼び出した後ファイル オブジェクトを無効化しているだけなので、f_close()直前にf_sync()を置くことは無意味です。

    -

    ‘Ήžî•ñ

    -

    _FS_READONLY == 0‚Ì‚Æ‚«‚ÉŽg—p‰Â”\‚Å‚·B

    +

    対応情報

    +

    _FS_READONLY == 0のときに使用可能です。

    -

    ŽQÆ

    +

    参照

    f_close

    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/tell.html b/fatfs/doc/ja/tell.html index 1dee982..d050691 100644 --- a/fatfs/doc/ja/tell.html +++ b/fatfs/doc/ja/tell.html @@ -1,7 +1,7 @@ - + @@ -13,33 +13,33 @@

    f_tell

    -

    Œ»Ý‚̃Š[ƒh/ƒ‰ƒCƒgEƒ|ƒCƒ“ƒ^‚ðŽæ“¾‚µ‚Ü‚·B

    +

    現在のリード/ライト ポインタを取得します。

     DWORD f_tell (
    -  FIL* fp   /* [IN] ƒtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg */
    +  FIL* fp   /* [IN] ファイル オブジェクト */
     );
     
    -

    ˆø”

    +

    引数

    fp
    -
    ƒtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg\‘¢‘̂ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B
    +
    ファイル オブジェクト構造体へのポインタを指定します。
    -

    –ß‚è’l

    -

    Œ»Ý‚̃Š[ƒh/ƒ‰ƒCƒgEƒ|ƒCƒ“ƒ^(ƒtƒ@ƒCƒ‹æ“ª‚©‚ç‚̃oƒCƒg’PˆÊ‚̃IƒtƒZƒbƒg)‚ª•Ô‚è‚Ü‚·B

    +

    戻り値

    +

    現在のリード/ライト ポインタ(ファイル先頭からのバイト単位のオフセット)が返ります。

    -

    ‰ðà

    -

    f_tellŠÖ”‚́AŒ»ƒŠƒrƒWƒ‡ƒ“‚ł̓}ƒNƒ‚Æ‚µ‚ÄŽÀ‘•‚³‚ê‚Ä‚¢‚Ü‚·B

    +

    解説

    +

    f_tell関数は、現リビジョンではマクロとして実装されています。

     #define f_tell(fp) ((fp)->fptr)
     
    @@ -47,16 +47,16 @@ DWORD f_tell (
    -

    ‘Ήžî•ñ

    -

    í‚ÉŽg—p‰Â”\B

    +

    対応情報

    +

    常に使用可能。

    -

    ŽQÆ

    +

    参照

    f_open, f_lseek, FIL

    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/truncate.html b/fatfs/doc/ja/truncate.html index 29bf480..b33a757 100644 --- a/fatfs/doc/ja/truncate.html +++ b/fatfs/doc/ja/truncate.html @@ -1,7 +1,7 @@ - + @@ -13,25 +13,25 @@

    f_truncate

    -

    ƒtƒ@ƒCƒ‹’·‚ðØ‚è‹l‚ß‚Ü‚·B

    +

    ファイル長を切り詰めます。

     FRESULT f_truncate (
    -  FIL* fp     /* [IN] ƒtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg‚ւ̃|ƒCƒ“ƒ^ */
    +  FIL* fp     /* [IN] ファイル オブジェクトへのポインタ */
     );
     
    -

    ˆø”

    +

    引数

    fp
    -
    Ø‚è‹l‚ߑΏۃtƒ@ƒCƒ‹‚̃tƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg‚ւ̃|ƒCƒ“ƒ^
    +
    切り詰め対象ファイルのファイル オブジェクトへのポインタ
    -

    –ß‚è’l

    +

    戻り値

    FR_OK, FR_DISK_ERR, @@ -45,19 +45,19 @@ FRESULT f_truncate (

    -

    ‰ðà

    -

    ƒtƒ@ƒCƒ‹‚Ì’·‚³‚ªŒ»Ý‚̃Š[ƒh/ƒ‰ƒCƒgEƒ|ƒCƒ“ƒ^‚ɐ؂è‹l‚ß‚ç‚ê‚Ü‚·BƒŠ[ƒh/ƒ‰ƒCƒgEƒ|ƒCƒ“ƒ^‚ªŠù‚Ƀtƒ@ƒCƒ‹‚̏I’[‚ðŽw‚µ‚Ä‚¢‚é‚Æ‚«‚́A‚±‚̊֐”‚͉½‚ÌŒø‰Ê‚àŽ‚¿‚Ü‚¹‚ñB

    +

    解説

    +

    ファイルの長さが現在のリード/ライト ポインタに切り詰められます。リード/ライト ポインタが既にファイルの終端を指しているときは、この関数は何の効果も持ちません。

    -

    ‘Ήžî•ñ

    -

    _FS_READONLY == 0‚ŁAŠŽ‚Â_FS_MINIMIZE == 0‚Ì‚Æ‚«‚ÉŽg—p‰Â”\‚Å‚·B

    +

    対応情報

    +

    _FS_READONLY == 0で、且つ_FS_MINIMIZE == 0のときに使用可能です。

    -

    ŽQÆ

    +

    参照

    f_open, f_lseek, FIL

    diff --git a/fatfs/doc/ja/unlink.html b/fatfs/doc/ja/unlink.html index 7cfb703..3ae691a 100644 --- a/fatfs/doc/ja/unlink.html +++ b/fatfs/doc/ja/unlink.html @@ -1,7 +1,7 @@ - + @@ -13,25 +13,25 @@

    f_unlink

    -

    ƒtƒ@ƒCƒ‹‚Ü‚½‚̓TƒuEƒfƒBƒŒƒNƒgƒŠ‚ðíœ‚µ‚Ü‚·B

    +

    ファイルまたはサブ ディレクトリを削除します。

     FRESULT f_unlink (
    -  const TCHAR* path  /* [IN] ƒIƒuƒWƒFƒNƒg–¼‚ւ̃|ƒCƒ“ƒ^ */
    +  const TCHAR* path  /* [IN] オブジェクト名へのポインタ */
     );
     
    -

    ˆø”

    +

    引数

    path
    -
    íœ‘Ώۂ̃pƒX–¼‚ðŽ¦‚·ƒkƒ‹•¶Žš'\0'I’[‚Ì•¶Žš—ñ‚ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B
    +
    削除対象のパス名を示すヌル文字'\0'終端の文字列へのポインタを指定します。
    -

    –ß‚è’l

    +

    戻り値

    FR_OK, FR_DISK_ERR, @@ -53,22 +53,22 @@ FRESULT f_unlink (

    -

    ‰ðà

    -

    íœ‘Ώۂ̃IƒuƒWƒFƒNƒg‚ªŽŸ‚ÌðŒ‚É“–‚Ä‚Í‚Ü‚éê‡A‚»‚̃AƒNƒZƒX‚Í‹‘”Û‚³‚êŠÖ”‚ÍŽ¸”s‚µ‚Ü‚·B +

    解説

    +

    削除対象のオブジェクトが次の条件に当てはまる場合、そのアクセスは拒否され関数は失敗します。

      -
    • ƒŠ[ƒhEƒIƒ“ƒŠ[‘®«(AM_RDO)‚ðŽ‚Á‚Ä‚¢‚éê‡‚́A‹‘”Û(FR_DENIED)‚³‚ê‚éB
    • -
    • ‹ó‚Å‚È‚¢ƒTƒuEƒfƒBƒŒƒNƒgƒŠ‚Ü‚½‚̓JƒŒƒ“ƒgEƒfƒBƒŒƒNƒgƒŠ‚Å‚ ‚éê‡‚́A‹‘”Û(FR_DENIED)‚³‚ê‚éB
    • -
    • ŠJ‚©‚ê‚Ä‚¢‚éƒtƒ@ƒCƒ‹‚Ü‚½‚̓TƒuEƒfƒBƒŒƒNƒgƒŠ‚Å‚ ‚éê‡‚́A‘½dƒAƒNƒZƒX§Œä‚ª—LŒø‚È‚çˆÀ‘S‚É‹‘”Û(FR_LOCKED)‚³‚ê‚Ü‚·‚ªA‚»‚¤‚Å‚È‚¢‚Æ‚«‚Í•s³‚È‘€ì‚Æ‚È‚èAFAT\‘¢‚ª”j‰ó‚³‚ê‚é‰Â”\«‚ª‚ ‚è‚Ü‚·B
    • +
    • リード オンリー属性(AM_RDO)を持っている場合は、拒否(FR_DENIED)される。
    • +
    • 空でないサブ ディレクトリまたはカレント ディレクトリである場合は、拒否(FR_DENIED)される。
    • +
    • 開かれているファイルまたはサブ ディレクトリである場合は、多重アクセス制御が有効なら安全に拒否(FR_LOCKED)されますが、そうでないときは不正な操作となり、FAT構造が破壊される可能性があります。

    -

    ‘Ήžî•ñ

    -

    _FS_READONLY == 0‚ŁAŠŽ‚Â_FS_MINIMIZE == 0‚Ì‚Æ‚«‚ÉŽg—p‰Â”\‚Å‚·B

    +

    対応情報

    +

    _FS_READONLY == 0で、且つ_FS_MINIMIZE == 0のときに使用可能です。

    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/utime.html b/fatfs/doc/ja/utime.html index 382defb..087f57f 100644 --- a/fatfs/doc/ja/utime.html +++ b/fatfs/doc/ja/utime.html @@ -1,7 +1,7 @@ - + @@ -13,28 +13,28 @@

    f_utime

    -

    ƒtƒ@ƒCƒ‹‚Ü‚½‚̓TƒuEƒfƒBƒŒƒNƒgƒŠ‚̃^ƒCƒ€ƒXƒ^ƒ“ƒv‚ð•ÏX‚µ‚Ü‚·B

    +

    ファイルまたはサブ ディレクトリのタイムスタンプを変更します。

     FRESULT f_utime (
    -  const TCHAR* path,  /* [IN] ƒIƒuƒWƒFƒNƒg–¼‚ւ̃|ƒCƒ“ƒ^ */
    -  const FILINFO* fno  /* [IN] Ý’è‚·‚é“ú•t */
    +  const TCHAR* path,  /* [IN] オブジェクト名へのポインタ */
    +  const FILINFO* fno  /* [IN] 設定する日付 */
     );
     
    -

    ˆø”

    +

    引数

    path
    -
    •ÏX‘Ώۂ̃IƒuƒWƒFƒNƒg‚̃pƒX–¼‚ðŽ¦‚·ƒkƒ‹•¶Žš'\0'I’[‚Ì•¶Žš—ñ‚ðŽw’肵‚Ü‚·B
    +
    変更対象のオブジェクトのパス名を示すヌル文字'\0'終端の文字列を指定します。
    fno
    -
    Ý’è‚·‚é“ú•t‚ÆŽžŠÔ‚ðfdate‚Æftimeƒƒ“ƒo‚ɐݒ肳‚ꂽFILINFO\‘¢‘̂ւ̃|ƒCƒ“ƒ^B‘¼‚̃ƒ“ƒo‚Í‚±‚̊֐”‚ł͈Ӗ¡‚ðŽ‚¿‚Ü‚¹‚ñB
    +
    設定する日付と時間をfdateとftimeメンバに設定されたFILINFO構造体へのポインタ。他のメンバはこの関数では意味を持ちません。
    -

    –ß‚è’l

    +

    戻り値

    FR_OK, FR_DISK_ERR, @@ -54,16 +54,16 @@ FRESULT f_utime (

    -

    ‰ðà

    -

    ƒIƒuƒWƒFƒNƒg‚̃^ƒCƒ€ƒXƒ^ƒ“ƒv‚ð•ÏX‚µ‚Ü‚·B

    +

    解説

    +

    オブジェクトのタイムスタンプを変更します。

    -

    Žg—p—á

    +

    使用例

     FRESULT set_timestamp (
    -    char *obj,     /* ƒtƒ@ƒCƒ‹–¼‚ւ̃|ƒCƒ“ƒ^ */
    +    char *obj,     /* ファイル名へのポインタ */
         int year,
         int month,
         int mday,
    @@ -84,16 +84,16 @@ FRESULT set_timestamp (
     
     
     
    -

    ‘Ήžî•ñ

    -

    _FS_READONLY == 0‚ŁAŠŽ‚Â_FS_MINIMIZE == 0‚Ì‚Æ‚«‚ÉŽg—p‰Â”\‚Å‚·B

    +

    対応情報

    +

    _FS_READONLY == 0で、且つ_FS_MINIMIZE == 0のときに使用可能です。

    -

    ŽQÆ

    +

    参照

    f_stat, FILINFO

    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/ja/write.html b/fatfs/doc/ja/write.html index 35da3fa..c3de4a0 100644 --- a/fatfs/doc/ja/write.html +++ b/fatfs/doc/ja/write.html @@ -1,7 +1,7 @@ - + @@ -13,34 +13,34 @@

    f_write

    -

    ƒtƒ@ƒCƒ‹‚Ƀf[ƒ^‚ð‘‚«ž‚Ý‚Ü‚·B

    +

    ファイルにデータを書き込みます。

     FRESULT f_write (
    -  FIL* fp,           /* [IN] ƒtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg */
    -  const void* buff,  /* [IN] ‘‚«ž‚݃f[ƒ^ */
    -  UINT btw,          /* [IN] ‘‚«ž‚ÞƒoƒCƒg” */
    -  UINT* bw           /* [OUT] ‘‚«ž‚܂ꂽƒoƒCƒg” */
    +  FIL* fp,           /* [IN] ファイル オブジェクト */
    +  const void* buff,  /* [IN] 書き込みデータ */
    +  UINT btw,          /* [IN] 書き込むバイト数 */
    +  UINT* bw           /* [OUT] 書き込まれたバイト数 */
     );
     
    -

    ˆø”

    +

    引数

    fp
    -
    ƒtƒ@ƒCƒ‹EƒIƒuƒWƒFƒNƒg\‘¢‘̂ւ̃|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B
    +
    ファイル オブジェクト構造体へのポインタを指定します。
    buff
    -
    ‘‚«ž‚Þƒf[ƒ^‚ðŠi”[‚µ‚½ƒoƒbƒtƒ@‚ðŽw‚·ƒ|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B
    +
    書き込むデータを格納したバッファを指すポインタを指定します。
    btw
    -
    ‘‚«ž‚ÞƒoƒCƒg”(0`UINTŒ^‚̍őå’l)‚ðŽw’肵‚Ü‚·B
    +
    書き込むバイト数(0~UINT型の最大値)を指定します。
    bw
    -
    ‘‚«ž‚܂ꂽƒoƒCƒg”‚ðŠi”[‚·‚é•Ï”‚ðŽw‚·ƒ|ƒCƒ“ƒ^‚ðŽw’肵‚Ü‚·B–ß‚è’l‚͊֐”‚̐¬”Û‚É‚©‚©‚í‚炸í‚É—LŒø‚Å‚·B
    +
    書き込まれたバイト数を格納する変数を指すポインタを指定します。戻り値は関数の成否にかかわらず常に有効です。
    -

    –ß‚è’l

    +

    戻り値

    FR_OK, FR_DISK_ERR, @@ -54,22 +54,22 @@ FRESULT f_write (

    -

    ‰ðà

    -

    ‘‚«ž‚ÝŠJŽnˆÊ’u‚́AƒŠ[ƒh/ƒ‰ƒCƒgEƒ|ƒCƒ“ƒ^‚̈ʒu‚©‚ç‚É‚È‚è‚Ü‚·BƒŠ[ƒh/ƒ‰ƒCƒgEƒ|ƒCƒ“ƒ^‚ÍŽÀÛ‚ɏ‘‚«ž‚܂ꂽƒoƒCƒg”‚¾‚¯i‚Ý‚Ü‚·BŠÖ”‚ª³íI—¹‚µ‚½ŒãA—v‹‚µ‚½ƒoƒCƒg”‚ª‘‚«ž‚܂ꂽ‚©‚Ç‚¤‚©*bw‚ðƒ`ƒFƒbƒN‚·‚ׂ«‚Å‚·B*bw‚ªbtw‚æ‚菬‚³‚¢‚Æ‚«‚́AƒfƒBƒXƒNEƒtƒ‹‚ðˆÓ–¡‚µ‚Ü‚·BƒfƒBƒXƒNEƒtƒ‹‚ª”­¶‚µ‚Ä‚¢‚é‚Æ‚«‚Ü‚½‚Í‚»‚ê‚É‹ß‚¢‚Æ‚«‚́A§Œä‚ª‹A‚é‚Ü‚ÅŽžŠÔ‚ª‚©‚©‚éê‡‚ª‚ ‚è‚Ü‚·B

    +

    解説

    +

    書き込み開始位置は、リード/ライト ポインタの位置からになります。リード/ライト ポインタは実際に書き込まれたバイト数だけ進みます。関数が正常終了した後、要求したバイト数が書き込まれたかどうか*bwをチェックすべきです。*bwがbtwより小さいときは、ディスク フルを意味します。ディスク フルが発生しているときまたはそれに近いときは、制御が帰るまで時間がかかる場合があります。

    -

    ‘Ήžî•ñ

    -

    _FS_READONLY == 0‚Ì‚Æ‚«‚ÉŽg—p‰Â”\‚Å‚·B

    +

    対応情報

    +

    _FS_READONLY == 0のときに使用可能です。

    -

    ŽQÆ

    +

    参照

    f_open, f_read, fputc, fputs, fprintf, f_close, FIL

    -

    –ß‚é

    +

    戻る

    diff --git a/fatfs/doc/updates.txt b/fatfs/doc/updates.txt index f3054ed..20f64f4 100644 --- a/fatfs/doc/updates.txt +++ b/fatfs/doc/updates.txt @@ -1,3 +1,9 @@ +R0.10c, Nov 09, 2014 + Added a configuration option for the platforms without RTC. (_FS_NORTC) + Fixed volume label created by Mac OS X cannot be retrieved with f_getlabel(). + Fixed a potential problem of FAT access that can appear on disk error. + Fixed null pointer dereference on attempting to delete the root direcotry. + R0.10b, May 19, 2014 Fixed a hard error in the disk I/O layer can collapse the directory entry. Fixed LFN entry is not deleted on delete/rename an object with its lossy converted SFN. diff --git a/fatfs/src/00readme.txt b/fatfs/src/00readme.txt index 7285d33..b30f7d3 100644 --- a/fatfs/src/00readme.txt +++ b/fatfs/src/00readme.txt @@ -1,4 +1,4 @@ -FatFs Module Source Files R0.10b (C)ChaN, 2014 +FatFs Module Source Files R0.10c (C)ChaN, 2014 FILES @@ -156,3 +156,8 @@ REVISION HISTORY Mar 19,'14 R0.10b Fixed a hard error in the disk I/O layer can collapse the directory entry. Fixed LFN entry is not deleted on delete/rename an object with lossy converted SFN. + + Nov 09,'14 R0.10c Added a configuration option for the platforms without RTC. (_FS_NORTC) + Fixed volume label created by Mac OS X cannot be retrieved with f_getlabel(). + Fixed a potential problem of FAT access that can appear on disk error. + Fixed null pointer dereference on attempting to delete the root direcotry. diff --git a/fatfs/src/diskio.c b/fatfs/src/diskio.c index 64194eb..169ae95 100644 --- a/fatfs/src/diskio.c +++ b/fatfs/src/diskio.c @@ -1,10 +1,10 @@ /*-----------------------------------------------------------------------*/ -/* Low level disk I/O module skeleton for FatFs (C)ChaN, 2013 */ +/* Low level disk I/O module skeleton for FatFs (C)ChaN, 2014 */ /*-----------------------------------------------------------------------*/ /* If a working storage control module is available, it should be */ /* attached to the FatFs via a glue function rather than modifying it. */ /* This is an example of glue functions to attach various exsisting */ -/* storage control module to the FatFs module with a defined API. */ +/* storage control modules to the FatFs module with a defined API. */ /*-----------------------------------------------------------------------*/ #include "diskio.h" /* FatFs lower layer API */ @@ -12,18 +12,18 @@ #include "atadrive.h" /* Example: ATA drive control */ #include "sdcard.h" /* Example: MMC/SDC contorl */ -/* Definitions of physical drive number for each media */ -#define ATA 0 -#define MMC 1 -#define USB 2 +/* Definitions of physical drive number for each drive */ +#define ATA 0 /* Example: Map ATA drive to drive number 0 */ +#define MMC 1 /* Example: Map MMC/SD card to drive number 1 */ +#define USB 2 /* Example: Map USB drive to drive number 2 */ /*-----------------------------------------------------------------------*/ -/* Inidialize a Drive */ +/* Get Drive Status */ /*-----------------------------------------------------------------------*/ -DSTATUS disk_initialize ( - BYTE pdrv /* Physical drive nmuber (0..) */ +DSTATUS disk_status ( + BYTE pdrv /* Physical drive nmuber to identify the drive */ ) { DSTATUS stat; @@ -31,21 +31,21 @@ DSTATUS disk_initialize ( switch (pdrv) { case ATA : - result = ATA_disk_initialize(); + result = ATA_disk_status(); // translate the reslut code here return stat; case MMC : - result = MMC_disk_initialize(); + result = MMC_disk_status(); // translate the reslut code here return stat; case USB : - result = USB_disk_initialize(); + result = USB_disk_status(); // translate the reslut code here @@ -57,11 +57,11 @@ DSTATUS disk_initialize ( /*-----------------------------------------------------------------------*/ -/* Get Disk Status */ +/* Inidialize a Drive */ /*-----------------------------------------------------------------------*/ -DSTATUS disk_status ( - BYTE pdrv /* Physical drive nmuber (0..) */ +DSTATUS disk_initialize ( + BYTE pdrv /* Physical drive nmuber to identify the drive */ ) { DSTATUS stat; @@ -69,21 +69,21 @@ DSTATUS disk_status ( switch (pdrv) { case ATA : - result = ATA_disk_status(); + result = ATA_disk_initialize(); // translate the reslut code here return stat; case MMC : - result = MMC_disk_status(); + result = MMC_disk_initialize(); // translate the reslut code here return stat; case USB : - result = USB_disk_status(); + result = USB_disk_initialize(); // translate the reslut code here @@ -99,10 +99,10 @@ DSTATUS disk_status ( /*-----------------------------------------------------------------------*/ DRESULT disk_read ( - BYTE pdrv, /* Physical drive nmuber (0..) */ + BYTE pdrv, /* Physical drive nmuber to identify the drive */ BYTE *buff, /* Data buffer to store read data */ - DWORD sector, /* Sector address (LBA) */ - UINT count /* Number of sectors to read (1..128) */ + DWORD sector, /* Sector address in LBA */ + UINT count /* Number of sectors to read */ ) { DRESULT res; @@ -136,6 +136,7 @@ DRESULT disk_read ( return res; } + return RES_PARERR; } @@ -147,10 +148,10 @@ DRESULT disk_read ( #if _USE_WRITE DRESULT disk_write ( - BYTE pdrv, /* Physical drive nmuber (0..) */ + BYTE pdrv, /* Physical drive nmuber to identify the drive */ const BYTE *buff, /* Data to be written */ - DWORD sector, /* Sector address (LBA) */ - UINT count /* Number of sectors to write (1..128) */ + DWORD sector, /* Sector address in LBA */ + UINT count /* Number of sectors to write */ ) { DRESULT res; @@ -184,6 +185,7 @@ DRESULT disk_write ( return res; } + return RES_PARERR; } #endif @@ -205,32 +207,24 @@ DRESULT disk_ioctl ( switch (pdrv) { case ATA : - // pre-process here - - result = ATA_disk_ioctl(cmd, buff); - // post-process here + // Process of the command for the ATA drive return res; case MMC : - // pre-process here - result = MMC_disk_ioctl(cmd, buff); - - // post-process here + // Process of the command for the MMC/SD card return res; case USB : - // pre-process here - - result = USB_disk_ioctl(cmd, buff); - // post-process here + // Process of the command the USB drive return res; } + return RES_PARERR; } #endif diff --git a/fatfs/src/diskio.h b/fatfs/src/diskio.h index 3c2b09d..9650f68 100644 --- a/fatfs/src/diskio.h +++ b/fatfs/src/diskio.h @@ -1,5 +1,5 @@ /*-----------------------------------------------------------------------/ -/ Low level disk interface modlue include file (C)ChaN, 2013 / +/ Low level disk interface modlue include file (C)ChaN, 2014 / /-----------------------------------------------------------------------*/ #ifndef _DISKIO_DEFINED @@ -48,14 +48,14 @@ DRESULT disk_ioctl (BYTE pdrv, BYTE cmd, void* buff); /* Command code for disk_ioctrl fucntion */ -/* Generic command (used by FatFs) */ -#define CTRL_SYNC 0 /* Flush disk cache (for write functions) */ -#define GET_SECTOR_COUNT 1 /* Get media size (for only f_mkfs()) */ -#define GET_SECTOR_SIZE 2 /* Get sector size (for multiple sector size (_MAX_SS >= 1024)) */ -#define GET_BLOCK_SIZE 3 /* Get erase block size (for only f_mkfs()) */ -#define CTRL_ERASE_SECTOR 4 /* Force erased a block of sectors (for only _USE_ERASE) */ +/* Generic command (Used by FatFs) */ +#define CTRL_SYNC 0 /* Complete pending write process (needed at _FS_READONLY == 0) */ +#define GET_SECTOR_COUNT 1 /* Get media size (needed at _USE_MKFS == 1) */ +#define GET_SECTOR_SIZE 2 /* Get sector size (needed at _MAX_SS != _MIN_SS) */ +#define GET_BLOCK_SIZE 3 /* Get erase block size (needed at _USE_MKFS == 1) */ +#define CTRL_TRIM 4 /* Inform device that the data on the block of sectors is no longer used (needed at _USE_TRIM == 1) */ -/* Generic command (not used by FatFs) */ +/* Generic command (Not used by FatFs) */ #define CTRL_POWER 5 /* Get/Set power status */ #define CTRL_LOCK 6 /* Lock/Unlock media removal */ #define CTRL_EJECT 7 /* Eject media */ diff --git a/fatfs/src/ff.c b/fatfs/src/ff.c index 2edbe32..9c887c4 100644 --- a/fatfs/src/ff.c +++ b/fatfs/src/ff.c @@ -1,5 +1,5 @@ /*----------------------------------------------------------------------------/ -/ FatFs - FAT file system module R0.10b (C)ChaN, 2014 +/ FatFs - FAT file system module R0.10c (C)ChaN, 2014 /-----------------------------------------------------------------------------/ / FatFs module is a generic FAT file system module for small embedded systems. / This is a free software that opened for education, research and commercial @@ -113,6 +113,10 @@ / Fixed creation of an entry with LFN fails on too many SFN collisions. / May 19,'14 R0.10b Fixed a hard error in the disk I/O layer can collapse the directory entry. / Fixed LFN entry is not deleted on delete/rename an object with lossy converted SFN. +/ Nov 09,'14 R0.10c Added a configuration option for the platforms without RTC. (_FS_NORTC) +/ Fixed volume label created by Mac OS X cannot be retrieved with f_getlabel(). +/ Fixed a potential problem of FAT access that can appear on disk error. +/ Fixed null pointer dereference on attempting to delete the root direcotry. /---------------------------------------------------------------------------*/ #include "ff.h" /* Declarations of FatFs API */ @@ -127,7 +131,7 @@ ---------------------------------------------------------------------------*/ -#if _FATFS != 8051 /* Revision ID */ +#if _FATFS != 80376 /* Revision ID */ #error Wrong include file (ff.h). #endif @@ -135,7 +139,7 @@ /* Reentrancy related */ #if _FS_REENTRANT #if _USE_LFN == 1 -#error Static LFN work area cannot be used at thread-safe configuration. +#error Static LFN work area cannot be used at thread-safe configuration #endif #define ENTER_FF(fs) { if (!lock_fs(fs)) return FR_TIMEOUT; } #define LEAVE_FF(fs, res) { unlock_fs(fs, res); return res; } @@ -149,7 +153,7 @@ /* Definitions of sector size */ #if (_MAX_SS < _MIN_SS) || (_MAX_SS != 512 && _MAX_SS != 1024 && _MAX_SS != 2048 && _MAX_SS != 4096) || (_MIN_SS != 512 && _MIN_SS != 1024 && _MIN_SS != 2048 && _MIN_SS != 4096) -#error Wrong sector size configuration. +#error Wrong sector size configuration #endif #if _MAX_SS == _MIN_SS #define SS(fs) ((UINT)_MAX_SS) /* Fixed sector size */ @@ -158,10 +162,18 @@ #endif +/* Timestamp feature */ +#if _FS_NORTC +#define GET_FATTIME() ((DWORD)_NORTC_YEAR << 25 | (DWORD)_NORTC_MON << 21 | (DWORD)_NORTC_MDAY << 16) +#else +#define GET_FATTIME() get_fattime() +#endif + + /* File access control feature */ #if _FS_LOCK #if _FS_READONLY -#error _FS_LOCK must be 0 at read-only cfg. +#error _FS_LOCK must be 0 at read-only configuration #endif typedef struct { FATFS *fs; /* Object ID 1, volume (NULL:blank entry) */ @@ -398,7 +410,7 @@ typedef struct { /* Name status flags */ -#define NS 11 /* Index of name status byte in fn[] */ +#define NSFLAG 11 /* Index of name status byte in fn[] */ #define NS_LOSS 0x01 /* Out of 8.3 format */ #define NS_LFN 0x02 /* Force to create LFN entry */ #define NS_LAST 0x04 /* Last segment */ @@ -407,16 +419,16 @@ typedef struct { #define NS_DOT 0x20 /* Dot entry */ -/* FAT sub-type boundaries */ -#define MIN_FAT16 4086U /* Minimum number of clusters for FAT16 */ -#define MIN_FAT32 65526U /* Minimum number of clusters for FAT32 */ +/* FAT sub-type boundaries (Differ from specs but correct for real DOS/Windows) */ +#define MIN_FAT16 4086U /* Minimum number of clusters as FAT16 */ +#define MIN_FAT32 65526U /* Minimum number of clusters as FAT32 */ /* FatFs refers the members in the FAT structures as byte array instead of / structure member because the structure is not binary compatible between / different platforms */ -#define BS_jmpBoot 0 /* Jump instruction (3) */ +#define BS_jmpBoot 0 /* x86 jump instruction (3) */ #define BS_OEMName 3 /* OEM name (8) */ #define BPB_BytsPerSec 11 /* Sector size [byte] (2) */ #define BPB_SecPerClus 13 /* Cluster size [sector] (1) */ @@ -482,63 +494,53 @@ typedef struct { /*------------------------------------------------------------*/ /* Module private work area */ /*------------------------------------------------------------*/ -/* Note that uninitialized variables with static duration are -/ guaranteed zero/null as initial value. If not, either the -/ linker or start-up routine is out of ANSI-C standard. +/* Remark: Uninitialized variables with static duration are +/ guaranteed zero/null at start-up. If not, either the linker +/ or start-up routine being used is out of ANSI-C standard. */ -#if _VOLUMES >= 1 || _VOLUMES <= 10 -static -FATFS *FatFs[_VOLUMES]; /* Pointer to the file system objects (logical drives) */ -#else -#error Number of volumes must be 1 to 10. +#if _VOLUMES < 1 || _VOLUMES > 9 +#error Wrong _VOLUMES setting #endif - -static -WORD Fsid; /* File system mount ID */ +static FATFS *FatFs[_VOLUMES]; /* Pointer to the file system objects (logical drives) */ +static WORD Fsid; /* File system mount ID */ #if _FS_RPATH && _VOLUMES >= 2 -static -BYTE CurrVol; /* Current drive */ +static BYTE CurrVol; /* Current drive */ #endif #if _FS_LOCK -static -FILESEM Files[_FS_LOCK]; /* Open object lock semaphores */ +static FILESEM Files[_FS_LOCK]; /* Open object lock semaphores */ #endif -#if _USE_LFN == 0 /* No LFN feature */ +#if _USE_LFN == 0 /* Non LFN feature */ #define DEF_NAMEBUF BYTE sfn[12] #define INIT_BUF(dobj) (dobj).fn = sfn #define FREE_BUF() - -#elif _USE_LFN == 1 /* LFN feature with static working buffer */ -static -WCHAR LfnBuf[_MAX_LFN+1]; +#else +#if _MAX_LFN < 12 || _MAX_LFN > 255 +#error Wrong _MAX_LFN setting +#endif +#if _USE_LFN == 1 /* LFN feature with static working buffer */ +static WCHAR LfnBuf[_MAX_LFN+1]; #define DEF_NAMEBUF BYTE sfn[12] #define INIT_BUF(dobj) { (dobj).fn = sfn; (dobj).lfn = LfnBuf; } #define FREE_BUF() - #elif _USE_LFN == 2 /* LFN feature with dynamic working buffer on the stack */ #define DEF_NAMEBUF BYTE sfn[12]; WCHAR lbuf[_MAX_LFN+1] #define INIT_BUF(dobj) { (dobj).fn = sfn; (dobj).lfn = lbuf; } #define FREE_BUF() - #elif _USE_LFN == 3 /* LFN feature with dynamic working buffer on the heap */ #define DEF_NAMEBUF BYTE sfn[12]; WCHAR *lfn -#define INIT_BUF(dobj) { lfn = ff_memalloc((_MAX_LFN + 1) * 2); \ - if (!lfn) LEAVE_FF((dobj).fs, FR_NOT_ENOUGH_CORE); \ - (dobj).lfn = lfn; (dobj).fn = sfn; } +#define INIT_BUF(dobj) { lfn = ff_memalloc((_MAX_LFN + 1) * 2); if (!lfn) LEAVE_FF((dobj).fs, FR_NOT_ENOUGH_CORE); (dobj).lfn = lfn; (dobj).fn = sfn; } #define FREE_BUF() ff_memfree(lfn) - #else -#error Wrong LFN configuration. +#error Wrong _USE_LFN setting +#endif #endif - #ifdef _EXCVT -static -const BYTE ExCvt[] = _EXCVT; /* Upper conversion table for extended characters */ +static const BYTE ExCvt[] = _EXCVT; /* Upper conversion table for extended characters */ #endif @@ -758,21 +760,24 @@ FRESULT sync_window ( { DWORD wsect; UINT nf; + FRESULT res = FR_OK; if (fs->wflag) { /* Write back the sector if it is dirty */ wsect = fs->winsect; /* Current sector number */ - if (disk_write(fs->drv, fs->win, wsect, 1)) - return FR_DISK_ERR; - fs->wflag = 0; - if (wsect - fs->fatbase < fs->fsize) { /* Is it in the FAT area? */ - for (nf = fs->n_fats; nf >= 2; nf--) { /* Reflect the change to all FAT copies */ - wsect += fs->fsize; - disk_write(fs->drv, fs->win, wsect, 1); + if (disk_write(fs->drv, fs->win, wsect, 1) != RES_OK) { + res = FR_DISK_ERR; + } else { + fs->wflag = 0; + if (wsect - fs->fatbase < fs->fsize) { /* Is it in the FAT area? */ + for (nf = fs->n_fats; nf >= 2; nf--) { /* Reflect the change to all FAT copies */ + wsect += fs->fsize; + disk_write(fs->drv, fs->win, wsect, 1); + } } } } - return FR_OK; + return res; } #endif @@ -783,17 +788,22 @@ FRESULT move_window ( DWORD sector /* Sector number to make appearance in the fs->win[] */ ) { - if (sector != fs->winsect) { /* Changed current window */ + FRESULT res = FR_OK; + + + if (sector != fs->winsect) { /* Window offset changed? */ #if !_FS_READONLY - if (sync_window(fs) != FR_OK) - return FR_DISK_ERR; + res = sync_window(fs); /* Write-back changes */ #endif - if (disk_read(fs->drv, fs->win, sector, 1)) - return FR_DISK_ERR; - fs->winsect = sector; + if (res == FR_OK) { /* Fill sector window with new data */ + if (disk_read(fs->drv, fs->win, sector, 1) != RES_OK) { + sector = 0xFFFFFFFF; /* Invalidate window if data is not reliable */ + res = FR_DISK_ERR; + } + fs->winsect = sector; + } } - - return FR_OK; + return res; } @@ -842,7 +852,7 @@ FRESULT sync_fs ( /* FR_OK: successful, FR_DISK_ERR: failed */ /*-----------------------------------------------------------------------*/ /* Get sector# from cluster# */ /*-----------------------------------------------------------------------*/ - +/* Hidden API for hacks and disk tools */ DWORD clust2sect ( /* !=0: Sector number, 0: Failed - invalid cluster# */ FATFS* fs, /* File system object */ @@ -850,7 +860,7 @@ DWORD clust2sect ( /* !=0: Sector number, 0: Failed - invalid cluster# */ ) { clst -= 2; - if (clst >= (fs->n_fatent - 2)) return 0; /* Invalid cluster# */ + if (clst >= fs->n_fatent - 2) return 0; /* Invalid cluster# */ return clst * fs->csize + fs->database; } @@ -860,44 +870,52 @@ DWORD clust2sect ( /* !=0: Sector number, 0: Failed - invalid cluster# */ /*-----------------------------------------------------------------------*/ /* FAT access - Read value of a FAT entry */ /*-----------------------------------------------------------------------*/ +/* Hidden API for hacks and disk tools */ - -DWORD get_fat ( /* 0xFFFFFFFF:Disk error, 1:Internal error, Else:Cluster status */ +DWORD get_fat ( /* 0xFFFFFFFF:Disk error, 1:Internal error, 2..0x0FFFFFFF:Cluster status */ FATFS* fs, /* File system object */ - DWORD clst /* Cluster# to get the link information */ + DWORD clst /* FAT item index (cluster#) to get the value */ ) { UINT wc, bc; BYTE *p; + DWORD val; - if (clst < 2 || clst >= fs->n_fatent) /* Check range */ - return 1; + if (clst < 2 || clst >= fs->n_fatent) { /* Check range */ + val = 1; /* Internal error */ - switch (fs->fs_type) { - case FS_FAT12 : - bc = (UINT)clst; bc += bc / 2; - if (move_window(fs, fs->fatbase + (bc / SS(fs)))) break; - wc = fs->win[bc % SS(fs)]; bc++; - if (move_window(fs, fs->fatbase + (bc / SS(fs)))) break; - wc |= fs->win[bc % SS(fs)] << 8; - return clst & 1 ? wc >> 4 : (wc & 0xFFF); + } else { + val = 0xFFFFFFFF; /* Default value falls on disk error */ - case FS_FAT16 : - if (move_window(fs, fs->fatbase + (clst / (SS(fs) / 2)))) break; - p = &fs->win[clst * 2 % SS(fs)]; - return LD_WORD(p); + switch (fs->fs_type) { + case FS_FAT12 : + bc = (UINT)clst; bc += bc / 2; + if (move_window(fs, fs->fatbase + (bc / SS(fs))) != FR_OK) break; + wc = fs->win[bc++ % SS(fs)]; + if (move_window(fs, fs->fatbase + (bc / SS(fs))) != FR_OK) break; + wc |= fs->win[bc % SS(fs)] << 8; + val = clst & 1 ? wc >> 4 : (wc & 0xFFF); + break; + + case FS_FAT16 : + if (move_window(fs, fs->fatbase + (clst / (SS(fs) / 2))) != FR_OK) break; + p = &fs->win[clst * 2 % SS(fs)]; + val = LD_WORD(p); + break; - case FS_FAT32 : - if (move_window(fs, fs->fatbase + (clst / (SS(fs) / 4)))) break; - p = &fs->win[clst * 4 % SS(fs)]; - return LD_DWORD(p) & 0x0FFFFFFF; + case FS_FAT32 : + if (move_window(fs, fs->fatbase + (clst / (SS(fs) / 4))) != FR_OK) break; + p = &fs->win[clst * 4 % SS(fs)]; + val = LD_DWORD(p) & 0x0FFFFFFF; + break; - default: - return 1; + default: + val = 1; /* Internal error */ + } } - return 0xFFFFFFFF; /* An error occurred at the disk I/O layer */ + return val; } @@ -906,11 +924,12 @@ DWORD get_fat ( /* 0xFFFFFFFF:Disk error, 1:Internal error, Else:Cluster status /*-----------------------------------------------------------------------*/ /* FAT access - Change value of a FAT entry */ /*-----------------------------------------------------------------------*/ -#if !_FS_READONLY +/* Hidden API for hacks and disk tools */ +#if !_FS_READONLY FRESULT put_fat ( FATFS* fs, /* File system object */ - DWORD clst, /* Cluster# to be changed in range of 2 to fs->n_fatent - 1 */ + DWORD clst, /* FAT item index (cluster#) to be set */ DWORD val /* New value to mark the cluster */ ) { @@ -928,14 +947,14 @@ FRESULT put_fat ( bc = (UINT)clst; bc += bc / 2; res = move_window(fs, fs->fatbase + (bc / SS(fs))); if (res != FR_OK) break; - p = &fs->win[bc % SS(fs)]; + p = &fs->win[bc++ % SS(fs)]; *p = (clst & 1) ? ((*p & 0x0F) | ((BYTE)val << 4)) : (BYTE)val; - bc++; fs->wflag = 1; res = move_window(fs, fs->fatbase + (bc / SS(fs))); if (res != FR_OK) break; p = &fs->win[bc % SS(fs)]; *p = (clst & 1) ? (BYTE)(val >> 4) : ((*p & 0xF0) | ((BYTE)(val >> 8) & 0x0F)); + fs->wflag = 1; break; case FS_FAT16 : @@ -943,6 +962,7 @@ FRESULT put_fat ( if (res != FR_OK) break; p = &fs->win[clst * 2 % SS(fs)]; ST_WORD(p, (WORD)val); + fs->wflag = 1; break; case FS_FAT32 : @@ -951,12 +971,12 @@ FRESULT put_fat ( p = &fs->win[clst * 4 % SS(fs)]; val |= LD_DWORD(p) & 0xF0000000; ST_DWORD(p, val); + fs->wflag = 1; break; default : res = FR_INT_ERR; } - fs->wflag = 1; } return res; @@ -978,7 +998,7 @@ FRESULT remove_chain ( { FRESULT res; DWORD nxt; -#if _USE_ERASE +#if _USE_TRIM DWORD scl = clst, ecl = clst, rt[2]; #endif @@ -998,13 +1018,13 @@ FRESULT remove_chain ( fs->free_clust++; fs->fsi_flag |= 1; } -#if _USE_ERASE +#if _USE_TRIM if (ecl + 1 == nxt) { /* Is next cluster contiguous? */ ecl = nxt; } else { /* End of contiguous clusters */ rt[0] = clust2sect(fs, scl); /* Start sector */ rt[1] = clust2sect(fs, ecl) + fs->csize - 1; /* End sector */ - disk_ioctl(fs->drv, CTRL_ERASE_SECTOR, rt); /* Erase the block */ + disk_ioctl(fs->drv, CTRL_TRIM, rt); /* Erase the block */ scl = ecl = nxt; } #endif @@ -1246,8 +1266,8 @@ FRESULT dir_alloc ( do { res = move_window(dp->fs, dp->sect); if (res != FR_OK) break; - if (dp->dir[0] == DDE || dp->dir[0] == 0) { /* Is it a blank entry? */ - if (++n == nent) break; /* A block of contiguous entries is found */ + if (dp->dir[0] == DDE || dp->dir[0] == 0) { /* Is it a free entry? */ + if (++n == nent) break; /* A block of contiguous free entries is found */ } else { n = 0; /* Not a blank entry. Restart to search */ } @@ -1526,7 +1546,7 @@ FRESULT dir_find ( } } else { /* An SFN entry is found */ if (!ord && sum == sum_sfn(dir)) break; /* LFN matched? */ - if (!(dp->fn[NS] & NS_LOSS) && !mem_cmp(dir, dp->fn, 11)) break; /* SFN matched? */ + if (!(dp->fn[NSFLAG] & NS_LOSS) && !mem_cmp(dir, dp->fn, 11)) break; /* SFN matched? */ ord = 0xFF; dp->lfn_idx = 0xFFFF; /* Reset LFN sequence */ } } @@ -1568,7 +1588,7 @@ FRESULT dir_read ( if (c == 0) { res = FR_NO_FILE; break; } /* Reached to end of table */ a = dir[DIR_Attr] & AM_MASK; #if _USE_LFN /* LFN configuration */ - if (c == DDE || (!_FS_RPATH && c == '.') || (int)(a == AM_VOL) != vol) { /* An entry without valid data */ + if (c == DDE || (!_FS_RPATH && c == '.') || (int)((a & ~AM_ARC) == AM_VOL) != vol) { /* An entry without valid data */ ord = 0xFF; } else { if (a == AM_LFN) { /* An LFN entry is found */ @@ -1586,7 +1606,7 @@ FRESULT dir_read ( } } #else /* Non LFN configuration */ - if (c != DDE && (_FS_RPATH || c != '.') && a != AM_LFN && (int)(a == AM_VOL) == vol) /* Is it a valid entry? */ + if (c != DDE && (_FS_RPATH || c != '.') && a != AM_LFN && (int)((a & ~AM_ARC) == AM_VOL) == vol) /* Is it a valid entry? */ break; #endif res = dir_next(dp, 0); /* Next entry */ @@ -1621,11 +1641,11 @@ FRESULT dir_register ( /* FR_OK:Successful, FR_DENIED:No free entry or too many fn = dp->fn; lfn = dp->lfn; mem_cpy(sn, fn, 12); - if (_FS_RPATH && (sn[NS] & NS_DOT)) /* Cannot create dot entry */ + if (_FS_RPATH && (sn[NSFLAG] & NS_DOT)) /* Cannot create dot entry */ return FR_INVALID_NAME; - if (sn[NS] & NS_LOSS) { /* When LFN is out of 8.3 format, generate a numbered name */ - fn[NS] = 0; dp->lfn = 0; /* Find only SFN */ + if (sn[NSFLAG] & NS_LOSS) { /* When LFN is out of 8.3 format, generate a numbered name */ + fn[NSFLAG] = 0; dp->lfn = 0; /* Find only SFN */ for (n = 1; n < 100; n++) { gen_numname(fn, sn, lfn, n); /* Generate a numbered name */ res = dir_find(dp); /* Check if the name collides with existing SFN */ @@ -1633,10 +1653,10 @@ FRESULT dir_register ( /* FR_OK:Successful, FR_DENIED:No free entry or too many } if (n == 100) return FR_DENIED; /* Abort if too many collisions */ if (res != FR_NO_FILE) return res; /* Abort if the result is other than 'not collided' */ - fn[NS] = sn[NS]; dp->lfn = lfn; + fn[NSFLAG] = sn[NSFLAG]; dp->lfn = lfn; } - if (sn[NS] & NS_LFN) { /* When LFN is to be created, allocate entries for an SFN + LFNs. */ + if (sn[NSFLAG] & NS_LFN) { /* When LFN is to be created, allocate entries for an SFN + LFNs. */ for (n = 0; lfn[n]; n++) ; nent = (n + 25) / 13; } else { /* Otherwise allocate an entry for an SFN */ @@ -1667,7 +1687,7 @@ FRESULT dir_register ( /* FR_OK:Successful, FR_DENIED:No free entry or too many mem_set(dp->dir, 0, SZ_DIR); /* Clean the entry */ mem_cpy(dp->dir, dp->fn, 11); /* Put SFN */ #if _USE_LFN - dp->dir[DIR_NTres] = dp->fn[NS] & (NS_BODY | NS_EXT); /* Put NT flag */ + dp->dir[DIR_NTres] = dp->fn[NSFLAG] & (NS_BODY | NS_EXT); /* Put NT flag */ #endif dp->fs->wflag = 1; } @@ -1923,7 +1943,7 @@ FRESULT create_name ( if ((b & 0x0C) == 0x04) cf |= NS_BODY; /* NT flag (Filename has only small capital) */ } - dp->fn[NS] = cf; /* SFN is created */ + dp->fn[NSFLAG] = cf; /* SFN is created */ return FR_OK; @@ -1947,7 +1967,7 @@ FRESULT create_name ( } if (c != '/' && c != '\\' && c > ' ') return FR_INVALID_NAME; *path = &p[si]; /* Return pointer to the next segment */ - sfn[NS] = (c <= ' ') ? NS_LAST | NS_DOT : NS_DOT; /* Set last segment flag if end of path */ + sfn[NSFLAG] = (c <= ' ') ? NS_LAST | NS_DOT : NS_DOT; /* Set last segment flag if end of path */ return FR_OK; } #endif @@ -1998,7 +2018,7 @@ FRESULT create_name ( if ((b & 0x03) == 0x01) c |= NS_EXT; /* NT flag (Name extension has only small capital) */ if ((b & 0x0C) == 0x04) c |= NS_BODY; /* NT flag (Name body has only small capital) */ - sfn[NS] = c; /* Store NT flag, File name is created */ + sfn[NSFLAG] = c; /* Store NT flag, File name is created */ return FR_OK; #endif @@ -2041,7 +2061,7 @@ FRESULT follow_path ( /* FR_OK(0): successful, !=0: error code */ res = create_name(dp, &path); /* Get a segment name of the path */ if (res != FR_OK) break; res = dir_find(dp); /* Find an object with the sagment name */ - ns = dp->fn[NS]; + ns = dp->fn[NSFLAG]; if (res != FR_OK) { /* Failed to find the object */ if (res == FR_NO_FILE) { /* Object is not found */ if (_FS_RPATH && (ns & NS_DOT)) { /* If dot entry is not exist, */ @@ -2283,7 +2303,7 @@ FRESULT find_volume ( /* FR_OK(0): successful, !=0: any error occurred */ szbfat = (fmt == FS_FAT16) ? /* (Needed FAT size) */ fs->n_fatent * 2 : fs->n_fatent * 3 / 2 + (fs->n_fatent & 1); } - if (fs->fsize < (szbfat + (SS(fs) - 1)) / SS(fs)) /* (BPB_FATSz must not be less than needed) */ + if (fs->fsize < (szbfat + (SS(fs) - 1)) / SS(fs)) /* (BPB_FATSz must not be less than the size needed) */ return FR_NO_FILESYSTEM; #if !_FS_READONLY @@ -2471,7 +2491,7 @@ FRESULT f_open ( } } if (res == FR_OK && (mode & FA_CREATE_ALWAYS)) { /* Truncate it if overwrite mode */ - dw = get_fattime(); /* Created time */ + dw = GET_FATTIME(); /* Created time */ ST_DWORD(dir+DIR_CrtTime, dw); dir[DIR_Attr] = 0; /* Reset attribute */ ST_DWORD(dir+DIR_FileSize, 0); /* size = 0 */ @@ -2597,7 +2617,7 @@ FRESULT f_read ( if (cc) { /* Read maximum contiguous sectors directly */ if (csect + cc > fp->fs->csize) /* Clip at cluster boundary */ cc = fp->fs->csize - csect; - if (disk_read(fp->fs->drv, rbuff, sect, cc)) + if (disk_read(fp->fs->drv, rbuff, sect, cc) != RES_OK) ABORT(fp->fs, FR_DISK_ERR); #if !_FS_READONLY && _FS_MINIMIZE <= 2 /* Replace one of the read sectors with cached data if it contains a dirty sector */ #if _FS_TINY @@ -2615,12 +2635,12 @@ FRESULT f_read ( if (fp->dsect != sect) { /* Load data sector if not in cache */ #if !_FS_READONLY if (fp->flag & FA__DIRTY) { /* Write-back dirty sector cache */ - if (disk_write(fp->fs->drv, fp->buf, fp->dsect, 1)) + if (disk_write(fp->fs->drv, fp->buf, fp->dsect, 1) != RES_OK) ABORT(fp->fs, FR_DISK_ERR); fp->flag &= ~FA__DIRTY; } #endif - if (disk_read(fp->fs->drv, fp->buf, sect, 1)) /* Fill sector cache */ + if (disk_read(fp->fs->drv, fp->buf, sect, 1) != RES_OK) /* Fill sector cache */ ABORT(fp->fs, FR_DISK_ERR); } #endif @@ -2629,7 +2649,7 @@ FRESULT f_read ( rcnt = SS(fp->fs) - ((UINT)fp->fptr % SS(fp->fs)); /* Get partial sector data from sector buffer */ if (rcnt > btr) rcnt = btr; #if _FS_TINY - if (move_window(fp->fs, fp->dsect)) /* Move sector window */ + if (move_window(fp->fs, fp->dsect) != FR_OK) /* Move sector window */ ABORT(fp->fs, FR_DISK_ERR); mem_cpy(rbuff, &fp->fs->win[fp->fptr % SS(fp->fs)], rcnt); /* Pick partial sector */ #else @@ -2700,7 +2720,7 @@ FRESULT f_write ( ABORT(fp->fs, FR_DISK_ERR); #else if (fp->flag & FA__DIRTY) { /* Write-back sector cache */ - if (disk_write(fp->fs->drv, fp->buf, fp->dsect, 1)) + if (disk_write(fp->fs->drv, fp->buf, fp->dsect, 1) != RES_OK) ABORT(fp->fs, FR_DISK_ERR); fp->flag &= ~FA__DIRTY; } @@ -2712,7 +2732,7 @@ FRESULT f_write ( if (cc) { /* Write maximum contiguous sectors directly */ if (csect + cc > fp->fs->csize) /* Clip at cluster boundary */ cc = fp->fs->csize - csect; - if (disk_write(fp->fs->drv, wbuff, sect, cc)) + if (disk_write(fp->fs->drv, wbuff, sect, cc) != RES_OK) ABORT(fp->fs, FR_DISK_ERR); #if _FS_MINIMIZE <= 2 #if _FS_TINY @@ -2738,7 +2758,7 @@ FRESULT f_write ( #else if (fp->dsect != sect) { /* Fill sector cache with file data */ if (fp->fptr < fp->fsize && - disk_read(fp->fs->drv, fp->buf, sect, 1)) + disk_read(fp->fs->drv, fp->buf, sect, 1) != RES_OK) ABORT(fp->fs, FR_DISK_ERR); } #endif @@ -2747,7 +2767,7 @@ FRESULT f_write ( wcnt = SS(fp->fs) - ((UINT)fp->fptr % SS(fp->fs));/* Put partial sector into file I/O buffer */ if (wcnt > btw) wcnt = btw; #if _FS_TINY - if (move_window(fp->fs, fp->dsect)) /* Move sector window */ + if (move_window(fp->fs, fp->dsect) != FR_OK) /* Move sector window */ ABORT(fp->fs, FR_DISK_ERR); mem_cpy(&fp->fs->win[fp->fptr % SS(fp->fs)], wbuff, wcnt); /* Fit partial sector */ fp->fs->wflag = 1; @@ -2785,7 +2805,7 @@ FRESULT f_sync ( /* Write-back dirty buffer */ #if !_FS_TINY if (fp->flag & FA__DIRTY) { - if (disk_write(fp->fs->drv, fp->buf, fp->dsect, 1)) + if (disk_write(fp->fs->drv, fp->buf, fp->dsect, 1) != RES_OK) LEAVE_FF(fp->fs, FR_DISK_ERR); fp->flag &= ~FA__DIRTY; } @@ -2797,7 +2817,7 @@ FRESULT f_sync ( dir[DIR_Attr] |= AM_ARC; /* Set archive bit */ ST_DWORD(dir+DIR_FileSize, fp->fsize); /* Update file size */ st_clust(dir, fp->sclust); /* Update start cluster */ - tm = get_fattime(); /* Update updated time */ + tm = GET_FATTIME(); /* Update updated time */ ST_DWORD(dir+DIR_WrtTime, tm); ST_WORD(dir+DIR_LstAccDate, 0); fp->flag &= ~FA__WRITTEN; @@ -3046,12 +3066,12 @@ FRESULT f_lseek ( #if !_FS_TINY #if !_FS_READONLY if (fp->flag & FA__DIRTY) { /* Write-back dirty sector cache */ - if (disk_write(fp->fs->drv, fp->buf, fp->dsect, 1)) + if (disk_write(fp->fs->drv, fp->buf, fp->dsect, 1) != RES_OK) ABORT(fp->fs, FR_DISK_ERR); fp->flag &= ~FA__DIRTY; } #endif - if (disk_read(fp->fs->drv, fp->buf, dsc, 1)) /* Load current sector */ + if (disk_read(fp->fs->drv, fp->buf, dsc, 1) != RES_OK) /* Load current sector */ ABORT(fp->fs, FR_DISK_ERR); #endif fp->dsect = dsc; @@ -3121,12 +3141,12 @@ FRESULT f_lseek ( #if !_FS_TINY #if !_FS_READONLY if (fp->flag & FA__DIRTY) { /* Write-back dirty sector cache */ - if (disk_write(fp->fs->drv, fp->buf, fp->dsect, 1)) + if (disk_write(fp->fs->drv, fp->buf, fp->dsect, 1) != RES_OK) ABORT(fp->fs, FR_DISK_ERR); fp->flag &= ~FA__DIRTY; } #endif - if (disk_read(fp->fs->drv, fp->buf, nsect, 1)) /* Fill sector cache */ + if (disk_read(fp->fs->drv, fp->buf, nsect, 1) != RES_OK) /* Fill sector cache */ ABORT(fp->fs, FR_DISK_ERR); #endif fp->dsect = nsect; @@ -3417,7 +3437,7 @@ FRESULT f_truncate ( } #if !_FS_TINY if (res == FR_OK && (fp->flag & FA__DIRTY)) { - if (disk_write(fp->fs->drv, fp->buf, fp->dsect, 1)) + if (disk_write(fp->fs->drv, fp->buf, fp->dsect, 1) != RES_OK) res = FR_DISK_ERR; else fp->flag &= ~FA__DIRTY; @@ -3444,7 +3464,7 @@ FRESULT f_unlink ( FRESULT res; DIR dj, sdj; BYTE *dir; - DWORD dclst; + DWORD dclst = 0; DEF_NAMEBUF; @@ -3453,45 +3473,43 @@ FRESULT f_unlink ( if (res == FR_OK) { INIT_BUF(dj); res = follow_path(&dj, path); /* Follow the file path */ - if (_FS_RPATH && res == FR_OK && (dj.fn[NS] & NS_DOT)) + if (_FS_RPATH && res == FR_OK && (dj.fn[NSFLAG] & NS_DOT)) res = FR_INVALID_NAME; /* Cannot remove dot entry */ #if _FS_LOCK - if (res == FR_OK) res = chk_lock(&dj, 2); /* Cannot remove open file */ + if (res == FR_OK) res = chk_lock(&dj, 2); /* Cannot remove open object */ #endif if (res == FR_OK) { /* The object is accessible */ dir = dj.dir; if (!dir) { - res = FR_INVALID_NAME; /* Cannot remove the start directory */ + res = FR_INVALID_NAME; /* Cannot remove the origin directory */ } else { if (dir[DIR_Attr] & AM_RDO) res = FR_DENIED; /* Cannot remove R/O object */ } - dclst = ld_clust(dj.fs, dir); if (res == FR_OK && (dir[DIR_Attr] & AM_DIR)) { /* Is it a sub-dir? */ - if (dclst < 2) { + dclst = ld_clust(dj.fs, dir); + if (!dclst) { res = FR_INT_ERR; - } else { - mem_cpy(&sdj, &dj, sizeof (DIR)); /* Check if the sub-directory is empty or not */ + } else { /* Make sure the sub-directory is empty */ + mem_cpy(&sdj, &dj, sizeof (DIR)); sdj.sclust = dclst; res = dir_sdi(&sdj, 2); /* Exclude dot entries */ if (res == FR_OK) { res = dir_read(&sdj, 0); /* Read an item */ if (res == FR_OK /* Not empty directory */ #if _FS_RPATH - || dclst == dj.fs->cdir /* Current directory */ + || dclst == dj.fs->cdir /* or current directory */ #endif ) res = FR_DENIED; - if (res == FR_NO_FILE) res = FR_OK; /* Empty */ + if (res == FR_NO_FILE) res = FR_OK; /* It is empty */ } } } if (res == FR_OK) { res = dir_remove(&dj); /* Remove the directory entry */ - if (res == FR_OK) { - if (dclst) /* Remove the cluster chain if exist */ - res = remove_chain(dj.fs, dclst); - if (res == FR_OK) res = sync_fs(dj.fs); - } + if (res == FR_OK && dclst) /* Remove the cluster chain if exist */ + res = remove_chain(dj.fs, dclst); + if (res == FR_OK) res = sync_fs(dj.fs); } } FREE_BUF(); @@ -3514,7 +3532,7 @@ FRESULT f_mkdir ( FRESULT res; DIR dj; BYTE *dir, n; - DWORD dsc, dcl, pcl, tm = get_fattime(); + DWORD dsc, dcl, pcl, tm = GET_FATTIME(); DEF_NAMEBUF; @@ -3524,7 +3542,7 @@ FRESULT f_mkdir ( INIT_BUF(dj); res = follow_path(&dj, path); /* Follow the file path */ if (res == FR_OK) res = FR_EXIST; /* Any object with same name is already existing */ - if (_FS_RPATH && res == FR_NO_FILE && (dj.fn[NS] & NS_DOT)) + if (_FS_RPATH && res == FR_NO_FILE && (dj.fn[NSFLAG] & NS_DOT)) res = FR_INVALID_NAME; if (res == FR_NO_FILE) { /* Can create a new directory */ dcl = create_chain(dj.fs, 0); /* Allocate a cluster for the new directory table */ @@ -3599,7 +3617,7 @@ FRESULT f_chmod ( INIT_BUF(dj); res = follow_path(&dj, path); /* Follow the file path */ FREE_BUF(); - if (_FS_RPATH && res == FR_OK && (dj.fn[NS] & NS_DOT)) + if (_FS_RPATH && res == FR_OK && (dj.fn[NSFLAG] & NS_DOT)) res = FR_INVALID_NAME; if (res == FR_OK) { dir = dj.dir; @@ -3620,48 +3638,6 @@ FRESULT f_chmod ( -/*-----------------------------------------------------------------------*/ -/* Change Timestamp */ -/*-----------------------------------------------------------------------*/ - -FRESULT f_utime ( - const TCHAR* path, /* Pointer to the file/directory name */ - const FILINFO* fno /* Pointer to the time stamp to be set */ -) -{ - FRESULT res; - DIR dj; - BYTE *dir; - DEF_NAMEBUF; - - - /* Get logical drive number */ - res = find_volume(&dj.fs, &path, 1); - if (res == FR_OK) { - INIT_BUF(dj); - res = follow_path(&dj, path); /* Follow the file path */ - FREE_BUF(); - if (_FS_RPATH && res == FR_OK && (dj.fn[NS] & NS_DOT)) - res = FR_INVALID_NAME; - if (res == FR_OK) { - dir = dj.dir; - if (!dir) { /* Root directory */ - res = FR_INVALID_NAME; - } else { /* File or sub-directory */ - ST_WORD(dir+DIR_WrtTime, fno->ftime); - ST_WORD(dir+DIR_WrtDate, fno->fdate); - dj.fs->wflag = 1; - res = sync_fs(dj.fs); - } - } - } - - LEAVE_FF(dj.fs, res); -} - - - - /*-----------------------------------------------------------------------*/ /* Rename File/Directory */ /*-----------------------------------------------------------------------*/ @@ -3684,7 +3660,7 @@ FRESULT f_rename ( djn.fs = djo.fs; INIT_BUF(djo); res = follow_path(&djo, path_old); /* Check old object */ - if (_FS_RPATH && res == FR_OK && (djo.fn[NS] & NS_DOT)) + if (_FS_RPATH && res == FR_OK && (djo.fn[NSFLAG] & NS_DOT)) res = FR_INVALID_NAME; #if _FS_LOCK if (res == FR_OK) res = chk_lock(&djo, 2); @@ -3696,19 +3672,19 @@ FRESULT f_rename ( mem_cpy(buf, djo.dir+DIR_Attr, 21); /* Save the object information except name */ mem_cpy(&djn, &djo, sizeof (DIR)); /* Duplicate the directory object */ if (get_ldnumber(&path_new) >= 0) /* Snip drive number off and ignore it */ - res = follow_path(&djn, path_new); /* and check if new object is exist */ + res = follow_path(&djn, path_new); /* and make sure if new object name is not conflicting */ else res = FR_INVALID_DRIVE; if (res == FR_OK) res = FR_EXIST; /* The new object name is already existing */ - if (res == FR_NO_FILE) { /* Is it a valid path and no name collision? */ -/* Start critical section that any interruption can cause a cross-link */ + if (res == FR_NO_FILE) { /* It is a valid path and no name collision */ +/* Start of critical section that any interruption can cause a cross-link */ res = dir_register(&djn); /* Register the new entry */ if (res == FR_OK) { dir = djn.dir; /* Copy object information except name */ mem_cpy(dir+13, buf+2, 19); dir[DIR_Attr] = buf[0] | AM_ARC; djo.fs->wflag = 1; - if (djo.sclust != djn.sclust && (dir[DIR_Attr] & AM_DIR)) { /* Update .. entry in the directory if needed */ + if ((dir[DIR_Attr] & AM_DIR) && djo.sclust != djn.sclust) { /* Update .. entry in the directory if needed */ dw = clust2sect(djo.fs, ld_clust(djo.fs, dir)); if (!dw) { res = FR_INT_ERR; @@ -3716,8 +3692,7 @@ FRESULT f_rename ( res = move_window(djo.fs, dw); dir = djo.fs->win+SZ_DIR; /* .. entry */ if (res == FR_OK && dir[1] == '.') { - dw = (djo.fs->fs_type == FS_FAT32 && djn.sclust == djo.fs->dirbase) ? 0 : djn.sclust; - st_clust(dir, dw); + st_clust(dir, djn.sclust); djo.fs->wflag = 1; } } @@ -3728,7 +3703,7 @@ FRESULT f_rename ( res = sync_fs(djo.fs); } } -/* End critical section */ +/* End of critical section */ } } } @@ -3738,6 +3713,48 @@ FRESULT f_rename ( LEAVE_FF(djo.fs, res); } + + + +/*-----------------------------------------------------------------------*/ +/* Change Timestamp */ +/*-----------------------------------------------------------------------*/ + +FRESULT f_utime ( + const TCHAR* path, /* Pointer to the file/directory name */ + const FILINFO* fno /* Pointer to the time stamp to be set */ +) +{ + FRESULT res; + DIR dj; + BYTE *dir; + DEF_NAMEBUF; + + + /* Get logical drive number */ + res = find_volume(&dj.fs, &path, 1); + if (res == FR_OK) { + INIT_BUF(dj); + res = follow_path(&dj, path); /* Follow the file path */ + FREE_BUF(); + if (_FS_RPATH && res == FR_OK && (dj.fn[NSFLAG] & NS_DOT)) + res = FR_INVALID_NAME; + if (res == FR_OK) { + dir = dj.dir; + if (!dir) { /* Root directory */ + res = FR_INVALID_NAME; + } else { /* File or sub-directory */ + ST_WORD(dir+DIR_WrtTime, fno->ftime); + ST_WORD(dir+DIR_WrtDate, fno->fdate); + dj.fs->wflag = 1; + res = sync_fs(dj.fs); + } + } + } + + LEAVE_FF(dj.fs, res); +} + #endif /* !_FS_READONLY */ #endif /* _FS_MINIMIZE == 0 */ #endif /* _FS_MINIMIZE <= 1 */ @@ -3871,7 +3888,7 @@ FRESULT f_setlabel ( if (res == FR_OK) { /* A volume label is found */ if (vn[0]) { mem_cpy(dj.dir, vn, 11); /* Change the volume label name */ - tm = get_fattime(); + tm = GET_FATTIME(); ST_DWORD(dj.dir+DIR_WrtTime, tm); } else { dj.dir[0] = DDE; /* Remove the volume label */ @@ -3887,7 +3904,7 @@ FRESULT f_setlabel ( mem_set(dj.dir, 0, SZ_DIR); /* Set volume label */ mem_cpy(dj.dir, vn, 11); dj.dir[DIR_Attr] = AM_VOL; - tm = get_fattime(); + tm = GET_FATTIME(); ST_DWORD(dj.dir+DIR_WrtTime, tm); dj.fs->wflag = 1; res = sync_fs(dj.fs); @@ -3950,7 +3967,7 @@ FRESULT f_forward ( sect = clust2sect(fp->fs, fp->clust); /* Get current data sector */ if (!sect) ABORT(fp->fs, FR_INT_ERR); sect += csect; - if (move_window(fp->fs, sect)) /* Move sector window */ + if (move_window(fp->fs, sect) != FR_OK) /* Move sector window */ ABORT(fp->fs, FR_DISK_ERR); fp->dsect = sect; rcnt = SS(fp->fs) - (WORD)(fp->fptr % SS(fp->fs)); /* Forward data from sector window */ @@ -3970,13 +3987,13 @@ FRESULT f_forward ( /* Create File System on the Drive */ /*-----------------------------------------------------------------------*/ #define N_ROOTDIR 512 /* Number of root directory entries for FAT12/16 */ -#define N_FATS 1 /* Number of FAT copies (1 or 2) */ +#define N_FATS 1 /* Number of FATs (1 or 2) */ FRESULT f_mkfs ( const TCHAR* path, /* Logical drive number */ BYTE sfd, /* Partitioning rule 0:FDISK, 1:SFD */ - UINT au /* Allocation unit [bytes] */ + UINT au /* Size of allocation unit in unit of byte or sector */ ) { static const WORD vst[] = { 1024, 512, 256, 128, 64, 32, 16, 8, 4, 2, 0}; @@ -3992,10 +4009,9 @@ FRESULT f_mkfs ( /* Check mounted drive and clear work area */ + if (sfd > 1) return FR_INVALID_PARAMETER; vol = get_ldnumber(&path); if (vol < 0) return FR_INVALID_DRIVE; - if (sfd > 1) return FR_INVALID_PARAMETER; - if (au & (au - 1)) return FR_INVALID_PARAMETER; fs = FatFs[vol]; if (!fs) return FR_NOT_ENABLED; fs->fs_type = 0; @@ -4012,7 +4028,7 @@ FRESULT f_mkfs ( #endif if (_MULTI_PARTITION && part) { /* Get partition information from partition table in the MBR */ - if (disk_read(pdrv, fs->win, 0, 1)) return FR_DISK_ERR; + if (disk_read(pdrv, fs->win, 0, 1) != RES_OK) return FR_DISK_ERR; if (LD_WORD(fs->win+BS_55AA) != 0xAA55) return FR_MKFS_ABORTED; tbl = &fs->win[MBR_Table + (part - 1) * SZ_PTE]; if (!tbl[4]) return FR_MKFS_ABORTED; /* No partition? */ @@ -4026,13 +4042,14 @@ FRESULT f_mkfs ( n_vol -= b_vol; /* Volume size */ } - if (!au) { /* AU auto selection */ + if (au & (au - 1)) au = 0; + if (!au) { /* AU auto selection */ vs = n_vol / (2000 / (SS(fs) / 512)); for (i = 0; vs < vst[i]; i++) ; au = cst[i]; } - au /= SS(fs); /* Number of sectors per cluster */ - if (au == 0) au = 1; + if (au >= _MIN_SS) au /= SS(fs); /* Number of sectors per cluster */ + if (!au) au = 1; if (au > 128) au = 128; /* Pre-compute number of clusters and FAT sub-type */ @@ -4089,7 +4106,7 @@ FRESULT f_mkfs ( /* Update system ID in the partition table */ tbl = &fs->win[MBR_Table + (part - 1) * SZ_PTE]; tbl[4] = sys; - if (disk_write(pdrv, fs->win, 0, 1)) /* Write it to teh MBR */ + if (disk_write(pdrv, fs->win, 0, 1) != RES_OK) /* Write it to teh MBR */ return FR_DISK_ERR; md = 0xF8; } else { @@ -4109,7 +4126,7 @@ FRESULT f_mkfs ( ST_DWORD(tbl+8, 63); /* Partition start in LBA */ ST_DWORD(tbl+12, n_vol); /* Partition size in LBA */ ST_WORD(fs->win+BS_55AA, 0xAA55); /* MBR signature */ - if (disk_write(pdrv, fs->win, 0, 1)) /* Write it to the MBR */ + if (disk_write(pdrv, fs->win, 0, 1) != RES_OK) /* Write it to the MBR */ return FR_DISK_ERR; md = 0xF8; } @@ -4135,7 +4152,7 @@ FRESULT f_mkfs ( ST_WORD(tbl+BPB_SecPerTrk, 63); /* Number of sectors per track */ ST_WORD(tbl+BPB_NumHeads, 255); /* Number of heads */ ST_DWORD(tbl+BPB_HiddSec, b_vol); /* Hidden sectors */ - n = get_fattime(); /* Use current time as VSN */ + n = GET_FATTIME(); /* Use current time as VSN */ if (fmt == FS_FAT32) { ST_DWORD(tbl+BS_VolID32, n); /* VSN */ ST_DWORD(tbl+BPB_FATSz32, n_fat); /* Number of sectors per FAT */ @@ -4153,7 +4170,7 @@ FRESULT f_mkfs ( mem_cpy(tbl+BS_VolLab, "NO NAME " "FAT ", 19); /* Volume label, FAT signature */ } ST_WORD(tbl+BS_55AA, 0xAA55); /* Signature (Offset is fixed here regardless of sector size) */ - if (disk_write(pdrv, tbl, b_vol, 1)) /* Write it to the VBR sector */ + if (disk_write(pdrv, tbl, b_vol, 1) != RES_OK) /* Write it to the VBR sector */ return FR_DISK_ERR; if (fmt == FS_FAT32) /* Write backup VBR if needed (VBR+6) */ disk_write(pdrv, tbl, b_vol + 6, 1); @@ -4172,11 +4189,11 @@ FRESULT f_mkfs ( ST_DWORD(tbl+4, 0xFFFFFFFF); ST_DWORD(tbl+8, 0x0FFFFFFF); /* Reserve cluster #2 for root directory */ } - if (disk_write(pdrv, tbl, wsect++, 1)) + if (disk_write(pdrv, tbl, wsect++, 1) != RES_OK) return FR_DISK_ERR; mem_set(tbl, 0, SS(fs)); /* Fill following FAT entries with zero */ for (n = 1; n < n_fat; n++) { /* This loop may take a time on FAT32 volume due to many single sector writes */ - if (disk_write(pdrv, tbl, wsect++, 1)) + if (disk_write(pdrv, tbl, wsect++, 1) != RES_OK) return FR_DISK_ERR; } } @@ -4184,16 +4201,16 @@ FRESULT f_mkfs ( /* Initialize root directory */ i = (fmt == FS_FAT32) ? au : (UINT)n_dir; do { - if (disk_write(pdrv, tbl, wsect++, 1)) + if (disk_write(pdrv, tbl, wsect++, 1) != RES_OK) return FR_DISK_ERR; } while (--i); -#if _USE_ERASE /* Erase data area if needed */ +#if _USE_TRIM /* Erase data area if needed */ { DWORD eb[2]; eb[0] = wsect; eb[1] = wsect + (n_clst - ((fmt == FS_FAT32) ? 1 : 0)) * au - 1; - disk_ioctl(pdrv, CTRL_ERASE_SECTOR, eb); + disk_ioctl(pdrv, CTRL_TRIM, eb); } #endif @@ -4276,7 +4293,7 @@ FRESULT f_fdisk ( ST_WORD(p, 0xAA55); /* Write it to the MBR */ - return (disk_write(pdrv, buf, 0, 1) || disk_ioctl(pdrv, CTRL_SYNC, 0)) ? FR_DISK_ERR : FR_OK; + return (disk_write(pdrv, buf, 0, 1) != RES_OK || disk_ioctl(pdrv, CTRL_SYNC, 0) != RES_OK) ? FR_DISK_ERR : FR_OK; } diff --git a/fatfs/src/ff.h b/fatfs/src/ff.h index 9894921..5eaad5f 100644 --- a/fatfs/src/ff.h +++ b/fatfs/src/ff.h @@ -1,5 +1,5 @@ /*---------------------------------------------------------------------------/ -/ FatFs - FAT file system module include file R0.10b (C)ChaN, 2014 +/ FatFs - FAT file system module include file R0.10c (C)ChaN, 2014 /----------------------------------------------------------------------------/ / FatFs module is a generic FAT file system module for small embedded systems. / This is a free software that opened for education, research and commercial @@ -15,7 +15,7 @@ /----------------------------------------------------------------------------*/ #ifndef _FATFS -#define _FATFS 8051 /* Revision ID */ +#define _FATFS 80376 /* Revision ID */ #ifdef __cplusplus extern "C" { @@ -23,7 +23,6 @@ extern "C" { #include "integer.h" /* Basic integer types */ #include "ffconf.h" /* FatFs configuration options */ - #if _FATFS != _FFCONF #error Wrong configuration file (ffconf.h). #endif @@ -236,7 +235,7 @@ int f_puts (const TCHAR* str, FIL* cp); /* Put a string to the file */ int f_printf (FIL* fp, const TCHAR* str, ...); /* Put a formatted string to the file */ TCHAR* f_gets (TCHAR* buff, int len, FIL* fp); /* Get a string from the file */ -#define f_eof(fp) (((fp)->fptr == (fp)->fsize) ? 1 : 0) +#define f_eof(fp) ((int)((fp)->fptr == (fp)->fsize)) #define f_error(fp) ((fp)->err) #define f_tell(fp) ((fp)->fptr) #define f_size(fp) ((fp)->fsize) @@ -252,7 +251,7 @@ TCHAR* f_gets (TCHAR* buff, int len, FIL* fp); /* Get a string from the fil /* Additional user defined functions */ /* RTC function */ -#if !_FS_READONLY +#if !_FS_READONLY && !_FS_NORTC DWORD get_fattime (void); #endif diff --git a/fatfs/src/ffconf.h b/fatfs/src/ffconf.h index d883c14..f968d7e 100644 --- a/fatfs/src/ffconf.h +++ b/fatfs/src/ffconf.h @@ -1,30 +1,30 @@ /*---------------------------------------------------------------------------/ -/ FatFs - FAT file system module configuration file R0.10b (C)ChaN, 2014 +/ FatFs - FAT file system module configuration file R0.10c (C)ChaN, 2014 /---------------------------------------------------------------------------*/ -#ifndef _FFCONF -#define _FFCONF 8051 /* Revision ID */ - +#define _FFCONF 80376 /* Revision ID */ /*---------------------------------------------------------------------------/ / Functions and Buffer Configurations /---------------------------------------------------------------------------*/ -#define _FS_TINY 0 /* 0:Normal or 1:Tiny */ -/* When _FS_TINY is set to 1, it reduces memory consumption _MAX_SS bytes each -/ file object. For file data transfer, FatFs uses the common sector buffer in -/ the file system object (FATFS) instead of private sector buffer eliminated -/ from the file object (FIL). */ +#define _FS_TINY 0 +/* This option switches tiny buffer configuration. (0:Normal or 1:Tiny) +/ At the tiny configuration, size of the file object (FIL) is reduced _MAX_SS +/ bytes. Instead of private sector buffer eliminated from the file object, +/ common sector buffer in the file system object (FATFS) is used for the file +/ data transfer. */ -#define _FS_READONLY 0 /* 0:Read/Write or 1:Read only */ -/* Setting _FS_READONLY to 1 defines read only configuration. This removes -/ writing functions, f_write(), f_sync(), f_unlink(), f_mkdir(), f_chmod(), -/ f_rename(), f_truncate() and useless f_getfree(). */ +#define _FS_READONLY 0 +/* This option switches read-only configuration. (0:Read/Write or 1:Read-only) +/ Read-only configuration removes basic writing API functions, f_write(), +/ f_sync(), f_unlink(), f_mkdir(), f_chmod(), f_rename(), f_truncate(), +/ f_getfree() and optional writing functions as well. */ -#define _FS_MINIMIZE 0 /* 0 to 3 */ -/* The _FS_MINIMIZE option defines minimization level to remove API functions. +#define _FS_MINIMIZE 0 +/* This option defines minimization level to remove some API functions. / / 0: All basic functions are enabled. / 1: f_stat(), f_getfree(), f_unlink(), f_mkdir(), f_chmod(), f_utime(), @@ -33,24 +33,32 @@ / 3: f_lseek() function is removed in addition to 2. */ -#define _USE_STRFUNC 0 /* 0:Disable or 1-2:Enable */ -/* To enable string functions, set _USE_STRFUNC to 1 or 2. */ +#define _USE_STRFUNC 0 +/* This option switches string functions, f_gets(), f_putc(), f_puts() and +/ f_printf(). +/ +/ 0: Disable string functions. +/ 1: Enable without LF-CRLF conversion. +/ 2: Enable with LF-CRLF conversion. */ -#define _USE_MKFS 0 /* 0:Disable or 1:Enable */ -/* To enable f_mkfs() function, set _USE_MKFS to 1 and set _FS_READONLY to 0 */ +#define _USE_MKFS 0 +/* This option switches f_mkfs() function. (0:Disable or 1:Enable) +/ To enable it, also _FS_READONLY need to be set to 0. */ -#define _USE_FASTSEEK 0 /* 0:Disable or 1:Enable */ -/* To enable fast seek feature, set _USE_FASTSEEK to 1. */ +#define _USE_FASTSEEK 0 +/* This option switches fast seek feature. (0:Disable or 1:Enable) */ -#define _USE_LABEL 0 /* 0:Disable or 1:Enable */ -/* To enable volume label functions, set _USE_LAVEL to 1 */ +#define _USE_LABEL 0 +/* This option switches volume label functions, f_getlabel() and f_setlabel(). +/ (0:Disable or 1:Enable) */ -#define _USE_FORWARD 0 /* 0:Disable or 1:Enable */ -/* To enable f_forward() function, set _USE_FORWARD to 1 and set _FS_TINY to 1. */ +#define _USE_FORWARD 0 +/* This option switches f_forward() function. (0:Disable or 1:Enable) */ +/* To enable it, also _FS_TINY need to be set to 1. */ /*---------------------------------------------------------------------------/ @@ -58,7 +66,7 @@ /---------------------------------------------------------------------------*/ #define _CODE_PAGE 932 -/* The _CODE_PAGE specifies the OEM code page to be used on the target system. +/* This option specifies the OEM code page to be used on the target system. / Incorrect setting of the code page can cause a file open failure. / / 932 - Japanese Shift_JIS (DBCS, OEM, Windows) @@ -86,11 +94,11 @@ / 857 - Turkish (OEM) / 862 - Hebrew (OEM) / 874 - Thai (OEM, Windows) -/ 1 - ASCII (Valid for only non-LFN configuration) */ +/ 1 - ASCII (No extended character. Valid for only non-LFN configuration.) */ -#define _USE_LFN 0 /* 0 to 3 */ -#define _MAX_LFN 255 /* Maximum LFN length to handle (12 to 255) */ +#define _USE_LFN 0 +#define _MAX_LFN 255 /* The _USE_LFN option switches the LFN feature. / / 0: Disable LFN feature. _MAX_LFN has no effect. @@ -98,35 +106,39 @@ / 2: Enable LFN with dynamic working buffer on the STACK. / 3: Enable LFN with dynamic working buffer on the HEAP. / -/ When enable LFN feature, Unicode handling functions ff_convert() and ff_wtoupper() -/ function must be added to the project. -/ The LFN working buffer occupies (_MAX_LFN + 1) * 2 bytes. When use stack for the -/ working buffer, take care on stack overflow. When use heap memory for the working -/ buffer, memory management functions, ff_memalloc() and ff_memfree(), must be added -/ to the project. */ +/ When enable the LFN feature, Unicode handling functions (option/unicode.c) must +/ be added to the project. The LFN working buffer occupies (_MAX_LFN + 1) * 2 bytes. +/ When use stack for the working buffer, take care on stack overflow. When use heap +/ memory for the working buffer, memory management functions, ff_memalloc() and +/ ff_memfree(), must be added to the project. */ -#define _LFN_UNICODE 0 /* 0:ANSI/OEM or 1:Unicode */ -/* To switch the character encoding on the FatFs API (TCHAR) to Unicode, enable LFN -/ feature and set _LFN_UNICODE to 1. This option affects behavior of string I/O -/ functions. This option must be 0 when LFN feature is not enabled. */ +#define _LFN_UNICODE 0 +/* This option switches character encoding on the API. (0:ANSI/OEM or 1:Unicode) +/ To use Unicode string for the path name, enable LFN feature and set _LFN_UNICODE +/ to 1. This option also affects behavior of string I/O functions. */ -#define _STRF_ENCODE 3 /* 0:ANSI/OEM, 1:UTF-16LE, 2:UTF-16BE, 3:UTF-8 */ -/* When Unicode API is enabled by _LFN_UNICODE option, this option selects the character -/ encoding on the file to be read/written via string I/O functions, f_gets(), f_putc(), -/ f_puts and f_printf(). This option has no effect when _LFN_UNICODE == 0. Note that -/ FatFs supports only BMP. */ +#define _STRF_ENCODE 3 +/* When _LFN_UNICODE is 1, this option selects the character encoding on the file to +/ be read/written via string I/O functions, f_gets(), f_putc(), f_puts and f_printf(). +/ +/ 0: ANSI/OEM +/ 1: UTF-16LE +/ 2: UTF-16BE +/ 3: UTF-8 +/ +/ When _LFN_UNICODE is 0, this option has no effect. */ -#define _FS_RPATH 0 /* 0 to 2 */ -/* The _FS_RPATH option configures relative path feature. +#define _FS_RPATH 0 +/* This option configures relative path feature. / / 0: Disable relative path feature and remove related functions. -/ 1: Enable relative path. f_chdrive() and f_chdir() function are available. +/ 1: Enable relative path feature. f_chdir() and f_chdrive() are available. / 2: f_getcwd() function is available in addition to 1. / -/ Note that output of the f_readdir() fnction is affected by this option. */ +/ Note that directory items read via f_readdir() are affected by this option. */ /*---------------------------------------------------------------------------/ @@ -137,39 +149,43 @@ /* Number of volumes (logical drives) to be used. */ -#define _STR_VOLUME_ID 0 /* 0:Use only 0-9 for drive ID, 1:Use strings for drive ID */ +#define _STR_VOLUME_ID 0 #define _VOLUME_STRS "RAM","NAND","CF","SD1","SD2","USB1","USB2","USB3" -/* When _STR_VOLUME_ID is set to 1, also pre-defined strings can be used as drive -/ number in the path name. _VOLUME_STRS defines the drive ID strings for each logical -/ drives. Number of items must be equal to _VOLUMES. Valid characters for the drive ID -/ strings are: 0-9 and A-Z. */ +/* _STR_VOLUME_ID option switches string volume ID feature. +/ When _STR_VOLUME_ID is set to 1, also pre-defined strings can be used as drive +/ number in the path name. _VOLUME_STRS defines the drive ID strings for each +/ logical drives. Number of items must be equal to _VOLUMES. Valid characters for +/ the drive ID strings are: A-Z and 0-9. */ -#define _MULTI_PARTITION 0 /* 0:Single partition, 1:Enable multiple partition */ -/* By default(0), each logical drive number is bound to the same physical drive number -/ and only a FAT volume found on the physical drive is mounted. When it is set to 1, -/ each logical drive number is bound to arbitrary drive/partition listed in VolToPart[]. -*/ +#define _MULTI_PARTITION 0 +/* This option switches multi-partition feature. By default (0), each logical drive +/ number is bound to the same physical drive number and only an FAT volume found on +/ the physical drive will be mounted. When multi-partition feature is enabled (1), +/ each logical drive number is bound to arbitrary physical drive and partition +/ listed in the VolToPart[]. Also f_fdisk() funciton will be enabled. */ #define _MIN_SS 512 #define _MAX_SS 512 -/* These options configure the range of sector size to be supported. (512, 1024, 2048 or -/ 4096) Always set both 512 for most systems, all memory card and harddisk. But a larger -/ value may be required for on-board flash memory and some type of optical media. -/ When _MAX_SS is larger than _MIN_SS, FatFs is configured to variable sector size and -/ GET_SECTOR_SIZE command must be implemented to the disk_ioctl() function. */ +/* These options configure the range of sector size to be supported. (512, 1024, +/ 2048 or 4096) Always set both 512 for most systems, all type of memory cards and +/ harddisk. But a larger value may be required for on-board flash memory and some +/ type of optical media. When _MAX_SS is larger than _MIN_SS, FatFs is configured +/ to variable sector size and GET_SECTOR_SIZE command must be implemented to the +/ disk_ioctl() function. */ -#define _USE_ERASE 0 /* 0:Disable or 1:Enable */ -/* To enable sector erase feature, set _USE_ERASE to 1. Also CTRL_ERASE_SECTOR command -/ should be added to the disk_ioctl() function. */ +#define _USE_TRIM 0 +/* This option switches ATA-TRIM feature. (0:Disable or 1:Enable) +/ To enable Trim feature, also CTRL_TRIM command should be implemented to the +/ disk_ioctl() function. */ -#define _FS_NOFSINFO 0 /* 0 to 3 */ -/* If you need to know correct free space on the FAT32 volume, set bit 0 of this option -/ and f_getfree() function at first time after volume mount will force a full FAT scan. -/ Bit 1 controls the last allocated cluster number as bit 0. +#define _FS_NOFSINFO 0 +/* If you need to know correct free space on the FAT32 volume, set bit 0 of this +/ option, and f_getfree() function at first time after volume mount will force +/ a full FAT scan. Bit 1 controls the use of last allocated cluster number. / / bit0=0: Use free cluster count in the FSINFO if available. / bit0=1: Do not trust free cluster count in the FSINFO. @@ -183,46 +199,72 @@ / System Configurations /---------------------------------------------------------------------------*/ -#define _FS_LOCK 0 /* 0:Disable or >=1:Enable */ -/* To enable file lock control feature, set _FS_LOCK to non-zero value. -/ The value defines how many files/sub-directories can be opened simultaneously -/ with file lock control. This feature uses bss _FS_LOCK * 12 bytes. */ - - -#define _FS_REENTRANT 0 /* 0:Disable or 1:Enable */ -#define _FS_TIMEOUT 1000 /* Timeout period in unit of time tick */ -#define _SYNC_t HANDLE /* O/S dependent sync object type. e.g. HANDLE, OS_EVENT*, ID, SemaphoreHandle_t and etc.. */ -/* The _FS_REENTRANT option switches the re-entrancy (thread safe) of the FatFs module. +#define _FS_NORTC 0 +#define _NORTC_MON 11 +#define _NORTC_MDAY 9 +#define _NORTC_YEAR 2014 +/* The _FS_NORTC option switches timestamp feature. If the system does not have +/ an RTC function or valid timestamp is not needed, set _FS_NORTC to 1 to disable +/ the timestamp feature. All objects modified by FatFs will have a fixed timestamp +/ defined by _NORTC_MON, _NORTC_MDAY and _NORTC_YEAR. +/ When timestamp feature is enabled (_FS_NORTC == 0), get_fattime() function need +/ to be added to the project to read current time form RTC. _NORTC_MON, +/ _NORTC_MDAY and _NORTC_YEAR have no effect. +/ These options have no effect at read-only configuration (_FS_READONLY == 1). */ + + +#define _FS_LOCK 0 +/* The _FS_LOCK option switches file lock feature to control duplicated file open +/ and illegal operation to open objects. This option must be 0 when _FS_READONLY +/ is 1. +/ +/ 0: Disable file lock feature. To avoid volume corruption, application program +/ should avoid illegal open, remove and rename to the open objects. +/ >0: Enable file lock feature. The value defines how many files/sub-directories +/ can be opened simultaneously under file lock control. Note that the file +/ lock feature is independent of re-entrancy. */ + + +#define _FS_REENTRANT 0 +#define _FS_TIMEOUT 1000 +#define _SYNC_t HANDLE +/* The _FS_REENTRANT option switches the re-entrancy (thread safe) of the FatFs +/ module itself. Note that regardless of this option, file access to different +/ volume is always re-entrant and volume control functions, f_mount(), f_mkfs() +/ and f_fdisk() function, are always not re-entrant. Only file/directory access +/ to the same volume is under control of this feature. / / 0: Disable re-entrancy. _FS_TIMEOUT and _SYNC_t have no effect. / 1: Enable re-entrancy. Also user provided synchronization handlers, / ff_req_grant(), ff_rel_grant(), ff_del_syncobj() and ff_cre_syncobj() -/ function must be added to the project. -*/ +/ function, must be added to the project. Samples are available in +/ option/syscall.c. +/ +/ The _FS_TIMEOUT defines timeout period in unit of time tick. +/ The _SYNC_t defines O/S dependent sync object type. e.g. HANDLE, ID, OS_EVENT*, +/ SemaphoreHandle_t and etc.. */ -#define _WORD_ACCESS 0 /* 0 or 1 */ +#define _WORD_ACCESS 0 /* The _WORD_ACCESS option is an only platform dependent option. It defines / which access method is used to the word data on the FAT volume. / / 0: Byte-by-byte access. Always compatible with all platforms. / 1: Word access. Do not choose this unless under both the following conditions. / -/ * Address misaligned memory access is always allowed for ALL instructions. +/ * Address misaligned memory access is always allowed to ALL instructions. / * Byte order on the memory is little-endian. / -/ If it is the case, _WORD_ACCESS can also be set to 1 to improve performance and -/ reduce code size. Following table shows an example of some processor types. +/ If it is the case, _WORD_ACCESS can also be set to 1 to reduce code size. +/ Following table shows allowable settings of some processor types. / / ARM7TDMI 0 ColdFire 0 V850E 0 / Cortex-M3 0 Z80 0/1 V850ES 0/1 -/ Cortex-M0 0 RX600(LE) 0/1 TLCS-870 0/1 -/ AVR 0/1 RX600(BE) 0 TLCS-900 0/1 +/ Cortex-M0 0 x86 0/1 TLCS-870 0/1 +/ AVR 0/1 RX600(LE) 0/1 TLCS-900 0/1 / AVR32 0 RL78 0 R32C 0 / PIC18 0/1 SH-2 0 M16C 0/1 / PIC24 0 H8S 0 MSP430 0 -/ PIC32 0 H8/300H 0 x86 0/1 +/ PIC32 0 H8/300H 0 8051 0/1 */ - -#endif /* _FFCONF */ diff --git a/fatfs/src/option/cc932.c b/fatfs/src/option/cc932.c index 26ac70f..36db384 100644 --- a/fatfs/src/option/cc932.c +++ b/fatfs/src/option/cc932.c @@ -3739,10 +3739,10 @@ WCHAR ff_convert ( /* Converted code, 0 means conversion error */ #if !_TINY_TABLE if (dir) { /* OEMCP to unicode */ p = sjis2uni; - hi = sizeof(sjis2uni) / 4 - 1; + hi = sizeof sjis2uni / 4 - 1; } else { /* Unicode to OEMCP */ p = uni2sjis; - hi = sizeof(uni2sjis) / 4 - 1; + hi = sizeof uni2sjis / 4 - 1; } li = 0; for (n = 16; n; n--) { @@ -3764,7 +3764,7 @@ WCHAR ff_convert ( /* Converted code, 0 means conversion error */ p -= 3; c = *p; } else { /* Unicode to OEMCP */ - li = 0; hi = sizeof(uni2sjis) / 4 - 1; + li = 0; hi = sizeof uni2sjis / 4 - 1; for (n = 16; n; n--) { i = li + (hi - li) / 2; if (chr == uni2sjis[i * 2]) break; diff --git a/fatfs/src/option/cc936.c b/fatfs/src/option/cc936.c index 07a7c1c..84bc329 100644 --- a/fatfs/src/option/cc936.c +++ b/fatfs/src/option/cc936.c @@ -10936,10 +10936,10 @@ WCHAR ff_convert ( /* Converted code, 0 means conversion error */ } else { if (dir) { /* OEMCP to unicode */ p = oem2uni; - hi = sizeof(oem2uni) / 4 - 1; + hi = sizeof oem2uni / 4 - 1; } else { /* Unicode to OEMCP */ p = uni2oem; - hi = sizeof(uni2oem) / 4 - 1; + hi = sizeof uni2oem / 4 - 1; } li = 0; for (n = 16; n; n--) { diff --git a/fatfs/src/option/cc949.c b/fatfs/src/option/cc949.c index 1fd075d..0abda85 100644 --- a/fatfs/src/option/cc949.c +++ b/fatfs/src/option/cc949.c @@ -8565,10 +8565,10 @@ WCHAR ff_convert ( /* Converted code, 0 means conversion error */ } else { if (dir) { /* OEMCP to unicode */ p = oem2uni; - hi = sizeof(oem2uni) / 4 - 1; + hi = sizeof oem2uni / 4 - 1; } else { /* Unicode to OEMCP */ p = uni2oem; - hi = sizeof(uni2oem) / 4 - 1; + hi = sizeof uni2oem / 4 - 1; } li = 0; for (n = 16; n; n--) { diff --git a/fatfs/src/option/cc950.c b/fatfs/src/option/cc950.c index a3c9c44..d914b6d 100644 --- a/fatfs/src/option/cc950.c +++ b/fatfs/src/option/cc950.c @@ -6791,10 +6791,10 @@ WCHAR ff_convert ( /* Converted code, 0 means conversion error */ } else { if (dir) { /* OEMCP to unicode */ p = oem2uni; - hi = sizeof(oem2uni) / 4 - 1; + hi = sizeof oem2uni / 4 - 1; } else { /* Unicode to OEMCP */ p = uni2oem; - hi = sizeof(uni2oem) / 4 - 1; + hi = sizeof uni2oem / 4 - 1; } li = 0; for (n = 16; n; n--) { diff --git a/fatfs/src/option/ccsbcs.c b/fatfs/src/option/ccsbcs.c index d6897bc..b16db30 100644 --- a/fatfs/src/option/ccsbcs.c +++ b/fatfs/src/option/ccsbcs.c @@ -444,7 +444,7 @@ const WCHAR Tbl[] = { /* CP1256(0x80-0xFF) to Unicode conversion table */ 0x00E8, 0x00E9, 0x00EA, 0x00EB, 0x0649, 0x064A, 0x00EE, 0x00EF, 0x064B, 0x064C, 0x064D, 0x064E, 0x00F4, 0x064F, 0x0650, 0x00F7, 0x0651, 0x00F9, 0x0652, 0x00FB, 0x00FC, 0x200E, 0x200F, 0x06D2 -} +}; #elif _CODE_PAGE == 1257 #define _TBLDEF 1 diff --git a/fatfs/src/option/syscall.c b/fatfs/src/option/syscall.c index ccfd47e..2036cb7 100644 --- a/fatfs/src/option/syscall.c +++ b/fatfs/src/option/syscall.c @@ -1,10 +1,8 @@ /*------------------------------------------------------------------------*/ /* Sample code of OS dependent controls for FatFs */ -/* (C)ChaN, 2012 */ +/* (C)ChaN, 2014 */ /*------------------------------------------------------------------------*/ -#include /* ANSI memory controls */ -#include /* ANSI memory controls */ #include "../ff.h" @@ -13,14 +11,14 @@ /*------------------------------------------------------------------------*/ /* Create a Synchronization Object /*------------------------------------------------------------------------*/ -/* This function is called by f_mount() function to create a new -/ synchronization object, such as semaphore and mutex. When a 0 is -/ returned, the f_mount() function fails with FR_INT_ERR. +/* This function is called in f_mount() function to create a new +/ synchronization object, such as semaphore and mutex. When a 0 is returned, +/ the f_mount() function fails with FR_INT_ERR. */ -int ff_cre_syncobj ( /* 1:Function succeeded, 0:Could not create due to any error */ +int ff_cre_syncobj ( /* !=0:Function succeeded, ==0:Could not create due to any error */ BYTE vol, /* Corresponding logical drive being processed */ - _SYNC_t* sobj /* Pointer to return the created sync object */ + _SYNC_t *sobj /* Pointer to return the created sync object */ ) { int ret; @@ -29,13 +27,13 @@ int ff_cre_syncobj ( /* 1:Function succeeded, 0:Could not create due to any erro *sobj = CreateMutex(NULL, FALSE, NULL); /* Win32 */ ret = (int)(*sobj != INVALID_HANDLE_VALUE); -// *sobj = SyncObjects[vol]; /* uITRON (give a static created semaphore) */ -// ret = 1; +// *sobj = SyncObjects[vol]; /* uITRON (give a static created sync object) */ +// ret = 1; /* The initial value of the semaphore must be 1. */ -// *sobj = OSMutexCreate(0, &err); /* uC/OS-II */ +// *sobj = OSMutexCreate(0, &err); /* uC/OS-II */ // ret = (int)(err == OS_NO_ERR); -// *sobj = xSemaphoreCreateMutex(); /* FreeRTOS */ +// *sobj = xSemaphoreCreateMutex(); /* FreeRTOS */ // ret = (int)(*sobj != NULL); return ret; @@ -47,11 +45,11 @@ int ff_cre_syncobj ( /* 1:Function succeeded, 0:Could not create due to any erro /* Delete a Synchronization Object */ /*------------------------------------------------------------------------*/ /* This function is called in f_mount() function to delete a synchronization -/ object that created with ff_cre_syncobj() function. When a 0 is -/ returned, the f_mount() function fails with FR_INT_ERR. +/ object that created with ff_cre_syncobj function. When a 0 is returned, +/ the f_mount() function fails with FR_INT_ERR. */ -int ff_del_syncobj ( /* 1:Function succeeded, 0:Could not delete due to any error */ +int ff_del_syncobj ( /* !=0:Function succeeded, ==0:Could not delete due to any error */ _SYNC_t sobj /* Sync object tied to the logical drive to be deleted */ ) { @@ -65,7 +63,7 @@ int ff_del_syncobj ( /* 1:Function succeeded, 0:Could not delete due to any erro // OSMutexDel(sobj, OS_DEL_ALWAYS, &err); /* uC/OS-II */ // ret = (int)(err == OS_NO_ERR); -// xSemaphoreDelete(sobj); /* FreeRTOS */ +// vSemaphoreDelete(sobj); /* FreeRTOS */ // ret = 1; return ret; @@ -77,10 +75,10 @@ int ff_del_syncobj ( /* 1:Function succeeded, 0:Could not delete due to any erro /* Request Grant to Access the Volume */ /*------------------------------------------------------------------------*/ /* This function is called on entering file functions to lock the volume. -/ When a FALSE is returned, the file function fails with FR_TIMEOUT. +/ When a 0 is returned, the file function fails with FR_TIMEOUT. */ -int ff_req_grant ( /* TRUE:Got a grant to access the volume, FALSE:Could not get a grant */ +int ff_req_grant ( /* 1:Got a grant to access the volume, 0:Could not get a grant */ _SYNC_t sobj /* Sync object to wait */ ) { @@ -135,7 +133,7 @@ void* ff_memalloc ( /* Returns pointer to the allocated memory block */ UINT msize /* Number of bytes to allocate */ ) { - return malloc(msize); + return malloc(msize); /* Allocate a new memory block with POSIX API */ } @@ -147,7 +145,7 @@ void ff_memfree ( void* mblock /* Pointer to the memory block to free */ ) { - free(mblock); + free(mblock); /* Discard the memory block with POSIX API */ } #endif -- 2.39.2