/* * linux/fs/umsdos/file.c * * Written 1993 by Jacques Gelinas * inspired from linux/fs/msdos/file.c Werner Almesberger * * Extended MS-DOS regular file handling primitives */ #ifdef MODULE #include #endif #include #include #include #include #include #include #include #include #include #include #define PRINTK(x) #define Printk(x) printk x /* Read a file into user space memory */ static int UMSDOS_file_read( struct inode *inode, struct file *filp, char *buf, int count) { /* We have to set the access time because msdos don't care */ int ret = msdos_file_read(inode,filp,buf,count); if (!IS_RDONLY(inode)){ inode->i_atime = CURRENT_TIME; inode->i_dirt = 1; } return ret; } /* Write a file from user space memory */ static int UMSDOS_file_write( struct inode *inode, struct file *filp, char *buf, int count) { return msdos_file_write(inode,filp,buf,count); } /* Truncate a file to 0 length. */ static void UMSDOS_truncate(struct inode *inode) { PRINTK (("UMSDOS_truncate\n")); msdos_truncate (inode); inode->i_ctime = inode->i_mtime = CURRENT_TIME; inode->i_dirt = 1; } /* Function for normal file system (512 bytes hardware sector size) */ struct file_operations umsdos_file_operations = { NULL, /* lseek - default */ UMSDOS_file_read, /* read */ UMSDOS_file_write, /* write */ NULL, /* readdir - bad */ NULL, /* select - default */ NULL, /* ioctl - default */ generic_mmap, /* mmap */ NULL, /* no special open is needed */ NULL, /* release */ file_fsync /* fsync */ }; struct inode_operations umsdos_file_inode_operations = { &umsdos_file_operations, /* default file operations */ NULL, /* create */ NULL, /* lookup */ NULL, /* link */ NULL, /* unlink */ NULL, /* symlink */ NULL, /* mkdir */ NULL, /* rmdir */ NULL, /* mknod */ NULL, /* rename */ NULL, /* readlink */ NULL, /* follow_link */ msdos_bmap, /* bmap */ UMSDOS_truncate,/* truncate */ NULL, /* permission */ msdos_smap /* smap */ }; /* For other with larger and unaligned file system */ struct file_operations umsdos_file_operations_no_bmap = { NULL, /* lseek - default */ UMSDOS_file_read, /* read */ UMSDOS_file_write, /* write */ NULL, /* readdir - bad */ NULL, /* select - default */ NULL, /* ioctl - default */ msdos_mmap, /* mmap */ NULL, /* no special open is needed */ NULL, /* release */ file_fsync /* fsync */ }; struct inode_operations umsdos_file_inode_operations_no_bmap = { &umsdos_file_operations_no_bmap, /* default file operations */ NULL, /* create */ NULL, /* lookup */ NULL, /* link */ NULL, /* unlink */ NULL, /* symlink */ NULL, /* mkdir */ NULL, /* rmdir */ NULL, /* mknod */ NULL, /* rename */ NULL, /* readlink */ NULL, /* follow_link */ NULL, /* bmap */ UMSDOS_truncate,/* truncate */ NULL, /* permission */ NULL, /* smap */ };