1 /* SPDX-License-Identifier: GPL-2.0-or-later */ 2 /* 3 * Copyright (C) International Business Machines Corp., 2000-2001 4 */ 5 #ifndef _H_JFS_DINODE 6 #define _H_JFS_DINODE 7 8 /* 9 * jfs_dinode.h: on-disk inode manager 10 */ 11 12 #define INODESLOTSIZE 128 13 #define L2INODESLOTSIZE 7 14 #define log2INODESIZE 9 /* log2(bytes per dinode) */ 15 16 17 /* 18 * on-disk inode : 512 bytes 19 * 20 * note: align 64-bit fields on 8-byte boundary. 21 */ 22 struct dinode { 23 /* 24 * I. base area (128 bytes) 25 * ------------------------ 26 * 27 * define generic/POSIX attributes 28 */ 29 __le32 di_inostamp; /* 4: stamp to show inode belongs to fileset */ 30 __le32 di_fileset; /* 4: fileset number */ 31 __le32 di_number; /* 4: inode number, aka file serial number */ 32 __le32 di_gen; /* 4: inode generation number */ 33 34 pxd_t di_ixpxd; /* 8: inode extent descriptor */ 35 36 __le64 di_size; /* 8: size */ 37 __le64 di_nblocks; /* 8: number of blocks allocated */ 38 39 __le32 di_nlink; /* 4: number of links to the object */ 40 41 __le32 di_uid; /* 4: user id of owner */ 42 __le32 di_gid; /* 4: group id of owner */ 43 44 __le32 di_mode; /* 4: attribute, format and permission */ 45 46 struct timestruc_t di_atime; /* 8: time last data accessed */ 47 struct timestruc_t di_ctime; /* 8: time last status changed */ 48 struct timestruc_t di_mtime; /* 8: time last data modified */ 49 struct timestruc_t di_otime; /* 8: time created */ 50 51 dxd_t di_acl; /* 16: acl descriptor */ 52 53 dxd_t di_ea; /* 16: ea descriptor */ 54 55 __le32 di_next_index; /* 4: Next available dir_table index */ 56 57 __le32 di_acltype; /* 4: Type of ACL */ 58 59 /* 60 * Extension Areas. 61 * 62 * Historically, the inode was partitioned into 4 128-byte areas, 63 * the last 3 being defined as unions which could have multiple 64 * uses. The first 96 bytes had been completely unused until 65 * an index table was added to the directory. It is now more 66 * useful to describe the last 3/4 of the inode as a single 67 * union. We would probably be better off redesigning the 68 * entire structure from scratch, but we don't want to break 69 * commonality with OS/2's JFS at this time. 70 */ 71 union { 72 struct { 73 /* 74 * This table contains the information needed to 75 * find a directory entry from a 32-bit index. 76 * If the index is small enough, the table is inline, 77 * otherwise, an x-tree root overlays this table 78 */ 79 struct dir_table_slot _table[12]; /* 96: inline */ 80 81 dtroot_t _dtroot; /* 288: dtree root */ 82 } _dir; /* (384) */ 83 #define di_dirtable u._dir._table 84 #define di_dtroot u._dir._dtroot 85 #define di_parent di_dtroot.header.idotdot 86 #define di_DASD di_dtroot.header.DASD 87 88 struct { 89 union { 90 u8 _data[96]; /* 96: unused */ 91 struct { 92 void *_imap; /* 4: unused */ 93 __le32 _gengen; /* 4: generator */ 94 } _imap; 95 } _u1; /* 96: */ 96 #define di_gengen u._file._u1._imap._gengen 97 98 union { 99 xtpage_t _xtroot; 100 struct { 101 u8 unused[16]; /* 16: */ 102 dxd_t _dxd; /* 16: */ 103 union { 104 __le32 _rdev; /* 4: */ 105 /* 106 * The fast symlink area 107 * is expected to overflow 108 * into _inlineea when 109 * needed (which will clear 110 * INLINEEA). 111 */ 112 u8 _fastsymlink[128]; 113 } _u; 114 u8 _inlineea[128]; 115 } _special; 116 } _u2; 117 } _file; 118 #define di_xtroot u._file._u2._xtroot 119 #define di_dxd u._file._u2._special._dxd 120 #define di_btroot di_xtroot 121 #define di_inlinedata u._file._u2._special._u 122 #define di_rdev u._file._u2._special._u._rdev 123 #define di_fastsymlink u._file._u2._special._u._fastsymlink 124 #define di_inlineea u._file._u2._special._inlineea 125 } u; 126 }; 127 128 /* extended mode bits (on-disk inode di_mode) */ 129 #define IFJOURNAL 0x00010000 /* journalled file */ 130 #define ISPARSE 0x00020000 /* sparse file enabled */ 131 #define INLINEEA 0x00040000 /* inline EA area free */ 132 #define ISWAPFILE 0x00800000 /* file open for pager swap space */ 133 134 /* more extended mode bits: attributes for OS/2 */ 135 #define IREADONLY 0x02000000 /* no write access to file */ 136 #define IHIDDEN 0x04000000 /* hidden file */ 137 #define ISYSTEM 0x08000000 /* system file */ 138 139 #define IDIRECTORY 0x20000000 /* directory (shadow of real bit) */ 140 #define IARCHIVE 0x40000000 /* file archive bit */ 141 #define INEWNAME 0x80000000 /* non-8.3 filename format */ 142 143 #define IRASH 0x4E000000 /* mask for changeable attributes */ 144 #define ATTRSHIFT 25 /* bits to shift to move attribute 145 specification to mode position */ 146 147 /* extended attributes for Linux */ 148 149 #define JFS_NOATIME_FL 0x00080000 /* do not update atime */ 150 151 #define JFS_DIRSYNC_FL 0x00100000 /* dirsync behaviour */ 152 #define JFS_SYNC_FL 0x00200000 /* Synchronous updates */ 153 #define JFS_SECRM_FL 0x00400000 /* Secure deletion */ 154 #define JFS_UNRM_FL 0x00800000 /* allow for undelete */ 155 156 #define JFS_APPEND_FL 0x01000000 /* writes to file may only append */ 157 #define JFS_IMMUTABLE_FL 0x02000000 /* Immutable file */ 158 159 #define JFS_FL_USER_VISIBLE 0x03F80000 160 #define JFS_FL_USER_MODIFIABLE 0x03F80000 161 #define JFS_FL_INHERIT 0x03C80000 162 163 #endif /*_H_JFS_DINODE */ 164