1*0b1e987cSChristoph Hellwig /* SPDX-License-Identifier: GPL-2.0-only */
21da177e4SLinus Torvalds /*
31da177e4SLinus Torvalds * Copyright (c) 2000-2001 Christoph Hellwig.
41cce1701SKrzysztof Błaszkowski * Copyright (c) 2016 Krzysztof Blaszkowski
51da177e4SLinus Torvalds */
61da177e4SLinus Torvalds #ifndef _VXFS_INODE_H_
71da177e4SLinus Torvalds #define _VXFS_INODE_H_
81da177e4SLinus Torvalds
91da177e4SLinus Torvalds /*
101da177e4SLinus Torvalds * Veritas filesystem driver - inode structure.
111da177e4SLinus Torvalds *
121da177e4SLinus Torvalds * This file contains the definition of the disk and core
131da177e4SLinus Torvalds * inodes of the Veritas Filesystem.
141da177e4SLinus Torvalds */
151da177e4SLinus Torvalds
161da177e4SLinus Torvalds
171da177e4SLinus Torvalds #define VXFS_ISIZE 0x100 /* Inode size */
181da177e4SLinus Torvalds
191da177e4SLinus Torvalds #define VXFS_NDADDR 10 /* Number of direct addrs in inode */
201da177e4SLinus Torvalds #define VXFS_NIADDR 2 /* Number of indirect addrs in inode */
211da177e4SLinus Torvalds #define VXFS_NIMMED 96 /* Size of immediate data in inode */
221da177e4SLinus Torvalds #define VXFS_NTYPED 6 /* Num of typed extents */
231da177e4SLinus Torvalds
241da177e4SLinus Torvalds #define VXFS_TYPED_OFFSETMASK (0x00FFFFFFFFFFFFFFULL)
251da177e4SLinus Torvalds #define VXFS_TYPED_TYPEMASK (0xFF00000000000000ULL)
261da177e4SLinus Torvalds #define VXFS_TYPED_TYPESHIFT 56
271da177e4SLinus Torvalds
281da177e4SLinus Torvalds #define VXFS_TYPED_PER_BLOCK(sbp) \
291da177e4SLinus Torvalds ((sbp)->s_blocksize / sizeof(struct vxfs_typed))
301da177e4SLinus Torvalds
311da177e4SLinus Torvalds /*
321da177e4SLinus Torvalds * Possible extent descriptor types for %VXFS_ORG_TYPED extents.
331da177e4SLinus Torvalds */
341da177e4SLinus Torvalds enum {
351da177e4SLinus Torvalds VXFS_TYPED_INDIRECT = 1,
361da177e4SLinus Torvalds VXFS_TYPED_DATA = 2,
371da177e4SLinus Torvalds VXFS_TYPED_INDIRECT_DEV4 = 3,
381da177e4SLinus Torvalds VXFS_TYPED_DATA_DEV4 = 4,
391da177e4SLinus Torvalds };
401da177e4SLinus Torvalds
411da177e4SLinus Torvalds /*
421da177e4SLinus Torvalds * Data stored immediately in the inode.
431da177e4SLinus Torvalds */
441da177e4SLinus Torvalds struct vxfs_immed {
450d83f7fcSKrzysztof Błaszkowski __u8 vi_immed[VXFS_NIMMED];
461da177e4SLinus Torvalds };
471da177e4SLinus Torvalds
481da177e4SLinus Torvalds struct vxfs_ext4 {
490d83f7fcSKrzysztof Błaszkowski __fs32 ve4_spare; /* ?? */
500d83f7fcSKrzysztof Błaszkowski __fs32 ve4_indsize; /* Indirect extent size */
510d83f7fcSKrzysztof Błaszkowski __fs32 ve4_indir[VXFS_NIADDR]; /* Indirect extents */
521da177e4SLinus Torvalds struct direct { /* Direct extents */
530d83f7fcSKrzysztof Błaszkowski __fs32 extent; /* Extent number */
540d83f7fcSKrzysztof Błaszkowski __fs32 size; /* Size of extent */
551da177e4SLinus Torvalds } ve4_direct[VXFS_NDADDR];
561da177e4SLinus Torvalds };
571da177e4SLinus Torvalds
581da177e4SLinus Torvalds struct vxfs_typed {
590d83f7fcSKrzysztof Błaszkowski __fs64 vt_hdr; /* Header, 0xTTOOOOOOOOOOOOOO; T=type,O=offs */
600d83f7fcSKrzysztof Błaszkowski __fs32 vt_block; /* Extent block */
610d83f7fcSKrzysztof Błaszkowski __fs32 vt_size; /* Size in blocks */
621da177e4SLinus Torvalds };
631da177e4SLinus Torvalds
641da177e4SLinus Torvalds struct vxfs_typed_dev4 {
650d83f7fcSKrzysztof Błaszkowski __fs64 vd4_hdr; /* Header, 0xTTOOOOOOOOOOOOOO; T=type,O=offs */
660d83f7fcSKrzysztof Błaszkowski __fs64 vd4_block; /* Extent block */
670d83f7fcSKrzysztof Błaszkowski __fs64 vd4_size; /* Size in blocks */
680d83f7fcSKrzysztof Błaszkowski __fs32 vd4_dev; /* Device ID */
690d83f7fcSKrzysztof Błaszkowski __u8 __pad1;
701da177e4SLinus Torvalds };
711da177e4SLinus Torvalds
721da177e4SLinus Torvalds /*
731da177e4SLinus Torvalds * The inode as contained on the physical device.
741da177e4SLinus Torvalds */
751da177e4SLinus Torvalds struct vxfs_dinode {
760d83f7fcSKrzysztof Błaszkowski __fs32 vdi_mode;
770d83f7fcSKrzysztof Błaszkowski __fs32 vdi_nlink; /* Link count */
780d83f7fcSKrzysztof Błaszkowski __fs32 vdi_uid; /* UID */
790d83f7fcSKrzysztof Błaszkowski __fs32 vdi_gid; /* GID */
800d83f7fcSKrzysztof Błaszkowski __fs64 vdi_size; /* Inode size in bytes */
810d83f7fcSKrzysztof Błaszkowski __fs32 vdi_atime; /* Last time accessed - sec */
820d83f7fcSKrzysztof Błaszkowski __fs32 vdi_autime; /* Last time accessed - usec */
830d83f7fcSKrzysztof Błaszkowski __fs32 vdi_mtime; /* Last modify time - sec */
840d83f7fcSKrzysztof Błaszkowski __fs32 vdi_mutime; /* Last modify time - usec */
850d83f7fcSKrzysztof Błaszkowski __fs32 vdi_ctime; /* Create time - sec */
860d83f7fcSKrzysztof Błaszkowski __fs32 vdi_cutime; /* Create time - usec */
870d83f7fcSKrzysztof Błaszkowski __u8 vdi_aflags; /* Allocation flags */
880d83f7fcSKrzysztof Błaszkowski __u8 vdi_orgtype; /* Organisation type */
890d83f7fcSKrzysztof Błaszkowski __fs16 vdi_eopflags;
900d83f7fcSKrzysztof Błaszkowski __fs32 vdi_eopdata;
911da177e4SLinus Torvalds union {
920d83f7fcSKrzysztof Błaszkowski __fs32 rdev;
930d83f7fcSKrzysztof Błaszkowski __fs32 dotdot;
941da177e4SLinus Torvalds struct {
950d83f7fcSKrzysztof Błaszkowski __u32 reserved;
960d83f7fcSKrzysztof Błaszkowski __fs32 fixextsize;
971da177e4SLinus Torvalds } i_regular;
981da177e4SLinus Torvalds struct {
990d83f7fcSKrzysztof Błaszkowski __fs32 matchino;
1000d83f7fcSKrzysztof Błaszkowski __fs32 fsetindex;
1011da177e4SLinus Torvalds } i_vxspec;
1020d83f7fcSKrzysztof Błaszkowski __u64 align;
1031da177e4SLinus Torvalds } vdi_ftarea;
1040d83f7fcSKrzysztof Błaszkowski __fs32 vdi_blocks; /* How much blocks does inode occupy */
1050d83f7fcSKrzysztof Błaszkowski __fs32 vdi_gen; /* Inode generation */
1060d83f7fcSKrzysztof Błaszkowski __fs64 vdi_version; /* Version */
1071da177e4SLinus Torvalds union {
1081da177e4SLinus Torvalds struct vxfs_immed immed;
1091da177e4SLinus Torvalds struct vxfs_ext4 ext4;
1101da177e4SLinus Torvalds struct vxfs_typed typed[VXFS_NTYPED];
1111da177e4SLinus Torvalds } vdi_org;
1120d83f7fcSKrzysztof Błaszkowski __fs32 vdi_iattrino;
1131da177e4SLinus Torvalds };
1141da177e4SLinus Torvalds
1151da177e4SLinus Torvalds #define vdi_rdev vdi_ftarea.rdev
1161da177e4SLinus Torvalds #define vdi_dotdot vdi_ftarea.dotdot
1171da177e4SLinus Torvalds #define vdi_fixextsize vdi_ftarea.regular.fixextsize
1181da177e4SLinus Torvalds #define vdi_matchino vdi_ftarea.vxspec.matchino
1191da177e4SLinus Torvalds #define vdi_fsetindex vdi_ftarea.vxspec.fsetindex
1201da177e4SLinus Torvalds
1211da177e4SLinus Torvalds #define vdi_immed vdi_org.immed
1221da177e4SLinus Torvalds #define vdi_ext4 vdi_org.ext4
1231da177e4SLinus Torvalds #define vdi_typed vdi_org.typed
1241da177e4SLinus Torvalds
1251da177e4SLinus Torvalds
1261da177e4SLinus Torvalds /*
1271da177e4SLinus Torvalds * The inode as represented in the main memory.
1281da177e4SLinus Torvalds */
1290d83f7fcSKrzysztof Błaszkowski struct vxfs_inode_info {
1302f137e31SChristoph Hellwig struct inode vfs_inode;
1312f137e31SChristoph Hellwig
1320d83f7fcSKrzysztof Błaszkowski __u32 vii_mode;
1330d83f7fcSKrzysztof Błaszkowski __u32 vii_nlink; /* Link count */
1340d83f7fcSKrzysztof Błaszkowski __u32 vii_uid; /* UID */
1350d83f7fcSKrzysztof Błaszkowski __u32 vii_gid; /* GID */
1360d83f7fcSKrzysztof Błaszkowski __u64 vii_size; /* Inode size in bytes */
1370d83f7fcSKrzysztof Błaszkowski __u32 vii_atime; /* Last time accessed - sec */
1380d83f7fcSKrzysztof Błaszkowski __u32 vii_autime; /* Last time accessed - usec */
1390d83f7fcSKrzysztof Błaszkowski __u32 vii_mtime; /* Last modify time - sec */
1400d83f7fcSKrzysztof Błaszkowski __u32 vii_mutime; /* Last modify time - usec */
1410d83f7fcSKrzysztof Błaszkowski __u32 vii_ctime; /* Create time - sec */
1420d83f7fcSKrzysztof Błaszkowski __u32 vii_cutime; /* Create time - usec */
1430d83f7fcSKrzysztof Błaszkowski __u8 vii_orgtype; /* Organisation type */
1440d83f7fcSKrzysztof Błaszkowski union {
1450d83f7fcSKrzysztof Błaszkowski __u32 rdev;
1460d83f7fcSKrzysztof Błaszkowski __u32 dotdot;
1470d83f7fcSKrzysztof Błaszkowski } vii_ftarea;
1480d83f7fcSKrzysztof Błaszkowski __u32 vii_blocks; /* How much blocks does inode occupy */
1490d83f7fcSKrzysztof Błaszkowski __u32 vii_gen; /* Inode generation */
1500d83f7fcSKrzysztof Błaszkowski union {
1510d83f7fcSKrzysztof Błaszkowski struct vxfs_immed immed;
1520d83f7fcSKrzysztof Błaszkowski struct vxfs_ext4 ext4;
1530d83f7fcSKrzysztof Błaszkowski struct vxfs_typed typed[VXFS_NTYPED];
1540d83f7fcSKrzysztof Błaszkowski } vii_org;
1550d83f7fcSKrzysztof Błaszkowski };
1561da177e4SLinus Torvalds
1570d83f7fcSKrzysztof Błaszkowski #define vii_rdev vii_ftarea.rdev
1580d83f7fcSKrzysztof Błaszkowski #define vii_dotdot vii_ftarea.dotdot
1591da177e4SLinus Torvalds
1600d83f7fcSKrzysztof Błaszkowski #define vii_immed vii_org.immed
1610d83f7fcSKrzysztof Błaszkowski #define vii_ext4 vii_org.ext4
1620d83f7fcSKrzysztof Błaszkowski #define vii_typed vii_org.typed
1631da177e4SLinus Torvalds
VXFS_INO(struct inode * inode)1642f137e31SChristoph Hellwig static inline struct vxfs_inode_info *VXFS_INO(struct inode *inode)
1652f137e31SChristoph Hellwig {
1662f137e31SChristoph Hellwig return container_of(inode, struct vxfs_inode_info, vfs_inode);
1672f137e31SChristoph Hellwig }
1682f137e31SChristoph Hellwig
1691da177e4SLinus Torvalds #endif /* _VXFS_INODE_H_ */
170