11da177e4SLinus Torvalds #include <linux/fs.h> 21da177e4SLinus Torvalds #include <linux/pagemap.h> 31da177e4SLinus Torvalds #include <linux/minix_fs.h> 41da177e4SLinus Torvalds 51da177e4SLinus Torvalds /* 61da177e4SLinus Torvalds * change the define below to 0 if you want names > info->s_namelen chars to be 71da177e4SLinus Torvalds * truncated. Else they will be disallowed (ENAMETOOLONG). 81da177e4SLinus Torvalds */ 91da177e4SLinus Torvalds #define NO_TRUNCATE 1 101da177e4SLinus Torvalds 111da177e4SLinus Torvalds #define INODE_VERSION(inode) minix_sb(inode->i_sb)->s_version 121da177e4SLinus Torvalds 131da177e4SLinus Torvalds #define MINIX_V1 0x0001 /* original minix fs */ 141da177e4SLinus Torvalds #define MINIX_V2 0x0002 /* minix V2 fs */ 151da177e4SLinus Torvalds 161da177e4SLinus Torvalds /* 171da177e4SLinus Torvalds * minix fs inode data in memory 181da177e4SLinus Torvalds */ 191da177e4SLinus Torvalds struct minix_inode_info { 201da177e4SLinus Torvalds union { 211da177e4SLinus Torvalds __u16 i1_data[16]; 221da177e4SLinus Torvalds __u32 i2_data[16]; 231da177e4SLinus Torvalds } u; 241da177e4SLinus Torvalds struct inode vfs_inode; 251da177e4SLinus Torvalds }; 261da177e4SLinus Torvalds 271da177e4SLinus Torvalds /* 281da177e4SLinus Torvalds * minix super-block data in memory 291da177e4SLinus Torvalds */ 301da177e4SLinus Torvalds struct minix_sb_info { 311da177e4SLinus Torvalds unsigned long s_ninodes; 321da177e4SLinus Torvalds unsigned long s_nzones; 331da177e4SLinus Torvalds unsigned long s_imap_blocks; 341da177e4SLinus Torvalds unsigned long s_zmap_blocks; 351da177e4SLinus Torvalds unsigned long s_firstdatazone; 361da177e4SLinus Torvalds unsigned long s_log_zone_size; 371da177e4SLinus Torvalds unsigned long s_max_size; 381da177e4SLinus Torvalds int s_dirsize; 391da177e4SLinus Torvalds int s_namelen; 401da177e4SLinus Torvalds int s_link_max; 411da177e4SLinus Torvalds struct buffer_head ** s_imap; 421da177e4SLinus Torvalds struct buffer_head ** s_zmap; 431da177e4SLinus Torvalds struct buffer_head * s_sbh; 441da177e4SLinus Torvalds struct minix_super_block * s_ms; 451da177e4SLinus Torvalds unsigned short s_mount_state; 461da177e4SLinus Torvalds unsigned short s_version; 471da177e4SLinus Torvalds }; 481da177e4SLinus Torvalds 491da177e4SLinus Torvalds extern struct minix_inode * minix_V1_raw_inode(struct super_block *, ino_t, struct buffer_head **); 501da177e4SLinus Torvalds extern struct minix2_inode * minix_V2_raw_inode(struct super_block *, ino_t, struct buffer_head **); 511da177e4SLinus Torvalds extern struct inode * minix_new_inode(const struct inode * dir, int * error); 521da177e4SLinus Torvalds extern void minix_free_inode(struct inode * inode); 531da177e4SLinus Torvalds extern unsigned long minix_count_free_inodes(struct minix_sb_info *sbi); 541da177e4SLinus Torvalds extern int minix_new_block(struct inode * inode); 551da177e4SLinus Torvalds extern void minix_free_block(struct inode * inode, int block); 561da177e4SLinus Torvalds extern unsigned long minix_count_free_blocks(struct minix_sb_info *sbi); 571da177e4SLinus Torvalds 581da177e4SLinus Torvalds extern int minix_getattr(struct vfsmount *, struct dentry *, struct kstat *); 591da177e4SLinus Torvalds 601da177e4SLinus Torvalds extern void V2_minix_truncate(struct inode *); 611da177e4SLinus Torvalds extern void V1_minix_truncate(struct inode *); 621da177e4SLinus Torvalds extern void V2_minix_truncate(struct inode *); 631da177e4SLinus Torvalds extern void minix_truncate(struct inode *); 641da177e4SLinus Torvalds extern int minix_sync_inode(struct inode *); 651da177e4SLinus Torvalds extern void minix_set_inode(struct inode *, dev_t); 661da177e4SLinus Torvalds extern int V1_minix_get_block(struct inode *, long, struct buffer_head *, int); 671da177e4SLinus Torvalds extern int V2_minix_get_block(struct inode *, long, struct buffer_head *, int); 681da177e4SLinus Torvalds extern unsigned V1_minix_blocks(loff_t); 691da177e4SLinus Torvalds extern unsigned V2_minix_blocks(loff_t); 701da177e4SLinus Torvalds 711da177e4SLinus Torvalds extern struct minix_dir_entry *minix_find_entry(struct dentry*, struct page**); 721da177e4SLinus Torvalds extern int minix_add_link(struct dentry*, struct inode*); 731da177e4SLinus Torvalds extern int minix_delete_entry(struct minix_dir_entry*, struct page*); 741da177e4SLinus Torvalds extern int minix_make_empty(struct inode*, struct inode*); 751da177e4SLinus Torvalds extern int minix_empty_dir(struct inode*); 761da177e4SLinus Torvalds extern void minix_set_link(struct minix_dir_entry*, struct page*, struct inode*); 771da177e4SLinus Torvalds extern struct minix_dir_entry *minix_dotdot(struct inode*, struct page**); 781da177e4SLinus Torvalds extern ino_t minix_inode_by_name(struct dentry*); 791da177e4SLinus Torvalds 801da177e4SLinus Torvalds extern int minix_sync_file(struct file *, struct dentry *, int); 811da177e4SLinus Torvalds 821da177e4SLinus Torvalds extern struct inode_operations minix_file_inode_operations; 831da177e4SLinus Torvalds extern struct inode_operations minix_dir_inode_operations; 841da177e4SLinus Torvalds extern struct file_operations minix_file_operations; 851da177e4SLinus Torvalds extern struct file_operations minix_dir_operations; 861da177e4SLinus Torvalds extern struct dentry_operations minix_dentry_operations; 871da177e4SLinus Torvalds 881da177e4SLinus Torvalds static inline struct minix_sb_info *minix_sb(struct super_block *sb) 891da177e4SLinus Torvalds { 901da177e4SLinus Torvalds return sb->s_fs_info; 911da177e4SLinus Torvalds } 921da177e4SLinus Torvalds 931da177e4SLinus Torvalds static inline struct minix_inode_info *minix_i(struct inode *inode) 941da177e4SLinus Torvalds { 951da177e4SLinus Torvalds return list_entry(inode, struct minix_inode_info, vfs_inode); 961da177e4SLinus Torvalds } 97