2 * Copyright (c) 2000-2002 Apple Computer, Inc. All rights reserved.
4 * @APPLE_LICENSE_HEADER_START@
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.
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
20 * @APPLE_LICENSE_HEADER_END@
25 Contains: IPI for File Manager (HFS Plus)
29 Copyright: © 1996-2001 by Apple Computer, Inc., all rights reserved.
32 #ifndef __FILEMGRINTERNAL__
33 #define __FILEMGRINTERNAL__
35 #include <sys/appleapiopts.h>
38 #ifdef __APPLE_API_PRIVATE
40 #include <sys/param.h>
41 #include <sys/vnode.h>
43 #include "../../hfs.h"
44 #include "../../hfs_macos_defs.h"
45 #include "../../hfs_format.h"
46 #include "../../hfs_cnode.h"
61 #if PRAGMA_STRUCT_ALIGN
62 #pragma options align=mac68k
63 #elif PRAGMA_STRUCT_PACKPUSH
65 #elif PRAGMA_STRUCT_PACK
69 /* CatalogNodeID is used to track catalog objects */
70 typedef UInt32 HFSCatalogNodeID
;
72 /* internal error codes*/
74 #if TARGET_API_MACOS_X
75 #define ERR_BASE -32767
82 fxRangeErr
= ERR_BASE
+ 16, /* file position beyond mapped range*/
83 fxOvFlErr
= ERR_BASE
+ 17, /* extents file overflow*/
85 uniTooLongErr
= ERR_BASE
+ 24, /* Unicode string too long to convert to Str31*/
86 uniBufferTooSmallErr
= ERR_BASE
+ 25, /* Unicode output buffer too small*/
87 uniNotMappableErr
= ERR_BASE
+ 26, /* Unicode string can't be mapped to given script*/
88 /* BTree Manager errors*/
89 btNotFound
= ERR_BASE
+ 32, /* record not found*/
90 btExists
= ERR_BASE
+ 33, /* record already exists*/
91 btNoSpaceAvail
= ERR_BASE
+ 34, /* no available space*/
92 btNoFit
= ERR_BASE
+ 35, /* record doesn't fit in node */
93 btBadNode
= ERR_BASE
+ 36, /* bad node detected*/
94 btBadHdr
= ERR_BASE
+ 37, /* bad BTree header record detected*/
95 dsBadRotate
= ERR_BASE
+ 64, /* bad BTree rotate*/
96 /* Catalog Manager errors*/
97 cmNotFound
= ERR_BASE
+ 48, /* CNode not found*/
98 cmExists
= ERR_BASE
+ 49, /* CNode already exists*/
99 cmNotEmpty
= ERR_BASE
+ 50, /* directory CNode not empty (valence = 0)*/
100 cmRootCN
= ERR_BASE
+ 51, /* invalid reference to root CNode*/
101 cmBadNews
= ERR_BASE
+ 52, /* detected bad catalog structure*/
102 cmFThdDirErr
= ERR_BASE
+ 53, /* thread belongs to a directory not a file*/
103 cmFThdGone
= ERR_BASE
+ 54, /* file thread doesn't exist*/
104 cmParentNotFound
= ERR_BASE
+ 55, /* CNode for parent ID does not exist*/
105 /* TFS internal errors*/
106 fsDSIntErr
= -127 /* Internal file system error*/
113 kEFAllMask
= 0x01, /* allocate all requested bytes or none */
114 kEFContigMask
= 0x02, /* force contiguous allocation */
115 kEFReserveMask
= 0x04, /* keep block reserve */
116 kEFDeferMask
= 0x08, /* defer file block allocations */
117 kEFNoClumpMask
= 0x10, /* don't round up to clump size */
119 kTFTrunExtBit
= 0, /* truncate to the extent containing new PEOF*/
124 kUndefinedStrLen
= 0, /* Unknown string length */
127 /* FileIDs variables*/
128 kNumExtentsToCache
= 4 /* just guessing for ExchangeFiles*/
132 /* Universal Extent Key */
136 HFSPlusExtentKey hfsPlus
;
138 typedef union ExtentKey ExtentKey
;
139 /* Universal extent descriptor */
141 union ExtentDescriptor
{
142 HFSExtentDescriptor hfs
;
143 HFSPlusExtentDescriptor hfsPlus
;
145 typedef union ExtentDescriptor ExtentDescriptor
;
146 /* Universal extent record */
150 HFSPlusExtentRecord hfsPlus
;
152 typedef union ExtentRecord ExtentRecord
;
153 /* Universal catalog key */
157 HFSPlusCatalogKey hfsPlus
;
159 typedef union CatalogKey CatalogKey
;
160 /* Universal catalog data record */
162 union CatalogRecord
{
164 HFSCatalogFolder hfsFolder
;
165 HFSCatalogFile hfsFile
;
166 HFSCatalogThread hfsThread
;
167 HFSPlusCatalogFolder hfsPlusFolder
;
168 HFSPlusCatalogFile hfsPlusFile
;
169 HFSPlusCatalogThread hfsPlusThread
;
171 typedef union CatalogRecord CatalogRecord
;
175 CMMaxCName
= kHFSMaxFileNameChars
180 /* Universal catalog name*/
186 typedef union CatalogName CatalogName
;
190 * MacOS accessor routines
192 #define GetFileControlBlock(fref) VTOF((fref))
193 #define GetFileRefNumFromFCB(fcb) FTOV((fcb))
196 /* The following macro marks a VCB as dirty by setting the upper 8 bits of the flags*/
198 MarkVCBDirty (ExtendedVCB
*vcb
);
201 MarkVCBClean (ExtendedVCB
*vcb
);
203 EXTERN_API_C( Boolean
)
204 IsVCBDirty (ExtendedVCB
*vcb
);
207 #define VCB_LOCK_INIT(vcb) simple_lock_init(&vcb->vcbSimpleLock)
208 #define VCB_LOCK(vcb) simple_lock(&vcb->vcbSimpleLock)
209 #define VCB_UNLOCK(vcb) simple_unlock(&vcb->vcbSimpleLock)
211 #define MarkVCBDirty(vcb) { ((vcb)->vcbFlags |= 0xFF00); }
212 #define MarkVCBClean(vcb) { ((vcb)->vcbFlags &= 0x00FF); }
213 #define IsVCBDirty(vcb) ((Boolean) ((vcb->vcbFlags & 0xFF00) != 0))
216 /* Test for error and return if error occurred*/
218 ReturnIfError (OSErr result
);
220 #define ReturnIfError(result) if ( (result) != noErr ) return (result); else ;
221 /* Test for passed condition and return if true*/
223 ReturnErrorIf (Boolean condition
,
226 #define ReturnErrorIf(condition, error) if ( (condition) ) return( (error) );
227 /* Exit function on error*/
229 ExitOnError (OSErr result
);
231 #define ExitOnError( result ) if ( ( result ) != noErr ) goto ErrorExit; else ;
235 /* Catalog Manager Routines (IPI)*/
237 EXTERN_API_C( OSErr
)
238 ExchangeFileIDs (ExtendedVCB
* volume
,
239 ConstUTF8Param srcName
,
240 ConstUTF8Param destName
,
241 HFSCatalogNodeID srcID
,
242 HFSCatalogNodeID destID
,
246 EXTERN_API_C( SInt32
)
247 CompareCatalogKeys (HFSCatalogKey
* searchKey
,
248 HFSCatalogKey
* trialKey
);
250 EXTERN_API_C( SInt32
)
251 CompareExtendedCatalogKeys (HFSPlusCatalogKey
* searchKey
,
252 HFSPlusCatalogKey
* trialKey
);
254 EXTERN_API_C( OSErr
)
255 InitCatalogCache (void);
258 InvalidateCatalogCache (ExtendedVCB
* volume
);
262 /* BTree Manager Routines*/
264 typedef CALLBACK_API_C( SInt32
, KeyCompareProcPtr
)(void *a
, void *b
);
267 EXTERN_API_C( OSErr
)
268 SearchBTreeRecord (FileReference refNum
,
276 EXTERN_API_C( OSErr
)
277 ReplaceBTreeRecord (FileReference refNum
,
285 /* Prototypes for exported routines in VolumeAllocation.c*/
286 EXTERN_API_C( OSErr
)
287 BlockAllocate (ExtendedVCB
* vcb
,
288 UInt32 startingBlock
,
289 SInt64 bytesRequested
,
291 Boolean forceContiguous
,
293 UInt32
* actualBlocks
);
295 EXTERN_API_C( OSErr
)
296 BlockDeallocate (ExtendedVCB
* vcb
,
300 EXTERN_API_C( UInt32
)
301 FileBytesToBlocks (SInt64 numerator
,
304 /* File Extent Mapping routines*/
305 EXTERN_API_C( OSErr
)
306 FlushExtentFile (ExtendedVCB
* vcb
);
308 EXTERN_API_C( SInt32
)
309 CompareExtentKeys (const HFSExtentKey
* searchKey
,
310 const HFSExtentKey
* trialKey
);
312 EXTERN_API_C( SInt32
)
313 CompareExtentKeysPlus (const HFSPlusExtentKey
*searchKey
,
314 const HFSPlusExtentKey
*trialKey
);
316 EXTERN_API_C( OSErr
)
317 TruncateFileC (ExtendedVCB
* vcb
,
320 Boolean truncateToExtent
);
322 EXTERN_API_C( OSErr
)
323 ExtendFileC (ExtendedVCB
* vcb
,
328 SInt64
* actualBytesAdded
);
330 EXTERN_API_C( OSErr
)
331 MapFileBlockC (ExtendedVCB
* vcb
,
333 size_t numberOfBytes
,
335 daddr_t
* startBlock
,
336 size_t * availableBytes
);
338 #if TARGET_API_MACOS_X
339 EXTERN_API_C( Boolean
)
340 NodesAreContiguous (ExtendedVCB
* vcb
,
345 /* Utility routines*/
347 EXTERN_API_C( OSErr
)
348 VolumeWritable (ExtendedVCB
* vcb
);
351 /* Get the current time in UTC (GMT)*/
352 EXTERN_API_C( UInt32
)
355 EXTERN_API_C( UInt32
)
356 LocalToUTC (UInt32 localTime
);
358 EXTERN_API_C( UInt32
)
359 UTCToLocal (UInt32 utcTime
);
362 #if PRAGMA_STRUCT_ALIGN
363 #pragma options align=reset
364 #elif PRAGMA_STRUCT_PACKPUSH
366 #elif PRAGMA_STRUCT_PACK
370 #ifdef PRAGMA_IMPORT_OFF
380 #endif /* __APPLE_API_PRIVATE */
382 #endif /* __FILEMGRINTERNAL__ */