2b7e5bcbd9
Stop the QNX4 filesystem from using iget() and read_inode(). Replace qnx4_read_inode() with qnx4_iget(), and call that instead of iget(). qnx4_iget() then uses iget_locked() directly and returns a proper error code instead of an inode in the event of an error. qnx4_fill_super() returns any error incurred when getting the root inode instead of EINVAL. [akpm@linux-foundation.org: coding-style fixes] Signed-off-by: David Howells <dhowells@redhat.com> Cc: Anders Larsen <al@alarsen.net> Acked-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
151 lines
4.3 KiB
C
151 lines
4.3 KiB
C
/*
|
|
* Name : qnx4_fs.h
|
|
* Author : Richard Frowijn
|
|
* Function : qnx4 global filesystem definitions
|
|
* Version : 1.0.2
|
|
* Last modified : 2000-01-31
|
|
*
|
|
* History : 23-03-1998 created
|
|
*/
|
|
#ifndef _LINUX_QNX4_FS_H
|
|
#define _LINUX_QNX4_FS_H
|
|
|
|
#include <linux/qnxtypes.h>
|
|
#include <linux/magic.h>
|
|
|
|
#define QNX4_ROOT_INO 1
|
|
|
|
#define QNX4_MAX_XTNTS_PER_XBLK 60
|
|
/* for di_status */
|
|
#define QNX4_FILE_USED 0x01
|
|
#define QNX4_FILE_MODIFIED 0x02
|
|
#define QNX4_FILE_BUSY 0x04
|
|
#define QNX4_FILE_LINK 0x08
|
|
#define QNX4_FILE_INODE 0x10
|
|
#define QNX4_FILE_FSYSCLEAN 0x20
|
|
|
|
#define QNX4_I_MAP_SLOTS 8
|
|
#define QNX4_Z_MAP_SLOTS 64
|
|
#define QNX4_VALID_FS 0x0001 /* Clean fs. */
|
|
#define QNX4_ERROR_FS 0x0002 /* fs has errors. */
|
|
#define QNX4_BLOCK_SIZE 0x200 /* blocksize of 512 bytes */
|
|
#define QNX4_BLOCK_SIZE_BITS 9 /* blocksize shift */
|
|
#define QNX4_DIR_ENTRY_SIZE 0x040 /* dir entry size of 64 bytes */
|
|
#define QNX4_DIR_ENTRY_SIZE_BITS 6 /* dir entry size shift */
|
|
#define QNX4_XBLK_ENTRY_SIZE 0x200 /* xblk entry size */
|
|
#define QNX4_INODES_PER_BLOCK 0x08 /* 512 / 64 */
|
|
|
|
/* for filenames */
|
|
#define QNX4_SHORT_NAME_MAX 16
|
|
#define QNX4_NAME_MAX 48
|
|
|
|
/*
|
|
* This is the original qnx4 inode layout on disk.
|
|
*/
|
|
struct qnx4_inode_entry {
|
|
char di_fname[QNX4_SHORT_NAME_MAX];
|
|
qnx4_off_t di_size;
|
|
qnx4_xtnt_t di_first_xtnt;
|
|
__le32 di_xblk;
|
|
__le32 di_ftime;
|
|
__le32 di_mtime;
|
|
__le32 di_atime;
|
|
__le32 di_ctime;
|
|
qnx4_nxtnt_t di_num_xtnts;
|
|
qnx4_mode_t di_mode;
|
|
qnx4_muid_t di_uid;
|
|
qnx4_mgid_t di_gid;
|
|
qnx4_nlink_t di_nlink;
|
|
__u8 di_zero[4];
|
|
qnx4_ftype_t di_type;
|
|
__u8 di_status;
|
|
};
|
|
|
|
struct qnx4_link_info {
|
|
char dl_fname[QNX4_NAME_MAX];
|
|
__le32 dl_inode_blk;
|
|
__u8 dl_inode_ndx;
|
|
__u8 dl_spare[10];
|
|
__u8 dl_status;
|
|
};
|
|
|
|
struct qnx4_xblk {
|
|
__le32 xblk_next_xblk;
|
|
__le32 xblk_prev_xblk;
|
|
__u8 xblk_num_xtnts;
|
|
__u8 xblk_spare[3];
|
|
__le32 xblk_num_blocks;
|
|
qnx4_xtnt_t xblk_xtnts[QNX4_MAX_XTNTS_PER_XBLK];
|
|
char xblk_signature[8];
|
|
qnx4_xtnt_t xblk_first_xtnt;
|
|
};
|
|
|
|
struct qnx4_super_block {
|
|
struct qnx4_inode_entry RootDir;
|
|
struct qnx4_inode_entry Inode;
|
|
struct qnx4_inode_entry Boot;
|
|
struct qnx4_inode_entry AltBoot;
|
|
};
|
|
|
|
#ifdef __KERNEL__
|
|
|
|
#define QNX4_DEBUG 0
|
|
|
|
#if QNX4_DEBUG
|
|
#define QNX4DEBUG(X) printk X
|
|
#else
|
|
#define QNX4DEBUG(X) (void) 0
|
|
#endif
|
|
|
|
struct qnx4_sb_info {
|
|
struct buffer_head *sb_buf; /* superblock buffer */
|
|
struct qnx4_super_block *sb; /* our superblock */
|
|
unsigned int Version; /* may be useful */
|
|
struct qnx4_inode_entry *BitMap; /* useful */
|
|
};
|
|
|
|
struct qnx4_inode_info {
|
|
struct qnx4_inode_entry raw;
|
|
loff_t mmu_private;
|
|
struct inode vfs_inode;
|
|
};
|
|
|
|
extern struct inode *qnx4_iget(struct super_block *, unsigned long);
|
|
extern struct dentry *qnx4_lookup(struct inode *dir, struct dentry *dentry, struct nameidata *nd);
|
|
extern unsigned long qnx4_count_free_blocks(struct super_block *sb);
|
|
extern unsigned long qnx4_block_map(struct inode *inode, long iblock);
|
|
|
|
extern struct buffer_head *qnx4_bread(struct inode *, int, int);
|
|
|
|
extern const struct inode_operations qnx4_file_inode_operations;
|
|
extern const struct inode_operations qnx4_dir_inode_operations;
|
|
extern const struct file_operations qnx4_file_operations;
|
|
extern const struct file_operations qnx4_dir_operations;
|
|
extern int qnx4_is_free(struct super_block *sb, long block);
|
|
extern int qnx4_set_bitmap(struct super_block *sb, long block, int busy);
|
|
extern int qnx4_create(struct inode *inode, struct dentry *dentry, int mode, struct nameidata *nd);
|
|
extern void qnx4_truncate(struct inode *inode);
|
|
extern void qnx4_free_inode(struct inode *inode);
|
|
extern int qnx4_unlink(struct inode *dir, struct dentry *dentry);
|
|
extern int qnx4_rmdir(struct inode *dir, struct dentry *dentry);
|
|
extern int qnx4_sync_file(struct file *file, struct dentry *dentry, int);
|
|
extern int qnx4_sync_inode(struct inode *inode);
|
|
|
|
static inline struct qnx4_sb_info *qnx4_sb(struct super_block *sb)
|
|
{
|
|
return sb->s_fs_info;
|
|
}
|
|
|
|
static inline struct qnx4_inode_info *qnx4_i(struct inode *inode)
|
|
{
|
|
return container_of(inode, struct qnx4_inode_info, vfs_inode);
|
|
}
|
|
|
|
static inline struct qnx4_inode_entry *qnx4_raw_inode(struct inode *inode)
|
|
{
|
|
return &qnx4_i(inode)->raw;
|
|
}
|
|
|
|
#endif /* __KERNEL__ */
|
|
|
|
#endif
|