f_fdisk

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

FRESULT f_fdisk (
  BYTE  Drive,              /* 物理ドライブ番号 */
  const DWORD Partitions[], /* 区画マップ・テーブル */
  void* Work                /* ワークエリア */
);

引数

Drive
分割する物理ドライブを指定します。
Partitions[]
区画マップ・テーブルへのポインタを指定します。
Work
ワークエリアへのポインタを指定します。サイズは_MAX_SSバイト必要です。

戻り値

FR_OK, FR_DISK_ERR, FR_NOT_READY, FR_WRITE_PROTECTED, FR_INVALID_PARAMETER

説明

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

対応情報

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

使用例

    /* ユーザ定義のボリューム管理テーブル (_MULTI_PARTITION != 0 のとき必要) */

    PARTITION VolToPart[] = {
        {0, 1},    /* 論理ドライブ 0 ==> 物理ドライブ 0, 第1区画 */
        {0, 2},    /* 論理ドライブ 1 ==> 物理ドライブ 0, 第2区画 */
        {1, 0}     /* 論理ドライブ 2 ==> 物理ドライブ 1, 自動検出 */
    };
    /* 新しい物理ドライブ(0)の初期化 */

    FATFS Fatfs;
    DWORD plist[] = {50, 50, 0, 0};  /* 2分割 */
    BYTE work[_MAX_SS];

    f_fdisk(0, plist, work);  /* 物理ドライブ 0 の分割 */

    f_mount(0, &Fatfs);
    f_mkfs(0, 0, 0);          /* 論理ドライブ 0 の初期化. 第二引数は無視される.  */
    f_mount(0, 0);

    f_mount(1, &Fatfs);
    f_mkfs(1, 0, 0);
    f_mount(1, 0);

See Also

Volume management, f_mkfs

Return