| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | /* | 
|  | 2 | *  Name                         : qnx4_fs.h | 
|  | 3 | *  Author                       : Richard Frowijn | 
|  | 4 | *  Function                     : qnx4 global filesystem definitions | 
|  | 5 | *  Version                      : 1.0.2 | 
|  | 6 | *  Last modified                : 2000-01-31 | 
|  | 7 | * | 
|  | 8 | *  History                      : 23-03-1998 created | 
|  | 9 | */ | 
|  | 10 | #ifndef _LINUX_QNX4_FS_H | 
|  | 11 | #define _LINUX_QNX4_FS_H | 
|  | 12 |  | 
|  | 13 | #include <linux/qnxtypes.h> | 
|  | 14 |  | 
|  | 15 | #define QNX4_ROOT_INO 1 | 
|  | 16 |  | 
|  | 17 | #define QNX4_MAX_XTNTS_PER_XBLK	60 | 
|  | 18 | /* for di_status */ | 
|  | 19 | #define QNX4_FILE_USED          0x01 | 
|  | 20 | #define QNX4_FILE_MODIFIED      0x02 | 
|  | 21 | #define QNX4_FILE_BUSY          0x04 | 
|  | 22 | #define QNX4_FILE_LINK          0x08 | 
|  | 23 | #define QNX4_FILE_INODE         0x10 | 
|  | 24 | #define QNX4_FILE_FSYSCLEAN     0x20 | 
|  | 25 |  | 
|  | 26 | #define QNX4_I_MAP_SLOTS	8 | 
|  | 27 | #define QNX4_Z_MAP_SLOTS	64 | 
|  | 28 | #define QNX4_SUPER_MAGIC	0x002f	/* qnx4 fs detection */ | 
|  | 29 | #define QNX4_VALID_FS		0x0001	/* Clean fs. */ | 
|  | 30 | #define QNX4_ERROR_FS		0x0002	/* fs has errors. */ | 
|  | 31 | #define QNX4_BLOCK_SIZE         0x200	/* blocksize of 512 bytes */ | 
|  | 32 | #define QNX4_BLOCK_SIZE_BITS    9	/* blocksize shift */ | 
|  | 33 | #define QNX4_DIR_ENTRY_SIZE     0x040	/* dir entry size of 64 bytes */ | 
|  | 34 | #define QNX4_DIR_ENTRY_SIZE_BITS 6	/* dir entry size shift */ | 
|  | 35 | #define QNX4_XBLK_ENTRY_SIZE    0x200	/* xblk entry size */ | 
|  | 36 | #define QNX4_INODES_PER_BLOCK   0x08	/* 512 / 64 */ | 
|  | 37 |  | 
|  | 38 | /* for filenames */ | 
|  | 39 | #define QNX4_SHORT_NAME_MAX	16 | 
|  | 40 | #define QNX4_NAME_MAX		48 | 
|  | 41 |  | 
|  | 42 | /* | 
|  | 43 | * This is the original qnx4 inode layout on disk. | 
|  | 44 | */ | 
|  | 45 | struct qnx4_inode_entry { | 
|  | 46 | char		di_fname[QNX4_SHORT_NAME_MAX]; | 
|  | 47 | qnx4_off_t	di_size; | 
|  | 48 | qnx4_xtnt_t	di_first_xtnt; | 
| Alexey Dobriyan | 75043cb | 2005-06-24 20:52:52 +0000 | [diff] [blame] | 49 | __le32		di_xblk; | 
|  | 50 | __le32		di_ftime; | 
|  | 51 | __le32		di_mtime; | 
|  | 52 | __le32		di_atime; | 
|  | 53 | __le32		di_ctime; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 54 | qnx4_nxtnt_t	di_num_xtnts; | 
|  | 55 | qnx4_mode_t	di_mode; | 
|  | 56 | qnx4_muid_t	di_uid; | 
|  | 57 | qnx4_mgid_t	di_gid; | 
|  | 58 | qnx4_nlink_t	di_nlink; | 
|  | 59 | __u8		di_zero[4]; | 
|  | 60 | qnx4_ftype_t	di_type; | 
|  | 61 | __u8		di_status; | 
|  | 62 | }; | 
|  | 63 |  | 
|  | 64 | struct qnx4_link_info { | 
|  | 65 | char		dl_fname[QNX4_NAME_MAX]; | 
| Alexey Dobriyan | 75043cb | 2005-06-24 20:52:52 +0000 | [diff] [blame] | 66 | __le32		dl_inode_blk; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 67 | __u8		dl_inode_ndx; | 
|  | 68 | __u8		dl_spare[10]; | 
|  | 69 | __u8		dl_status; | 
|  | 70 | }; | 
|  | 71 |  | 
|  | 72 | struct qnx4_xblk { | 
| Alexey Dobriyan | 75043cb | 2005-06-24 20:52:52 +0000 | [diff] [blame] | 73 | __le32		xblk_next_xblk; | 
|  | 74 | __le32		xblk_prev_xblk; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 75 | __u8		xblk_num_xtnts; | 
|  | 76 | __u8		xblk_spare[3]; | 
| Alexey Dobriyan | 75043cb | 2005-06-24 20:52:52 +0000 | [diff] [blame] | 77 | __le32		xblk_num_blocks; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 78 | qnx4_xtnt_t	xblk_xtnts[QNX4_MAX_XTNTS_PER_XBLK]; | 
|  | 79 | char		xblk_signature[8]; | 
|  | 80 | qnx4_xtnt_t	xblk_first_xtnt; | 
|  | 81 | }; | 
|  | 82 |  | 
|  | 83 | struct qnx4_super_block { | 
|  | 84 | struct qnx4_inode_entry RootDir; | 
|  | 85 | struct qnx4_inode_entry Inode; | 
|  | 86 | struct qnx4_inode_entry Boot; | 
|  | 87 | struct qnx4_inode_entry AltBoot; | 
|  | 88 | }; | 
|  | 89 |  | 
|  | 90 | #ifdef __KERNEL__ | 
|  | 91 |  | 
|  | 92 | #define QNX4_DEBUG 0 | 
|  | 93 |  | 
|  | 94 | #if QNX4_DEBUG | 
|  | 95 | #define QNX4DEBUG(X) printk X | 
|  | 96 | #else | 
|  | 97 | #define QNX4DEBUG(X) (void) 0 | 
|  | 98 | #endif | 
|  | 99 |  | 
|  | 100 | struct qnx4_sb_info { | 
|  | 101 | struct buffer_head	*sb_buf;	/* superblock buffer */ | 
|  | 102 | struct qnx4_super_block	*sb;		/* our superblock */ | 
|  | 103 | unsigned int		Version;	/* may be useful */ | 
|  | 104 | struct qnx4_inode_entry	*BitMap;	/* useful */ | 
|  | 105 | }; | 
|  | 106 |  | 
|  | 107 | struct qnx4_inode_info { | 
|  | 108 | struct qnx4_inode_entry raw; | 
|  | 109 | loff_t mmu_private; | 
|  | 110 | struct inode vfs_inode; | 
|  | 111 | }; | 
|  | 112 |  | 
|  | 113 | extern struct dentry *qnx4_lookup(struct inode *dir, struct dentry *dentry, struct nameidata *nd); | 
|  | 114 | extern unsigned long qnx4_count_free_blocks(struct super_block *sb); | 
|  | 115 | extern unsigned long qnx4_block_map(struct inode *inode, long iblock); | 
|  | 116 |  | 
|  | 117 | extern struct buffer_head *qnx4_bread(struct inode *, int, int); | 
|  | 118 |  | 
|  | 119 | extern struct inode_operations qnx4_file_inode_operations; | 
|  | 120 | extern struct inode_operations qnx4_dir_inode_operations; | 
|  | 121 | extern struct file_operations qnx4_file_operations; | 
|  | 122 | extern struct file_operations qnx4_dir_operations; | 
|  | 123 | extern int qnx4_is_free(struct super_block *sb, long block); | 
|  | 124 | extern int qnx4_set_bitmap(struct super_block *sb, long block, int busy); | 
|  | 125 | extern int qnx4_create(struct inode *inode, struct dentry *dentry, int mode, struct nameidata *nd); | 
|  | 126 | extern void qnx4_truncate(struct inode *inode); | 
|  | 127 | extern void qnx4_free_inode(struct inode *inode); | 
|  | 128 | extern int qnx4_unlink(struct inode *dir, struct dentry *dentry); | 
|  | 129 | extern int qnx4_rmdir(struct inode *dir, struct dentry *dentry); | 
|  | 130 | extern int qnx4_sync_file(struct file *file, struct dentry *dentry, int); | 
|  | 131 | extern int qnx4_sync_inode(struct inode *inode); | 
|  | 132 |  | 
|  | 133 | static inline struct qnx4_sb_info *qnx4_sb(struct super_block *sb) | 
|  | 134 | { | 
|  | 135 | return sb->s_fs_info; | 
|  | 136 | } | 
|  | 137 |  | 
|  | 138 | static inline struct qnx4_inode_info *qnx4_i(struct inode *inode) | 
|  | 139 | { | 
|  | 140 | return container_of(inode, struct qnx4_inode_info, vfs_inode); | 
|  | 141 | } | 
|  | 142 |  | 
|  | 143 | static inline struct qnx4_inode_entry *qnx4_raw_inode(struct inode *inode) | 
|  | 144 | { | 
|  | 145 | return &qnx4_i(inode)->raw; | 
|  | 146 | } | 
|  | 147 |  | 
|  | 148 | #endif				/* __KERNEL__ */ | 
|  | 149 |  | 
|  | 150 | #endif |