1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0 */ 2*4882a593Smuzhiyun /* 3*4882a593Smuzhiyun * linux/include/linux/hfsplus_raw.h 4*4882a593Smuzhiyun * 5*4882a593Smuzhiyun * Copyright (C) 1999 6*4882a593Smuzhiyun * Brad Boyer (flar@pants.nu) 7*4882a593Smuzhiyun * (C) 2003 Ardis Technologies <roman@ardistech.com> 8*4882a593Smuzhiyun * 9*4882a593Smuzhiyun * Format of structures on disk 10*4882a593Smuzhiyun * Information taken from Apple Technote #1150 (HFS Plus Volume Format) 11*4882a593Smuzhiyun * 12*4882a593Smuzhiyun */ 13*4882a593Smuzhiyun 14*4882a593Smuzhiyun #ifndef _LINUX_HFSPLUS_RAW_H 15*4882a593Smuzhiyun #define _LINUX_HFSPLUS_RAW_H 16*4882a593Smuzhiyun 17*4882a593Smuzhiyun #include <linux/types.h> 18*4882a593Smuzhiyun 19*4882a593Smuzhiyun /* Some constants */ 20*4882a593Smuzhiyun #define HFSPLUS_SECTOR_SIZE 512 21*4882a593Smuzhiyun #define HFSPLUS_SECTOR_SHIFT 9 22*4882a593Smuzhiyun #define HFSPLUS_VOLHEAD_SECTOR 2 23*4882a593Smuzhiyun #define HFSPLUS_VOLHEAD_SIG 0x482b 24*4882a593Smuzhiyun #define HFSPLUS_VOLHEAD_SIGX 0x4858 25*4882a593Smuzhiyun #define HFSPLUS_SUPER_MAGIC 0x482b 26*4882a593Smuzhiyun #define HFSPLUS_MIN_VERSION 4 27*4882a593Smuzhiyun #define HFSPLUS_CURRENT_VERSION 5 28*4882a593Smuzhiyun 29*4882a593Smuzhiyun #define HFSP_WRAP_MAGIC 0x4244 30*4882a593Smuzhiyun #define HFSP_WRAP_ATTRIB_SLOCK 0x8000 31*4882a593Smuzhiyun #define HFSP_WRAP_ATTRIB_SPARED 0x0200 32*4882a593Smuzhiyun 33*4882a593Smuzhiyun #define HFSP_WRAPOFF_SIG 0x00 34*4882a593Smuzhiyun #define HFSP_WRAPOFF_ATTRIB 0x0A 35*4882a593Smuzhiyun #define HFSP_WRAPOFF_ABLKSIZE 0x14 36*4882a593Smuzhiyun #define HFSP_WRAPOFF_ABLKSTART 0x1C 37*4882a593Smuzhiyun #define HFSP_WRAPOFF_EMBEDSIG 0x7C 38*4882a593Smuzhiyun #define HFSP_WRAPOFF_EMBEDEXT 0x7E 39*4882a593Smuzhiyun 40*4882a593Smuzhiyun #define HFSP_HIDDENDIR_NAME \ 41*4882a593Smuzhiyun "\xe2\x90\x80\xe2\x90\x80\xe2\x90\x80\xe2\x90\x80HFS+ Private Data" 42*4882a593Smuzhiyun 43*4882a593Smuzhiyun #define HFSP_HARDLINK_TYPE 0x686c6e6b /* 'hlnk' */ 44*4882a593Smuzhiyun #define HFSP_HFSPLUS_CREATOR 0x6866732b /* 'hfs+' */ 45*4882a593Smuzhiyun 46*4882a593Smuzhiyun #define HFSP_SYMLINK_TYPE 0x736c6e6b /* 'slnk' */ 47*4882a593Smuzhiyun #define HFSP_SYMLINK_CREATOR 0x72686170 /* 'rhap' */ 48*4882a593Smuzhiyun 49*4882a593Smuzhiyun #define HFSP_MOUNT_VERSION 0x482b4c78 /* 'H+Lx' */ 50*4882a593Smuzhiyun 51*4882a593Smuzhiyun /* Structures used on disk */ 52*4882a593Smuzhiyun 53*4882a593Smuzhiyun typedef __be32 hfsplus_cnid; 54*4882a593Smuzhiyun typedef __be16 hfsplus_unichr; 55*4882a593Smuzhiyun 56*4882a593Smuzhiyun #define HFSPLUS_MAX_STRLEN 255 57*4882a593Smuzhiyun #define HFSPLUS_ATTR_MAX_STRLEN 127 58*4882a593Smuzhiyun 59*4882a593Smuzhiyun /* A "string" as used in filenames, etc. */ 60*4882a593Smuzhiyun struct hfsplus_unistr { 61*4882a593Smuzhiyun __be16 length; 62*4882a593Smuzhiyun hfsplus_unichr unicode[HFSPLUS_MAX_STRLEN]; 63*4882a593Smuzhiyun } __packed; 64*4882a593Smuzhiyun 65*4882a593Smuzhiyun /* 66*4882a593Smuzhiyun * A "string" is used in attributes file 67*4882a593Smuzhiyun * for name of extended attribute 68*4882a593Smuzhiyun */ 69*4882a593Smuzhiyun struct hfsplus_attr_unistr { 70*4882a593Smuzhiyun __be16 length; 71*4882a593Smuzhiyun hfsplus_unichr unicode[HFSPLUS_ATTR_MAX_STRLEN]; 72*4882a593Smuzhiyun } __packed; 73*4882a593Smuzhiyun 74*4882a593Smuzhiyun /* POSIX permissions */ 75*4882a593Smuzhiyun struct hfsplus_perm { 76*4882a593Smuzhiyun __be32 owner; 77*4882a593Smuzhiyun __be32 group; 78*4882a593Smuzhiyun u8 rootflags; 79*4882a593Smuzhiyun u8 userflags; 80*4882a593Smuzhiyun __be16 mode; 81*4882a593Smuzhiyun __be32 dev; 82*4882a593Smuzhiyun } __packed; 83*4882a593Smuzhiyun 84*4882a593Smuzhiyun #define HFSPLUS_FLG_NODUMP 0x01 85*4882a593Smuzhiyun #define HFSPLUS_FLG_IMMUTABLE 0x02 86*4882a593Smuzhiyun #define HFSPLUS_FLG_APPEND 0x04 87*4882a593Smuzhiyun 88*4882a593Smuzhiyun /* A single contiguous area of a file */ 89*4882a593Smuzhiyun struct hfsplus_extent { 90*4882a593Smuzhiyun __be32 start_block; 91*4882a593Smuzhiyun __be32 block_count; 92*4882a593Smuzhiyun } __packed; 93*4882a593Smuzhiyun typedef struct hfsplus_extent hfsplus_extent_rec[8]; 94*4882a593Smuzhiyun 95*4882a593Smuzhiyun /* Information for a "Fork" in a file */ 96*4882a593Smuzhiyun struct hfsplus_fork_raw { 97*4882a593Smuzhiyun __be64 total_size; 98*4882a593Smuzhiyun __be32 clump_size; 99*4882a593Smuzhiyun __be32 total_blocks; 100*4882a593Smuzhiyun hfsplus_extent_rec extents; 101*4882a593Smuzhiyun } __packed; 102*4882a593Smuzhiyun 103*4882a593Smuzhiyun /* HFS+ Volume Header */ 104*4882a593Smuzhiyun struct hfsplus_vh { 105*4882a593Smuzhiyun __be16 signature; 106*4882a593Smuzhiyun __be16 version; 107*4882a593Smuzhiyun __be32 attributes; 108*4882a593Smuzhiyun __be32 last_mount_vers; 109*4882a593Smuzhiyun u32 reserved; 110*4882a593Smuzhiyun 111*4882a593Smuzhiyun __be32 create_date; 112*4882a593Smuzhiyun __be32 modify_date; 113*4882a593Smuzhiyun __be32 backup_date; 114*4882a593Smuzhiyun __be32 checked_date; 115*4882a593Smuzhiyun 116*4882a593Smuzhiyun __be32 file_count; 117*4882a593Smuzhiyun __be32 folder_count; 118*4882a593Smuzhiyun 119*4882a593Smuzhiyun __be32 blocksize; 120*4882a593Smuzhiyun __be32 total_blocks; 121*4882a593Smuzhiyun __be32 free_blocks; 122*4882a593Smuzhiyun 123*4882a593Smuzhiyun __be32 next_alloc; 124*4882a593Smuzhiyun __be32 rsrc_clump_sz; 125*4882a593Smuzhiyun __be32 data_clump_sz; 126*4882a593Smuzhiyun hfsplus_cnid next_cnid; 127*4882a593Smuzhiyun 128*4882a593Smuzhiyun __be32 write_count; 129*4882a593Smuzhiyun __be64 encodings_bmp; 130*4882a593Smuzhiyun 131*4882a593Smuzhiyun u32 finder_info[8]; 132*4882a593Smuzhiyun 133*4882a593Smuzhiyun struct hfsplus_fork_raw alloc_file; 134*4882a593Smuzhiyun struct hfsplus_fork_raw ext_file; 135*4882a593Smuzhiyun struct hfsplus_fork_raw cat_file; 136*4882a593Smuzhiyun struct hfsplus_fork_raw attr_file; 137*4882a593Smuzhiyun struct hfsplus_fork_raw start_file; 138*4882a593Smuzhiyun } __packed; 139*4882a593Smuzhiyun 140*4882a593Smuzhiyun /* HFS+ volume attributes */ 141*4882a593Smuzhiyun #define HFSPLUS_VOL_UNMNT (1 << 8) 142*4882a593Smuzhiyun #define HFSPLUS_VOL_SPARE_BLK (1 << 9) 143*4882a593Smuzhiyun #define HFSPLUS_VOL_NOCACHE (1 << 10) 144*4882a593Smuzhiyun #define HFSPLUS_VOL_INCNSTNT (1 << 11) 145*4882a593Smuzhiyun #define HFSPLUS_VOL_NODEID_REUSED (1 << 12) 146*4882a593Smuzhiyun #define HFSPLUS_VOL_JOURNALED (1 << 13) 147*4882a593Smuzhiyun #define HFSPLUS_VOL_SOFTLOCK (1 << 15) 148*4882a593Smuzhiyun #define HFSPLUS_VOL_UNUSED_NODE_FIX (1 << 31) 149*4882a593Smuzhiyun 150*4882a593Smuzhiyun /* HFS+ BTree node descriptor */ 151*4882a593Smuzhiyun struct hfs_bnode_desc { 152*4882a593Smuzhiyun __be32 next; 153*4882a593Smuzhiyun __be32 prev; 154*4882a593Smuzhiyun s8 type; 155*4882a593Smuzhiyun u8 height; 156*4882a593Smuzhiyun __be16 num_recs; 157*4882a593Smuzhiyun u16 reserved; 158*4882a593Smuzhiyun } __packed; 159*4882a593Smuzhiyun 160*4882a593Smuzhiyun /* HFS+ BTree node types */ 161*4882a593Smuzhiyun #define HFS_NODE_INDEX 0x00 /* An internal (index) node */ 162*4882a593Smuzhiyun #define HFS_NODE_HEADER 0x01 /* The tree header node (node 0) */ 163*4882a593Smuzhiyun #define HFS_NODE_MAP 0x02 /* Holds part of the bitmap of used nodes */ 164*4882a593Smuzhiyun #define HFS_NODE_LEAF 0xFF /* A leaf (ndNHeight==1) node */ 165*4882a593Smuzhiyun 166*4882a593Smuzhiyun /* HFS+ BTree header */ 167*4882a593Smuzhiyun struct hfs_btree_header_rec { 168*4882a593Smuzhiyun __be16 depth; 169*4882a593Smuzhiyun __be32 root; 170*4882a593Smuzhiyun __be32 leaf_count; 171*4882a593Smuzhiyun __be32 leaf_head; 172*4882a593Smuzhiyun __be32 leaf_tail; 173*4882a593Smuzhiyun __be16 node_size; 174*4882a593Smuzhiyun __be16 max_key_len; 175*4882a593Smuzhiyun __be32 node_count; 176*4882a593Smuzhiyun __be32 free_nodes; 177*4882a593Smuzhiyun u16 reserved1; 178*4882a593Smuzhiyun __be32 clump_size; 179*4882a593Smuzhiyun u8 btree_type; 180*4882a593Smuzhiyun u8 key_type; 181*4882a593Smuzhiyun __be32 attributes; 182*4882a593Smuzhiyun u32 reserved3[16]; 183*4882a593Smuzhiyun } __packed; 184*4882a593Smuzhiyun 185*4882a593Smuzhiyun /* BTree attributes */ 186*4882a593Smuzhiyun #define HFS_TREE_BIGKEYS 2 187*4882a593Smuzhiyun #define HFS_TREE_VARIDXKEYS 4 188*4882a593Smuzhiyun 189*4882a593Smuzhiyun /* HFS+ BTree misc info */ 190*4882a593Smuzhiyun #define HFSPLUS_TREE_HEAD 0 191*4882a593Smuzhiyun #define HFSPLUS_NODE_MXSZ 32768 192*4882a593Smuzhiyun #define HFSPLUS_ATTR_TREE_NODE_SIZE 8192 193*4882a593Smuzhiyun #define HFSPLUS_BTREE_HDR_NODE_RECS_COUNT 3 194*4882a593Smuzhiyun #define HFSPLUS_BTREE_HDR_USER_BYTES 128 195*4882a593Smuzhiyun 196*4882a593Smuzhiyun /* Some special File ID numbers (stolen from hfs.h) */ 197*4882a593Smuzhiyun #define HFSPLUS_POR_CNID 1 /* Parent Of the Root */ 198*4882a593Smuzhiyun #define HFSPLUS_ROOT_CNID 2 /* ROOT directory */ 199*4882a593Smuzhiyun #define HFSPLUS_EXT_CNID 3 /* EXTents B-tree */ 200*4882a593Smuzhiyun #define HFSPLUS_CAT_CNID 4 /* CATalog B-tree */ 201*4882a593Smuzhiyun #define HFSPLUS_BAD_CNID 5 /* BAD blocks file */ 202*4882a593Smuzhiyun #define HFSPLUS_ALLOC_CNID 6 /* ALLOCation file */ 203*4882a593Smuzhiyun #define HFSPLUS_START_CNID 7 /* STARTup file */ 204*4882a593Smuzhiyun #define HFSPLUS_ATTR_CNID 8 /* ATTRibutes file */ 205*4882a593Smuzhiyun #define HFSPLUS_EXCH_CNID 15 /* ExchangeFiles temp id */ 206*4882a593Smuzhiyun #define HFSPLUS_FIRSTUSER_CNID 16 /* first available user id */ 207*4882a593Smuzhiyun 208*4882a593Smuzhiyun /* btree key type */ 209*4882a593Smuzhiyun #define HFSPLUS_KEY_CASEFOLDING 0xCF /* case-insensitive */ 210*4882a593Smuzhiyun #define HFSPLUS_KEY_BINARY 0xBC /* case-sensitive */ 211*4882a593Smuzhiyun 212*4882a593Smuzhiyun /* HFS+ catalog entry key */ 213*4882a593Smuzhiyun struct hfsplus_cat_key { 214*4882a593Smuzhiyun __be16 key_len; 215*4882a593Smuzhiyun hfsplus_cnid parent; 216*4882a593Smuzhiyun struct hfsplus_unistr name; 217*4882a593Smuzhiyun } __packed; 218*4882a593Smuzhiyun 219*4882a593Smuzhiyun #define HFSPLUS_CAT_KEYLEN (sizeof(struct hfsplus_cat_key)) 220*4882a593Smuzhiyun 221*4882a593Smuzhiyun /* Structs from hfs.h */ 222*4882a593Smuzhiyun struct hfsp_point { 223*4882a593Smuzhiyun __be16 v; 224*4882a593Smuzhiyun __be16 h; 225*4882a593Smuzhiyun } __packed; 226*4882a593Smuzhiyun 227*4882a593Smuzhiyun struct hfsp_rect { 228*4882a593Smuzhiyun __be16 top; 229*4882a593Smuzhiyun __be16 left; 230*4882a593Smuzhiyun __be16 bottom; 231*4882a593Smuzhiyun __be16 right; 232*4882a593Smuzhiyun } __packed; 233*4882a593Smuzhiyun 234*4882a593Smuzhiyun 235*4882a593Smuzhiyun /* HFS directory info (stolen from hfs.h */ 236*4882a593Smuzhiyun struct DInfo { 237*4882a593Smuzhiyun struct hfsp_rect frRect; 238*4882a593Smuzhiyun __be16 frFlags; 239*4882a593Smuzhiyun struct hfsp_point frLocation; 240*4882a593Smuzhiyun __be16 frView; 241*4882a593Smuzhiyun } __packed; 242*4882a593Smuzhiyun 243*4882a593Smuzhiyun struct DXInfo { 244*4882a593Smuzhiyun struct hfsp_point frScroll; 245*4882a593Smuzhiyun __be32 frOpenChain; 246*4882a593Smuzhiyun __be16 frUnused; 247*4882a593Smuzhiyun __be16 frComment; 248*4882a593Smuzhiyun __be32 frPutAway; 249*4882a593Smuzhiyun } __packed; 250*4882a593Smuzhiyun 251*4882a593Smuzhiyun /* HFS+ folder data (part of an hfsplus_cat_entry) */ 252*4882a593Smuzhiyun struct hfsplus_cat_folder { 253*4882a593Smuzhiyun __be16 type; 254*4882a593Smuzhiyun __be16 flags; 255*4882a593Smuzhiyun __be32 valence; 256*4882a593Smuzhiyun hfsplus_cnid id; 257*4882a593Smuzhiyun __be32 create_date; 258*4882a593Smuzhiyun __be32 content_mod_date; 259*4882a593Smuzhiyun __be32 attribute_mod_date; 260*4882a593Smuzhiyun __be32 access_date; 261*4882a593Smuzhiyun __be32 backup_date; 262*4882a593Smuzhiyun struct hfsplus_perm permissions; 263*4882a593Smuzhiyun struct DInfo user_info; 264*4882a593Smuzhiyun struct DXInfo finder_info; 265*4882a593Smuzhiyun __be32 text_encoding; 266*4882a593Smuzhiyun __be32 subfolders; /* Subfolder count in HFSX. Reserved in HFS+. */ 267*4882a593Smuzhiyun } __packed; 268*4882a593Smuzhiyun 269*4882a593Smuzhiyun /* HFS file info (stolen from hfs.h) */ 270*4882a593Smuzhiyun struct FInfo { 271*4882a593Smuzhiyun __be32 fdType; 272*4882a593Smuzhiyun __be32 fdCreator; 273*4882a593Smuzhiyun __be16 fdFlags; 274*4882a593Smuzhiyun struct hfsp_point fdLocation; 275*4882a593Smuzhiyun __be16 fdFldr; 276*4882a593Smuzhiyun } __packed; 277*4882a593Smuzhiyun 278*4882a593Smuzhiyun struct FXInfo { 279*4882a593Smuzhiyun __be16 fdIconID; 280*4882a593Smuzhiyun u8 fdUnused[8]; 281*4882a593Smuzhiyun __be16 fdComment; 282*4882a593Smuzhiyun __be32 fdPutAway; 283*4882a593Smuzhiyun } __packed; 284*4882a593Smuzhiyun 285*4882a593Smuzhiyun /* HFS+ file data (part of a cat_entry) */ 286*4882a593Smuzhiyun struct hfsplus_cat_file { 287*4882a593Smuzhiyun __be16 type; 288*4882a593Smuzhiyun __be16 flags; 289*4882a593Smuzhiyun u32 reserved1; 290*4882a593Smuzhiyun hfsplus_cnid id; 291*4882a593Smuzhiyun __be32 create_date; 292*4882a593Smuzhiyun __be32 content_mod_date; 293*4882a593Smuzhiyun __be32 attribute_mod_date; 294*4882a593Smuzhiyun __be32 access_date; 295*4882a593Smuzhiyun __be32 backup_date; 296*4882a593Smuzhiyun struct hfsplus_perm permissions; 297*4882a593Smuzhiyun struct FInfo user_info; 298*4882a593Smuzhiyun struct FXInfo finder_info; 299*4882a593Smuzhiyun __be32 text_encoding; 300*4882a593Smuzhiyun u32 reserved2; 301*4882a593Smuzhiyun 302*4882a593Smuzhiyun struct hfsplus_fork_raw data_fork; 303*4882a593Smuzhiyun struct hfsplus_fork_raw rsrc_fork; 304*4882a593Smuzhiyun } __packed; 305*4882a593Smuzhiyun 306*4882a593Smuzhiyun /* File and folder flag bits */ 307*4882a593Smuzhiyun #define HFSPLUS_FILE_LOCKED 0x0001 308*4882a593Smuzhiyun #define HFSPLUS_FILE_THREAD_EXISTS 0x0002 309*4882a593Smuzhiyun #define HFSPLUS_XATTR_EXISTS 0x0004 310*4882a593Smuzhiyun #define HFSPLUS_ACL_EXISTS 0x0008 311*4882a593Smuzhiyun #define HFSPLUS_HAS_FOLDER_COUNT 0x0010 /* Folder has subfolder count 312*4882a593Smuzhiyun * (HFSX only) */ 313*4882a593Smuzhiyun 314*4882a593Smuzhiyun /* HFS+ catalog thread (part of a cat_entry) */ 315*4882a593Smuzhiyun struct hfsplus_cat_thread { 316*4882a593Smuzhiyun __be16 type; 317*4882a593Smuzhiyun s16 reserved; 318*4882a593Smuzhiyun hfsplus_cnid parentID; 319*4882a593Smuzhiyun struct hfsplus_unistr nodeName; 320*4882a593Smuzhiyun } __packed; 321*4882a593Smuzhiyun 322*4882a593Smuzhiyun #define HFSPLUS_MIN_THREAD_SZ 10 323*4882a593Smuzhiyun 324*4882a593Smuzhiyun /* A data record in the catalog tree */ 325*4882a593Smuzhiyun typedef union { 326*4882a593Smuzhiyun __be16 type; 327*4882a593Smuzhiyun struct hfsplus_cat_folder folder; 328*4882a593Smuzhiyun struct hfsplus_cat_file file; 329*4882a593Smuzhiyun struct hfsplus_cat_thread thread; 330*4882a593Smuzhiyun } __packed hfsplus_cat_entry; 331*4882a593Smuzhiyun 332*4882a593Smuzhiyun /* HFS+ catalog entry type */ 333*4882a593Smuzhiyun #define HFSPLUS_FOLDER 0x0001 334*4882a593Smuzhiyun #define HFSPLUS_FILE 0x0002 335*4882a593Smuzhiyun #define HFSPLUS_FOLDER_THREAD 0x0003 336*4882a593Smuzhiyun #define HFSPLUS_FILE_THREAD 0x0004 337*4882a593Smuzhiyun 338*4882a593Smuzhiyun /* HFS+ extents tree key */ 339*4882a593Smuzhiyun struct hfsplus_ext_key { 340*4882a593Smuzhiyun __be16 key_len; 341*4882a593Smuzhiyun u8 fork_type; 342*4882a593Smuzhiyun u8 pad; 343*4882a593Smuzhiyun hfsplus_cnid cnid; 344*4882a593Smuzhiyun __be32 start_block; 345*4882a593Smuzhiyun } __packed; 346*4882a593Smuzhiyun 347*4882a593Smuzhiyun #define HFSPLUS_EXT_KEYLEN sizeof(struct hfsplus_ext_key) 348*4882a593Smuzhiyun 349*4882a593Smuzhiyun #define HFSPLUS_XATTR_FINDER_INFO_NAME "com.apple.FinderInfo" 350*4882a593Smuzhiyun #define HFSPLUS_XATTR_ACL_NAME "com.apple.system.Security" 351*4882a593Smuzhiyun 352*4882a593Smuzhiyun #define HFSPLUS_ATTR_INLINE_DATA 0x10 353*4882a593Smuzhiyun #define HFSPLUS_ATTR_FORK_DATA 0x20 354*4882a593Smuzhiyun #define HFSPLUS_ATTR_EXTENTS 0x30 355*4882a593Smuzhiyun 356*4882a593Smuzhiyun /* HFS+ attributes tree key */ 357*4882a593Smuzhiyun struct hfsplus_attr_key { 358*4882a593Smuzhiyun __be16 key_len; 359*4882a593Smuzhiyun __be16 pad; 360*4882a593Smuzhiyun hfsplus_cnid cnid; 361*4882a593Smuzhiyun __be32 start_block; 362*4882a593Smuzhiyun struct hfsplus_attr_unistr key_name; 363*4882a593Smuzhiyun } __packed; 364*4882a593Smuzhiyun 365*4882a593Smuzhiyun #define HFSPLUS_ATTR_KEYLEN sizeof(struct hfsplus_attr_key) 366*4882a593Smuzhiyun 367*4882a593Smuzhiyun /* HFS+ fork data attribute */ 368*4882a593Smuzhiyun struct hfsplus_attr_fork_data { 369*4882a593Smuzhiyun __be32 record_type; 370*4882a593Smuzhiyun __be32 reserved; 371*4882a593Smuzhiyun struct hfsplus_fork_raw the_fork; 372*4882a593Smuzhiyun } __packed; 373*4882a593Smuzhiyun 374*4882a593Smuzhiyun /* HFS+ extension attribute */ 375*4882a593Smuzhiyun struct hfsplus_attr_extents { 376*4882a593Smuzhiyun __be32 record_type; 377*4882a593Smuzhiyun __be32 reserved; 378*4882a593Smuzhiyun struct hfsplus_extent extents; 379*4882a593Smuzhiyun } __packed; 380*4882a593Smuzhiyun 381*4882a593Smuzhiyun #define HFSPLUS_MAX_INLINE_DATA_SIZE 3802 382*4882a593Smuzhiyun 383*4882a593Smuzhiyun /* HFS+ attribute inline data */ 384*4882a593Smuzhiyun struct hfsplus_attr_inline_data { 385*4882a593Smuzhiyun __be32 record_type; 386*4882a593Smuzhiyun __be32 reserved1; 387*4882a593Smuzhiyun u8 reserved2[6]; 388*4882a593Smuzhiyun __be16 length; 389*4882a593Smuzhiyun u8 raw_bytes[HFSPLUS_MAX_INLINE_DATA_SIZE]; 390*4882a593Smuzhiyun } __packed; 391*4882a593Smuzhiyun 392*4882a593Smuzhiyun /* A data record in the attributes tree */ 393*4882a593Smuzhiyun typedef union { 394*4882a593Smuzhiyun __be32 record_type; 395*4882a593Smuzhiyun struct hfsplus_attr_fork_data fork_data; 396*4882a593Smuzhiyun struct hfsplus_attr_extents extents; 397*4882a593Smuzhiyun struct hfsplus_attr_inline_data inline_data; 398*4882a593Smuzhiyun } __packed hfsplus_attr_entry; 399*4882a593Smuzhiyun 400*4882a593Smuzhiyun /* HFS+ generic BTree key */ 401*4882a593Smuzhiyun typedef union { 402*4882a593Smuzhiyun __be16 key_len; 403*4882a593Smuzhiyun struct hfsplus_cat_key cat; 404*4882a593Smuzhiyun struct hfsplus_ext_key ext; 405*4882a593Smuzhiyun struct hfsplus_attr_key attr; 406*4882a593Smuzhiyun } __packed hfsplus_btree_key; 407*4882a593Smuzhiyun 408*4882a593Smuzhiyun #endif 409