]> git.saurik.com Git - apple/xnu.git/blobdiff - bsd/hfs/hfs_format.h
xnu-2782.40.9.tar.gz
[apple/xnu.git] / bsd / hfs / hfs_format.h
index 151cadde7d23c4bb6c2cf51eaea7adc49ced806b..ba00a272a2f52e8b68bb541ba288e3666b9497a7 100644 (file)
@@ -1,5 +1,5 @@
 /*
 /*
- * Copyright (c) 2000-2009 Apple Inc. All rights reserved.
+ * Copyright (c) 2000-2013 Apple Inc. All rights reserved.
  *
  * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
  * 
  *
  * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
  * 
 
 #include <sys/types.h>
 #include <sys/appleapiopts.h>
 
 #include <sys/types.h>
 #include <sys/appleapiopts.h>
+#include <hfs/hfs_unistr.h>
 
 /*
 
 /*
- * hfs_format.c
+ * hfs_format.h
  *
  * This file describes the on-disk format for HFS and HFS Plus volumes.
  * The HFS Plus volume format is desciibed in detail in Apple Technote 1150.
  *
  * http://developer.apple.com/technotes/tn/tn1150.html
  *
  *
  * This file describes the on-disk format for HFS and HFS Plus volumes.
  * The HFS Plus volume format is desciibed in detail in Apple Technote 1150.
  *
  * http://developer.apple.com/technotes/tn/tn1150.html
  *
+ * Note: Starting 10.9, definition of struct HFSUniStr255 exists in hfs_unitstr.h
+ *
  */
 
 #ifdef __cplusplus
  */
 
 #ifdef __cplusplus
@@ -132,17 +135,6 @@ enum {
 };
 
 
 };
 
 
-#ifndef _HFSUNISTR255_DEFINED_
-#define _HFSUNISTR255_DEFINED_
-/* Unicode strings are used for HFS Plus file and folder names */
-struct HFSUniStr255 {
-       u_int16_t       length;         /* number of unicode characters */
-       u_int16_t       unicode[255];   /* unicode characters */
-} __attribute__((aligned(2), packed));
-typedef struct HFSUniStr255 HFSUniStr255;
-typedef const HFSUniStr255 *ConstHFSUniStr255Param;
-#endif /* _HFSUNISTR255_DEFINED_ */
-
 enum {
        kHFSMaxVolumeNameChars          = 27,
        kHFSMaxFileNameChars            = 31,
 enum {
        kHFSMaxVolumeNameChars          = 27,
        kHFSMaxFileNameChars            = 31,
@@ -232,6 +224,21 @@ struct FndrOpaqueInfo {
 } __attribute__((aligned(2), packed));
 typedef struct FndrOpaqueInfo FndrOpaqueInfo;
 
 } __attribute__((aligned(2), packed));
 typedef struct FndrOpaqueInfo FndrOpaqueInfo;
 
+struct FndrExtendedDirInfo {
+       u_int32_t document_id;
+       u_int32_t date_added;
+       u_int16_t extended_flags;
+       u_int16_t reserved3;
+       u_int32_t write_gen_counter;
+} __attribute__((aligned(2), packed));
+
+struct FndrExtendedFileInfo {
+       u_int32_t document_id;
+       u_int32_t date_added;
+       u_int16_t extended_flags;
+       u_int16_t reserved2;
+       u_int32_t write_gen_counter;
+} __attribute__((aligned(2), packed));
 
 /* HFS Plus Fork data info - 80 bytes */
 struct HFSPlusForkData {
 
 /* HFS Plus Fork data info - 80 bytes */
 struct HFSPlusForkData {
@@ -354,7 +361,10 @@ enum {
        kHFSHasLinkChainMask    = 0x0020,
 
        kHFSHasChildLinkBit     = 0x0006,       /* folder has a child that's a dir link */
        kHFSHasLinkChainMask    = 0x0020,
 
        kHFSHasChildLinkBit     = 0x0006,       /* folder has a child that's a dir link */
-       kHFSHasChildLinkMask    = 0x0040
+       kHFSHasChildLinkMask    = 0x0040,
+
+       kHFSHasDateAddedBit = 0x0007,   /* File/Folder has the date-added stored in the finder info. */
+       kHFSHasDateAddedMask = 0x0080 
 };
 
 
 };
 
 
@@ -459,9 +469,9 @@ typedef struct HFSPlusCatalogThread HFSPlusCatalogThread;
 
 #ifdef __APPLE_API_UNSTABLE
 /*
 
 #ifdef __APPLE_API_UNSTABLE
 /*
      These are the types of records in the attribute B-tree.  The values were
      chosen so that they wouldn't conflict with the catalog record types.
-*/
*     These are the types of records in the attribute B-tree.  The values were
*     chosen so that they wouldn't conflict with the catalog record types.
+ */
 enum {
        kHFSPlusAttrInlineData  = 0x10,   /* attributes whose data fits in a b-tree node */
        kHFSPlusAttrForkData    = 0x20,   /* extent based attributes (data lives in extents) */
 enum {
        kHFSPlusAttrInlineData  = 0x10,   /* attributes whose data fits in a b-tree node */
        kHFSPlusAttrForkData    = 0x20,   /* extent based attributes (data lives in extents) */
@@ -470,11 +480,11 @@ enum {
 
 
 /*
 
 
 /*
      HFSPlusAttrForkData
      For larger attributes, whose value is stored in allocation blocks.
      If the attribute has more than 8 extents, there will be additional
      records (of type HFSPlusAttrExtents) for this attribute.
-*/
*     HFSPlusAttrForkData
*     For larger attributes, whose value is stored in allocation blocks.
*     If the attribute has more than 8 extents, there will be additional
*     records (of type HFSPlusAttrExtents) for this attribute.
+ */
 struct HFSPlusAttrForkData {
        u_int32_t       recordType;             /* == kHFSPlusAttrForkData*/
        u_int32_t       reserved;
 struct HFSPlusAttrForkData {
        u_int32_t       recordType;             /* == kHFSPlusAttrForkData*/
        u_int32_t       reserved;
@@ -483,10 +493,10 @@ struct HFSPlusAttrForkData {
 typedef struct HFSPlusAttrForkData HFSPlusAttrForkData;
 
 /*
 typedef struct HFSPlusAttrForkData HFSPlusAttrForkData;
 
 /*
      HFSPlusAttrExtents
      This record contains information about overflow extents for large,
      fragmented attributes.
-*/
*     HFSPlusAttrExtents
*     This record contains information about overflow extents for large,
*     fragmented attributes.
+ */
 struct HFSPlusAttrExtents {
        u_int32_t               recordType;     /* == kHFSPlusAttrExtents*/
        u_int32_t               reserved;
 struct HFSPlusAttrExtents {
        u_int32_t               recordType;     /* == kHFSPlusAttrExtents*/
        u_int32_t               reserved;
@@ -519,7 +529,7 @@ struct HFSPlusAttrInlineData {
 typedef struct HFSPlusAttrInlineData HFSPlusAttrInlineData;
 
 
 typedef struct HFSPlusAttrInlineData HFSPlusAttrInlineData;
 
 
-/*     A generic Attribute Record*/
+/* A generic Attribute Record */
 union HFSPlusAttrRecord {
        u_int32_t               recordType;
        HFSPlusAttrInlineData   inlineData;   /* NOT USED */
 union HFSPlusAttrRecord {
        u_int32_t               recordType;
        HFSPlusAttrInlineData   inlineData;   /* NOT USED */
@@ -577,18 +587,25 @@ enum {
         * Therefore, bits 16-31 can only be used on HFS Plus.
         */
        kHFSUnusedNodeFixBit = 31,                              /* Unused nodes in the Catalog B-tree have been zero-filled.  See Radar #6947811. */
         * Therefore, bits 16-31 can only be used on HFS Plus.
         */
        kHFSUnusedNodeFixBit = 31,                              /* Unused nodes in the Catalog B-tree have been zero-filled.  See Radar #6947811. */
+       kHFSContentProtectionBit = 30,                  /* Volume has per-file content protection */
+
+       /***  Keep these in sync with the bits above ! ****/
+       kHFSVolumeHardwareLockMask              = 0x00000080,
+       kHFSVolumeUnmountedMask                 = 0x00000100,
+       kHFSVolumeSparedBlocksMask              = 0x00000200,
+       kHFSVolumeNoCacheRequiredMask   = 0x00000400,
+       kHFSBootVolumeInconsistentMask  = 0x00000800,
+       kHFSCatalogNodeIDsReusedMask    = 0x00001000,
+       kHFSVolumeJournaledMask                 = 0x00002000,
+       kHFSVolumeInconsistentMask              = 0x00004000,
+       kHFSVolumeSoftwareLockMask              = 0x00008000,
+       
+       /* Bits 16-31 are allocated from high to low */
+
+       kHFSContentProtectionMask               = 0x40000000,
+       kHFSUnusedNodeFixMask                   = 0x80000000,
        
        
-       kHFSVolumeHardwareLockMask      = 1 << kHFSVolumeHardwareLockBit,
-       kHFSVolumeUnmountedMask         = 1 << kHFSVolumeUnmountedBit,
-       kHFSVolumeSparedBlocksMask      = 1 << kHFSVolumeSparedBlocksBit,
-       kHFSVolumeNoCacheRequiredMask = 1 << kHFSVolumeNoCacheRequiredBit,
-       kHFSBootVolumeInconsistentMask = 1 << kHFSBootVolumeInconsistentBit,
-       kHFSCatalogNodeIDsReusedMask = 1 << kHFSCatalogNodeIDsReusedBit,
-       kHFSVolumeJournaledMask = 1 << kHFSVolumeJournaledBit,
-       kHFSVolumeInconsistentMask = 1 << kHFSVolumeInconsistentBit,
-       kHFSVolumeSoftwareLockMask      = 1 << kHFSVolumeSoftwareLockBit,
-       kHFSUnusedNodeFixMask = 1 << kHFSUnusedNodeFixBit,
-       kHFSMDBAttributesMask           = 0x8380
+       kHFSMDBAttributesMask                   = 0x8380
 };
 
 enum {
 };
 
 enum {