Annotation of XNU/bsd/hfs/hfscommon/headers/BTreesInternal.h, revision 1.1

1.1     ! root        1: /*
        !             2:  * Copyright (c) 2000 Apple Computer, Inc. All rights reserved.
        !             3:  *
        !             4:  * @APPLE_LICENSE_HEADER_START@
        !             5:  * 
        !             6:  * The contents of this file constitute Original Code as defined in and
        !             7:  * are subject to the Apple Public Source License Version 1.1 (the
        !             8:  * "License").  You may not use this file except in compliance with the
        !             9:  * License.  Please obtain a copy of the License at
        !            10:  * http://www.apple.com/publicsource and read it before using this file.
        !            11:  * 
        !            12:  * This Original Code and all software distributed under the License are
        !            13:  * distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER
        !            14:  * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
        !            15:  * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
        !            16:  * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT.  Please see the
        !            17:  * License for the specific language governing rights and limitations
        !            18:  * under the License.
        !            19:  * 
        !            20:  * @APPLE_LICENSE_HEADER_END@
        !            21:  */
        !            22: /*
        !            23:        File:           BTreesInternal.h
        !            24: 
        !            25:        Contains:       IPI to File Manager B-tree
        !            26: 
        !            27:        Version:        HFS Plus 1.0
        !            28: 
        !            29:        Copyright:      � 1996-1998 by Apple Computer, Inc., all rights reserved.
        !            30: 
        !            31:        File Ownership:
        !            32: 
        !            33:                DRI:                            Don Brady
        !            34: 
        !            35:                Other Contact:          Mark Day
        !            36: 
        !            37:                Technology:                     File Systems
        !            38: 
        !            39:        Writers:
        !            40: 
        !            41:                (msd)   Mark Day
        !            42:                (DSH)   Deric Horn
        !            43:                (djb)   Don Brady
        !            44: 
        !            45:        Change History (most recent first):
        !            46:        
        !            47:          <RHAP>         9/22/99        ser             Added prototypes for BTGetLastSync and BTSetLastSync
        !            48:          <RHAP>         6/22/98        djb             Add ERR_BASE to btree error codes to make them negative (for MacOS X only).
        !            49: 
        !            50:           <CS7>         7/28/97        msd             Add enum for fsBTTimeOutErr.
        !            51:           <CS6>         7/25/97        DSH             Added heuristicHint as parameter to BTSearchRecord.
        !            52:           <CS5>         7/24/97        djb             Add blockReadFromDisk flag to BlockDescriptor. Callbacks now use
        !            53:                                                                        a file refNum instead of an FCB.
        !            54:           <CS4>         7/16/97        DSH             FilesInternal.i renamed FileMgrInternal.i to avoid name
        !            55:                                                                        collision
        !            56:           <CS3>          6/2/97        DSH             Added SetEndOfForkProc() prototype, so Attributes.c can call it
        !            57:                                                                        directly.
        !            58:           <CS2>         5/19/97        djb             kMaxKeyLength is now 520.
        !            59:           <CS1>         4/28/97        djb             first checked in
        !            60: 
        !            61:          <HFS6>         3/17/97        DSH             Remove Key Comparison prototype, already in FilesInternal.h.
        !            62:          <HFS5>         2/19/97        djb             Add SetBlockSizeProcPtr. Add blockSize field to BlockDescriptor.
        !            63:                                                                        Remove E_ type error enums.
        !            64:          <HFS4>         1/27/97        djb             Include Types.h and FilesInternal.h.
        !            65:          <HFS3>         1/13/97        djb             Added kBTreeCurrentRecord for BTIterateRecord.
        !            66:          <HFS2>          1/3/97        djb             Added support for large keys.
        !            67:          <HFS1>        12/19/96        djb             first checked in
        !            68: 
        !            69: */
        !            70: 
        !            71: #ifndef        __BTREESINTERNAL__
        !            72: #define __BTREESINTERNAL__
        !            73: 
        !            74: #ifndef __FILEMGRINTERNAL__
        !            75: #include "FileMgrInternal.h"
        !            76: #endif
        !            77: 
        !            78: enum {
        !            79:        fsBTInvalidHeaderErr                    = btBadHdr,
        !            80:        fsBTBadRotateErr                                = dsBadRotate,
        !            81:        fsBTInvalidNodeErr                              = btBadNode,
        !            82:        fsBTRecordTooLargeErr                   = btNoFit,
        !            83:        fsBTRecordNotFoundErr                   = btNotFound,
        !            84:        fsBTDuplicateRecordErr                  = btExists,
        !            85:        fsBTFullErr                                             = btNoSpaceAvail,
        !            86: 
        !            87:        fsBTInvalidFileErr                              = ERR_BASE + 0x0302,    /* no BTreeCB has been allocated for fork*/
        !            88:        fsBTrFileAlreadyOpenErr                 = ERR_BASE + 0x0303,
        !            89:        fsBTInvalidIteratorErr                  = ERR_BASE + 0x0308,
        !            90:        fsBTEmptyErr                                    = ERR_BASE + 0x030A,
        !            91:        fsBTNoMoreMapNodesErr                   = ERR_BASE + 0x030B,
        !            92:        fsBTBadNodeSize                                 = ERR_BASE + 0x030C,
        !            93:        fsBTBadNodeType                                 = ERR_BASE + 0x030D,
        !            94:        fsBTInvalidKeyLengthErr                 = ERR_BASE + 0x030E,
        !            95:        fsBTStartOfIterationErr                 = ERR_BASE + 0x0353,
        !            96:        fsBTEndOfIterationErr                   = ERR_BASE + 0x0354,
        !            97:        fsBTUnknownVersionErr                   = ERR_BASE + 0x0355,
        !            98:        fsBTTreeTooDeepErr                              = ERR_BASE + 0x0357,
        !            99:        fsIteratorExitedScopeErr                = ERR_BASE + 0x0A02,    /* iterator exited the scope*/
        !           100:        fsIteratorScopeExceptionErr             = ERR_BASE + 0x0A03,    /* iterator is undefined due to error or movement of scope locality*/
        !           101:        fsUnknownIteratorMovementErr    = ERR_BASE + 0x0A04,    /* iterator movement is not defined*/
        !           102:        fsInvalidIterationMovmentErr    = ERR_BASE + 0x0A05,    /* iterator movement is invalid in current context*/
        !           103:        fsClientIDMismatchErr                   = ERR_BASE + 0x0A06,    /* wrong client process ID*/
        !           104:        fsEndOfIterationErr                             = ERR_BASE + 0x0A07,    /* there were no objects left to return on iteration*/
        !           105:        fsBTTimeOutErr                                  = ERR_BASE + 0x0A08             /* BTree scan interrupted -- no time left for physical I/O */
        !           106: };
        !           107: 
        !           108: struct BlockDescriptor{
        !           109:        void            *buffer;
        !           110:        void            *blockHeader;
        !           111:        ByteCount        blockSize;
        !           112:        Boolean          blockReadFromDisk;
        !           113:        Byte             reserved[3];
        !           114: };
        !           115: typedef struct BlockDescriptor BlockDescriptor;
        !           116: typedef BlockDescriptor *BlockDescPtr;
        !           117: 
        !           118: 
        !           119: struct FSBufferDescriptor {
        !           120:        LogicalAddress                                  bufferAddress;
        !           121:        ByteCount                                               itemSize;
        !           122:        ItemCount                                               itemCount;
        !           123: };
        !           124: typedef struct FSBufferDescriptor FSBufferDescriptor;
        !           125: 
        !           126: typedef FSBufferDescriptor *FSBufferDescriptorPtr;
        !           127: 
        !           128: 
        !           129: /*
        !           130:        Fork Level Access Method Block get options
        !           131: */
        !           132: enum {
        !           133:                kGetBlock                       = 0x00000000,
        !           134:                kForceReadBlock         = 0x00000002,   //�� how does this relate to Read/Verify? Do we need this?
        !           135:                kGetEmptyBlock          = 0x00000008
        !           136: };
        !           137: typedef OptionBits     GetBlockOptions;
        !           138: 
        !           139: /*
        !           140:        Fork Level Access Method Block release options
        !           141: */
        !           142: enum {
        !           143:                kReleaseBlock           = 0x00000000,
        !           144:                kForceWriteBlock        = 0x00000001,
        !           145:                kMarkBlockDirty         = 0x00000002,
        !           146:                kTrashBlock                     = 0x00000004,
        !           147:                kLockTransaction    = 0x00000100
        !           148: };
        !           149: typedef OptionBits     ReleaseBlockOptions;
        !           150: 
        !           151: typedef        UInt32  FSSize;
        !           152: typedef        UInt32  ForkBlockNumber;
        !           153: 
        !           154: /*============================================================================
        !           155:        Fork Level Buffered I/O Access Method
        !           156: ============================================================================*/
        !           157: 
        !           158: typedef        OSStatus        (* GetBlockProcPtr)             (FileReference                           fileRefNum,
        !           159:                                                                                         UInt32                                          blockNum,
        !           160:                                                                                         GetBlockOptions                         options,
        !           161:                                                                                         BlockDescriptor                        *block );
        !           162:                                                         
        !           163: 
        !           164: typedef        OSStatus        (* ReleaseBlockProcPtr) (FileReference                           fileRefNum,
        !           165:                                                                                         BlockDescPtr                            blockPtr,
        !           166:                                                                                         ReleaseBlockOptions             options );
        !           167: 
        !           168: typedef        OSStatus        (* SetEndOfForkProcPtr) (FileReference                           fileRefNum,
        !           169:                                                                                         FSSize                                          minEOF,
        !           170:                                                                                         FSSize                                          maxEOF );
        !           171:                                                                 
        !           172: typedef        OSStatus        (* SetBlockSizeProcPtr) (FileReference                           fileRefNum,
        !           173:                                                                                         ByteCount                                       blockSize,
        !           174:                                                                                         ItemCount                                       minBlockCount );
        !           175: 
        !           176: OSStatus               SetEndOfForkProc ( FileReference fileRefNum, FSSize minEOF, FSSize maxEOF );
        !           177: 
        !           178: 
        !           179: /*
        !           180:        B*Tree Information Version
        !           181: */
        !           182: 
        !           183: enum BTreeInformationVersion{
        !           184:        kBTreeInfoVersion       = 0
        !           185: };
        !           186: 
        !           187: /*
        !           188:        B*Tree Iteration Operation Constants
        !           189: */
        !           190: 
        !           191: enum BTreeIterationOperations{
        !           192:        kBTreeFirstRecord,
        !           193:        kBTreeNextRecord,
        !           194:        kBTreePrevRecord,
        !           195:        kBTreeLastRecord,
        !           196:        kBTreeCurrentRecord
        !           197: };
        !           198: typedef UInt16 BTreeIterationOperation;
        !           199: 
        !           200: 
        !           201: /*
        !           202:        Btree types: 0 is HFS CAT/EXT file, 1~127 are AppleShare B*Tree files, 128~254 unused
        !           203:        hfsBtreeType    EQU             0                       ; control file
        !           204:        validBTType             EQU             $80                     ; user btree type starts from 128
        !           205:        userBT1Type             EQU             $FF                     ; 255 is our Btree type. Used by BTInit and BTPatch
        !           206: */
        !           207: 
        !           208: enum BTreeTypes{
        !           209:        kHFSBTreeType                   =   0,          // control file
        !           210:        kUserBTreeType                  = 128,          // user btree type starts from 128
        !           211:        kReservedBTreeType              = 255           //
        !           212: };
        !           213: 
        !           214: 
        !           215: typedef BTreeKey *BTreeKeyPtr;
        !           216: 
        !           217: 
        !           218: /*
        !           219:        BTreeInfoRec Structure - for BTGetInformation
        !           220: */
        !           221: struct BTreeInfoRec{
        !           222:        UInt16                          version;
        !           223:        UInt16                          nodeSize;
        !           224:        UInt16                          maxKeyLength;
        !           225:        UInt16                          treeDepth;
        !           226:        UInt32                          lastfsync;              /* Last time that this was fsynced  */
        !           227:        ItemCount                       numRecords;
        !           228:        ItemCount                       numNodes;
        !           229:        ItemCount                       numFreeNodes;
        !           230:        UInt32                          reserved;
        !           231: };
        !           232: typedef struct BTreeInfoRec BTreeInfoRec;
        !           233: typedef BTreeInfoRec *BTreeInfoPtr;
        !           234: 
        !           235: /*
        !           236:        BTreeHint can never be exported to the outside. Use UInt32 BTreeHint[4],
        !           237:        UInt8 BTreeHint[16], etc.
        !           238:  */
        !           239: struct BTreeHint{
        !           240:        ItemCount                               writeCount;
        !           241:        UInt32                                  nodeNum;                        // node the key was last seen in
        !           242:        UInt16                                  index;                          // index then key was last seen at
        !           243:        UInt16                                  reserved1;
        !           244:        UInt32                                  reserved2;
        !           245: };
        !           246: typedef struct BTreeHint BTreeHint;
        !           247: typedef BTreeHint *BTreeHintPtr;
        !           248: 
        !           249: /*
        !           250:        BTree Iterator
        !           251: */
        !           252: struct BTreeIterator{
        !           253:        BTreeHint                               hint;
        !           254:        UInt16                                  version;
        !           255:        UInt16                                  reserved;
        !           256:        BTreeKey                                key;
        !           257: };
        !           258: typedef struct BTreeIterator BTreeIterator;
        !           259: typedef BTreeIterator *BTreeIteratorPtr;
        !           260: 
        !           261: 
        !           262: /*============================================================================
        !           263:        B*Tree SPI
        !           264: ============================================================================*/
        !           265: 
        !           266: /*
        !           267:        Key Comparison Function ProcPtr Type - for BTOpenPath
        !           268: */
        !           269: //typedef SInt32                               (* KeyCompareProcPtr)(BTreeKeyPtr a, BTreeKeyPtr b);
        !           270: 
        !           271: 
        !           272: typedef SInt32 (* IterateCallBackProcPtr)(BTreeKeyPtr key, void * record, UInt16 recordLen, void * state);
        !           273: 
        !           274: extern OSStatus        BTOpenPath                      (FCB                                            *filePtr,
        !           275:                                                                         KeyCompareProcPtr                       keyCompareProc,
        !           276:                                                                         GetBlockProcPtr                         getBlockProc,
        !           277:                                                                         ReleaseBlockProcPtr             releaseBlockProc,
        !           278:                                                                         SetEndOfForkProcPtr             setEndOfForkProc,
        !           279:                                                                         SetBlockSizeProcPtr             setBlockSizeProc );
        !           280: 
        !           281: extern OSStatus        BTClosePath                     (FCB                                            *filePtr );
        !           282: 
        !           283: 
        !           284: extern OSStatus        BTSearchRecord          (FCB                                            *filePtr,
        !           285:                                                                         BTreeIterator                          *searchIterator,
        !           286:                                                                         UInt32                                         heuristicHint,
        !           287:                                                                         FSBufferDescriptor                     *btRecord,
        !           288:                                                                         UInt16                                         *recordLen,
        !           289:                                                                         BTreeIterator                          *resultIterator );
        !           290: 
        !           291: extern OSStatus        BTIterateRecord         (FCB                                            *filePtr,
        !           292:                                                                         BTreeIterationOperation         operation,
        !           293:                                                                         BTreeIterator                          *iterator,
        !           294:                                                                         FSBufferDescriptor                     *btRecord,
        !           295:                                                                         UInt16                                         *recordLen );
        !           296: 
        !           297: 
        !           298: extern OSStatus BTIterateRecords(FCB *filePtr, BTreeIterationOperation operation, BTreeIterator *iterator,
        !           299:                 IterateCallBackProcPtr  callBackProc, void * callBackState);
        !           300: 
        !           301: extern OSStatus        BTInsertRecord          (FCB                                            *filePtr,
        !           302:                                                                         BTreeIterator                          *iterator,
        !           303:                                                                         FSBufferDescriptor                     *btrecord,
        !           304:                                                                         UInt16                                          recordLen );
        !           305: 
        !           306: extern OSStatus        BTReplaceRecord         (FCB                                            *filePtr,
        !           307:                                                                         BTreeIterator                          *iterator,
        !           308:                                                                         FSBufferDescriptor                     *btRecord,
        !           309:                                                                         UInt16                                          recordLen );
        !           310: 
        !           311: 
        !           312: extern OSStatus        BTDeleteRecord          (FCB                                            *filePtr,
        !           313:                                                                         BTreeIterator                          *iterator );
        !           314: 
        !           315: extern OSStatus        BTGetInformation        (FCB                                            *filePtr,
        !           316:                                                                         UInt16                                          version,
        !           317:                                                                         BTreeInfoRec                           *info );
        !           318: 
        !           319: extern OSStatus        BTFlushPath                     (FCB                                            *filePtr );
        !           320: 
        !           321: extern OSStatus        BTInvalidateHint        (BTreeIterator                          *iterator );
        !           322: 
        !           323: extern OSStatus        BTGetLastSync           (FCB                                            *filePtr,
        !           324:                                                                         UInt32                                         *lastfsync );
        !           325: 
        !           326: extern OSStatus        BTSetLastSync           (FCB                                            *filePtr,
        !           327:                                                                         UInt32                                         lastfsync );
        !           328: 
        !           329: #endif // __BTREESINTERNAL__

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.