2020-09-30 17:17:25 +02:00

146 lines
4.1 KiB
C

/*++
Copyright (c) 1989-2001 Microsoft Corporation
Module Name:
fat.h
Abstract:
This module defines the on-disk structure of the FAT file system.
--*/
#ifndef _FAT_
#define _FAT_
#include <pshpack1.h>
//
// Define the length of the volume name stored in the FAT volume metadata block.
// This includes one character for storing a null terminator. This should be
// equal to MAX_MUNAME (from xbox.h).
//
#define FAT_VOLUME_NAME_LENGTH 32
//
// Defines the length of region reserved for online related data.
//
#define FAT_ONLINE_DATA_LENGTH 2048
//
// Define the structure of the FAT volume metadata block. The metadata block
// is at physical byte offset zero of the volume. The metadata block is either
// 4096 bytes or one device sector in length, whichever is greater.
//
typedef struct _FAT_VOLUME_METADATA {
ULONG Signature;
ULONG SerialNumber;
ULONG SectorsPerCluster;
ULONG RootDirFirstCluster;
WCHAR VolumeName[FAT_VOLUME_NAME_LENGTH];
UCHAR OnlineData[FAT_ONLINE_DATA_LENGTH];
// Unused space in the block is filled with 0xFF bytes.
} FAT_VOLUME_METADATA, *PFAT_VOLUME_METADATA;
//
// Define the volume signature value contained in the volume metadata block.
//
#define FAT_VOLUME_SIGNATURE 'XTAF'
//
// The first entry of the FAT is reserved in order to catch media errors that
// cause part of the FAT to be zeroed out.
//
#define FAT_RESERVED_FAT_ENTRIES 1
//
// The following constants the are the valid FAT index values.
//
#define FAT_CLUSTER_AVAILABLE (ULONG)0x00000000
#define FAT_CLUSTER_RESERVED (ULONG)0xfffffff0
#define FAT_CLUSTER_BAD (ULONG)0xfffffff7
#define FAT_CLUSTER_MEDIA (ULONG)0xfffffff8
#define FAT_CLUSTER_LAST (ULONG)0xffffffff
#define FAT_CLUSTER16_AVAILABLE (USHORT)0x0000
#define FAT_CLUSTER16_RESERVED (USHORT)0xfff0
#define FAT_CLUSTER16_BAD (USHORT)0xfff7
#define FAT_CLUSTER16_MEDIA (USHORT)0xfff8
#define FAT_CLUSTER16_LAST (USHORT)0xffff
#define FAT_CLUSTER_NULL (ULONG)0
//
// FAT files have the following time/date structures.
//
typedef union _FAT_TIME_STAMP {
struct {
USHORT DoubleSeconds : 5;
USHORT Minute : 6;
USHORT Hour : 5;
USHORT Day : 5;
USHORT Month : 4;
USHORT Year : 7; // Relative to 2000
};
ULONG AsULONG;
} FAT_TIME_STAMP;
typedef FAT_TIME_STAMP *PFAT_TIME_STAMP;
//
// FAT files have the following name length.
//
#define FAT_FILE_NAME_LENGTH 42
//
// FAT paths have the following name limit.
//
#define FAT_PATH_NAME_LIMIT 250
//
// The directory entry record exists for every file/directory on the
// disk except for the root directory.
//
typedef struct _DIRENT {
UCHAR FileNameLength; // offset 0x00
UCHAR FileAttributes; // offset 0x01
UCHAR FileName[FAT_FILE_NAME_LENGTH]; // offset 0x02
ULONG FirstCluster; // offset 0x2C
ULONG FileSize; // offset 0x30
FAT_TIME_STAMP CreationTime; // offset 0x34
FAT_TIME_STAMP LastWriteTime; // offset 0x38
FAT_TIME_STAMP LastAccessTime; // offset 0x3C
} DIRENT, *PDIRENT; // sizeof = 64
//
// The first byte of a dirent describes the dirent.
//
#define FAT_DIRENT_NEVER_USED 0x00
#define FAT_DIRENT_DELETED 0xE5
#define FAT_DIRENT_NEVER_USED2 0xFF
//
// FAT directories have the following file size restriction. The restriction
// helps to avoid circular FAT corruption (directories don't track the file
// size in their directory entry) and to ensure that titles don't create a
// directory structure that's slow to search.
//
#define FAT_MAXIMUM_DIRECTORY_FILE_SIZE (4096 * sizeof(DIRENT))
#include <poppack.h>
#endif // _FAT_