]> git.saurik.com Git - apple/xnu.git/blobdiff - bsd/hfs/hfs_catalog.h
xnu-1228.5.20.tar.gz
[apple/xnu.git] / bsd / hfs / hfs_catalog.h
index 208d94df07d3980444612217ca350de6c32ab672..03c36567b894b7f634b196bf7cf7abceb081d4d0 100644 (file)
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2002-2005 Apple Computer, Inc. All rights reserved.
+ * Copyright (c) 2002-2007 Apple Inc. All rights reserved.
  *
  * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
  * 
@@ -57,7 +57,7 @@ struct cat_desc {
        u_int8_t  cd_flags;       /* see below (8 bits) */
        u_int8_t  cd_encoding;    /* name encoding */
        int16_t   cd_namelen;     /* length of cnode name */
-       char *    cd_nameptr;     /* pointer to cnode name */
+       const u_int8_t * cd_nameptr; /* pointer to cnode name */
        cnid_t    cd_parentcnid;  /* parent directory CNID */
        u_long    cd_hint;        /* catalog file hint */
        cnid_t    cd_cnid;        /* cnode id (for getattrlist) */
@@ -76,10 +76,13 @@ struct cat_attr {
        cnid_t          ca_fileid;      /* inode number (for stat) normally == cnid */
        mode_t          ca_mode;        /* file access mode and type (16 bits) */
        u_int16_t       ca_recflags;    /* catalog record flags (16 bit integer) */
-       u_int32_t       ca_nlink;       /* file link count */
+       u_int32_t       ca_linkcount;   /* real hard link count */
        uid_t           ca_uid;         /* file owner */
        gid_t           ca_gid;         /* file group */
-       dev_t           ca_rdev;        /* device a special file represents */
+       union {
+           dev_t       cau_rdev;       /* special file device (VBLK or VCHAR only) */
+           u_int32_t   cau_linkref;    /* hardlink reference number */
+       } ca_union1;
        time_t          ca_atime;       /* last access time */
        time_t          ca_atimeondisk; /* access time value on disk */
        time_t          ca_mtime;       /* last data modification time */
@@ -88,15 +91,23 @@ struct cat_attr {
        time_t          ca_btime;       /* last backup time */
        u_int32_t       ca_flags;       /* status flags (chflags) */
        union {
-               u_int32_t  cau_blocks;  /* total file blocks used (rsrc + data) */
-               u_int32_t  cau_entries; /* total directory entries (valence) */
-       } ca_union;
+           u_int32_t   cau_blocks;     /* total file blocks used (rsrc + data) */
+           u_int32_t   cau_entries;    /* total directory entries (valence) */
+       } ca_union2;
+       union {
+           u_int32_t   cau_dircount;   /* count of sub dirs (for posix nlink) */
+           u_int32_t   cau_firstlink;  /* first hardlink link (files only) */
+       } ca_union3;
        u_int8_t        ca_finderinfo[32]; /* Opaque Finder information */
-       u_int32_t       ca_attrblks;    /* cached count of attribute data blocks */
 };
+
 /* Aliases for common fields */
-#define        ca_blocks       ca_union.cau_blocks
-#define        ca_entries      ca_union.cau_entries
+#define        ca_rdev         ca_union1.cau_rdev      
+#define        ca_linkref      ca_union1.cau_linkref
+#define        ca_blocks       ca_union2.cau_blocks
+#define        ca_entries      ca_union2.cau_entries
+#define        ca_dircount     ca_union3.cau_dircount
+#define        ca_firstlink    ca_union3.cau_firstlink
 
 /*
  * Catalog Node Fork (runtime)
@@ -104,7 +115,7 @@ struct cat_attr {
  * NOTE: this is not the same as a struct HFSPlusForkData
  */
 struct cat_fork {
-       u_int64_t      cf_size;        /* fork's logical size in bytes */
+       off_t          cf_size;        /* fork's logical size in bytes */
        union {
            u_int32_t  cfu_clump;      /* fork's clump size in bytes (sys files only) */
            u_int64_t  cfu_bytesread;  /* bytes read from this fork */
@@ -126,6 +137,7 @@ struct cat_fork {
 struct directoryhint {
        TAILQ_ENTRY(directoryhint) dh_link; /* chain */
        int     dh_index;                   /* index into directory (zero relative) */
+       u_int32_t  dh_threadhint;           /* node hint of a directory's thread record */
        u_int32_t  dh_time;
        struct  cat_desc  dh_desc;          /* entry's descriptor */
 };
@@ -159,18 +171,33 @@ struct cat_entry {
        u_long          ce_rsrcblks;
 };
 
-#define MAXCATENTRIES 8
+/*
+ * Starting in 10.5, hfs_vnop_readdirattr() only makes one
+ * call to cat_getentriesattr(). So we increased MAXCATENTRIES
+ * while keeping the total size of the CE LIST buffer <= 8K
+ * (which works out to be 60 entries per call).  The 8K limit
+ * keeps the memory coming from a kalloc zone instead of
+ * valuable/fragment-able kernel map space.
+ */
+#define MAXCATENTRIES  \
+       (1 + (8192 - sizeof (struct cat_entrylist)) / sizeof (struct cat_entry))
+
 /*
  * Catalog Node Entry List
  *
  * A cat_entrylist is a list of Catalog Node Entries.
  */
 struct cat_entrylist {
-       u_long  maxentries;    /* length of list */
-       u_long  realentries;   /* valid entry count */
-       struct cat_entry  entry[MAXCATENTRIES];   /* array of entries */
+       u_long  maxentries;    /* number of entries requested */
+       u_long  realentries;   /* number of valid entries returned */
+       u_long  skipentries;   /* number of entries skipped (reserved HFS+ files) */
+       struct cat_entry  entry[1];   /* array of entries */
 };
 
+#define CE_LIST_SIZE(entries)  \
+       sizeof (*ce_list) + (((entries) - 1) * sizeof (struct cat_entry))
+
+
 /*
  * Catalog Operations Hint
  *
@@ -178,10 +205,10 @@ struct cat_entrylist {
  * upper 16 bits: count of B-tree delete operations
  *
  */
-#define CAT_DELETE     0x00020000
+#define CAT_DELETE     0x00010000
 #define CAT_CREATE     0x00000002
-#define CAT_RENAME     0x00020002
-#define CAT_EXCHANGE   0x00020002
+#define CAT_RENAME     0x00010002
+#define CAT_EXCHANGE   0x00010002
 
 typedef u_int32_t      catops_t;
 
@@ -244,6 +271,7 @@ extern int cat_lookup (     struct hfsmount *hfsmp,
 
 extern int cat_idlookup (struct hfsmount *hfsmp,
                        cnid_t cnid,
+                       int allow_system_files,
                        struct cat_desc *outdescp,
                        struct cat_attr *attrp,
                        struct cat_fork *forkp);
@@ -318,17 +346,62 @@ extern int cat_convertkey(
                        CatalogRecord * recp,
                        struct cat_desc *descp);
 
-extern int resolvelink(
-                       struct hfsmount *hfsmp,
-                       u_long linkref,
-                       struct HFSPlusCatalogFile *recp);
-
 extern int cat_getkeyplusattr(
                        struct hfsmount *hfsmp, 
                        cnid_t cnid, 
                        CatalogKey *key, 
                        struct cat_attr *attrp);
 
+/* Hard link functions. */
+
+extern int cat_check_link_ancestry(
+                       struct hfsmount *hfsmp,
+                       cnid_t parentid, 
+                       cnid_t pointed_at_cnid);
+
+extern int cat_set_childlinkbit(
+                       struct hfsmount *hfsmp, 
+                       cnid_t cnid);
+
+#define HFS_IGNORABLE_LINK  0x00000001
+
+extern int cat_resolvelink( struct hfsmount *hfsmp,
+                            u_long linkref,
+                            int isdirlink,
+                            struct HFSPlusCatalogFile *recp);
+
+extern int cat_createlink( struct hfsmount *hfsmp,
+                           struct cat_desc *descp,
+                           struct cat_attr *attr,
+                           cnid_t nextlinkid,
+                           cnid_t *linkfileid);
+
+/* Finder Info's file type and creator for directory hard link alias */
+enum {
+       kHFSAliasType    = 0x66647270,  /* 'fdrp' */
+       kHFSAliasCreator = 0x4D414353   /* 'MACS' */
+};
+
+extern int cat_deletelink( struct hfsmount *hfsmp,
+                           struct cat_desc *descp);
+
+extern int cat_updatelink( struct hfsmount *hfsmp,
+                           cnid_t linkfileid,
+                           cnid_t prevlinkid,
+                           cnid_t nextlinkid);
+
+extern int cat_lookuplink( struct hfsmount *hfsmp,
+                           struct cat_desc *descp,
+                           cnid_t *linkfileid,
+                           cnid_t *prevlinkid,
+                           cnid_t *nextlinkid);
+
+extern int cat_lookuplinkbyid( struct hfsmount *hfsmp,
+                               cnid_t linkfileid,
+                               cnid_t *prevlinkid,
+                               cnid_t *nextlinkid);
+
+
 #endif /* __APPLE_API_PRIVATE */
 #endif /* KERNEL */
 #endif /* __HFS_CATALOG__ */