mac-rom/Internal/C/HFSDefs.h
Elliot Nunn 4325cdcc78 Bring in CubeE sources
Resource forks are included only for .rsrc files. These are DeRezzed into their data fork. 'ckid' resources, from the Projector VCS, are not included.

The Tools directory, containing mostly junk, is also excluded.
2017-12-26 09:52:23 +08:00

553 lines
20 KiB
C

/*------------------------------------------------------------------------------
File: HFSDefs.h
Contains: HFS data structure definitions.
Written by: Bill Bruffey
Copyright: © 1986-1990 by Apple Computer, Inc., all rights reserved.
Change History (most recent first):
<2> 6/16/90 PK cleaning up
<1> 6/14/90 PK first checked in
29 May 90 PK Added BB_FNum and VAtrb_BB for sparing
6 Jul 89 EN Added cdrFThdRec for FileIDs support for BigBang. (changed comments too)
10 May 86 BB New today.
To Do:
------------------------------------------------------------------------------*/
/*------------------------------------------------------------------------------
Misc constants
------------------------------------------------------------------------------*/
#define HFS_SigW 0x4244 /* HFS signature bytes */
#define NxFreeFN 16 /* 1st free file number for user files */
#define NxFreeDID 3 /* 1st free directory ID for user directories */
#define FSRtDirID 2 /* directory ID fo root directory */
#define AlBlkSize 512 /* default allocation block size (bytes) */
#define ClpSize (4*512) /* default clump size (bytes) */
#define MDB_FNum 1 /* file number representing the MDB */
#define AMDB_FNum -1 /* file number representing the alternate MDB */
#define VBM_FNum 2 /* file number representing the volume bit map */
#define Ext_FNum 3 /* file number for the Extent file */
#define Cat_FNum 4 /* file number for the Catalog file */
#define BB_FNum 5 /* file number for the Bad Block extents */
#define MDB_BlkN 2 /* logical block number for the MDB */
#define Vol_RefN (-1) /* refnum of volume being scavenged */
#define Ext_RefN 0x02 /* extent file refnum */
#define Cat_RefN 0x60 /* extent file refnum */
#define Max_XKey 7 /* max extent file key length */
#define Max_CKey 37 /* max catalog file key length */
#define Max_VName 27 /* max volume name length */
#define Max_ABSiz 0xFFFF /* max allocation block size (64K - 1) */
#define Max_ABlks 0xFFFF /* max number of allocation blocks (64K - 1) */
#define Blk_Size 512 /* size of a logical block */
#define Num_CBufs 32 /* number of cache buffers */
#define CBuf_Size 512 /* cache buffer size */
#define VAtrb_Msk 0x7C7F /* volume attribute mask - invalid bits */
#define VAtrb_BB 0x0200 /* bad blocks have been spared */
#define VAtrb_DFlt 0x0100 /* default volume attribute flags */
#define VAtrb_Cons 0x0100 /* volume consistency flag */
/*------------------------------------------------------------------------------
BTree data structures
------------------------------------------------------------------------------*/
/* misc BTree constants */
#define BTNodeSize 512 /* default node size */
#define BTMaxDepth 8 /* max tree depth */
#define Num_HRecs 3 /* number of records in BTree Header node */
#define Num_MRecs 1 /* number of records in BTree Map node */
/* the records in the BTree Header node are: */
#define HRec_BTH 1 /* record 1: the BTree header record */
#define HRec_Unused 2 /* record 2: 128 unused 'user' bytes */
#define HRec_Map 3 /* record 3: the initial 256 byte bitmap */
/*
* Scavenger BTree Control Block (SBTCB)
*/
typedef struct SBTCB {
unsigned char BTCFlags; /* flags */
char BTCResv; /* reserved */
short BTCRefNum; /* file refnum */
ProcPtr BTCKeyCR; /* pointer to ext key compare routine */
Ptr BTCCQPtr; /* pointer to cache queue */
Ptr BTCVarPtr; /* pointer to BTree variables */
short BTCLevel; /* current level */
long BTCNodeM; /* current node mark */
short BTCIndexM; /* current index mark */
/* this part of a BTCB is the memory resident portion of the BTH */
short BTCDepth; /* current depth of tree */
long BTCRoot; /* root node number */
long BTCNRecs; /* number of leaf records in BTree */
long BTCFNode; /* node number of 1st leaf node */
long BTCLNode; /* node number of last leaf node */
short BTCNodeSize; /* BTree node size in bytes */
short BTCKeyLen; /* max key length */
long BTCNNodes; /* total number of nodes */
long BTCFree; /* number of free nodes */
/* Scavenger extensions to the HFS BTCB */
Ptr BTCBMPtr; /* pointer to scavenger BTree bit map */
Ptr BTCFCBAPtr; /* pointer to scavenger FCB array */
} SBTCB, *SBTCBPtr;
#define LenBTCB 54 /* length of a HFS BTCB */
#define LenSBTCB 62 /* length of a Scavenger BTCB */
/* BTCB flag definitions (contents of BTCFlags) */
#define BTCDirty 128 /* dirty flag */
#define BTCKeyUpd 64 /* index key update required */
#define BTCNewIRec 32 /* new index record required */
#define BTCDelIRec 16 /* index record delete required */
/*
* BTree Header (BTH) on disk
*/
typedef struct BTH {
short BTHDepth; /* current depth of tree */
long BTHRoot; /* root node number */
long BTHNRecs; /* number of leaf records in BTree */
long BTHFNode; /* node number of 1st leaf node */
long BTHLNode; /* node number of last leaf node */
short BTHNodeSize; /* BTree node size in bytes */
short BTHKeyLen; /* max key length */
long BTHNNodes; /* total number of nodes */
long BTHFree; /* number of free nodes */
} BTH, *BTHPtr;
#define LenMemBTH 30 /* length of memory resident portion of BTH */
#define LenBTH 106 /* length of a BTH */
/*
* Node Descriptor (prefix ND)
*/
typedef struct ND {
long NDFlink; /* forward link */
long NDBlink; /* backward link */
char NDType; /* node type */
char NDNHeight; /* node height */
short NDNRecs; /* number of records */
short NDResv2; /* reserved */
} ND, *NDPtr;
#define lenND 14 /* length of node descriptor */
/* node types (contents of NDType) */
#define NDHdrNode 1 /* header node */
#define NDMapNode 2 /* map node */
#define NDIndxNode 0 /* index node */
#define NDLeafNode (-1) /* leaf node */
/*
* Scavenger BTree Path Record (STPR)
*/
typedef struct STPR {
long TPRNodeN; /* node number */
short TPRRIndx; /* record index */
short Unused; /* not used - makes debugging easier */
long TPRLtSib; /* node number of left sibling node */
long TPRRtSib; /* node number of right sibling node */
} STPR, *STPRPtr;
typedef STPR SBTPT[BTMaxDepth]; /* BTree path table */
#define LenSTPR 16 /* length of Tree Path Record */
#define LenSBTPT (LenSTPR*BTMaxDepth) /* length of BTree Path Table */
/*------------------------------------------------------------------------------
FXM (File Extents Manager) data structures
------------------------------------------------------------------------------*/
/*
* ExtendFile option flags
*/
#define EFContig 2 /* force contiguous allocation */
#define EFAll 1 /* allocate all requested bytes or none */
/*
* TruncateFile option flags
*/
#define TFTrunExt 1 /* truncate to the extent containing new PEOF */
/*
* extent key record (prefix xkr)
*/
typedef struct xkr {
unsigned char xkrKeyLen; /* key length (byte) */
unsigned char xkrFkType; /* fork type (byte) */
/* $00 = data fork */
/* $FF = resource fork */
long xkrFNum; /* file number (long) */
unsigned short xkrFABN; /* starting file allocation block number (word) */
} xkr, *xkrPtr;
#define Lenxkr 8 /* length of a xkr */
/*
* extent entry (prefix ext)
*/
typedef struct ext {
unsigned short extStABN; /* starting physical allocation block number (word) */
unsigned short extNumABlks; /* number of allocation blocks (word) */
} ext;
/*
* extent data record (prefix xdr)
*/
#define NumExts 3 /* number of extents per record */
typedef ext xdr[NumExts]; /* xdr = (3 extent entries) */
/*------------------------------------------------------------------------------
CM (Catalog Manager) data structures
------------------------------------------------------------------------------*/
/*
* Misc constants
*/
#define CMMaxKey 37 /* max catalog key length */
#define CMMaxCName 31 /* max CName length */
#define CMMaxDepth 64 /* max catalog depth */
#define CMClpSize 20 /* catalog clump size */
/*
* CNode types
*/
#define CMDirCN 1 /* directory CNode */
#define CMFilCN 2 /* file CNode */
/*
* catalog key record (prefix ckr)
*/
typedef struct ckr {
unsigned char ckrKeyLen; /* key length (byte) */
char ckrResrv1; /* reserved (byte) */
long ckrParID; /* parent directory ID (long) */
unsigned char ckrCName[32]; /* CNode name (str31) */
} ckr, *ckrPtr;
#define Lenckr 38 /* length of a ckr */
/*
* catalog data record (prefix cdr)
*/
typedef struct cdr {
char cdrType; /* record type (byte) */
char cdrResrv; /* reserved (byte) */
} cdr, *cdrPtr;
#define cdrData 2 /* start of catalog record data */
/*
* catalog directory record (prefix dir)
*/
typedef struct dir {
char cdrType; /* record type (byte) */
char cdrResrv; /* reserved (byte) */
unsigned short dirFlags; /* flags (word) */
short dirVal; /* valence (word) */
long dirDirID; /* DirID for this directory (long) */
unsigned long dirCrDat; /* date/time created (long) */
unsigned long dirMdDat; /* date/time last modified (long) */
unsigned long dirBkDat; /* date/time last backed up (long) */
char dirUsrInfo[16]; /* User info bytes (16 bytes) */
FInfo dirFndrInfo; /* Finder Info bytes (16 bytes) */
char dirResrv[16]; /* reserved (16 bytes) */
} dir;
#define Lendir 70 /* length of a directory record */
/*
* catalog thread record (prefix thd)
*/
typedef struct thd {
char cdrType; /* record type (byte) */
char cdrResrv; /* reserved (byte) */
char thdResrv[8]; /* reserved (8 bytes) */
long thdParID; /* Parent ID for this directory (long) */
unsigned char thdCName[32]; /* CName for this directory (str31) */
} thd;
#define Lenthd 46 /* length of a thread record */
/*
* catalog file record (prefix fil)
*/
typedef struct fil {
char cdrType; /* record type (byte) */
char cdrResrv; /* reserved (byte) */
unsigned char filFlags; /* bit 7=1 (used), bit 0=file lock flag, bit 1=file thread flag */
char filTyp; /* file type (used as a name extension) */
char filUsrWds[16]; /* user words for file. (16 bytes) */
long filFlNum; /* file number */
short filStBlk; /* Start file block (alloc blk size)(0000 if none) */
long filLgLen; /* File logical length in bytes (EOF) */
long filPyLen; /* File physical length in bytes */
short filRStBlk; /* Start file block, resource fork (0000 if none) */
long filRLgLen; /* File logical length (EOF), resource fork */
long filRPyLen; /* File physical length, resource fork */
unsigned long filCrDat; /* date/time created (long) */
unsigned long filMdDat; /* date/time last modified (long) */
unsigned long filBkDat; /* date/time last backed up (long) */
char filFndrInfo[16]; /* Additional finder info for file (16 bytes) */
short filClpSize; /* file clump size (word) */
xdr filExtRec; /* First 3 data fork extents (12 bytes) */
xdr filRExtRec; /* First 3 resource fork extents (12 bytes) */
long filResrv; /* reserved (4 bytes) */
} fil;
#define Lenfil 102 /* length of a file record */
#define Lencdr Lenfil /* max length of a catalog data record */
/* catalog data record types (varients) */
#define cdrDirRec CMDirCN /* directory record (directory CNode type) */
#define cdrFilRec CMFilCN /* file record (file CNode type) */
#define cdrThdRec 3 /* thread record */
#define cdrFThdRec 4 /* file thread record */
/*
* Scavenger Directory Path Record (SDPR)
*/
typedef struct SDPR {
long DirID; /* directory ID */
short OffIndx; /* offspring index */
long DirHint; /* BTree hint for directory record */
long ThdHint; /* BTree hint for thread record */
long ParID; /* parent directory ID */
unsigned char DirCName[32]; /* directory CName */
} SDPR;
typedef SDPR SDPT[CMMaxDepth]; /* directory path table */
#define LenSDPR 50 /* length of Directory Path Record */
#define LenSDPT (LenSDPR*CMMaxDepth) /* length of Tree Path Table */
/*------------------------------------------------------------------------------
Scavenger VCB (SVCB)
------------------------------------------------------------------------------*/
typedef struct SVCB {
struct QElem *qLink; /* link to next VCB */
short qType; /* queue type */
unsigned short VCBFlags; /* VCB flags */
unsigned short VCBSigWord; /* signature word */
unsigned long VCBCrDate; /* Creation date */
unsigned long VCBLsMod; /* last backup date */
unsigned short VCBAtrb; /* volume attributes. bit 15=write(locked=1) */
unsigned short VCBNmFls; /* number files in root directory */
short VCBVBMSt; /* starting sector of allocation map (overlaps) */
unsigned short VCBAllocPtr; /* Start of next allocation search */
unsigned short VCBNmAlBlks; /* number of blocks (of alloc size) this volume */
long VCBAlBlkSiz; /* min num of bytes to allocate (must be 512 mult) */
long VCBClpSiz; /* num of bytes to try to alloc as a clump */
short VCBAlBlSt; /* starting diskette (512-byte) block in block map */
long VCBNxtCNID; /* Next CNode identifier */
unsigned short VCBFreeBks; /* number of free blocks on this volume */
unsigned char VCBVN[Max_VName+1]; /* volume name (including name length) */
short VCBDrvNum; /* drive number for this VCB */
short VCBDRefNum; /* driver refnum for this VCB */
short VCBFSID; /* ID of file system handling this volume */
short VCBVRefNum; /* unique refnum for this VCB */
Ptr VCBMAdr; /* volume map address (MFS volume) */
Ptr VCBBufAdr; /* volume buffer address */
short VCBMLen; /* length of voume map (MFS volume) */
short VCBDirIndex; /* directory index and block number */
short VCBDirBlk; /* (used by GetFileInfo searches by index) */
/* VCB extensions for HFS (copied from the MDB) */
unsigned long VCBVolBkup; /* date volume was last backed up */
short VCBVSeqNum; /* index of volume in backup set */
unsigned long VCBWrCnt; /* volume write count */
long VCBXTClpSiz; /* extent file clump size */
long VCBCTClpSiz; /* catalog file clump size */
short VCBNmRtDirs; /* number of directories in root */
long VCBFilCnt; /* total number of files on volume */
long VCBDirCnt; /* total number of directories on volume */
char VCBFndrInfo[32]; /* Finder info for volume */
short VCBVCSize; /* Volume cache size in blocks */
short VCBVBMCSize; /* volume bitmap cache size in blocks */
short VCBCtlCSize; /* control (BTree) cache size in blocks */
/* VCB extensions for HFS (not copied from the MDB) */
short VCBXTAlBlks; /* size of extent BTree in alloc blocks */
short VCBCTAlBlks; /* size of catalog BTree in alloc blocks */
short VCBXTRef; /* file refnum for extent file */
short VCBCTRef; /* file refnum for catalog file */
Ptr VCBCtlBuf; /* pointer to control (BTree) cache */
long VCBDirIDM; /* directory last searched ( 0 if invalid) */
short VCBOffsM; /* offspring index at last search */
/* Scavenger extensions to the HFS VCB */
short VCBRWErr; /* last read/write error on volume */
Ptr VCBBMPtr; /* pointer to scavenger volume bit map */
Ptr VCBFCBAPtr; /* pointer to scavenger FCB array */
} SVCB, *SVCBPtr;
#define LenSVCB 188 /* length of a Scavenger VCB */
/*------------------------------------------------------------------------------
Master Directory Block (MDB) on disk
------------------------------------------------------------------------------*/
typedef struct MDB {
unsigned short DrSigWord; /* signature word */
unsigned long DrCrDate; /* Creation date */
unsigned long DrLsMod; /* last backup date */
unsigned short DrAtrb; /* volume attributes. bit 15=write(locked=1) */
unsigned short DrNmFls; /* number files in root directory */
short DrVBMSt; /* starting sector of allocation map (overlaps) */
short DrAllocPtr; /* Start of next allocation search */
unsigned short DrNmAlBlks; /* number of blocks (of alloc size) this volume */
long DrAlBlkSiz; /* min num of bytes to allocate (must be 512 mult) */
long DrClpSiz; /* num of bytes to try to alloc as a clump */
short DrAlBlSt; /* starting diskette (512-byte) block in block map */
long DrNxtCNID; /* Next CNode identifier */
unsigned short DrFreeBks; /* number of free blocks on this volume */
unsigned char DrVN[Max_VName+1]; /* volume name (including name length) */
/* Master Directory Block extensions for HFS */
unsigned long DrVolBkup; /* Date of last volume backup */
short DrVSeqNum; /* Sequence number of volume within backup set */
unsigned long DrWrCnt; /* Volume write count */
long DrXTClpSiz; /* extent B*-Tree clump size */
long DrCTClpSiz; /* Catalog B*-Tree clump size */
short DrNmRtDirs; /* Number of subdirectories in the root */
long DrFilCnt; /* Total number of files in volume */
long DrDirCnt; /* Total number of directories in volume */
char DrFndrInfo[32]; /* Finder info for volume */
short DrVCSize; /* Volume cache size */
short DrVBMCSize; /* Volume Bitmap cache size */
short DrCtlCSize; /* Size of common volume cache */
/* Information not copied into VCB */
long DrXTFlSize; /* Length of extent B*-Tree (LEOF and PEOF) */
xdr DrXTExtRec; /* First (and only) extent-tree extent record */
long DrCTFlSize; /* Length of catalog B*-Tree (LEOF and PEOF) */
xdr DrCTExtRec; /* First catalog extent record */
char reserved[94]; /* reserved */
char DrUsrInfo[256]; /* User information for volume */
} MDB, *MDBPtr;
#define LenMDB 162 /* length of full MDB */
#define LenMFSMDB 64 /* length of VCB data from MDB (MFS) */
#define LenHFSMDB 66 /* length of additional VCB data from MDB (HFS) */
/*------------------------------------------------------------------------------
Scavenger File Control Block (SFCB) in memory
------------------------------------------------------------------------------*/
typedef struct SFCB {
long FCBFlNm; /* FCB file number. Non-zero marks FCB used */
unsigned char FCBFlags; /* FCB flags */
unsigned char FCBTypByt; /* file type byte */
short FCBSBlk; /* File start block (in alloc size blks) */
long FCBEOF; /* logical length or EOF in bytes */
long FCBPLen; /* Physical file length in bytes */
long FCBCrPs; /* current position within file */
SVCBPtr FCBVPtr; /* Absolute pointer to the corresponding VCB */
Ptr FCBBfAdr; /* file's buffer address */
short FCBFlPos; /* directory block this file is in */
/* FCB Extensions for HFS */
long FCBClmpSize; /* Number of bytes per clump */
SBTCBPtr FCBBTCBPtr; /* pointer to B*-Tree control block for this file */
xdr FCBExtRec; /* First 3 file extents */
long FCBFType; /* file's 4 Finder Type bytes */
long FCBCatPos; /* Catalog hint for use on Close */
long FCBDirID; /* Parent Directory ID */
unsigned char FCBCName[32]; /* CName of open file Str(31) */
} SFCB, *SFCBPtr;
#define LenSFCB 94 /* length of a SFCB */
/* FCB flag definitions (contents of FCBFlags) */
#define FCBModBit 128 /* dirty bit for FCB entry */
#define FCBRscBit 2 /* 1 if this is resource fork */
/*------------------------------------------------------------------------------
Low-level File System Error codes
------------------------------------------------------------------------------*/
/* Cache errors */
#define ChNoBuf 1 /* no free cache buffers (all in use) */
#define ChInUse 2 /* requested block in use */
#define Chnotfound 3 /* requested block not found */
#define ChNotInUse 4 /* block being released was not in use */
/* FXM Internal error codes */
#define FXRangeErr 16 /* file position beyond mapped range */
#define FXOvFlErr 17 /* extents file overflow */
/* BTree error codes */
#define BTnotfound 32 /* record not found */
#define BTexists 33 /* record already exists */
#define BTnospace 34 /* no available space */
#define BTnoFit 35 /* record doesn't fit in node */
#define BTbadNode 36 /* bad node detected */
#define BTbadHdr 37 /* bad BTree header record detected */
#define dsBadRotate 64 /* bad BTree rotate */
/* CM error codes */
#define CMnotfound 48 /* CNode not found */
#define CMexists 49 /* CNode already exists */
#define CMnotempty 50 /* directory CNode not empty (valence = 0) */
#define CMRootCN 51 /* invalid reference to root CNode */
#define CMbadnews 52 /* detected bad catalog structure */